{"id":"https://openalex.org/W2761343098","doi":"https://doi.org/10.1145/3133907","title":"Exploiting implicit beliefs to resolve sparse usage problem in usage-based specification mining","display_name":"Exploiting implicit beliefs to resolve sparse usage problem in usage-based specification mining","publication_year":2017,"publication_date":"2017-10-12","ids":{"openalex":"https://openalex.org/W2761343098","doi":"https://doi.org/10.1145/3133907","mag":"2761343098"},"language":"en","primary_location":{"id":"doi:10.1145/3133907","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3133907","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3133907","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":null,"license_id":null,"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"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3133907","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5036590636","display_name":"Samantha Syeda Khairunnesa","orcid":"https://orcid.org/0009-0008-3733-2101"},"institutions":[{"id":"https://openalex.org/I173911158","display_name":"Iowa State University","ror":"https://ror.org/04rswrd78","country_code":"US","type":"education","lineage":["https://openalex.org/I173911158"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Samantha Syeda Khairunnesa","raw_affiliation_strings":["Iowa State University, USA"],"affiliations":[{"raw_affiliation_string":"Iowa State University, USA","institution_ids":["https://openalex.org/I173911158"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5044339946","display_name":"Hoan Anh Nguyen","orcid":"https://orcid.org/0000-0002-6194-7930"},"institutions":[{"id":"https://openalex.org/I173911158","display_name":"Iowa State University","ror":"https://ror.org/04rswrd78","country_code":"US","type":"education","lineage":["https://openalex.org/I173911158"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Hoan Anh Nguyen","raw_affiliation_strings":["Iowa State University, USA"],"affiliations":[{"raw_affiliation_string":"Iowa State University, USA","institution_ids":["https://openalex.org/I173911158"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5089000736","display_name":"Tien N. Nguyen","orcid":"https://orcid.org/0009-0006-7962-6090"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Tien N. Nguyen","raw_affiliation_strings":["University of Texas at Dallas, USA"],"affiliations":[{"raw_affiliation_string":"University of Texas at Dallas, USA","institution_ids":[]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5059626072","display_name":"Hridesh Rajan","orcid":"https://orcid.org/0000-0002-9410-9562"},"institutions":[{"id":"https://openalex.org/I173911158","display_name":"Iowa State University","ror":"https://ror.org/04rswrd78","country_code":"US","type":"education","lineage":["https://openalex.org/I173911158"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Hridesh Rajan","raw_affiliation_strings":["Iowa State University, USA"],"affiliations":[{"raw_affiliation_string":"Iowa State University, USA","institution_ids":["https://openalex.org/I173911158"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5036590636"],"corresponding_institution_ids":["https://openalex.org/I173911158"],"apc_list":null,"apc_paid":null,"fwci":3.0353,"has_fulltext":true,"cited_by_count":8,"citation_normalized_percentile":{"value":0.93136038,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":"1","issue":"OOPSLA","first_page":"1","last_page":"29"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/T10260","display_name":"Software Engineering Research","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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.9994000196456909,"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/T12127","display_name":"Software System Performance and Reliability","score":0.9983000159263611,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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.8505650162696838},{"id":"https://openalex.org/keywords/precondition","display_name":"Precondition","score":0.6927869319915771},{"id":"https://openalex.org/keywords/leverage","display_name":"Leverage (statistics)","score":0.6875424981117249},{"id":"https://openalex.org/keywords/programmer","display_name":"Programmer","score":0.6044558882713318},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5306678414344788},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.474382221698761},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.47201842069625854},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.4552946388721466},{"id":"https://openalex.org/keywords/data-science","display_name":"Data science","score":0.38919827342033386},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.37743133306503296},{"id":"https://openalex.org/keywords/data-mining","display_name":"Data mining","score":0.3606605529785156},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.34263768792152405},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.24892199039459229}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8505650162696838},{"id":"https://openalex.org/C192465680","wikidata":"https://www.wikidata.org/wiki/Q1413450","display_name":"Precondition","level":2,"score":0.6927869319915771},{"id":"https://openalex.org/C153083717","wikidata":"https://www.wikidata.org/wiki/Q6535263","display_name":"Leverage (statistics)","level":2,"score":0.6875424981117249},{"id":"https://openalex.org/C2778514511","wikidata":"https://www.wikidata.org/wiki/Q1374194","display_name":"Programmer","level":2,"score":0.6044558882713318},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5306678414344788},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.474382221698761},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.47201842069625854},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.4552946388721466},{"id":"https://openalex.org/C2522767166","wikidata":"https://www.wikidata.org/wiki/Q2374463","display_name":"Data science","level":1,"score":0.38919827342033386},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.37743133306503296},{"id":"https://openalex.org/C124101348","wikidata":"https://www.wikidata.org/wiki/Q172491","display_name":"Data mining","level":1,"score":0.3606605529785156},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.34263768792152405},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.24892199039459229},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3133907","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3133907","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3133907","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":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1145/3133907","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3133907","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3133907","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":null,"license_id":null,"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":[{"display_name":"Decent work and economic growth","id":"https://metadata.un.org/sdg/8","score":0.47999998927116394}],"awards":[{"id":"https://openalex.org/G4373322509","display_name":null,"funder_award_id":"1518897, 1513263","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G7770872176","display_name":null,"funder_award_id":"CNS-15-13263","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2761343098.pdf","grobid_xml":"https://content.openalex.org/works/W2761343098.grobid-xml"},"referenced_works_count":44,"referenced_works":["https://openalex.org/W10127936","https://openalex.org/W146475325","https://openalex.org/W1533857697","https://openalex.org/W1754514437","https://openalex.org/W1767990287","https://openalex.org/W1786676049","https://openalex.org/W1987615754","https://openalex.org/W1992105245","https://openalex.org/W2025677988","https://openalex.org/W2031300675","https://openalex.org/W2043100293","https://openalex.org/W2043811931","https://openalex.org/W2047694629","https://openalex.org/W2055095027","https://openalex.org/W2059215200","https://openalex.org/W2064081154","https://openalex.org/W2074644416","https://openalex.org/W2077359497","https://openalex.org/W2093938715","https://openalex.org/W2098629748","https://openalex.org/W2103275664","https://openalex.org/W2103318645","https://openalex.org/W2104251622","https://openalex.org/W2113548992","https://openalex.org/W2114114632","https://openalex.org/W2124666592","https://openalex.org/W2131954495","https://openalex.org/W2132852010","https://openalex.org/W2133832333","https://openalex.org/W2136646111","https://openalex.org/W2145020764","https://openalex.org/W2146177878","https://openalex.org/W2148190602","https://openalex.org/W2148702066","https://openalex.org/W2154326517","https://openalex.org/W2156417145","https://openalex.org/W2156841542","https://openalex.org/W2166019458","https://openalex.org/W2295399529","https://openalex.org/W2295595661","https://openalex.org/W2584780271","https://openalex.org/W3004040842","https://openalex.org/W3196044867","https://openalex.org/W4243208953"],"related_works":["https://openalex.org/W2294916142","https://openalex.org/W1988458526","https://openalex.org/W2953046944","https://openalex.org/W1581362285","https://openalex.org/W2185407019","https://openalex.org/W2368102490","https://openalex.org/W146475325","https://openalex.org/W4379251913","https://openalex.org/W233844114","https://openalex.org/W2104462386"],"abstract_inverted_index":{"Frameworks":[0],"and":[1,71,76,100,169,171,197,237,254,270,299,303,313],"libraries":[2,256],"provide":[3],"application":[4],"programming":[5],"interfaces":[6],"(APIs)":[7],"that":[8,210,226,257,274,292],"serve":[9],"as":[10,106],"building":[11],"blocks":[12],"in":[13,44,60,89,95,123,178,200,214,224,297,301,311,315],"modern":[14],"software":[15],"development.":[16],"As":[17],"APIs":[18,70],"present":[19,213],"the":[20,55,58,65,69,90,114,119,144,149,152,166,179,195,201,215,260,282,304],"opportunity":[21],"of":[22,57,68,92,97,184,220,240,242,252,284],"increased":[23],"productivity,":[24],"it":[25],"also":[26],"calls":[27,206],"for":[28,83,323],"correct":[29],"use":[30,56],"to":[31,63,104,117,131,135,162,193,204,207,230,318],"avoid":[32],"buggy":[33],"code.":[34,153,180],"The":[35,181,289],"usage-based":[36,124,320],"specification":[37],"mining":[38,188,321],"technique":[39,85,116,192],"has":[40],"shown":[41],"great":[42],"promise":[43],"solving":[45],"this":[46,105],"problem":[47,122],"through":[48],"a":[49,107,157,163,191,218,235],"data-driven":[50],"approach.":[51],"These":[52],"techniques":[53],"leverage":[54,132],"API":[59,205],"large":[61],"corpora":[62],"understand":[64],"recurring":[66],"usages":[67],"infer":[72,208],"behavioral":[73],"specifications":[74],"(preconditions":[75],"postconditions)":[77],"from":[78,148,234,259],"such":[79,84],"usages.":[80],"A":[81],"challenge":[82],"is":[86,130,143,159,306],"thus":[87,172],"inference":[88],"presence":[91],"insufficient":[93],"usages,":[94],"terms":[96],"both":[98],"frequency":[99],"richness.":[101],"We":[102,245],"refer":[103],"\"sparse":[108],"usage":[109,121,262,285],"problem.\"":[110],"This":[111],"paper":[112],"presents":[113],"first":[115],"solve":[118],"sparse":[120,137,261],"precondition":[125,187,287],"mining.":[126,288],"Our":[127,264],"key":[128],"insight":[129],"implicit":[133,140,232,268],"beliefs":[134,233,269],"overcome":[136],"usage.":[138],"An":[139,154],"belief":[141],"(IB)":[142],"knowledge":[145],"implicitly":[146,161,212],"derived":[147],"fact":[150],"about":[151,156],"IB":[155],"program":[158,202],"known":[160],"programmer":[164],"via":[165],"language's":[167],"constructs":[168],"semantics,":[170],"not":[173],"explicitly":[174],"written":[175],"or":[176],"specified":[177],"technical":[182],"underpinnings":[183],"our":[185],"new":[186],"approach":[189,265,322],"include":[190],"analyze":[194],"data":[196],"control":[198],"flow":[199],"leading":[203],"preconditions":[209],"are":[211],"code":[216,222,253],"corpus,":[217],"catalog":[219],"35":[221],"elements":[223],"total":[225],"can":[227,279],"be":[228],"used":[229],"derive":[231],"program,":[236],"empirical":[238],"evaluation":[239],"all":[241],"these":[243,324],"ideas.":[244],"have":[246,272],"analyzed":[247],"over":[248],"350":[249],"millions":[250],"lines":[251],"7":[255],"suffer":[258],"problem.":[263],"realizes":[266],"6":[267],"we":[271,293],"observed":[273],"adding":[275],"single-level":[276],"context":[277],"sensitivity":[278],"further":[280],"improve":[281],"result":[283,290],"based":[286],"shows":[291],"achieve":[294],"overall":[295],"60%":[296],"precision":[298,312],"69%":[300],"recall":[302,316],"accuracy":[305],"relatively":[307],"improved":[308],"by":[309],"32%":[310],"78%":[314],"compared":[317],"base":[319],"libraries.":[325]},"counts_by_year":[{"year":2023,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":1}],"updated_date":"2026-04-21T08:09:41.155169","created_date":"2025-10-10T00:00:00"}
