{"id":"https://openalex.org/W3092578037","doi":"https://doi.org/10.22152/programming-journal.org/2022/6/6","title":"Type Checking Extracted Methods","display_name":"Type Checking Extracted Methods","publication_year":2021,"publication_date":"2021-11-15","ids":{"openalex":"https://openalex.org/W3092578037","doi":"https://doi.org/10.22152/programming-journal.org/2022/6/6","mag":"3092578037"},"language":"en","primary_location":{"id":"doi:10.22152/programming-journal.org/2022/6/6","is_oa":true,"landing_page_url":"https://doi.org/10.22152/programming-journal.org/2022/6/6","pdf_url":"https://arxiv.org/pdf/2010.03608v3","source":{"id":"https://openalex.org/S4210199781","display_name":"The Art Science and Engineering of Programming","issn_l":"2473-7321","issn":["2473-7321"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Art, Science, and Engineering of Programming","raw_type":"journal-article"},"type":"preprint","indexed_in":["arxiv","crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://arxiv.org/pdf/2010.03608v3","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5060845270","display_name":"Yuquan Fu","orcid":null},"institutions":[{"id":"https://openalex.org/I592451","display_name":"Indiana University","ror":"https://ror.org/01kg8sb98","country_code":"US","type":"education","lineage":["https://openalex.org/I592451"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Yuquan Fu","raw_affiliation_strings":["Indiana University, USA","Indiana University; USA"],"affiliations":[{"raw_affiliation_string":"Indiana University, USA","institution_ids":["https://openalex.org/I592451"]},{"raw_affiliation_string":"Indiana University; USA","institution_ids":["https://openalex.org/I592451"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5043677781","display_name":"Sam Tobin-Hochstadt","orcid":"https://orcid.org/0000-0003-1302-6499"},"institutions":[{"id":"https://openalex.org/I592451","display_name":"Indiana University","ror":"https://ror.org/01kg8sb98","country_code":"US","type":"education","lineage":["https://openalex.org/I592451"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Sam Tobin-Hochstadt","raw_affiliation_strings":["Indiana University, USA","Indiana University; USA"],"affiliations":[{"raw_affiliation_string":"Indiana University, USA","institution_ids":["https://openalex.org/I592451"]},{"raw_affiliation_string":"Indiana University; USA","institution_ids":["https://openalex.org/I592451"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5060845270"],"corresponding_institution_ids":["https://openalex.org/I592451"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.00849016,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"6","issue":"2","first_page":null,"last_page":null},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998000264167786,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998000264167786,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10142","display_name":"Formal Methods in Verification","score":0.9955999851226807,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9937000274658203,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7980678677558899},{"id":"https://openalex.org/keywords/racket","display_name":"Racket","score":0.7635473012924194},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6025453805923462},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.5597330927848816},{"id":"https://openalex.org/keywords/typescript","display_name":"TypeScript","score":0.5441104769706726},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.4997982978820801},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.4940958321094513},{"id":"https://openalex.org/keywords/indirection","display_name":"Indirection","score":0.4470043182373047},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3281632661819458},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.3267250657081604},{"id":"https://openalex.org/keywords/engineering","display_name":"Engineering","score":0.09200429916381836}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7980678677558899},{"id":"https://openalex.org/C2778707667","wikidata":"https://www.wikidata.org/wiki/Q1254148","display_name":"Racket","level":3,"score":0.7635473012924194},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6025453805923462},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.5597330927848816},{"id":"https://openalex.org/C2777869424","wikidata":"https://www.wikidata.org/wiki/Q978185","display_name":"TypeScript","level":2,"score":0.5441104769706726},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.4997982978820801},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.4940958321094513},{"id":"https://openalex.org/C89377073","wikidata":"https://www.wikidata.org/wiki/Q1171224","display_name":"Indirection","level":2,"score":0.4470043182373047},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3281632661819458},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.3267250657081604},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.09200429916381836},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C78519656","wikidata":"https://www.wikidata.org/wiki/Q101333","display_name":"Mechanical engineering","level":1,"score":0.0},{"id":"https://openalex.org/C65655974","wikidata":"https://www.wikidata.org/wiki/Q14867674","display_name":"Swing","level":2,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.22152/programming-journal.org/2022/6/6","is_oa":true,"landing_page_url":"https://doi.org/10.22152/programming-journal.org/2022/6/6","pdf_url":"https://arxiv.org/pdf/2010.03608v3","source":{"id":"https://openalex.org/S4210199781","display_name":"The Art Science and Engineering of Programming","issn_l":"2473-7321","issn":["2473-7321"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Art, Science, and Engineering of Programming","raw_type":"journal-article"},{"id":"pmh:oai:arXiv.org:2010.03608","is_oa":true,"landing_page_url":"http://arxiv.org/abs/2010.03608","pdf_url":"https://arxiv.org/pdf/2010.03608","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"},{"id":"mag:3092578037","is_oa":true,"landing_page_url":"https://arxiv.org/pdf/2010.03608.pdf","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"arXiv (Cornell University)","raw_type":null},{"id":"doi:10.48550/arxiv.2010.03608","is_oa":true,"landing_page_url":"https://doi.org/10.48550/arxiv.2010.03608","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article-journal"}],"best_oa_location":{"id":"doi:10.22152/programming-journal.org/2022/6/6","is_oa":true,"landing_page_url":"https://doi.org/10.22152/programming-journal.org/2022/6/6","pdf_url":"https://arxiv.org/pdf/2010.03608v3","source":{"id":"https://openalex.org/S4210199781","display_name":"The Art Science and Engineering of Programming","issn_l":"2473-7321","issn":["2473-7321"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Art, Science, and Engineering of Programming","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Quality Education","score":0.4099999964237213,"id":"https://metadata.un.org/sdg/4"}],"awards":[{"id":"https://openalex.org/G3163158226","display_name":"CRI: CI-SUSTAIN: Racket on Alternative Platforms","funder_award_id":"1823244","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G4084077383","display_name":null,"funder_award_id":"1763922","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G848032724","display_name":null,"funder_award_id":"Science","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W3092578037.pdf","grobid_xml":"https://content.openalex.org/works/W3092578037.grobid-xml"},"referenced_works_count":18,"referenced_works":["https://openalex.org/W1525643703","https://openalex.org/W1606286650","https://openalex.org/W1970227944","https://openalex.org/W1973186567","https://openalex.org/W1990365157","https://openalex.org/W2045900383","https://openalex.org/W2052973434","https://openalex.org/W2096368963","https://openalex.org/W2100759424","https://openalex.org/W2104204098","https://openalex.org/W2128303158","https://openalex.org/W2138839382","https://openalex.org/W2232609331","https://openalex.org/W2273111921","https://openalex.org/W2911692446","https://openalex.org/W2962829798","https://openalex.org/W4206448372","https://openalex.org/W4381304672"],"related_works":["https://openalex.org/W3206533211","https://openalex.org/W2076401377","https://openalex.org/W1561474574","https://openalex.org/W2029126323","https://openalex.org/W2157976942","https://openalex.org/W2230757399","https://openalex.org/W1544637752","https://openalex.org/W2129003527","https://openalex.org/W2285299036","https://openalex.org/W1954113551","https://openalex.org/W2144416276","https://openalex.org/W3143845920","https://openalex.org/W259429217","https://openalex.org/W2952172093","https://openalex.org/W3091193824","https://openalex.org/W2403840518","https://openalex.org/W2076062002","https://openalex.org/W2736547892","https://openalex.org/W2898097209","https://openalex.org/W2889297400"],"abstract_inverted_index":{"Many":[0],"object-oriented":[1],"dynamic":[2],"languages":[3],"allow":[4],"programmers":[5],"to":[6,39],"extract":[7],"methods":[8,38],"from":[9],"objects":[10],"and":[11,62],"treat":[12],"them":[13],"as":[14,57,59],"functions.":[15],"This":[16],"allows":[17],"for":[18,25],"flexible":[19],"programming":[20],"patterns,":[21],"but":[22],"presents":[23],"challenges":[24],"type":[26],"systems.":[27],"In":[28],"particular,":[29],"a":[30,51],"simple":[31],"treatment":[32],"of":[33,54],"method":[34],"extraction":[35],"would":[36],"require":[37],"be":[40],"contravariant":[41],"in":[42],"the":[43],"receiver":[44],"type,":[45],"making":[46],"overriding":[47],"all-but-impossible.":[48],"We":[49],"present":[50],"detailed":[52],"investigation":[53],"this":[55],"problem,":[56],"well":[58],"an":[60],"implemented":[61],"evaluated":[63],"solution.":[64]},"counts_by_year":[],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
