{"id":"https://openalex.org/W2075559812","doi":"https://doi.org/10.1145/2804302.2804312","title":"Formally proving a compiler transformation safe","display_name":"Formally proving a compiler transformation safe","publication_year":2015,"publication_date":"2015-08-24","ids":{"openalex":"https://openalex.org/W2075559812","doi":"https://doi.org/10.1145/2804302.2804312","mag":"2075559812"},"language":"en","primary_location":{"id":"doi:10.1145/2804302.2804312","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804312","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","raw_type":"proceedings-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/A5049741143","display_name":"Joachim Breitner","orcid":"https://orcid.org/0000-0003-3753-6821"},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Joachim Breitner","raw_affiliation_strings":["KIT, Germany"],"affiliations":[{"raw_affiliation_string":"KIT, Germany","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":0,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5049741143"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.1572,"has_fulltext":false,"cited_by_count":9,"citation_normalized_percentile":{"value":0.90074139,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"35","last_page":"46"},"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.9998999834060669,"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.9998999834060669,"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.9987999796867371,"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/T11424","display_name":"Security and Verification in Computing","score":0.9976999759674072,"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.8219609260559082},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.80901038646698},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.7215027809143066},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6865447163581848},{"id":"https://openalex.org/keywords/abstract-syntax-tree","display_name":"Abstract syntax tree","score":0.5972285270690918},{"id":"https://openalex.org/keywords/transformation","display_name":"Transformation (genetics)","score":0.5378578901290894},{"id":"https://openalex.org/keywords/automated-theorem-proving","display_name":"Automated theorem proving","score":0.4763079881668091},{"id":"https://openalex.org/keywords/optimizing-compiler","display_name":"Optimizing compiler","score":0.473578542470932},{"id":"https://openalex.org/keywords/trace","display_name":"TRACE (psycholinguistics)","score":0.44364774227142334},{"id":"https://openalex.org/keywords/gas-meter-prover","display_name":"Gas meter prover","score":0.43771037459373474},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.4328608810901642},{"id":"https://openalex.org/keywords/compiler-correctness","display_name":"Compiler correctness","score":0.4156377911567688},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.4148516058921814},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.37483158707618713},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.29532480239868164},{"id":"https://openalex.org/keywords/parsing","display_name":"Parsing","score":0.2678893506526947},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.20983079075813293},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.11735197901725769}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8219609260559082},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.80901038646698},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.7215027809143066},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6865447163581848},{"id":"https://openalex.org/C58646249","wikidata":"https://www.wikidata.org/wiki/Q127380","display_name":"Abstract syntax tree","level":3,"score":0.5972285270690918},{"id":"https://openalex.org/C204241405","wikidata":"https://www.wikidata.org/wiki/Q461499","display_name":"Transformation (genetics)","level":3,"score":0.5378578901290894},{"id":"https://openalex.org/C206880738","wikidata":"https://www.wikidata.org/wiki/Q431667","display_name":"Automated theorem proving","level":2,"score":0.4763079881668091},{"id":"https://openalex.org/C190902152","wikidata":"https://www.wikidata.org/wiki/Q1325106","display_name":"Optimizing compiler","level":3,"score":0.473578542470932},{"id":"https://openalex.org/C75291252","wikidata":"https://www.wikidata.org/wiki/Q1315756","display_name":"TRACE (psycholinguistics)","level":2,"score":0.44364774227142334},{"id":"https://openalex.org/C159718280","wikidata":"https://www.wikidata.org/wiki/Q5526353","display_name":"Gas meter prover","level":3,"score":0.43771037459373474},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.4328608810901642},{"id":"https://openalex.org/C68366613","wikidata":"https://www.wikidata.org/wiki/Q5156378","display_name":"Compiler correctness","level":3,"score":0.4156377911567688},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.4148516058921814},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.37483158707618713},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.29532480239868164},{"id":"https://openalex.org/C186644900","wikidata":"https://www.wikidata.org/wiki/Q194152","display_name":"Parsing","level":2,"score":0.2678893506526947},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.20983079075813293},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.11735197901725769},{"id":"https://openalex.org/C41895202","wikidata":"https://www.wikidata.org/wiki/Q8162","display_name":"Linguistics","level":1,"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/C185592680","wikidata":"https://www.wikidata.org/wiki/Q2329","display_name":"Chemistry","level":0,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C104317684","wikidata":"https://www.wikidata.org/wiki/Q7187","display_name":"Gene","level":2,"score":0.0},{"id":"https://openalex.org/C55493867","wikidata":"https://www.wikidata.org/wiki/Q7094","display_name":"Biochemistry","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2804302.2804312","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804312","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":31,"referenced_works":["https://openalex.org/W153348447","https://openalex.org/W1480753098","https://openalex.org/W1485845471","https://openalex.org/W1495561703","https://openalex.org/W1521087854","https://openalex.org/W1585990765","https://openalex.org/W1597593202","https://openalex.org/W2004843654","https://openalex.org/W2006731094","https://openalex.org/W2016408482","https://openalex.org/W2035636826","https://openalex.org/W2038401271","https://openalex.org/W2054386188","https://openalex.org/W2061969020","https://openalex.org/W2088030260","https://openalex.org/W2091345373","https://openalex.org/W2103859677","https://openalex.org/W2106192381","https://openalex.org/W2131802241","https://openalex.org/W2167433695","https://openalex.org/W2176417916","https://openalex.org/W2394811111","https://openalex.org/W2401842409","https://openalex.org/W2520285515","https://openalex.org/W2763665294","https://openalex.org/W2914870158","https://openalex.org/W2963887901","https://openalex.org/W4250846042","https://openalex.org/W6712072000","https://openalex.org/W6713006968","https://openalex.org/W6726781528"],"related_works":["https://openalex.org/W2958080190","https://openalex.org/W1551673055","https://openalex.org/W2952185493","https://openalex.org/W1182916745","https://openalex.org/W2054386188","https://openalex.org/W4246454774","https://openalex.org/W2121223013","https://openalex.org/W2536586774","https://openalex.org/W4247754322","https://openalex.org/W4252080451"],"abstract_inverted_index":{"We":[0,27,76],"prove":[1],"that":[2],"the":[3,12,22,25,31,34,37,78,81],"Call":[4],"Arity":[5],"analysis":[6,32],"and":[7,33,47,64],"transformation,":[8],"as":[9,68],"implemented":[10],"in":[11,36,72],"Haskell":[13],"compiler":[14,56],"GHC,":[15],"is":[16,62],"safe,":[17],"i.e.":[18],"does":[19],"not":[20],"impede":[21],"performance":[23],"of":[24,51,80],"program.":[26],"formalized":[28],"syntax,":[29],"semantics,":[30],"transformation":[35],"interactive":[38],"theorem":[39],"prover":[40],"Isabelle":[41],"to":[42],"obtain":[43],"a":[44,49,69],"machine-checked":[45],"proof":[46,61],"hence":[48],"level":[50],"rigor":[52],"rarely":[53],"obtained":[54],"for":[55],"optimization":[57],"safety":[58],"theorems.":[59],"The":[60],"modular":[63],"introduces":[65],"trace":[66],"trees":[67],"suitable":[70],"abstraction":[71],"abstract":[73],"cardinality":[74],"analyses.":[75],"discuss":[77],"breadth":[79],"formalization":[82],"gap.":[83]},"counts_by_year":[{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
