{"id":"https://openalex.org/W2120339165","doi":"https://doi.org/10.1145/2003476.2003493","title":"Nitpicking c++ concurrency","display_name":"Nitpicking c++ concurrency","publication_year":2011,"publication_date":"2011-07-20","ids":{"openalex":"https://openalex.org/W2120339165","doi":"https://doi.org/10.1145/2003476.2003493","mag":"2120339165"},"language":"en","primary_location":{"id":"doi:10.1145/2003476.2003493","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2003476.2003493","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 13th international ACM SIGPLAN symposium on Principles and practices of declarative programming","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/A5079200257","display_name":"Jasmin Christian Blanchette","orcid":"https://orcid.org/0000-0002-8367-0936"},"institutions":[{"id":"https://openalex.org/I62916508","display_name":"Technical University of Munich","ror":"https://ror.org/02kkvpp62","country_code":"DE","type":"education","lineage":["https://openalex.org/I62916508"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Jasmin Christian Blanchette","raw_affiliation_strings":["Technische Universit\u00e4t M\u00fcnchen, Munich, Germany"],"affiliations":[{"raw_affiliation_string":"Technische Universit\u00e4t M\u00fcnchen, Munich, Germany","institution_ids":["https://openalex.org/I62916508"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5083906333","display_name":"Tjark Weber","orcid":"https://orcid.org/0000-0001-8967-6987"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Tjark Weber","raw_affiliation_strings":["University of Cambridge, Cambridge, United Kingdom"],"affiliations":[{"raw_affiliation_string":"University of Cambridge, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I241749"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5043076240","display_name":"Mark Batty","orcid":"https://orcid.org/0000-0001-7053-4364"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Mark Batty","raw_affiliation_strings":["University of Cambridge, Cambridge, United Kingdom"],"affiliations":[{"raw_affiliation_string":"University of Cambridge, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I241749"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5049346665","display_name":"Scott Owens","orcid":"https://orcid.org/0000-0002-7437-4780"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Scott Owens","raw_affiliation_strings":["University of Cambridge, Cambridge, United Kingdom"],"affiliations":[{"raw_affiliation_string":"University of Cambridge, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I241749"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5073254249","display_name":"Susmit Sarkar","orcid":"https://orcid.org/0000-0002-4259-9213"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Susmit Sarkar","raw_affiliation_strings":["University of Cambridge, Cambridge, United Kingdom"],"affiliations":[{"raw_affiliation_string":"University of Cambridge, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I241749"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5079200257"],"corresponding_institution_ids":["https://openalex.org/I62916508"],"apc_list":null,"apc_paid":null,"fwci":4.0478,"has_fulltext":false,"cited_by_count":38,"citation_normalized_percentile":{"value":0.93817505,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"113","last_page":"124"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9997000098228455,"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"}},"topics":[{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9997000098228455,"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/T11424","display_name":"Security and Verification in Computing","score":0.9994999766349792,"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.9993000030517578,"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/hol","display_name":"HOL","score":0.9068202972412109},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.817925214767456},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.711231529712677},{"id":"https://openalex.org/keywords/memory-model","display_name":"Memory model","score":0.6978552937507629},{"id":"https://openalex.org/keywords/concurrency","display_name":"Concurrency","score":0.6800632476806641},{"id":"https://openalex.org/keywords/litmus","display_name":"Litmus","score":0.6034467220306396},{"id":"https://openalex.org/keywords/model-checking","display_name":"Model checking","score":0.5786272287368774},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.5116518139839172},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.429749995470047},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4182434380054474},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.3189430236816406},{"id":"https://openalex.org/keywords/shared-memory","display_name":"Shared memory","score":0.289232075214386}],"concepts":[{"id":"https://openalex.org/C17435882","wikidata":"https://www.wikidata.org/wiki/Q17030435","display_name":"HOL","level":2,"score":0.9068202972412109},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.817925214767456},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.711231529712677},{"id":"https://openalex.org/C12186640","wikidata":"https://www.wikidata.org/wiki/Q6815743","display_name":"Memory model","level":3,"score":0.6978552937507629},{"id":"https://openalex.org/C193702766","wikidata":"https://www.wikidata.org/wiki/Q1414548","display_name":"Concurrency","level":2,"score":0.6800632476806641},{"id":"https://openalex.org/C157329479","wikidata":"https://www.wikidata.org/wiki/Q185082","display_name":"Litmus","level":2,"score":0.6034467220306396},{"id":"https://openalex.org/C110251889","wikidata":"https://www.wikidata.org/wiki/Q1569697","display_name":"Model checking","level":2,"score":0.5786272287368774},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.5116518139839172},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.429749995470047},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4182434380054474},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.3189430236816406},{"id":"https://openalex.org/C133875982","wikidata":"https://www.wikidata.org/wiki/Q764810","display_name":"Shared memory","level":2,"score":0.289232075214386},{"id":"https://openalex.org/C185592680","wikidata":"https://www.wikidata.org/wiki/Q2329","display_name":"Chemistry","level":0,"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/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C147789679","wikidata":"https://www.wikidata.org/wiki/Q11372","display_name":"Physical chemistry","level":1,"score":0.0}],"mesh":[],"locations_count":6,"locations":[{"id":"doi:10.1145/2003476.2003493","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2003476.2003493","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 13th international ACM SIGPLAN symposium on Principles and practices of declarative programming","raw_type":"proceedings-article"},{"id":"pmh:oai:kar.kent.ac.uk:50260","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2003476.2003493>)","pdf_url":null,"source":{"id":"https://openalex.org/S4377196264","display_name":"Kent Academic Repository (University of Kent)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I20581793","host_organization_name":"University of Kent","host_organization_lineage":["https://openalex.org/I20581793"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":null,"raw_type":"PeerReviewed"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.221.5773","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.221.5773","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www4.in.tum.de/%7Eblanchet/ppdp2011-cpp-mem.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.299.3138","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.299.3138","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www4.in.tum.de/~blanchet/ppdp2011-cpp-mem.pdf","raw_type":"text"},{"id":"pmh:oai:eprints.ucl.ac.uk.OAI2:1371910","is_oa":false,"landing_page_url":"http://discovery.ucl.ac.uk/1371910/","pdf_url":null,"source":{"id":"https://openalex.org/S4306400024","display_name":"UCL Discovery (University College London)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I45129253","host_organization_name":"University College London","host_organization_lineage":["https://openalex.org/I45129253"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"     In: Schneider-Kamp, P and Hanus, M, (eds.)   (pp. pp. 113-124).  ACM (2011)     ","raw_type":"Proceedings paper"},{"id":"pmh:oai:kar.kent.ac.uk:31895","is_oa":false,"landing_page_url":"https://kar.kent.ac.uk/31895/","pdf_url":null,"source":{"id":"https://openalex.org/S4377196264","display_name":"Kent Academic Repository (University of Kent)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I20581793","host_organization_name":"University of Kent","host_organization_lineage":["https://openalex.org/I20581793"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Conference or workshop item"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G3213815105","display_name":null,"funder_award_id":"Ni 491/11-2","funder_id":"https://openalex.org/F4320320879","funder_display_name":"Deutsche Forschungsgemeinschaft"},{"id":"https://openalex.org/G341710930","display_name":null,"funder_award_id":"EP/H027351/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G6428170234","display_name":null,"funder_award_id":"EP/H005633","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"}],"funders":[{"id":"https://openalex.org/F4320320879","display_name":"Deutsche Forschungsgemeinschaft","ror":"https://ror.org/018mejw64"},{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":35,"referenced_works":["https://openalex.org/W1482397304","https://openalex.org/W1490967459","https://openalex.org/W1498505994","https://openalex.org/W1498523273","https://openalex.org/W1500635751","https://openalex.org/W1518705996","https://openalex.org/W1519503479","https://openalex.org/W1521083034","https://openalex.org/W1521087854","https://openalex.org/W1589643726","https://openalex.org/W1595209293","https://openalex.org/W1895387792","https://openalex.org/W1924116124","https://openalex.org/W1995825057","https://openalex.org/W1996404651","https://openalex.org/W2033818578","https://openalex.org/W2054739713","https://openalex.org/W2084797476","https://openalex.org/W2085025498","https://openalex.org/W2091085450","https://openalex.org/W2098643127","https://openalex.org/W2106192381","https://openalex.org/W2133866986","https://openalex.org/W2134433063","https://openalex.org/W2138074470","https://openalex.org/W2149911648","https://openalex.org/W2152484464","https://openalex.org/W2171480813","https://openalex.org/W2364800968","https://openalex.org/W2398188754","https://openalex.org/W4234066571","https://openalex.org/W4250846042","https://openalex.org/W4256124958","https://openalex.org/W4299731435","https://openalex.org/W4301005547"],"related_works":["https://openalex.org/W2462966030","https://openalex.org/W2625764229","https://openalex.org/W2161970779","https://openalex.org/W3019068005","https://openalex.org/W2984491831","https://openalex.org/W2605308338","https://openalex.org/W4251930438","https://openalex.org/W51021667","https://openalex.org/W1822674892","https://openalex.org/W2120339165"],"abstract_inverted_index":{"Previous":[0],"work":[1],"formalized":[2],"the":[3,14,21,32,59,75,84],"C++":[4,60],"memory":[5,33,61],"model":[6,22,87],"in":[7,9,94],"Isabelle/HOL":[8],"an":[10],"effort":[11],"to":[12,25,58,66,74],"clarify":[13],"proposed":[15],"standard's":[16],"semantics.":[17],"Here":[18],"we":[19],"employ":[20],"finder":[23],"Nitpick":[24,40,95],"check":[26],"litmus":[27],"test":[28],"programs":[29],"that":[30],"exercise":[31],"model,":[34],"including":[35],"a":[36,69],"simple":[37],"locking":[38],"algorithm.":[39],"is":[41],"built":[42],"on":[43],"Kodkod":[44],"(Alloy's":[45],"backend)":[46],"but":[47],"understands":[48],"Isabelle's":[49],"richer":[50],"logic;":[51],"hence":[52],"it":[53,68,79],"can":[54,100],"be":[55],"applied":[56],"directly":[57],"model.":[62],"We":[63],"only":[64],"need":[65],"give":[67],"few":[70],"hints,":[71],"and":[72],"thanks":[73],"underlying":[76],"SAT":[77],"solver":[78],"scales":[80],"much":[81],"better":[82],"than":[83],"Cppmem":[85],"explicit-state":[86],"checker.":[88],"This":[89],"case":[90],"study":[91],"inspired":[92],"optimizations":[93],"from":[96],"which":[97],"other":[98],"formalizations":[99],"now":[101],"benefit.":[102]},"counts_by_year":[{"year":2021,"cited_by_count":3},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":1},{"year":2017,"cited_by_count":3},{"year":2016,"cited_by_count":11},{"year":2015,"cited_by_count":7},{"year":2014,"cited_by_count":1},{"year":2013,"cited_by_count":4},{"year":2012,"cited_by_count":4}],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
