{"id":"https://openalex.org/W4293812621","doi":"https://doi.org/10.1145/3547621","title":"Beyond Relooper: recursive translation of unstructured control flow to structured control flow (functional pearl)","display_name":"Beyond Relooper: recursive translation of unstructured control flow to structured control flow (functional pearl)","publication_year":2022,"publication_date":"2022-08-29","ids":{"openalex":"https://openalex.org/W4293812621","doi":"https://doi.org/10.1145/3547621"},"language":"en","primary_location":{"id":"doi:10.1145/3547621","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3547621","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3547621","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3547621","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5068702687","display_name":"Norman F. Ramsey","orcid":"https://orcid.org/0000-0002-5435-1135"},"institutions":[{"id":"https://openalex.org/I121934306","display_name":"Tufts University","ror":"https://ror.org/05wvpxv85","country_code":"US","type":"education","lineage":["https://openalex.org/I121934306"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Norman Ramsey","raw_affiliation_strings":["Tweag, France / Tufts University, USA"],"affiliations":[{"raw_affiliation_string":"Tweag, France / Tufts University, USA","institution_ids":["https://openalex.org/I121934306"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5068702687"],"corresponding_institution_ids":["https://openalex.org/I121934306"],"apc_list":null,"apc_paid":null,"fwci":0.6628,"has_fulltext":true,"cited_by_count":5,"citation_normalized_percentile":{"value":0.74035545,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":97,"max":98},"biblio":{"volume":"6","issue":"ICFP","first_page":"1","last_page":"22"},"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.9988999962806702,"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.9988999962806702,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9979000091552734,"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/T11424","display_name":"Security and Verification in Computing","score":0.9914000034332275,"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/computer-science","display_name":"Computer science","score":0.8156793117523193},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.7564988136291504},{"id":"https://openalex.org/keywords/control-flow","display_name":"Control flow","score":0.7298835515975952},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6870417594909668},{"id":"https://openalex.org/keywords/javascript","display_name":"JavaScript","score":0.6540588140487671},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.5091347098350525},{"id":"https://openalex.org/keywords/tweaking","display_name":"Tweaking","score":0.5072085857391357},{"id":"https://openalex.org/keywords/control-flow-analysis","display_name":"Control flow analysis","score":0.5047012567520142},{"id":"https://openalex.org/keywords/control-flow-graph","display_name":"Control flow graph","score":0.49484318494796753},{"id":"https://openalex.org/keywords/control","display_name":"Control (management)","score":0.41062426567077637},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3829711079597473},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.27404922246932983},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.25832414627075195},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.13228252530097961},{"id":"https://openalex.org/keywords/procedural-programming","display_name":"Procedural programming","score":0.09289249777793884}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8156793117523193},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.7564988136291504},{"id":"https://openalex.org/C160191386","wikidata":"https://www.wikidata.org/wiki/Q868299","display_name":"Control flow","level":2,"score":0.7298835515975952},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6870417594909668},{"id":"https://openalex.org/C544833334","wikidata":"https://www.wikidata.org/wiki/Q2005","display_name":"JavaScript","level":2,"score":0.6540588140487671},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.5091347098350525},{"id":"https://openalex.org/C2780200862","wikidata":"https://www.wikidata.org/wiki/Q4453309","display_name":"Tweaking","level":2,"score":0.5072085857391357},{"id":"https://openalex.org/C176359209","wikidata":"https://www.wikidata.org/wiki/Q2348963","display_name":"Control flow analysis","level":5,"score":0.5047012567520142},{"id":"https://openalex.org/C27458966","wikidata":"https://www.wikidata.org/wiki/Q1187693","display_name":"Control flow graph","level":2,"score":0.49484318494796753},{"id":"https://openalex.org/C2775924081","wikidata":"https://www.wikidata.org/wiki/Q55608371","display_name":"Control (management)","level":2,"score":0.41062426567077637},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3829711079597473},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.27404922246932983},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.25832414627075195},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.13228252530097961},{"id":"https://openalex.org/C120558287","wikidata":"https://www.wikidata.org/wiki/Q1418502","display_name":"Procedural programming","level":4,"score":0.09289249777793884},{"id":"https://openalex.org/C50033165","wikidata":"https://www.wikidata.org/wiki/Q15712089","display_name":"Inductive programming","level":3,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3547621","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3547621","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3547621","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1145/3547621","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3547621","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3547621","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4293812621.pdf","grobid_xml":"https://content.openalex.org/works/W4293812621.grobid-xml"},"referenced_works_count":16,"referenced_works":["https://openalex.org/W1538992328","https://openalex.org/W1995405030","https://openalex.org/W2054572543","https://openalex.org/W2059518671","https://openalex.org/W2074556793","https://openalex.org/W2078508340","https://openalex.org/W2079430385","https://openalex.org/W2083828778","https://openalex.org/W2095621310","https://openalex.org/W2111379929","https://openalex.org/W2125690388","https://openalex.org/W2127637733","https://openalex.org/W2156487548","https://openalex.org/W4251805752","https://openalex.org/W4307886860","https://openalex.org/W6931716571"],"related_works":["https://openalex.org/W2080682474","https://openalex.org/W4229928981","https://openalex.org/W10692195","https://openalex.org/W2138149796","https://openalex.org/W1461715167","https://openalex.org/W2599014345","https://openalex.org/W2131031571","https://openalex.org/W2294309217","https://openalex.org/W4293812621","https://openalex.org/W630634248"],"abstract_inverted_index":{"In":[0],"many":[1],"compilers,":[2],"control":[3,23,52,60],"flow":[4,24,53],"is":[5,127],"represented":[6],"using":[7,32],"an":[8],"arbitrary":[9,59],"directed":[10],"graph.":[11],"But":[12],"in":[13,29,48,120],"some":[14],"interesting":[15],"target":[16],"languages,":[17],"including":[18],"JavaScript":[19],"and":[20,35,46,94,104,143],"WebAssembly,":[21],"intraprocedural":[22],"can":[25,54,117],"be":[26,55,118,130],"expressed":[27],"only":[28],"structured":[30,51],"ways,":[31],"loops,":[33],"conditionals,":[34],"multilevel":[36],"breaks":[37],"or":[38],"exits.":[39],"As":[40],"was":[41,79],"shown":[42],"by":[43,57,81,95],"Peterson,":[44],"Kasami,":[45],"Tokura":[47],"1973,":[49],"such":[50],"obtained":[56],"translating":[58],"flow.":[61],"The":[62],"translation":[63],"uses":[64],"two":[65],"standard":[66],"analyses,":[67],"but":[68],"as":[69],"published,":[70],"it":[71,78,150],"takes":[72],"three":[73],"passes\u2014which":[74],"may":[75],"explain":[76],"why":[77],"overlooked":[80],"Emscripten,":[82],"a":[83,112,121],"popular":[84],"compiler":[85],"from":[86,99],"C":[87],"to":[88,129,132,153],"JavaScript.":[89],"By":[90],"tweaking":[91],"the":[92,108,133,157],"analyses":[93],"applying":[96],"fundamental":[97],"ideas":[98],"functional":[100],"programming":[101],"(recursive":[102],"functions":[103],"immutable":[105,141],"abstract-syntax":[106],"trees),":[107],"translation,":[109,139],"along":[110],"with":[111],"couple":[113],"of":[114,146],"code":[115],"improvements,":[116],"implemented":[119],"single":[122],"pass.":[123],"This":[124],"new":[125],"implementation":[126],"slated":[128],"added":[131],"Glasgow":[134],"Haskell":[135],"Compiler.":[136],"Its":[137],"single-pass":[138],"its":[140,144],"representation,":[142],"use":[145],"dominator":[147],"trees":[148],"make":[149],"much":[151],"easier":[152],"reason":[154],"about":[155],"than":[156],"original":[158],"translation.":[159]},"counts_by_year":[{"year":2025,"cited_by_count":5}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
