{"id":"https://openalex.org/W4362661194","doi":"https://doi.org/10.1145/3586037","title":"Verus: Verifying Rust Programs using Linear Ghost Types","display_name":"Verus: Verifying Rust Programs using Linear Ghost Types","publication_year":2023,"publication_date":"2023-04-06","ids":{"openalex":"https://openalex.org/W4362661194","doi":"https://doi.org/10.1145/3586037"},"language":"en","primary_location":{"id":"doi:10.1145/3586037","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3586037","pdf_url":null,"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":"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":"article","indexed_in":["crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://doi.org/10.1145/3586037","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5013888261","display_name":"Andrea Lattuada","orcid":"https://orcid.org/0000-0002-9303-452X"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Andrea Lattuada","raw_affiliation_strings":["VMware Research, Switzerland"],"raw_orcid":"https://orcid.org/0000-0002-9303-452X","affiliations":[{"raw_affiliation_string":"VMware Research, Switzerland","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5022553295","display_name":"Travis Hance","orcid":"https://orcid.org/0009-0003-1104-7795"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Travis Hance","raw_affiliation_strings":["Carnegie Mellon University, USA"],"raw_orcid":"https://orcid.org/0009-0003-1104-7795","affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5022943987","display_name":"Chanhee Cho","orcid":"https://orcid.org/0009-0009-6620-9070"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Chanhee Cho","raw_affiliation_strings":["Carnegie Mellon University, USA"],"raw_orcid":"https://orcid.org/0009-0009-6620-9070","affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5113020325","display_name":"Matthias Brun","orcid":null},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Matthias Brun","raw_affiliation_strings":["ETH Zurich, Switzerland"],"raw_orcid":"https://orcid.org/0009-0004-5349-4347","affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5029057295","display_name":"Isitha Subasinghe","orcid":"https://orcid.org/0009-0001-2401-1682"},"institutions":[{"id":"https://openalex.org/I31746571","display_name":"UNSW Sydney","ror":"https://ror.org/03r8z3t63","country_code":"AU","type":"education","lineage":["https://openalex.org/I31746571"]}],"countries":["AU"],"is_corresponding":false,"raw_author_name":"Isitha Subasinghe","raw_affiliation_strings":["UNSW Sydney, Australia"],"raw_orcid":"https://orcid.org/0009-0001-2401-1682","affiliations":[{"raw_affiliation_string":"UNSW Sydney, Australia","institution_ids":["https://openalex.org/I31746571"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5041219275","display_name":"Yi Zhou","orcid":"https://orcid.org/0000-0001-7597-1176"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Yi Zhou","raw_affiliation_strings":["Carnegie Mellon University, USA"],"raw_orcid":"https://orcid.org/0000-0001-7597-1176","affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5023305744","display_name":"Jon Howell","orcid":"https://orcid.org/0000-0002-1781-2473"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Jon Howell","raw_affiliation_strings":["VMware Research, USA"],"raw_orcid":"https://orcid.org/0000-0002-1781-2473","affiliations":[{"raw_affiliation_string":"VMware Research, USA","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5048461894","display_name":"Bryan Parno","orcid":"https://orcid.org/0000-0002-9113-1684"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Bryan Parno","raw_affiliation_strings":["Carnegie Mellon University, USA"],"raw_orcid":"https://orcid.org/0000-0002-9113-1684","affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5016958899","display_name":"Chris Hawblitzel","orcid":"https://orcid.org/0000-0002-5676-0362"},"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":"Chris Hawblitzel","raw_affiliation_strings":["Microsoft Research, USA"],"raw_orcid":"https://orcid.org/0000-0002-5676-0362","affiliations":[{"raw_affiliation_string":"Microsoft Research, USA","institution_ids":["https://openalex.org/I1290206253"]}]}],"institutions":[],"countries_distinct_count":3,"institutions_distinct_count":9,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":12.3888,"has_fulltext":false,"cited_by_count":76,"citation_normalized_percentile":{"value":0.99047964,"is_in_top_1_percent":true,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":98,"max":100},"biblio":{"volume":"7","issue":"OOPSLA1","first_page":"286","last_page":"315"},"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.9991000294685364,"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.9991000294685364,"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.9986000061035156,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.996999979019165,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.7948640584945679},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7738228440284729},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7522570490837097},{"id":"https://openalex.org/keywords/memory-safety","display_name":"Memory safety","score":0.7273697257041931},{"id":"https://openalex.org/keywords/executable","display_name":"Executable","score":0.6255106925964355},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.5908524990081787},{"id":"https://openalex.org/keywords/rust","display_name":"Rust (programming language)","score":0.5399752259254456},{"id":"https://openalex.org/keywords/soundness","display_name":"Soundness","score":0.5260158181190491},{"id":"https://openalex.org/keywords/ansi-c","display_name":"ANSI C","score":0.44895070791244507},{"id":"https://openalex.org/keywords/pointer","display_name":"Pointer (user interface)","score":0.4435622990131378},{"id":"https://openalex.org/keywords/linearity","display_name":"Linearity","score":0.4385485053062439},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.3436456322669983},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.32213374972343445},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.15850341320037842},{"id":"https://openalex.org/keywords/computer-hardware","display_name":"Computer hardware","score":0.09835857152938843},{"id":"https://openalex.org/keywords/engineering","display_name":"Engineering","score":0.08247780799865723}],"concepts":[{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.7948640584945679},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7738228440284729},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7522570490837097},{"id":"https://openalex.org/C28180684","wikidata":"https://www.wikidata.org/wiki/Q4080983","display_name":"Memory safety","level":3,"score":0.7273697257041931},{"id":"https://openalex.org/C160145156","wikidata":"https://www.wikidata.org/wiki/Q778586","display_name":"Executable","level":2,"score":0.6255106925964355},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.5908524990081787},{"id":"https://openalex.org/C197781089","wikidata":"https://www.wikidata.org/wiki/Q575650","display_name":"Rust (programming language)","level":2,"score":0.5399752259254456},{"id":"https://openalex.org/C39920170","wikidata":"https://www.wikidata.org/wiki/Q693083","display_name":"Soundness","level":2,"score":0.5260158181190491},{"id":"https://openalex.org/C158100120","wikidata":"https://www.wikidata.org/wiki/Q1931402","display_name":"ANSI C","level":3,"score":0.44895070791244507},{"id":"https://openalex.org/C150202949","wikidata":"https://www.wikidata.org/wiki/Q107602","display_name":"Pointer (user interface)","level":2,"score":0.4435622990131378},{"id":"https://openalex.org/C77170095","wikidata":"https://www.wikidata.org/wiki/Q1753188","display_name":"Linearity","level":2,"score":0.4385485053062439},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.3436456322669983},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.32213374972343445},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.15850341320037842},{"id":"https://openalex.org/C9390403","wikidata":"https://www.wikidata.org/wiki/Q3966","display_name":"Computer hardware","level":1,"score":0.09835857152938843},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.08247780799865723},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C119599485","wikidata":"https://www.wikidata.org/wiki/Q43035","display_name":"Electrical engineering","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/3586037","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3586037","pdf_url":null,"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":"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:www.research-collection.ethz.ch:20.500.11850/610518","is_oa":true,"landing_page_url":"http://hdl.handle.net/20.500.11850/610518","pdf_url":null,"source":{"id":"https://openalex.org/S4306402302","display_name":"Repository for Publications and Research Data (ETH Zurich)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I35440088","host_organization_name":"ETH Zurich","host_organization_lineage":["https://openalex.org/I35440088"],"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, 7 (OOPSLA1)","raw_type":"info:eu-repo/semantics/publishedVersion"},{"id":"doi:10.3929/ethz-b-000610518","is_oa":true,"landing_page_url":"https://doi.org/10.3929/ethz-b-000610518","pdf_url":null,"source":{"id":"https://openalex.org/S7407051236","display_name":"ETH Z\u00fcrich Research Collection","issn_l":null,"issn":[],"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":null,"license_id":null,"version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article-journal"}],"best_oa_location":{"id":"doi:10.1145/3586037","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3586037","pdf_url":null,"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":"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":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":35,"referenced_works":["https://openalex.org/W1480909796","https://openalex.org/W1529441891","https://openalex.org/W1552077729","https://openalex.org/W1565541828","https://openalex.org/W1606177908","https://openalex.org/W1773735832","https://openalex.org/W2038677544","https://openalex.org/W2066210260","https://openalex.org/W2130427425","https://openalex.org/W2132761501","https://openalex.org/W2137628566","https://openalex.org/W2158376721","https://openalex.org/W2195119025","https://openalex.org/W2267469130","https://openalex.org/W2294722445","https://openalex.org/W2779850521","https://openalex.org/W2901454403","https://openalex.org/W2913530642","https://openalex.org/W2994905145","https://openalex.org/W2996725384","https://openalex.org/W3007744929","https://openalex.org/W3100536147","https://openalex.org/W3136970019","https://openalex.org/W3152550240","https://openalex.org/W3194104197","https://openalex.org/W4225147576","https://openalex.org/W4241006348","https://openalex.org/W4254983202","https://openalex.org/W4281773296","https://openalex.org/W4283019774","https://openalex.org/W4285303404","https://openalex.org/W4305010641","https://openalex.org/W4323927452","https://openalex.org/W6894169706","https://openalex.org/W6969058062"],"related_works":["https://openalex.org/W2141365240","https://openalex.org/W132701981","https://openalex.org/W4245736681","https://openalex.org/W4319323806","https://openalex.org/W4242254025","https://openalex.org/W4239042909","https://openalex.org/W2362192177","https://openalex.org/W4321012239","https://openalex.org/W4200542740","https://openalex.org/W4206254495"],"abstract_inverted_index":{"The":[0],"Rust":[1,25,58,69,96],"programming":[2],"language":[3],"provides":[4],"a":[5,111,146,166],"powerful":[6],"type":[7,46,154],"system":[8,114],"that":[9,94,115],"checks":[10],"linearity":[11,123,135],"and":[12,23,65,80,102,108,124,129,136,143,156,160,182],"borrowing,":[13,125,142],"allowing":[14,71],"code":[15,97,128,172,178],"to":[16,40,73,89],"safely":[17,98],"manipulate":[18,90,99],"memory":[19],"without":[20],"garbage":[21],"collection":[22],"making":[24],"ideal":[26],"for":[27,55,122,134,150],"developing":[28],"low-level,":[29],"high-assurance":[30],"systems.":[31],"For":[32],"such":[33],"systems,":[34],"formal":[35],"verification":[36],"can":[37],"be":[38],"useful":[39],"prove":[41,153],"functional":[42],"correctness":[43],"properties":[44],"beyond":[45],"safety.":[47],"This":[48],"paper":[49],"presents":[50],"Verus,":[51,61],"an":[52],"SMT-based":[53],"tool":[54],"formally":[56],"verifying":[57],"programs.":[59],"With":[60],"programmers":[62],"express":[63],"proofs":[64,72,88,107],"specifications":[66,109,159],"using":[67,110],"the":[68],"language,":[70],"take":[74],"advantage":[75],"of":[76,158,168],"Rust's":[77],"linear":[78],"types":[79],"borrow":[81],"checking.":[82],"We":[83,138,162],"show":[84],"how":[85],"this":[86],"allows":[87],"linearly":[91],"typed":[92],"permissions":[93],"let":[95],"memory,":[100],"pointers,":[101],"concurrent":[103,183],"resources.":[104],"Verus":[105,164],"organizes":[106],"novel":[112],"mode":[113],"distinguishes":[116],"specifications,":[117],"which":[118,131,151],"are":[119,132],"not":[120],"checked":[121,133],"from":[126],"executable":[127],"proofs,":[130],"borrowing.":[137],"formalize":[139],"Verus'":[140],"linearity,":[141],"modes":[144],"in":[145],"small":[147],"lambda":[148],"calculus,":[149],"we":[152],"safety":[155],"termination":[157],"proofs.":[161],"demonstrate":[163],"on":[165],"series":[167],"examples,":[169],"including":[170],"pointer-manipulating":[171],"(an":[173],"xor-based":[174],"doubly":[175],"linked":[176],"list),":[177],"with":[179],"interior":[180],"mutability,":[181],"code.":[184]},"counts_by_year":[{"year":2026,"cited_by_count":9},{"year":2025,"cited_by_count":42},{"year":2024,"cited_by_count":19},{"year":2023,"cited_by_count":6}],"updated_date":"2026-06-12T08:23:45.883708","created_date":"2025-10-10T00:00:00"}
