{"id":"https://openalex.org/W2302344383","doi":"https://doi.org/10.1145/2908080.2908119","title":"Polymorphic type inference for machine code","display_name":"Polymorphic type inference for machine code","publication_year":2016,"publication_date":"2016-06-02","ids":{"openalex":"https://openalex.org/W2302344383","doi":"https://doi.org/10.1145/2908080.2908119","mag":"2302344383"},"language":"en","primary_location":{"id":"doi:10.1145/2908080.2908119","is_oa":true,"landing_page_url":"https://doi.org/10.1145/2908080.2908119","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/2908080.2908119","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 37th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"gold","oa_url":"https://dl.acm.org/doi/pdf/10.1145/2908080.2908119","any_repository_has_fulltext":null},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5091297606","display_name":"Matt Noonan","orcid":null},"institutions":[{"id":"https://openalex.org/I4210135696","display_name":"GrammaTech (United States)","ror":"https://ror.org/03mwfxd89","country_code":"US","type":"company","lineage":["https://openalex.org/I4210135696"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Matt Noonan","raw_affiliation_strings":["GrammaTech, USA"],"affiliations":[{"raw_affiliation_string":"GrammaTech, USA","institution_ids":["https://openalex.org/I4210135696"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5054314962","display_name":"\u0410. \u0410. \u041b\u043e\u0433\u0438\u043d\u043e\u0432","orcid":"https://orcid.org/0000-0002-3966-4045"},"institutions":[{"id":"https://openalex.org/I4210135696","display_name":"GrammaTech (United States)","ror":"https://ror.org/03mwfxd89","country_code":"US","type":"company","lineage":["https://openalex.org/I4210135696"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Alexey Loginov","raw_affiliation_strings":["GrammaTech, USA"],"affiliations":[{"raw_affiliation_string":"GrammaTech, USA","institution_ids":["https://openalex.org/I4210135696"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5073886655","display_name":"David R. Cok","orcid":"https://orcid.org/0000-0003-1864-4974"},"institutions":[{"id":"https://openalex.org/I4210135696","display_name":"GrammaTech (United States)","ror":"https://ror.org/03mwfxd89","country_code":"US","type":"company","lineage":["https://openalex.org/I4210135696"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"David Cok","raw_affiliation_strings":["GrammaTech, USA"],"affiliations":[{"raw_affiliation_string":"GrammaTech, USA","institution_ids":["https://openalex.org/I4210135696"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5091297606"],"corresponding_institution_ids":["https://openalex.org/I4210135696"],"apc_list":null,"apc_paid":null,"fwci":6.6349,"has_fulltext":true,"cited_by_count":31,"citation_normalized_percentile":{"value":0.96491015,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"27","last_page":"41"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9973000288009644,"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"}},"topics":[{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9973000288009644,"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"}},{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9968000054359436,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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/T10126","display_name":"Logic, programming, and type systems","score":0.9965999722480774,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.8598940372467041},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7944231033325195},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7430909872055054},{"id":"https://openalex.org/keywords/subtyping","display_name":"Subtyping","score":0.6387314200401306},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6048038005828857},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.5868731737136841},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.5582338571548462},{"id":"https://openalex.org/keywords/type-safety","display_name":"Type safety","score":0.485464870929718},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.4632514715194702},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.44386807084083557},{"id":"https://openalex.org/keywords/static-analysis","display_name":"Static analysis","score":0.43354275822639465},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.41083383560180664},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.38755473494529724}],"concepts":[{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.8598940372467041},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7944231033325195},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7430909872055054},{"id":"https://openalex.org/C83852419","wikidata":"https://www.wikidata.org/wiki/Q2713292","display_name":"Subtyping","level":2,"score":0.6387314200401306},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6048038005828857},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.5868731737136841},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.5582338571548462},{"id":"https://openalex.org/C44779574","wikidata":"https://www.wikidata.org/wiki/Q736866","display_name":"Type safety","level":2,"score":0.485464870929718},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.4632514715194702},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.44386807084083557},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.43354275822639465},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.41083383560180664},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.38755473494529724},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2908080.2908119","is_oa":true,"landing_page_url":"https://doi.org/10.1145/2908080.2908119","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/2908080.2908119","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 37th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"}],"best_oa_location":{"id":"doi:10.1145/2908080.2908119","is_oa":true,"landing_page_url":"https://doi.org/10.1145/2908080.2908119","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/2908080.2908119","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 37th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G860720456","display_name":null,"funder_award_id":"FA8750-12-C-0023_BBN","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"}],"funders":[{"id":"https://openalex.org/F4320306078","display_name":"U.S. Department of Defense","ror":"https://ror.org/0447fe631"},{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"},{"id":"https://openalex.org/F4320332815","display_name":"Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2302344383.pdf","grobid_xml":"https://content.openalex.org/works/W2302344383.grobid-xml"},"referenced_works_count":36,"referenced_works":["https://openalex.org/W191489030","https://openalex.org/W1515906028","https://openalex.org/W1523029584","https://openalex.org/W1553136405","https://openalex.org/W1568194905","https://openalex.org/W1582456956","https://openalex.org/W1997385049","https://openalex.org/W2016712834","https://openalex.org/W2035561341","https://openalex.org/W2047170808","https://openalex.org/W2052440299","https://openalex.org/W2055292912","https://openalex.org/W2061117785","https://openalex.org/W2079752311","https://openalex.org/W2099963114","https://openalex.org/W2105321460","https://openalex.org/W2120708837","https://openalex.org/W2123727486","https://openalex.org/W2131135493","https://openalex.org/W2132295002","https://openalex.org/W2141843850","https://openalex.org/W2147118954","https://openalex.org/W2149237601","https://openalex.org/W2156211387","https://openalex.org/W2157859774","https://openalex.org/W2163627399","https://openalex.org/W2170371367","https://openalex.org/W2302344383","https://openalex.org/W2398729674","https://openalex.org/W2401156470","https://openalex.org/W2504609973","https://openalex.org/W2993781365","https://openalex.org/W3141621133","https://openalex.org/W4232505977","https://openalex.org/W4299301436","https://openalex.org/W6903381972"],"related_works":["https://openalex.org/W1575522358","https://openalex.org/W85134812","https://openalex.org/W1580969192","https://openalex.org/W2763815264","https://openalex.org/W4205979273","https://openalex.org/W2104216136","https://openalex.org/W2167486301","https://openalex.org/W2302344383","https://openalex.org/W2950327322","https://openalex.org/W4297355057"],"abstract_inverted_index":{"For":[0],"many":[1],"compiled":[2],"languages,":[3],"source-level":[4],"types":[5,53,197],"are":[6,151],"erased":[7],"very":[8],"early":[9],"in":[10,30,41,71,155],"the":[11,31,135,147,224,228,231],"compilation":[12],"process.":[13],"As":[14],"a":[15,42,68,85,105,115,129,171,177],"result,":[16],"further":[17],"compiler":[18],"passes":[19],"may":[20,238],"convert":[21],"type-safe":[22],"source":[23,33],"into":[24],"type-unsafe":[25,35],"machine":[26,60,183],"code.":[27],"Type-unsafe":[28],"idioms":[29,127],"original":[32],"and":[34,66,76,83,89,111,157,190],"optimizations":[36],"mean":[37],"that":[38,125,185,237],"type":[39,56,64,87,93,99,121,136,159],"information":[40,236],"stripped":[43,59],"binary":[44],"is":[45,62],"essentially":[46],"nonexistent.":[47],"The":[48,95],"problem":[49],"of":[50,73,97,108,117,132,146,209,227],"recovering":[51],"high-level":[52,163],"by":[54,103,162],"performing":[55],"inference":[57],"over":[58],"code":[61,184],"called":[63],"reconstruction,":[65],"offers":[67],"useful":[69],"capability":[70],"support":[72],"reverse":[74],"engineering":[75],"decompilation.":[77],"In":[78],"this":[79,98],"paper,":[80],"we":[81,149,173],"motivate":[82],"develop":[84],"novel":[86,178],"system":[88,100],"algorithm":[90,181],"for":[91,120,182,233],"machine-code":[92,112],"inference.":[94],"features":[96,139,148,169],"were":[101],"developed":[102,175],"surveying":[104],"wide":[106],"collection":[107],"common":[109],"source-":[110],"idioms,":[113],"building":[114],"catalog":[116],"challenging":[118],"cases":[119],"reconstruction.":[122],"We":[123],"found":[124],"these":[126,167],"place":[128],"sophisticated":[130],"set":[131],"requirements":[133],"on":[134,219],"system,":[137],"inducing":[138],"such":[140,206],"as":[141,170,207],"recursively-constrained":[142],"polymorphic":[143],"types.":[144],"Many":[145],"identify":[150],"often":[152],"seen":[153],"only":[154],"expressive":[156],"powerful":[158],"systems":[160],"used":[161],"functional":[164],"languages.":[165],"Using":[166],"type-system":[168],"guideline,":[172],"have":[174],"Retypd:":[176],"static":[179],"type-inference":[180],"supports":[186],"recursive":[187],"types,":[188],"polymorphism,":[189],"subtyping.":[191],"Retypd":[192,216],"yields":[193],"more":[194],"accurate":[195],"inferred":[196],"than":[198,223],"existing":[199],"algorithms,":[200],"while":[201],"also":[202],"enabling":[203],"new":[204],"capabilities":[205],"reconstruction":[208],"pointer":[210],"const":[211],"annotations":[212],"with":[213],"98%":[214],"recall.":[215],"can":[217],"operate":[218],"weaker":[220],"program":[221],"representations":[222],"current":[225],"state":[226],"art,":[229],"removing":[230],"need":[232],"high-quality":[234],"points-to":[235],"be":[239],"impractical":[240],"to":[241],"compute.":[242]},"counts_by_year":[{"year":2025,"cited_by_count":4},{"year":2024,"cited_by_count":5},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":4},{"year":2021,"cited_by_count":3},{"year":2020,"cited_by_count":4},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":4},{"year":2016,"cited_by_count":2}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
