{"id":"https://openalex.org/W2158848314","doi":"https://doi.org/10.1017/s0956796815000180","title":"Calculating correct compilers","display_name":"Calculating correct compilers","publication_year":2015,"publication_date":"2015-01-01","ids":{"openalex":"https://openalex.org/W2158848314","doi":"https://doi.org/10.1017/s0956796815000180","mag":"2158848314"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796815000180","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796815000180","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/70AA17724EBCA4182B1B2B522362A9AF/S0956796815000180a.pdf/div-class-title-calculating-correct-compilers-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/70AA17724EBCA4182B1B2B522362A9AF/S0956796815000180a.pdf/div-class-title-calculating-correct-compilers-div.pdf","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5015853763","display_name":"Patrick Bahr","orcid":"https://orcid.org/0000-0003-1600-8261"},"institutions":[{"id":"https://openalex.org/I124055696","display_name":"University of Copenhagen","ror":"https://ror.org/035b05819","country_code":"DK","type":"education","lineage":["https://openalex.org/I124055696"]}],"countries":["DK"],"is_corresponding":true,"raw_author_name":"PATRICK BAHR","raw_affiliation_strings":["Department of Computer Science, University of Copenhagen, Denmark (e-mail:"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, University of Copenhagen, Denmark (e-mail:","institution_ids":["https://openalex.org/I124055696"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5069634739","display_name":"Graham Hutton","orcid":"https://orcid.org/0000-0001-9584-5150"},"institutions":[{"id":"https://openalex.org/I142263535","display_name":"University of Nottingham","ror":"https://ror.org/01ee9ar58","country_code":"GB","type":"education","lineage":["https://openalex.org/I142263535"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"GRAHAM HUTTON","raw_affiliation_strings":["School of Computer Science, University of Nottingham, UK (e-mail:"],"affiliations":[{"raw_affiliation_string":"School of Computer Science, University of Nottingham, UK (e-mail:","institution_ids":["https://openalex.org/I142263535"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5015853763"],"corresponding_institution_ids":["https://openalex.org/I124055696"],"apc_list":null,"apc_paid":null,"fwci":3.1158,"has_fulltext":true,"cited_by_count":19,"citation_normalized_percentile":{"value":0.92860878,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":"25","issue":null,"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.9994000196456909,"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.9994000196456909,"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.9936000108718872,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9846000075340271,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.9164398312568665},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8974329233169556},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6628963947296143},{"id":"https://openalex.org/keywords/range","display_name":"Range (aeronautics)","score":0.5366316437721252},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.5124876499176025},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.4844098687171936}],"concepts":[{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.9164398312568665},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8974329233169556},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6628963947296143},{"id":"https://openalex.org/C204323151","wikidata":"https://www.wikidata.org/wiki/Q905424","display_name":"Range (aeronautics)","level":2,"score":0.5366316437721252},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.5124876499176025},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.4844098687171936},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C192562407","wikidata":"https://www.wikidata.org/wiki/Q228736","display_name":"Materials science","level":0,"score":0.0},{"id":"https://openalex.org/C159985019","wikidata":"https://www.wikidata.org/wiki/Q181790","display_name":"Composite material","level":1,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0}],"mesh":[],"locations_count":5,"locations":[{"id":"doi:10.1017/s0956796815000180","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796815000180","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/70AA17724EBCA4182B1B2B522362A9AF/S0956796815000180a.pdf/div-class-title-calculating-correct-compilers-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},{"id":"pmh:oai:eprints.nottingham.ac.uk:32702","is_oa":false,"landing_page_url":"http://journals.cambridge.org/action/displayAbstract?fromPage=online&aid=9961488&fileId=S0956796815000180","pdf_url":null,"source":{"id":"https://openalex.org/S4306402013","display_name":"Nottingham ePrints (University of Nottingham)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I142263535","host_organization_name":"University of Nottingham","host_organization_lineage":["https://openalex.org/I142263535"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Article"},{"id":"pmh:oai:nottingham-repository.worktribe.com:761112","is_oa":true,"landing_page_url":"https://nottingham-repository.worktribe.com/output/761112","pdf_url":null,"source":{"id":"https://openalex.org/S4306402483","display_name":"Repository@Nottingham (University of Nottingham)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I142263535","host_organization_name":"University of Nottingham","host_organization_lineage":["https://openalex.org/I142263535"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"acceptedVersion"},{"id":"pmh:oai:pure.atira.dk:openaire_cris_publications/90161e71-2cb6-4451-9801-ad6fc45805da","is_oa":false,"landing_page_url":"https://curis.ku.dk/portal/da/publications/calculating-correct-compilers(90161e71-2cb6-4451-9801-ad6fc45805da).html","pdf_url":null,"source":{"id":"https://openalex.org/S4306401983","display_name":"Research at the University of Copenhagen (University of Copenhagen)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I124055696","host_organization_name":"University of Copenhagen","host_organization_lineage":["https://openalex.org/I124055696"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Bahr , P & Hutton , G 2015 , ' Calculating correct compilers ' , Journal of Functional Programming , vol. 25 , e14 . https://doi.org/10.1017/S0956796815000180","raw_type":"article"},{"id":"pmh:oai:pure.atira.dk:publications/90161e71-2cb6-4451-9801-ad6fc45805da","is_oa":false,"landing_page_url":"https://researchprofiles.ku.dk/da/publications/90161e71-2cb6-4451-9801-ad6fc45805da","pdf_url":null,"source":{"id":"https://openalex.org/S4306401983","display_name":"Research at the University of Copenhagen (University of Copenhagen)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I124055696","host_organization_name":"University of Copenhagen","host_organization_lineage":["https://openalex.org/I124055696"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Bahr , P & Hutton , G 2015 , ' Calculating correct compilers ' , Journal of Functional Programming , vol. 25 , e14 . https://doi.org/10.1017/S0956796815000180","raw_type":"article"}],"best_oa_location":{"id":"doi:10.1017/s0956796815000180","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796815000180","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/70AA17724EBCA4182B1B2B522362A9AF/S0956796815000180a.pdf/div-class-title-calculating-correct-compilers-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G8321407669","display_name":null,"funder_award_id":"12-132365","funder_id":"https://openalex.org/F4320322928","funder_display_name":"Danmarks Frie Forskningsfond"}],"funders":[{"id":"https://openalex.org/F4320322928","display_name":"Danmarks Frie Forskningsfond","ror":"https://ror.org/02sptwz63"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2158848314.pdf","grobid_xml":"https://content.openalex.org/works/W2158848314.grobid-xml"},"referenced_works_count":33,"referenced_works":["https://openalex.org/W15565884","https://openalex.org/W43926523","https://openalex.org/W141479201","https://openalex.org/W168212000","https://openalex.org/W1467316755","https://openalex.org/W1511668635","https://openalex.org/W1522720500","https://openalex.org/W1522809628","https://openalex.org/W1532043382","https://openalex.org/W1552581850","https://openalex.org/W1553992341","https://openalex.org/W1580664042","https://openalex.org/W1593280365","https://openalex.org/W1760139041","https://openalex.org/W1829885432","https://openalex.org/W1985220128","https://openalex.org/W1987031623","https://openalex.org/W2021712311","https://openalex.org/W2037339733","https://openalex.org/W2043416466","https://openalex.org/W2057292961","https://openalex.org/W2102435409","https://openalex.org/W2103859677","https://openalex.org/W2111304450","https://openalex.org/W2112147599","https://openalex.org/W2126126443","https://openalex.org/W2133979298","https://openalex.org/W2490166346","https://openalex.org/W2912137735","https://openalex.org/W3016921254","https://openalex.org/W4213279211","https://openalex.org/W4234924236","https://openalex.org/W4240127846"],"related_works":["https://openalex.org/W4240253816","https://openalex.org/W3096456556","https://openalex.org/W2169584677","https://openalex.org/W2979513934","https://openalex.org/W4232954277","https://openalex.org/W1713081424","https://openalex.org/W2127315869","https://openalex.org/W1523769955","https://openalex.org/W2245390655","https://openalex.org/W4379536100"],"abstract_inverted_index":{"Abstract":[0],"In":[1,15],"this":[2],"article,":[3],"we":[4,17],"present":[5],"a":[6,19,73,116],"new":[7],"approach":[8,54],"to":[9,27,69],"the":[10,41,44,50,58,100,103,109,124],"problem":[11],"of":[12,40,43,49,60,76,89],"calculating":[13],"compilers.":[14],"particular,":[16],"develop":[18],"simple":[20],"but":[21],"general":[22],"technique":[23],"that":[24],"allows":[25],"us":[26],"derive":[28],"correct":[29],"compilers":[30,45,71],"from":[31],"high-level":[32],"semantics":[33],"by":[34],"systematic":[35],"calculation,":[36],"with":[37],"all":[38],"details":[39],"implementation":[42],"falling":[46],"naturally":[47],"out":[48],"calculation":[51],"process.":[52],"Our":[53],"is":[55],"based":[56],"upon":[57],"use":[59],"standard":[61],"equational":[62],"reasoning":[63],"techniques,":[64],"and":[65,79,93,97,122],"has":[66],"been":[67,106],"applied":[68],"calculate":[70],"for":[72,120],"wide":[74],"range":[75],"language":[77],"features":[78],"their":[80],"combination,":[81],"including":[82],"arithmetic":[83],"expressions,":[84],"exceptions,":[85],"state,":[86],"various":[87],"forms":[88],"lambda":[90],"calculi,":[91],"bounded":[92],"unbounded":[94],"loops,":[95],"non-determinism":[96],"interrupts.":[98],"All":[99],"calculations":[101],"in":[102],"article":[104],"have":[105],"formalised":[107],"using":[108],"Coq":[110],"proof":[111],"assistant,":[112],"which":[113],"serves":[114],"as":[115],"convenient":[117],"interactive":[118],"tool":[119],"developing":[121],"verifying":[123],"calculations.":[125]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":2},{"year":2023,"cited_by_count":3},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":2},{"year":2015,"cited_by_count":1},{"year":2014,"cited_by_count":1}],"updated_date":"2026-04-11T08:14:18.477133","created_date":"2025-10-10T00:00:00"}
