{"id":"https://openalex.org/W4205535283","doi":"https://doi.org/10.1145/3498685","title":"Certifying derivation of state machines from coroutines","display_name":"Certifying derivation of state machines from coroutines","publication_year":2022,"publication_date":"2022-01-12","ids":{"openalex":"https://openalex.org/W4205535283","doi":"https://doi.org/10.1145/3498685"},"language":"en","primary_location":{"id":"doi:10.1145/3498685","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3498685","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3498685","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/3498685","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5076423472","display_name":"Mirai Ikebuchi","orcid":null},"institutions":[{"id":"https://openalex.org/I184597095","display_name":"National Institute of Informatics","ror":"https://ror.org/04ksd4g47","country_code":"JP","type":"facility","lineage":["https://openalex.org/I1319490839","https://openalex.org/I184597095","https://openalex.org/I4210158934"]}],"countries":["JP"],"is_corresponding":true,"raw_author_name":"Mirai Ikebuchi","raw_affiliation_strings":["National Institute of Informatics, Japan"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"National Institute of Informatics, Japan","institution_ids":["https://openalex.org/I184597095"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5082766906","display_name":"Andres Erbsen","orcid":"https://orcid.org/0000-0002-9854-7500"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Andres Erbsen","raw_affiliation_strings":["Massachusetts Institute of Technology, USA"],"raw_orcid":"https://orcid.org/0000-0002-9854-7500","affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5078100439","display_name":"Adam Chlipala","orcid":"https://orcid.org/0000-0001-7085-9417"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Adam Chlipala","raw_affiliation_strings":["Massachusetts Institute of Technology, USA"],"raw_orcid":"https://orcid.org/0000-0001-7085-9417","affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, USA","institution_ids":["https://openalex.org/I63966007"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5076423472"],"corresponding_institution_ids":["https://openalex.org/I184597095"],"apc_list":null,"apc_paid":null,"fwci":0.2775,"has_fulltext":true,"cited_by_count":2,"citation_normalized_percentile":{"value":0.60287708,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":94,"max":96},"biblio":{"volume":"6","issue":"POPL","first_page":"1","last_page":"31"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T11424","display_name":"Security and Verification in Computing","score":0.9998000264167786,"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/T11424","display_name":"Security and Verification in Computing","score":0.9998000264167786,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.998199999332428,"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/T10142","display_name":"Formal Methods in Verification","score":0.9976999759674072,"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/computer-science","display_name":"Computer science","score":0.9055957198143005},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.7896776795387268},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.713973343372345},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.6854183673858643},{"id":"https://openalex.org/keywords/coding","display_name":"Coding (social sciences)","score":0.425537645816803},{"id":"https://openalex.org/keywords/javascript","display_name":"JavaScript","score":0.42187392711639404},{"id":"https://openalex.org/keywords/state","display_name":"State (computer science)","score":0.41939643025398254},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.22408217191696167}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9055957198143005},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.7896776795387268},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.713973343372345},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.6854183673858643},{"id":"https://openalex.org/C179518139","wikidata":"https://www.wikidata.org/wiki/Q5140297","display_name":"Coding (social sciences)","level":2,"score":0.425537645816803},{"id":"https://openalex.org/C544833334","wikidata":"https://www.wikidata.org/wiki/Q2005","display_name":"JavaScript","level":2,"score":0.42187392711639404},{"id":"https://openalex.org/C48103436","wikidata":"https://www.wikidata.org/wiki/Q599031","display_name":"State (computer science)","level":2,"score":0.41939643025398254},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.22408217191696167},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3498685","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3498685","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3498685","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/3498685","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3498685","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3498685","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":[{"id":"https://openalex.org/G1824535694","display_name":null,"funder_award_id":"1521584","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G529548107","display_name":null,"funder_award_id":"CCF-1521584","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320310598","display_name":"Amazon Web Services","ror":"https://ror.org/04mv4n011"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4205535283.pdf","grobid_xml":"https://content.openalex.org/works/W4205535283.grobid-xml"},"referenced_works_count":22,"referenced_works":["https://openalex.org/W78774630","https://openalex.org/W1939647617","https://openalex.org/W1976978933","https://openalex.org/W2043416466","https://openalex.org/W2073001576","https://openalex.org/W2078944436","https://openalex.org/W2108978217","https://openalex.org/W2148662736","https://openalex.org/W2170114248","https://openalex.org/W2295885203","https://openalex.org/W2751246305","https://openalex.org/W2887348000","https://openalex.org/W2903499634","https://openalex.org/W2951467711","https://openalex.org/W2966873892","https://openalex.org/W2995075587","https://openalex.org/W3037570434","https://openalex.org/W3112414036","https://openalex.org/W3124307800","https://openalex.org/W3175804584","https://openalex.org/W3195831978","https://openalex.org/W4353004773"],"related_works":["https://openalex.org/W1601811574","https://openalex.org/W4297749046","https://openalex.org/W4234755189","https://openalex.org/W2803248237","https://openalex.org/W1757338326","https://openalex.org/W2177866842","https://openalex.org/W1461715167","https://openalex.org/W10692195","https://openalex.org/W2192862863","https://openalex.org/W2131031571"],"abstract_inverted_index":{"One":[0],"of":[1,54,69,149,159],"the":[2,52,67,108,173],"biggest":[3],"implementation":[4],"challenges":[5],"in":[6,31,74,107],"security-critical":[7],"network":[8],"protocols":[9,73],"is":[10,102,128],"nested":[11,84],"state":[12,17],"machines.":[13],"In":[14,98],"practice":[15],"today,":[16],"machines":[18],"are":[19,34,88],"either":[20],"implemented":[21,103,156],"manually":[22],"at":[23],"a":[24,63,75,105,152,157],"low":[25],"level,":[26],"risking":[27],"bugs":[28],"easily":[29],"missed":[30],"audits;":[32],"or":[33,49],"written":[35],"using":[36,79],"higher-level":[37],"abstractions":[38],"like":[39],"threads,":[40],"depending":[41],"on":[42],"runtime":[43],"systems":[44],"that":[45,142,172],"may":[46,143],"sacrifice":[47],"performance":[48],"compatibility":[50],"with":[51,95,133,164],"ABIs":[53],"important":[55],"platforms":[56],"(e.g.,":[57],"resource-constrained":[58],"IoT":[59],"systems).":[60],"We":[61],"present":[62],"compiler-based":[64],"technique":[65],"allowing":[66],"best":[68],"both":[70],"worlds,":[71],"coding":[72],"natural":[76],"high-level":[77],"form,":[78],"freer":[80],"monads":[81],"to":[82,92],"represent":[83],"coroutines":[85],",":[86],"which":[87],"then":[89],"compiled":[90],"automatically":[91],"lower-level":[93],"code":[94,176],"explicit":[96],"state.":[97],"fact,":[99],"our":[100,169],"compiler":[101],"as":[104,114],"tactic":[106],"Coq":[109],"proof":[110,119],"assistant,":[111],"structuring":[112],"compilation":[113],"search":[115],"for":[116,120,136,146,162],"an":[117],"equivalence":[118],"source":[121],"and":[122,168],"target":[123],"programs.":[124],"As":[125,151],"such,":[126],"it":[127],"straightforwardly":[129],"(and":[130],"soundly)":[131],"extensible":[132],"new":[134,139],"hints,":[135],"instance":[137],"regarding":[138],"data":[140],"structures":[141],"be":[144],"used":[145],"efficient":[147],"lookup":[148],"coroutines.":[150],"case":[153],"study,":[154],"we":[155],"core":[158],"TLS":[160],"sufficient":[161],"use":[163],"popular":[165],"Web":[166],"browsers,":[167],"experiments":[170],"show":[171],"extracted":[174],"Haskell":[175],"achieves":[177],"reasonable":[178],"performance.":[179]},"counts_by_year":[{"year":2024,"cited_by_count":2}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
