{"id":"https://openalex.org/W2026114025","doi":"https://doi.org/10.1145/981009.981016","title":"Generalized typestate checking using set interfaces and pluggable analyses","display_name":"Generalized typestate checking using set interfaces and pluggable analyses","publication_year":2004,"publication_date":"2004-03-01","ids":{"openalex":"https://openalex.org/W2026114025","doi":"https://doi.org/10.1145/981009.981016","mag":"2026114025"},"language":"en","primary_location":{"is_oa":false,"landing_page_url":"https://doi.org/10.1145/981009.981016","pdf_url":null,"source":{"id":"https://openalex.org/S148324379","display_name":"ACM SIGPLAN Notices","issn_l":"0362-1340","issn":["0362-1340","1558-1160"],"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":null,"license_id":null,"version":null,"is_accepted":false,"is_published":false},"type":"article","type_crossref":"journal-article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://infoscience.epfl.ch/bitstreams/8e35e83b-c00e-4545-bba4-ec43072c0de0/download","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5016375266","display_name":"Patrick Lam","orcid":"https://orcid.org/0000-0001-8278-5400"},"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":"Patrick Lam","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5008699657","display_name":"Viktor Kun\u010dak","orcid":"https://orcid.org/0000-0001-7044-9522"},"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":"Viktor Kuncak","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5045127387","display_name":"Martin Rinard","orcid":"https://orcid.org/0000-0001-8095-8523"},"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":"Martin Rinard","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]}],"institution_assertions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":10.628,"has_fulltext":true,"fulltext_origin":"pdf","cited_by_count":37,"citation_normalized_percentile":{"value":0.878697,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":91},"biblio":{"volume":"39","issue":"3","first_page":"46","last_page":"55"},"is_retracted":false,"is_paratext":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9997,"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.9997,"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.9987,"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/T11424","display_name":"Security and Verification in Computing","score":0.9974,"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/abstract-data-type","display_name":"Abstract data type","score":0.7186042},{"id":"https://openalex.org/keywords/representation","display_name":"Representation","score":0.6414638},{"id":"https://openalex.org/keywords/abstraction","display_name":"Abstraction","score":0.61109054},{"id":"https://openalex.org/keywords/data-model","display_name":"Data model (GIS)","score":0.4115787}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8295159},{"id":"https://openalex.org/C177148314","wikidata":"https://www.wikidata.org/wiki/Q170084","display_name":"Generalization","level":2,"score":0.765991},{"id":"https://openalex.org/C175971053","wikidata":"https://www.wikidata.org/wiki/Q827335","display_name":"Abstract data type","level":2,"score":0.7186042},{"id":"https://openalex.org/C2776359362","wikidata":"https://www.wikidata.org/wiki/Q2145286","display_name":"Representation (politics)","level":3,"score":0.6414638},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.6277678},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.62650496},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.6136931},{"id":"https://openalex.org/C124304363","wikidata":"https://www.wikidata.org/wiki/Q673661","display_name":"Abstraction","level":2,"score":0.61109054},{"id":"https://openalex.org/C2781238097","wikidata":"https://www.wikidata.org/wiki/Q175026","display_name":"Object (grammar)","level":2,"score":0.52952594},{"id":"https://openalex.org/C100463513","wikidata":"https://www.wikidata.org/wiki/Q5227322","display_name":"Data model (GIS)","level":2,"score":0.4115787},{"id":"https://openalex.org/C124101348","wikidata":"https://www.wikidata.org/wiki/Q172491","display_name":"Data mining","level":1,"score":0.38304996},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.33374554},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.13918635},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.12133324},{"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/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C94625758","wikidata":"https://www.wikidata.org/wiki/Q7163","display_name":"Politics","level":2,"score":0.0},{"id":"https://openalex.org/C17744445","wikidata":"https://www.wikidata.org/wiki/Q36442","display_name":"Political science","level":0,"score":0.0},{"id":"https://openalex.org/C199539241","wikidata":"https://www.wikidata.org/wiki/Q7748","display_name":"Law","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"is_oa":false,"landing_page_url":"https://doi.org/10.1145/981009.981016","pdf_url":null,"source":{"id":"https://openalex.org/S148324379","display_name":"ACM SIGPLAN Notices","issn_l":"0362-1340","issn":["0362-1340","1558-1160"],"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":null,"license_id":null,"version":null,"is_accepted":false,"is_published":false},{"is_oa":true,"landing_page_url":"http://infoscience.epfl.ch/record/110233","pdf_url":"https://infoscience.epfl.ch/bitstreams/8e35e83b-c00e-4545-bba4-ec43072c0de0/download","source":{"id":"https://openalex.org/S4306400488","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false},{"is_oa":true,"landing_page_url":"https://infoscience.epfl.ch/record/110233/files/LamETAL04GeneralizedTypestateCheckingUsingSets.pdf","pdf_url":"https://infoscience.epfl.ch/record/110233/files/LamETAL04GeneralizedTypestateCheckingUsingSets.pdf","source":{"id":"https://openalex.org/S4306400488","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"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":"submittedVersion","is_accepted":false,"is_published":false}],"best_oa_location":{"is_oa":true,"landing_page_url":"http://infoscience.epfl.ch/record/110233","pdf_url":"https://infoscience.epfl.ch/bitstreams/8e35e83b-c00e-4545-bba4-ec43072c0de0/download","source":{"id":"https://openalex.org/S4306400488","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false},"sustainable_development_goals":[],"grants":[],"datasets":[],"versions":[],"referenced_works_count":24,"referenced_works":["https://openalex.org/W117718117","https://openalex.org/W1495368328","https://openalex.org/W1511982475","https://openalex.org/W1604735471","https://openalex.org/W1755257908","https://openalex.org/W1975914482","https://openalex.org/W1988441831","https://openalex.org/W1991837261","https://openalex.org/W1993836075","https://openalex.org/W1998070736","https://openalex.org/W2029682051","https://openalex.org/W2044590882","https://openalex.org/W2087612811","https://openalex.org/W2130853806","https://openalex.org/W2131135493","https://openalex.org/W2139356751","https://openalex.org/W2142837069","https://openalex.org/W2149237601","https://openalex.org/W2151360539","https://openalex.org/W2166985644","https://openalex.org/W2295622790","https://openalex.org/W2912166712","https://openalex.org/W2914074464","https://openalex.org/W4250522981"],"related_works":["https://openalex.org/W3160136729","https://openalex.org/W283924426","https://openalex.org/W2274578477","https://openalex.org/W2120892093","https://openalex.org/W2073202004","https://openalex.org/W2050776543","https://openalex.org/W2026233770","https://openalex.org/W2026114025","https://openalex.org/W2005803685","https://openalex.org/W1992184515"],"abstract_inverted_index":{"We":[0],"present":[1],"a":[2,21,74,113,119],"generalization":[3,28],"of":[4,12,23,98,126],"standard":[5],"typestate":[6,11,25,53,63],"systems":[7],"in":[8,20,34,44,52,59,80,88,118,145],"which":[9],"the":[10,96,99,124,129,135,153],"each":[13,71],"object":[14],"is":[15],"determined":[16],"by":[17,166],"its":[18,89],"membership":[19,43,51,79],"collection":[22],"abstract":[24,35,81],"sets.":[26],"This":[27],"supports":[29],"typestates":[30,39],"that":[31,40,95,115,160],"model":[32],"participation":[33,58],"data":[36,60,75,90,105,130,147],"types,":[37],"composite":[38],"correspond":[41],"to":[42,57,83,112,122,139,150,157],"multiple":[45,146,163],"sets,":[46],"and":[47,77,109,149],"hierarchical":[48],"typestates.":[49],"Because":[50],"sets":[54,82],"corresponds":[55],"directly":[56],"structures,":[61],"our":[62,69],"system":[64],"characterizes":[65],"global":[66],"sharing":[67],"patterns.In":[68],"approach,":[70],"module":[72,100],"encapsulates":[73],"structure":[76,106],"uses":[78,116],"characterize":[84,123,141],"how":[85,142],"objects":[86,143],"participate":[87,144],"structure.":[91,131],"Each":[92],"analysis":[93],"verifies":[94],"implementation":[97],"1)":[101,140],"preserves":[102],"important":[103],"internal":[104],"representation":[107],"invariants":[108],"2)":[110,151],"conforms":[111],"specification":[114],"formulas":[117],"set":[120,137],"algebra":[121],"effects":[125],"operations":[127],"on":[128,162],"The":[132],"analyses":[133],"use":[134],"common":[136],"abstraction":[138],"structures":[148],"enable":[152],"inter-analysis":[154],"communication":[155],"required":[156],"verify":[158],"properties":[159],"depend":[161],"modules":[164],"analyzed":[165],"different":[167],"analyses.":[168]},"cited_by_api_url":"https://api.openalex.org/works?filter=cites:W2026114025","counts_by_year":[{"year":2023,"cited_by_count":2},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2012,"cited_by_count":1}],"updated_date":"2024-12-23T18:34:42.156696","created_date":"2016-06-24"}