{"id":"https://openalex.org/W4289874386","doi":"https://doi.org/10.1007/978-3-031-13188-2_16","title":"Hemiola: A DSL and\u00a0Verification Tools to\u00a0Guide Design and\u00a0Proof of\u00a0Hierarchical Cache-Coherence Protocols","display_name":"Hemiola: A DSL and\u00a0Verification Tools to\u00a0Guide Design and\u00a0Proof of\u00a0Hierarchical Cache-Coherence Protocols","publication_year":2022,"publication_date":"2022-01-01","ids":{"openalex":"https://openalex.org/W4289874386","doi":"https://doi.org/10.1007/978-3-031-13188-2_16"},"language":"en","primary_location":{"id":"doi:10.1007/978-3-031-13188-2_16","is_oa":true,"landing_page_url":"https://doi.org/10.1007/978-3-031-13188-2_16","pdf_url":"https://link.springer.com/content/pdf/10.1007/978-3-031-13188-2_16.pdf","source":{"id":"https://openalex.org/S106296714","display_name":"Lecture notes in computer science","issn_l":"0302-9743","issn":["0302-9743","1611-3349"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"book series"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Lecture Notes in Computer Science","raw_type":"book-chapter"},"type":"book-chapter","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://link.springer.com/content/pdf/10.1007/978-3-031-13188-2_16.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5003461001","display_name":"Joonwon Choi","orcid":null},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Joonwon Choi","raw_affiliation_strings":["MIT CSAIL, Cambridge, USA"],"affiliations":[{"raw_affiliation_string":"MIT CSAIL, Cambridge, USA","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5078100439","display_name":"Adam Chlipala","orcid":"https://orcid.org/0000-0001-7085-9417"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Adam Chlipala","raw_affiliation_strings":["MIT CSAIL, Cambridge, USA"],"affiliations":[{"raw_affiliation_string":"MIT CSAIL, Cambridge, USA","institution_ids":[]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5060692552","display_name":"Arvind Arvind","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Arvind","raw_affiliation_strings":["MIT CSAIL, Cambridge, USA"],"affiliations":[{"raw_affiliation_string":"MIT CSAIL, Cambridge, USA","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":0,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5003461001"],"corresponding_institution_ids":[],"apc_list":{"value":5000,"currency":"EUR","value_usd":5392},"apc_paid":{"value":5000,"currency":"EUR","value_usd":5392},"fwci":3.3196,"has_fulltext":true,"cited_by_count":6,"citation_normalized_percentile":{"value":0.92915834,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":94,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"317","last_page":"339"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10142","display_name":"Formal Methods in Verification","score":0.9994999766349792,"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"}},"topics":[{"id":"https://openalex.org/T10142","display_name":"Formal Methods in Verification","score":0.9994999766349792,"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.9990000128746033,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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.9987000226974487,"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.9115068912506104},{"id":"https://openalex.org/keywords/cache-coherence","display_name":"Cache coherence","score":0.7942063808441162},{"id":"https://openalex.org/keywords/toolchain","display_name":"Toolchain","score":0.548180341720581},{"id":"https://openalex.org/keywords/protocol","display_name":"Protocol (science)","score":0.5351866483688354},{"id":"https://openalex.org/keywords/digital-subscriber-line","display_name":"Digital subscriber line","score":0.47831204533576965},{"id":"https://openalex.org/keywords/embedded-system","display_name":"Embedded system","score":0.45659977197647095},{"id":"https://openalex.org/keywords/mesi-protocol","display_name":"MESI protocol","score":0.42352673411369324},{"id":"https://openalex.org/keywords/cache","display_name":"Cache","score":0.4166876971721649},{"id":"https://openalex.org/keywords/computer-architecture","display_name":"Computer architecture","score":0.3587544560432434},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.33264482021331787},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.30768948793411255},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.29763996601104736},{"id":"https://openalex.org/keywords/cpu-cache","display_name":"CPU cache","score":0.2767750918865204},{"id":"https://openalex.org/keywords/cache-algorithms","display_name":"Cache algorithms","score":0.25254279375076294},{"id":"https://openalex.org/keywords/computer-network","display_name":"Computer network","score":0.16057637333869934},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.09040525555610657}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9115068912506104},{"id":"https://openalex.org/C141917322","wikidata":"https://www.wikidata.org/wiki/Q1025017","display_name":"Cache coherence","level":5,"score":0.7942063808441162},{"id":"https://openalex.org/C2777062904","wikidata":"https://www.wikidata.org/wiki/Q545406","display_name":"Toolchain","level":3,"score":0.548180341720581},{"id":"https://openalex.org/C2780385302","wikidata":"https://www.wikidata.org/wiki/Q367158","display_name":"Protocol (science)","level":3,"score":0.5351866483688354},{"id":"https://openalex.org/C201374245","wikidata":"https://www.wikidata.org/wiki/Q104534","display_name":"Digital subscriber line","level":2,"score":0.47831204533576965},{"id":"https://openalex.org/C149635348","wikidata":"https://www.wikidata.org/wiki/Q193040","display_name":"Embedded system","level":1,"score":0.45659977197647095},{"id":"https://openalex.org/C120936851","wikidata":"https://www.wikidata.org/wiki/Q1408065","display_name":"MESI protocol","level":5,"score":0.42352673411369324},{"id":"https://openalex.org/C115537543","wikidata":"https://www.wikidata.org/wiki/Q165596","display_name":"Cache","level":2,"score":0.4166876971721649},{"id":"https://openalex.org/C118524514","wikidata":"https://www.wikidata.org/wiki/Q173212","display_name":"Computer architecture","level":1,"score":0.3587544560432434},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.33264482021331787},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.30768948793411255},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.29763996601104736},{"id":"https://openalex.org/C189783530","wikidata":"https://www.wikidata.org/wiki/Q352090","display_name":"CPU cache","level":3,"score":0.2767750918865204},{"id":"https://openalex.org/C38556500","wikidata":"https://www.wikidata.org/wiki/Q13404475","display_name":"Cache algorithms","level":4,"score":0.25254279375076294},{"id":"https://openalex.org/C31258907","wikidata":"https://www.wikidata.org/wiki/Q1301371","display_name":"Computer network","level":1,"score":0.16057637333869934},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.09040525555610657},{"id":"https://openalex.org/C204787440","wikidata":"https://www.wikidata.org/wiki/Q188504","display_name":"Alternative medicine","level":2,"score":0.0},{"id":"https://openalex.org/C71924100","wikidata":"https://www.wikidata.org/wiki/Q11190","display_name":"Medicine","level":0,"score":0.0},{"id":"https://openalex.org/C142724271","wikidata":"https://www.wikidata.org/wiki/Q7208","display_name":"Pathology","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1007/978-3-031-13188-2_16","is_oa":true,"landing_page_url":"https://doi.org/10.1007/978-3-031-13188-2_16","pdf_url":"https://link.springer.com/content/pdf/10.1007/978-3-031-13188-2_16.pdf","source":{"id":"https://openalex.org/S106296714","display_name":"Lecture notes in computer science","issn_l":"0302-9743","issn":["0302-9743","1611-3349"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"book series"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Lecture Notes in Computer Science","raw_type":"book-chapter"}],"best_oa_location":{"id":"doi:10.1007/978-3-031-13188-2_16","is_oa":true,"landing_page_url":"https://doi.org/10.1007/978-3-031-13188-2_16","pdf_url":"https://link.springer.com/content/pdf/10.1007/978-3-031-13188-2_16.pdf","source":{"id":"https://openalex.org/S106296714","display_name":"Lecture notes in computer science","issn_l":"0302-9743","issn":["0302-9743","1611-3349"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"book series"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Lecture Notes in Computer Science","raw_type":"book-chapter"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G6432411175","display_name":null,"funder_award_id":"HR001118C0018","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"}],"funders":[{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"},{"id":"https://openalex.org/F4320332815","display_name":"Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4289874386.pdf","grobid_xml":"https://content.openalex.org/works/W4289874386.grobid-xml"},"referenced_works_count":33,"referenced_works":["https://openalex.org/W14360457","https://openalex.org/W1147832988","https://openalex.org/W1496148388","https://openalex.org/W1547100201","https://openalex.org/W1548644447","https://openalex.org/W1879996931","https://openalex.org/W2072062729","https://openalex.org/W2075201692","https://openalex.org/W2080146642","https://openalex.org/W2082471399","https://openalex.org/W2093356672","https://openalex.org/W2098170468","https://openalex.org/W2115716046","https://openalex.org/W2119845125","https://openalex.org/W2128767383","https://openalex.org/W2148392844","https://openalex.org/W2155063683","https://openalex.org/W2163947040","https://openalex.org/W2166423938","https://openalex.org/W2168113051","https://openalex.org/W2617836188","https://openalex.org/W2753285289","https://openalex.org/W2765110025","https://openalex.org/W2802339701","https://openalex.org/W2904603148","https://openalex.org/W3033189783","https://openalex.org/W3043482870","https://openalex.org/W3043774277","https://openalex.org/W4238041321","https://openalex.org/W4241192608","https://openalex.org/W4241197535","https://openalex.org/W4300021588","https://openalex.org/W6600117060"],"related_works":["https://openalex.org/W4285204597","https://openalex.org/W2290195868","https://openalex.org/W3193874149","https://openalex.org/W2584505417","https://openalex.org/W3047895653","https://openalex.org/W2013212244","https://openalex.org/W2139534474","https://openalex.org/W2002047509","https://openalex.org/W2107914397","https://openalex.org/W2352722396"],"abstract_inverted_index":{"Abstract":[0],"Cache-coherence":[1],"protocols":[2,48,97,122,132],"have":[3],"been":[4],"one":[5],"of":[6,13,20],"the":[7,44,68,72,80,130],"greatest":[8],"challenges":[9],"in":[10,40,67,99],"formal":[11],"verification":[12],"hardware,":[14],"due":[15],"to":[16,46,78,114],"their":[17],"central":[18],"complication":[19],"executing":[21],"multiple":[22],"memory-access":[23],"transactions":[24,56,84],"concurrently":[25],"within":[26],"a":[27,37,61,76,91,137],"distributed":[28],"message-passing":[29],"system.":[30],"In":[31],"this":[32],"paper,":[33],"we":[34],"introduce":[35],"Hemiola,":[36,100],"framework":[38,59],"embedded":[39],"Coq":[41],"that":[42,49,83,101,129],"guides":[43],"user":[45,77],"design":[47,115],"never":[50],"experience":[51],"inconsistent":[52],"interleavings":[53],"while":[54],"handling":[55],"concurrently.":[57],"The":[58],"provides":[60,90],"DSL,":[62],"where":[63],"any":[64],"protocol":[65,81],"designed":[66,98],"DSL":[69],"always":[70],"satisfies":[71],"serializability":[73],"property,":[74],"allowing":[75],"verify":[79],"assuming":[82],"are":[85,133],"executed":[86],"one-at-a-time.":[87],"Hemiola":[88,113],"also":[89,127],"novel":[92],"invariant":[93],"proof":[94],"method,":[95],"for":[96],"only":[102],"requires":[103],"considering":[104],"execution":[105],"histories":[106],"without":[107],"interleaved":[108],"memory":[109],"accesses.":[110],"We":[111,126],"used":[112],"and":[116,120],"prove":[117],"hierarchical":[118],"MSI":[119],"MESI":[121],"as":[123],"case":[124],"studies.":[125],"demonstrated":[128],"case-study":[131],"hardware-synthesizable,":[134],"by":[135],"using":[136],"compilation/synthesis":[138],"toolchain":[139],"targeting":[140],"FPGAs.":[141]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":3},{"year":2023,"cited_by_count":2}],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
