{"id":"https://openalex.org/W2734330146","doi":"https://doi.org/10.1145/3158153","title":"Recalling a witness: foundations and applications of monotonic state","display_name":"Recalling a witness: foundations and applications of monotonic state","publication_year":2017,"publication_date":"2017-12-27","ids":{"openalex":"https://openalex.org/W2734330146","doi":"https://doi.org/10.1145/3158153","mag":"2734330146"},"language":"en","primary_location":{"id":"doi:10.1145/3158153","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3158153","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3158153?download=true","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":false,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"preprint","indexed_in":["arxiv","crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3158153?download=true","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5050436525","display_name":"Danel Ahman","orcid":"https://orcid.org/0000-0001-6595-2756"},"institutions":[{"id":"https://openalex.org/I1326498283","display_name":"Institut national de recherche en informatique et en automatique","ror":"https://ror.org/02kvxyf05","country_code":"FR","type":"funder","lineage":["https://openalex.org/I1326498283"]}],"countries":["FR"],"is_corresponding":true,"raw_author_name":"Danel Ahman","raw_affiliation_strings":["Inria, France"],"affiliations":[{"raw_affiliation_string":"Inria, France","institution_ids":["https://openalex.org/I1326498283"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5108519702","display_name":"C\u00e9dric Fournet","orcid":"https://orcid.org/0000-0001-6929-886X"},"institutions":[{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"C\u00e9dric Fournet","raw_affiliation_strings":["Microsoft Research, UK"],"affiliations":[{"raw_affiliation_string":"Microsoft Research, UK","institution_ids":["https://openalex.org/I4210164937"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5106466226","display_name":"C\u0103t\u0103lin Hri\u0163cu","orcid":"https://orcid.org/0000-0001-8919-8081"},"institutions":[{"id":"https://openalex.org/I1326498283","display_name":"Institut national de recherche en informatique et en automatique","ror":"https://ror.org/02kvxyf05","country_code":"FR","type":"funder","lineage":["https://openalex.org/I1326498283"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"C\u0103t\u0103lin Hri\u0163cu","raw_affiliation_strings":["Inria, France"],"affiliations":[{"raw_affiliation_string":"Inria, France","institution_ids":["https://openalex.org/I1326498283"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5083750560","display_name":"Kenji Maillard","orcid":"https://orcid.org/0000-0001-5554-3203"},"institutions":[{"id":"https://openalex.org/I1326498283","display_name":"Institut national de recherche en informatique et en automatique","ror":"https://ror.org/02kvxyf05","country_code":"FR","type":"funder","lineage":["https://openalex.org/I1326498283"]},{"id":"https://openalex.org/I29607241","display_name":"\u00c9cole Normale Sup\u00e9rieure - PSL","ror":"https://ror.org/05a0dhs15","country_code":"FR","type":"funder","lineage":["https://openalex.org/I2746051580","https://openalex.org/I29607241"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"Kenji Maillard","raw_affiliation_strings":["Inria, France / ENS Paris, France"],"affiliations":[{"raw_affiliation_string":"Inria, France / ENS Paris, France","institution_ids":["https://openalex.org/I1326498283","https://openalex.org/I29607241"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5109204161","display_name":"Aseem Rastogi","orcid":null},"institutions":[{"id":"https://openalex.org/I4210124949","display_name":"Microsoft Research (India)","ror":"https://ror.org/02w7f3w92","country_code":"IN","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210124949"]}],"countries":["IN"],"is_corresponding":false,"raw_author_name":"Aseem Rastogi","raw_affiliation_strings":["Microsoft Research, India"],"affiliations":[{"raw_affiliation_string":"Microsoft Research, India","institution_ids":["https://openalex.org/I4210124949"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5039334115","display_name":"Nikhil Swamy","orcid":"https://orcid.org/0000-0001-5348-9266"},"institutions":[{"id":"https://openalex.org/I1290206253","display_name":"Microsoft (United States)","ror":"https://ror.org/00d0nc645","country_code":"US","type":"company","lineage":["https://openalex.org/I1290206253"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Nikhil Swamy","raw_affiliation_strings":["Microsoft Research, USA"],"affiliations":[{"raw_affiliation_string":"Microsoft Research, USA","institution_ids":["https://openalex.org/I1290206253"]}]}],"institutions":[],"countries_distinct_count":4,"institutions_distinct_count":6,"corresponding_author_ids":["https://openalex.org/A5050436525"],"corresponding_institution_ids":["https://openalex.org/I1326498283"],"apc_list":null,"apc_paid":null,"fwci":0.4157,"has_fulltext":true,"cited_by_count":2,"citation_normalized_percentile":{"value":0.71683805,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":94},"biblio":{"volume":"2","issue":"POPL","first_page":"1","last_page":"30"},"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.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/T10126","display_name":"Logic, programming, and type systems","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/T11424","display_name":"Security and Verification in Computing","score":0.9997000098228455,"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.9987000226974487,"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/soundness","display_name":"Soundness","score":0.7648807764053345},{"id":"https://openalex.org/keywords/monotonic-function","display_name":"Monotonic function","score":0.6988356709480286},{"id":"https://openalex.org/keywords/monad","display_name":"Monad (category theory)","score":0.6794159412384033},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.6362983584403992},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.6332133412361145},{"id":"https://openalex.org/keywords/state","display_name":"State (computer science)","score":0.598816990852356},{"id":"https://openalex.org/keywords/preorder","display_name":"Preorder","score":0.5658217668533325},{"id":"https://openalex.org/keywords/property","display_name":"Property (philosophy)","score":0.559581995010376},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5246463418006897},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.521510899066925},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.5145744681358337},{"id":"https://openalex.org/keywords/modularity","display_name":"Modularity (biology)","score":0.4830256402492523},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.463519424200058},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.23801791667938232},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.2269420325756073},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.1507180631160736}],"concepts":[{"id":"https://openalex.org/C39920170","wikidata":"https://www.wikidata.org/wiki/Q693083","display_name":"Soundness","level":2,"score":0.7648807764053345},{"id":"https://openalex.org/C72169020","wikidata":"https://www.wikidata.org/wiki/Q194404","display_name":"Monotonic function","level":2,"score":0.6988356709480286},{"id":"https://openalex.org/C33959348","wikidata":"https://www.wikidata.org/wiki/Q1630568","display_name":"Monad (category theory)","level":3,"score":0.6794159412384033},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.6362983584403992},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.6332133412361145},{"id":"https://openalex.org/C48103436","wikidata":"https://www.wikidata.org/wiki/Q599031","display_name":"State (computer science)","level":2,"score":0.598816990852356},{"id":"https://openalex.org/C2333172","wikidata":"https://www.wikidata.org/wiki/Q1425985","display_name":"Preorder","level":2,"score":0.5658217668533325},{"id":"https://openalex.org/C189950617","wikidata":"https://www.wikidata.org/wiki/Q937228","display_name":"Property (philosophy)","level":2,"score":0.559581995010376},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5246463418006897},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.521510899066925},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.5145744681358337},{"id":"https://openalex.org/C2779478453","wikidata":"https://www.wikidata.org/wiki/Q6889748","display_name":"Modularity (biology)","level":2,"score":0.4830256402492523},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.463519424200058},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.23801791667938232},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.2269420325756073},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.1507180631160736},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","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/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","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/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C54355233","wikidata":"https://www.wikidata.org/wiki/Q7162","display_name":"Genetics","level":1,"score":0.0},{"id":"https://openalex.org/C156772000","wikidata":"https://www.wikidata.org/wiki/Q864475","display_name":"Functor","level":2,"score":0.0}],"mesh":[],"locations_count":6,"locations":[{"id":"doi:10.1145/3158153","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3158153","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3158153?download=true","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":false,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:arXiv.org:1707.02466","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1707.02466","pdf_url":"https://arxiv.org/pdf/1707.02466","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"text"},{"id":"mag:2734330146","is_oa":true,"landing_page_url":"https://arxiv.org/pdf/1707.02466","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"arXiv (Cornell University)","raw_type":null},{"id":"pmh:oai:HAL:hal-01672733v1","is_oa":true,"landing_page_url":"https://hal.science/hal-01672733","pdf_url":null,"source":{"id":"https://openalex.org/S4406922466","display_name":"SPIRE - Sciences Po Institutional REpository","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"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":"Proceedings of the ACM on Programming Languages, 2018, 2 (POPL), &#x27E8;10.1145/3158153&#x27E9;","raw_type":"Journal articles"},{"id":"doi:10.48550/arxiv.1707.02466","is_oa":true,"landing_page_url":"https://doi.org/10.48550/arxiv.1707.02466","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article"},{"id":"mag:2898855465","is_oa":false,"landing_page_url":"https://popl18.sigplan.org/event/popl-2018-papers-recalling-a-witness-foundations-and-applications-of-monotonic-state","pdf_url":null,"source":{"id":"https://openalex.org/S4306420994","display_name":"Symposium on Principles of Programming Languages","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"conference"},"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":null,"raw_source_name":"Symposium on Principles of Programming Languages","raw_type":null}],"best_oa_location":{"id":"doi:10.1145/3158153","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3158153","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3158153?download=true","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":false,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","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/G7637084964","display_name":null,"funder_award_id":"715753","funder_id":"https://openalex.org/F4320334678","funder_display_name":"European Research Council"}],"funders":[{"id":"https://openalex.org/F4320308943","display_name":"Microsoft Research","ror":"https://ror.org/00d0nc645"},{"id":"https://openalex.org/F4320334678","display_name":"European Research Council","ror":"https://ror.org/0472cxd90"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2734330146.pdf","grobid_xml":"https://content.openalex.org/works/W2734330146.grobid-xml"},"referenced_works_count":39,"referenced_works":["https://openalex.org/W1488885199","https://openalex.org/W1489778371","https://openalex.org/W1493411447","https://openalex.org/W1498831343","https://openalex.org/W1553421328","https://openalex.org/W1557299972","https://openalex.org/W1974265510","https://openalex.org/W1990409169","https://openalex.org/W2007738069","https://openalex.org/W2008880956","https://openalex.org/W2035383849","https://openalex.org/W2036961426","https://openalex.org/W2044590882","https://openalex.org/W2065266923","https://openalex.org/W2090663022","https://openalex.org/W2100878175","https://openalex.org/W2103131117","https://openalex.org/W2103222205","https://openalex.org/W2131053137","https://openalex.org/W2134692477","https://openalex.org/W2147778310","https://openalex.org/W2152845220","https://openalex.org/W2154768716","https://openalex.org/W2154942048","https://openalex.org/W2267469130","https://openalex.org/W2294422796","https://openalex.org/W2507710874","https://openalex.org/W2596377803","https://openalex.org/W2599650177","https://openalex.org/W2604664164","https://openalex.org/W2640092413","https://openalex.org/W2736133668","https://openalex.org/W2751696670","https://openalex.org/W2767162229","https://openalex.org/W2776248742","https://openalex.org/W2955321487","https://openalex.org/W4237730680","https://openalex.org/W4247464325","https://openalex.org/W4256027310"],"related_works":["https://openalex.org/W2898855465","https://openalex.org/W3178034096","https://openalex.org/W2973760949","https://openalex.org/W2021081188","https://openalex.org/W3136909257","https://openalex.org/W1560733996","https://openalex.org/W1995361020","https://openalex.org/W3167607673","https://openalex.org/W2070864670","https://openalex.org/W1845792698","https://openalex.org/W3033059456","https://openalex.org/W3141833118","https://openalex.org/W1602113634","https://openalex.org/W1938581937","https://openalex.org/W1540321537","https://openalex.org/W3108594459","https://openalex.org/W2052184002","https://openalex.org/W2945188579","https://openalex.org/W1573343851","https://openalex.org/W2809678222"],"abstract_inverted_index":{"We":[0,69,94],"provide":[1],"a":[2,19,23,40,78,90,106],"way":[3],"to":[4,39,141],"ease":[5],"the":[6,31,45,63,74,96,99,115,142],"verification":[7,118,143],"of":[8,98,144],"programs":[9],"whose":[10],"state":[11,25,36,88,113],"evolves":[12,37],"monotonically.":[13],"The":[14],"main":[15],"idea":[16],"is":[17,47],"that":[18],"property":[20,46],"witnessed":[21],"in":[22,30,89,114],"prior":[24],"can":[26],"be":[27],"soundly":[28],"recalled":[29],"current":[32],"state,":[33],"provided":[34],"(1)":[35],"according":[38],"given":[41],"preorder,":[42],"and":[43,102,135],"(2)":[44],"preserved":[48],"by":[49],"this":[50,122],"preorder.":[51],"In":[52],"many":[53],"scenarios,":[54],"such":[55],"monotonic":[56,87,112,133],"reasoning":[57,85,110],"yields":[58],"concise":[59],"modular":[60],"proofs,":[61],"saving":[62],"need":[64],"for":[65,83,109,127],"explicit":[66],"program":[67],"invariants.":[68],"distill":[70],"our":[71],"approach":[72],"into":[73],"monotonic-state":[75,100],"monad":[76,101],",":[77],"general":[79],"yet":[80],"compact":[81],"interface":[82],"Hoare-style":[84],"about":[86,111],"dependently":[91],"typed":[92],"language.":[93],"prove":[95],"soundness":[97],"use":[103],"it":[104],"as":[105],"unified":[107],"foundation":[108],"F":[116],"\u22c6":[117],"system.":[119],"Based":[120],"on":[121],"foundation,":[123],"we":[124],"build":[125],"libraries":[126,138],"various":[128],"mutable":[129],"data":[130],"structures":[131],"like":[132],"references":[134],"apply":[136],"these":[137],"at":[139],"scale":[140],"several":[145],"distributed":[146],"applications.":[147]},"counts_by_year":[{"year":2020,"cited_by_count":1},{"year":2017,"cited_by_count":1}],"updated_date":"2026-04-09T08:11:56.329763","created_date":"2025-10-10T00:00:00"}
