{"id":"https://openalex.org/W2075496182","doi":"https://doi.org/10.1002/spe.4380140906","title":"Register allocation and exhaustive peephole optimization","display_name":"Register allocation and exhaustive peephole optimization","publication_year":1984,"publication_date":"1984-09-01","ids":{"openalex":"https://openalex.org/W2075496182","doi":"https://doi.org/10.1002/spe.4380140906","mag":"2075496182"},"language":"en","primary_location":{"id":"doi:10.1002/spe.4380140906","is_oa":false,"landing_page_url":"https://doi.org/10.1002/spe.4380140906","pdf_url":null,"source":{"id":"https://openalex.org/S122199241","display_name":"Software Practice and Experience","issn_l":"0038-0644","issn":["0038-0644","1097-024X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320595","host_organization_name":"Wiley","host_organization_lineage":["https://openalex.org/P4310320595"],"host_organization_lineage_names":["Wiley"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Software: Practice and Experience","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5068264173","display_name":"Jack W. Davidson","orcid":null},"institutions":[{"id":"https://openalex.org/I51556381","display_name":"University of Virginia","ror":"https://ror.org/0153tk833","country_code":"US","type":"education","lineage":["https://openalex.org/I51556381"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Jack W. Davidson","raw_affiliation_strings":["Department of Computer Science, University of Virginia, Charlottesville, VA 22901, U.S.A"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, University of Virginia, Charlottesville, VA 22901, U.S.A","institution_ids":["https://openalex.org/I51556381"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5108356183","display_name":"Christopher W. Fraser","orcid":null},"institutions":[{"id":"https://openalex.org/I138006243","display_name":"University of Arizona","ror":"https://ror.org/03m2x1q45","country_code":"US","type":"education","lineage":["https://openalex.org/I138006243"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Christopher W. Fraser","raw_affiliation_strings":["Department of Computer Science, University of Arizona, Tucson, AZ 85721 U.S.A","Department of Computer Science, University of Arizona, Tucson AZ 85721, U.S.A"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, University of Arizona, Tucson, AZ 85721 U.S.A","institution_ids":["https://openalex.org/I138006243"]},{"raw_affiliation_string":"Department of Computer Science, University of Arizona, Tucson AZ 85721, U.S.A","institution_ids":["https://openalex.org/I138006243"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5068264173"],"corresponding_institution_ids":["https://openalex.org/I51556381"],"apc_list":{"value":4220,"currency":"USD","value_usd":4220},"apc_paid":null,"fwci":4.1931,"has_fulltext":false,"cited_by_count":36,"citation_normalized_percentile":{"value":0.93246037,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":"14","issue":"9","first_page":"857","last_page":"865"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9990000128746033,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9990000128746033,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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.9916999936103821,"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.9794999957084656,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/register-allocation","display_name":"Register allocation","score":0.951697587966919},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.9131932258605957},{"id":"https://openalex.org/keywords/object-code","display_name":"Object code","score":0.6469506621360779},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.641242265701294},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5828168392181396},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5635904669761658},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.543965220451355},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.5234394073486328},{"id":"https://openalex.org/keywords/processor-register","display_name":"Processor register","score":0.5043991804122925},{"id":"https://openalex.org/keywords/optimizing-compiler","display_name":"Optimizing compiler","score":0.501528263092041},{"id":"https://openalex.org/keywords/program-optimization","display_name":"Program optimization","score":0.464288592338562},{"id":"https://openalex.org/keywords/unreachable-code","display_name":"Unreachable code","score":0.44622179865837097},{"id":"https://openalex.org/keywords/register-file","display_name":"Register file","score":0.41062289476394653},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.2501506805419922},{"id":"https://openalex.org/keywords/instruction-set","display_name":"Instruction set","score":0.178187757730484},{"id":"https://openalex.org/keywords/memory-address","display_name":"Memory address","score":0.08560425043106079},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.08213889598846436}],"concepts":[{"id":"https://openalex.org/C128916667","wikidata":"https://www.wikidata.org/wiki/Q1343660","display_name":"Register allocation","level":3,"score":0.951697587966919},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9131932258605957},{"id":"https://openalex.org/C154526789","wikidata":"https://www.wikidata.org/wiki/Q157965","display_name":"Object code","level":4,"score":0.6469506621360779},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.641242265701294},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5828168392181396},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5635904669761658},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.543965220451355},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.5234394073486328},{"id":"https://openalex.org/C2871975","wikidata":"https://www.wikidata.org/wiki/Q187466","display_name":"Processor register","level":4,"score":0.5043991804122925},{"id":"https://openalex.org/C190902152","wikidata":"https://www.wikidata.org/wiki/Q1325106","display_name":"Optimizing compiler","level":3,"score":0.501528263092041},{"id":"https://openalex.org/C139571649","wikidata":"https://www.wikidata.org/wiki/Q1156793","display_name":"Program optimization","level":3,"score":0.464288592338562},{"id":"https://openalex.org/C50951305","wikidata":"https://www.wikidata.org/wiki/Q2482534","display_name":"Unreachable code","level":5,"score":0.44622179865837097},{"id":"https://openalex.org/C117280010","wikidata":"https://www.wikidata.org/wiki/Q180944","display_name":"Register file","level":3,"score":0.41062289476394653},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.2501506805419922},{"id":"https://openalex.org/C202491316","wikidata":"https://www.wikidata.org/wiki/Q272683","display_name":"Instruction set","level":2,"score":0.178187757730484},{"id":"https://openalex.org/C153247305","wikidata":"https://www.wikidata.org/wiki/Q835713","display_name":"Memory address","level":3,"score":0.08560425043106079},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.08213889598846436},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C98986596","wikidata":"https://www.wikidata.org/wiki/Q1143031","display_name":"Semiconductor memory","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1002/spe.4380140906","is_oa":false,"landing_page_url":"https://doi.org/10.1002/spe.4380140906","pdf_url":null,"source":{"id":"https://openalex.org/S122199241","display_name":"Software Practice and Experience","issn_l":"0038-0644","issn":["0038-0644","1097-024X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320595","host_organization_name":"Wiley","host_organization_lineage":["https://openalex.org/P4310320595"],"host_organization_lineage_names":["Wiley"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Software: Practice and Experience","raw_type":"journal-article"}],"best_oa_location":null,"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","score":0.5,"id":"https://metadata.un.org/sdg/16"}],"awards":[],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320320719","display_name":"Department of Science and Technology, Ministry of Science and Technology, India","ror":"https://ror.org/0101xrq71"}],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":17,"referenced_works":["https://openalex.org/W1482854495","https://openalex.org/W1493792056","https://openalex.org/W1513250879","https://openalex.org/W1566687055","https://openalex.org/W1676883323","https://openalex.org/W2003804316","https://openalex.org/W2012181512","https://openalex.org/W2065496085","https://openalex.org/W2066539484","https://openalex.org/W2068650790","https://openalex.org/W2086643496","https://openalex.org/W2087585770","https://openalex.org/W2102575054","https://openalex.org/W2163756016","https://openalex.org/W2987803397","https://openalex.org/W4235077482","https://openalex.org/W4244520328"],"related_works":["https://openalex.org/W2282591083","https://openalex.org/W2479182427","https://openalex.org/W2134984227","https://openalex.org/W61798728","https://openalex.org/W2043465108","https://openalex.org/W2184725892","https://openalex.org/W2075496182","https://openalex.org/W1482854495","https://openalex.org/W2953385523","https://openalex.org/W4300524054"],"abstract_inverted_index":{"Abstract":[0],"Emerging":[1],"peephole":[2,71],"optimizers":[3],"can":[4],"relieve":[5],"code":[6,14,24],"generators":[7],"of":[8,26],"much":[9],"case":[10],"analysis,":[11],"but":[12],"delaying":[13],"generation":[15],"decisions":[16],"requires":[17],"register":[18],"allocation":[19],"algorithms":[20,40],"that":[21,37],"accept":[22],"object":[23],"instead":[25],"the":[27,69],"more":[28],"usual":[29],"intermediate":[30],"code.":[31],"This":[32],"paper":[33],"describes":[34],"two":[35],"programs":[36],"implement":[38],"such":[39],"for":[41,68,75],"a":[42,47],"retargetable":[43],"optimizing":[44],"compiler.":[45],"In":[46],"machine\u2010independent":[48],"fashion,":[49],"they":[50],"allocate":[51],"and":[52,65],"assign":[53],"registers,":[54],"eliminate":[55],"common":[56],"subexpressions":[57],"(including":[58],"often\u2010missed":[59],"machine\u2010specific":[60,77],"ones),":[61],"identify":[62],"dead":[63],"variables,":[64],"define":[66],"windows":[67],"companion":[70],"optimizer.":[72],"Their":[73],"techniques":[74],"handling":[76],"data":[78],"should":[79],"generalize":[80],"to":[81],"other":[82],"optimizations":[83],"as":[84],"well.":[85]},"counts_by_year":[{"year":2022,"cited_by_count":2},{"year":2017,"cited_by_count":1},{"year":2013,"cited_by_count":2},{"year":2012,"cited_by_count":1}],"updated_date":"2026-02-24T19:35:01.260952","created_date":"2025-10-10T00:00:00"}
