{"id":"https://openalex.org/W2032774097","doi":"https://doi.org/10.1145/1094811.1094818","title":"Deriving object typestates in the presence of inter-object references","display_name":"Deriving object typestates in the presence of inter-object references","publication_year":2005,"publication_date":"2005-10-12","ids":{"openalex":"https://openalex.org/W2032774097","doi":"https://doi.org/10.1145/1094811.1094818","mag":"2032774097"},"language":"en","primary_location":{"id":"doi:10.1145/1094811.1094818","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1094811.1094818","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th annual ACM SIGPLAN conference on Object-oriented programming, systems, languages, and applications","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/A5041153412","display_name":"Mangala Gowri Nanda","orcid":null},"institutions":[{"id":"https://openalex.org/I1341412227","display_name":"IBM (United States)","ror":"https://ror.org/05hh8d621","country_code":"US","type":"company","lineage":["https://openalex.org/I1341412227"]},{"id":"https://openalex.org/I4210103279","display_name":"IBM Research - India","ror":"https://ror.org/014wt7r80","country_code":"IN","type":"facility","lineage":["https://openalex.org/I1341412227","https://openalex.org/I4210103279","https://openalex.org/I4210114115"]}],"countries":["IN","US"],"is_corresponding":true,"raw_author_name":"Mangala Gowri Nanda","raw_affiliation_strings":["IBM India Research Laboratory","[IBM India Research Laboratory]"],"affiliations":[{"raw_affiliation_string":"IBM India Research Laboratory","institution_ids":["https://openalex.org/I4210103279"]},{"raw_affiliation_string":"[IBM India Research Laboratory]","institution_ids":["https://openalex.org/I1341412227"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5039190860","display_name":"Christian Grothoff","orcid":"https://orcid.org/0000-0002-6858-6808"},"institutions":[{"id":"https://openalex.org/I161318765","display_name":"University of California, Los Angeles","ror":"https://ror.org/046rm7j60","country_code":"US","type":"education","lineage":["https://openalex.org/I161318765"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Christian Grothoff","raw_affiliation_strings":["University of California - Los Angeles"],"affiliations":[{"raw_affiliation_string":"University of California - Los Angeles","institution_ids":["https://openalex.org/I161318765"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5104084134","display_name":"Satish Chandra","orcid":"https://orcid.org/0000-0001-7625-4726"},"institutions":[{"id":"https://openalex.org/I4210103279","display_name":"IBM Research - India","ror":"https://ror.org/014wt7r80","country_code":"IN","type":"facility","lineage":["https://openalex.org/I1341412227","https://openalex.org/I4210103279","https://openalex.org/I4210114115"]},{"id":"https://openalex.org/I1341412227","display_name":"IBM (United States)","ror":"https://ror.org/05hh8d621","country_code":"US","type":"company","lineage":["https://openalex.org/I1341412227"]}],"countries":["IN","US"],"is_corresponding":false,"raw_author_name":"Satish Chandra","raw_affiliation_strings":["IBM India Research Laboratory","[IBM India Research Laboratory]"],"affiliations":[{"raw_affiliation_string":"IBM India Research Laboratory","institution_ids":["https://openalex.org/I4210103279"]},{"raw_affiliation_string":"[IBM India Research Laboratory]","institution_ids":["https://openalex.org/I1341412227"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5041153412"],"corresponding_institution_ids":["https://openalex.org/I1341412227","https://openalex.org/I4210103279"],"apc_list":null,"apc_paid":null,"fwci":5.4803,"has_fulltext":false,"cited_by_count":38,"citation_normalized_percentile":{"value":0.95492367,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"77","last_page":"96"},"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/T10142","display_name":"Formal Methods in Verification","score":0.9987999796867371,"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.9987000226974487,"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/computer-science","display_name":"Computer science","score":0.8076976537704468},{"id":"https://openalex.org/keywords/method","display_name":"Method","score":0.6997054815292358},{"id":"https://openalex.org/keywords/predicate","display_name":"Predicate (mathematical logic)","score":0.6370962858200073},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6137546300888062},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.6041899919509888},{"id":"https://openalex.org/keywords/predicate-abstraction","display_name":"Predicate abstraction","score":0.5734633207321167},{"id":"https://openalex.org/keywords/object","display_name":"Object (grammar)","score":0.5385627746582031},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.5079198479652405},{"id":"https://openalex.org/keywords/object-model","display_name":"Object model","score":0.4837920367717743},{"id":"https://openalex.org/keywords/abstract-interpretation","display_name":"Abstract interpretation","score":0.4813412129878998},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.4358675181865692},{"id":"https://openalex.org/keywords/object-oriented-programming","display_name":"Object-oriented programming","score":0.3813844919204712},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.30724412202835083},{"id":"https://openalex.org/keywords/model-checking","display_name":"Model checking","score":0.1294333040714264}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8076976537704468},{"id":"https://openalex.org/C512554520","wikidata":"https://www.wikidata.org/wiki/Q815844","display_name":"Method","level":3,"score":0.6997054815292358},{"id":"https://openalex.org/C140146324","wikidata":"https://www.wikidata.org/wiki/Q1144319","display_name":"Predicate (mathematical logic)","level":2,"score":0.6370962858200073},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6137546300888062},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.6041899919509888},{"id":"https://openalex.org/C2779907942","wikidata":"https://www.wikidata.org/wiki/Q7239630","display_name":"Predicate abstraction","level":3,"score":0.5734633207321167},{"id":"https://openalex.org/C2781238097","wikidata":"https://www.wikidata.org/wiki/Q175026","display_name":"Object (grammar)","level":2,"score":0.5385627746582031},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.5079198479652405},{"id":"https://openalex.org/C20894473","wikidata":"https://www.wikidata.org/wiki/Q1116105","display_name":"Object model","level":3,"score":0.4837920367717743},{"id":"https://openalex.org/C2780654840","wikidata":"https://www.wikidata.org/wiki/Q333341","display_name":"Abstract interpretation","level":2,"score":0.4813412129878998},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.4358675181865692},{"id":"https://openalex.org/C73752529","wikidata":"https://www.wikidata.org/wiki/Q79872","display_name":"Object-oriented programming","level":2,"score":0.3813844919204712},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.30724412202835083},{"id":"https://openalex.org/C110251889","wikidata":"https://www.wikidata.org/wiki/Q1569697","display_name":"Model checking","level":2,"score":0.1294333040714264}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1094811.1094818","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1094811.1094818","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th annual ACM SIGPLAN conference on Object-oriented programming, systems, languages, and applications","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.127.2046","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.127.2046","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://grothoff.org/christian/percolator.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":22,"referenced_works":["https://openalex.org/W121750629","https://openalex.org/W152322867","https://openalex.org/W1511982475","https://openalex.org/W1557880268","https://openalex.org/W1991837261","https://openalex.org/W2014530617","https://openalex.org/W2026114025","https://openalex.org/W2044590882","https://openalex.org/W2074040276","https://openalex.org/W2089139117","https://openalex.org/W2098495346","https://openalex.org/W2119467398","https://openalex.org/W2121059325","https://openalex.org/W2149901829","https://openalex.org/W2158395308","https://openalex.org/W2162284942","https://openalex.org/W2294152467","https://openalex.org/W2561675875","https://openalex.org/W4231709874","https://openalex.org/W4242057943","https://openalex.org/W6606105673","https://openalex.org/W6630566465"],"related_works":["https://openalex.org/W1531204343","https://openalex.org/W2522501807","https://openalex.org/W4232099822","https://openalex.org/W2120526551","https://openalex.org/W1780369767","https://openalex.org/W96703786","https://openalex.org/W2136767512","https://openalex.org/W191072716","https://openalex.org/W2611025373","https://openalex.org/W2032774097"],"abstract_inverted_index":{"We":[0],"are":[1,233],"interested":[2],"in":[3,117,150,206,246,253,267,280,287,295],"static":[4],"analysis":[5,157,218],"of":[6,12,33,40,60,71,125,135,153,171,194,201,229,264],"Java":[7,172,202,265,285],"classes":[8,173,203,266,286],"with":[9],"the":[10,14,31,52,65,86,95,123,151,184,217,296],"goal":[11],"discovering":[13],"preconditions":[15],"under":[16],"which":[17,55],"a":[18,23,57,72,91,129,160,199,225,256,262,268],"certain":[19],"program":[20,211],"point":[21],"within":[22],"method":[24,35,73,189],"may":[25,88,114],"be":[26,242,251,278],"reached,":[27],"taking":[28],"into":[29],"account":[30],"effects":[32],"previous":[34],"calls":[36],"on":[37,75],"an":[38,76,111,273],"object":[39,87,142],"that":[41,63,198,270],"class.":[42],"The":[43,69,132],"information":[44,238],"pertinent":[45],"to":[46,90,102,105,119,139,167,182,244,289],"this":[47,136,195],"computation":[48],"is":[49,56,98,138,197,204],"represented":[50],"as":[51,80,82,144,146,175],"object's":[53,66,77,112],"typestate,":[54],"finite":[58],"set":[59,200,263],"relevant":[61,141,292],"predicates":[62],"abstract":[64,180],"actual":[67],"state.":[68],"execution":[70],"depends":[74],"current":[78],"typestate":[79,93,185],"well":[81,145],"other":[83,106],"input":[84],"parameters;":[85],"transition":[89],"different":[92],"during":[94],"method's":[96],"execution.It":[97],"common":[99],"for":[100,284],"objects":[101,126],"contain":[103],"references":[104],"ob-jects.":[107],"In":[108],"such":[109],"cases,":[110],"behavior":[113],"depend":[115],"on,":[116],"addition":[118],"its":[120],"own":[121],"state,":[122],"state":[124],"it":[127],"has":[128],"refer-ence":[130],"to.":[131],"main":[133],"contribution":[134],"paper":[137],"discover":[140],"typestates,":[143,149],"transitions":[147,186],"between":[148],"presence":[152],"inter-object":[154],"references.":[155],"Our":[156],"first":[158],"performs":[159],"combined":[161],"predicate":[162,165],"discovery":[163],"and":[164],"abstraction":[166],"derive":[168],"\"boolean\"":[169],"versions":[170],"given":[174,257],"input.":[176],"It":[177,249,275],"then":[178],"uses":[179,261],"interpretation":[181],"compute":[183,240],"caused":[187],"by":[188,235],"calls.":[190],"A":[191],"novel":[192],"aspect":[193],"work":[196],"analyzed":[205],"isolation,":[207],"without":[208],"any":[209],"client":[210,258],"being":[212],"pro-vided.":[213],"To":[214],"do":[215],"this,":[216],"simulates":[219],"all":[220,228,291],"possible":[221],"client's":[222],"actions":[223],"via":[224],"synthetic":[226],"heap,":[227],"whose":[230],"interesting":[231],"config-urations":[232],"explored":[234],"our":[236],"analysis.The":[237],"we":[239],"can":[241,250,271,276],"put":[243],"use":[245],"several":[247],"ways.":[248],"used":[252,279],"checking":[254],"whether":[255],"code":[259,293],"erroneously":[260],"way":[269],"throw":[272],"exception.":[274],"also":[277],"creating":[281],"test":[282],"drivers":[283],"order":[288],"exercise":[290],"paths":[294],"corresponding":[297],"methods.":[298]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2018,"cited_by_count":1},{"year":2014,"cited_by_count":2},{"year":2013,"cited_by_count":6},{"year":2012,"cited_by_count":1}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
