{"id":"https://openalex.org/W2900015620","doi":"https://doi.org/10.1145/3290326","title":"Type-guided worst-case input generation","display_name":"Type-guided worst-case input generation","publication_year":2019,"publication_date":"2019-01-02","ids":{"openalex":"https://openalex.org/W2900015620","doi":"https://doi.org/10.1145/3290326","mag":"2900015620"},"language":"en","primary_location":{"id":"doi:10.1145/3290326","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3290326","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3290326","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":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":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3290326","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5100401412","display_name":"Di Wang","orcid":"https://orcid.org/0000-0002-2418-7987"},"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":true,"raw_author_name":"Di Wang","raw_affiliation_strings":["Carnegie Mellon University, USA"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5101496943","display_name":"Jan Hoffmann","orcid":"https://orcid.org/0000-0001-8326-0788"},"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":"Jan Hoffmann","raw_affiliation_strings":["Carnegie Mellon University, USA"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5100401412"],"corresponding_institution_ids":["https://openalex.org/I74973139"],"apc_list":null,"apc_paid":null,"fwci":3.9535,"has_fulltext":true,"cited_by_count":13,"citation_normalized_percentile":{"value":0.93382353,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":"3","issue":"POPL","first_page":"1","last_page":"30"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9998999834060669,"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"}},"topics":[{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9998999834060669,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9968000054359436,"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.9965999722480774,"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.858603835105896},{"id":"https://openalex.org/keywords/amortized-analysis","display_name":"Amortized analysis","score":0.592258095741272},{"id":"https://openalex.org/keywords/completeness","display_name":"Completeness (order theory)","score":0.5749716758728027},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.5098549723625183},{"id":"https://openalex.org/keywords/function","display_name":"Function (biology)","score":0.4988412857055664},{"id":"https://openalex.org/keywords/upper-and-lower-bounds","display_name":"Upper and lower bounds","score":0.49171048402786255},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.46450042724609375},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.46002593636512756},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.4559124708175659},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.4319281280040741},{"id":"https://openalex.org/keywords/constraint","display_name":"Constraint (computer-aided design)","score":0.4177272319793701},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.36004549264907837},{"id":"https://openalex.org/keywords/mathematical-optimization","display_name":"Mathematical optimization","score":0.34977975487709045},{"id":"https://openalex.org/keywords/data-structure","display_name":"Data structure","score":0.32911795377731323},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3038913607597351},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.09862902760505676}],"concepts":[{"id":"https://openalex.org/C39920170","wikidata":"https://www.wikidata.org/wiki/Q693083","display_name":"Soundness","level":2,"score":0.858603835105896},{"id":"https://openalex.org/C142417499","wikidata":"https://www.wikidata.org/wiki/Q331716","display_name":"Amortized analysis","level":3,"score":0.592258095741272},{"id":"https://openalex.org/C17231256","wikidata":"https://www.wikidata.org/wiki/Q5156540","display_name":"Completeness (order theory)","level":2,"score":0.5749716758728027},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.5098549723625183},{"id":"https://openalex.org/C14036430","wikidata":"https://www.wikidata.org/wiki/Q3736076","display_name":"Function (biology)","level":2,"score":0.4988412857055664},{"id":"https://openalex.org/C77553402","wikidata":"https://www.wikidata.org/wiki/Q13222579","display_name":"Upper and lower bounds","level":2,"score":0.49171048402786255},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.46450042724609375},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.46002593636512756},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.4559124708175659},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.4319281280040741},{"id":"https://openalex.org/C2776036281","wikidata":"https://www.wikidata.org/wiki/Q48769818","display_name":"Constraint (computer-aided design)","level":2,"score":0.4177272319793701},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.36004549264907837},{"id":"https://openalex.org/C126255220","wikidata":"https://www.wikidata.org/wiki/Q141495","display_name":"Mathematical optimization","level":1,"score":0.34977975487709045},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.32911795377731323},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3038913607597351},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.09862902760505676},{"id":"https://openalex.org/C78458016","wikidata":"https://www.wikidata.org/wiki/Q840400","display_name":"Evolutionary biology","level":1,"score":0.0},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","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/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3290326","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3290326","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3290326","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":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/3290326","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3290326","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3290326","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":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":[],"awards":[{"id":"https://openalex.org/G2617278512","display_name":"SHF: Small: Collaborative Research: Resource-Guided Program Synthesis","funder_award_id":"1812876","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G2935204323","display_name":null,"funder_award_id":"AA Contract FA8750-18-C-0092","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G3423355903","display_name":null,"funder_award_id":"FA8750-18-C-0092","funder_id":"https://openalex.org/F4320332467","funder_display_name":"U.S. Air Force"},{"id":"https://openalex.org/G4215626907","display_name":null,"funder_award_id":"FA8750-18-C-009","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G4577670171","display_name":null,"funder_award_id":"FA8750-15-C-0082","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G4713059963","display_name":null,"funder_award_id":"FA8750","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G4895191527","display_name":null,"funder_award_id":"FA8750-18-C-0092","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G848032724","display_name":null,"funder_award_id":"Science","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"},{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"},{"id":"https://openalex.org/F4320332467","display_name":"U.S. Air Force","ror":"https://ror.org/006gmme17"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2900015620.pdf","grobid_xml":"https://content.openalex.org/works/W2900015620.grobid-xml"},"referenced_works_count":71,"referenced_works":["https://openalex.org/W110849379","https://openalex.org/W116894366","https://openalex.org/W157156687","https://openalex.org/W612689541","https://openalex.org/W1230660382","https://openalex.org/W1424217719","https://openalex.org/W1480909796","https://openalex.org/W1515621470","https://openalex.org/W1550112417","https://openalex.org/W1553136405","https://openalex.org/W1563402047","https://openalex.org/W1599625180","https://openalex.org/W1636902686","https://openalex.org/W1710734607","https://openalex.org/W1760139041","https://openalex.org/W1848153821","https://openalex.org/W1963739845","https://openalex.org/W1982529770","https://openalex.org/W1987927249","https://openalex.org/W1996748114","https://openalex.org/W2009489720","https://openalex.org/W2010790229","https://openalex.org/W2020692742","https://openalex.org/W2029976661","https://openalex.org/W2058033966","https://openalex.org/W2066550846","https://openalex.org/W2068055184","https://openalex.org/W2071589768","https://openalex.org/W2090759054","https://openalex.org/W2094647969","https://openalex.org/W2095867533","https://openalex.org/W2096449544","https://openalex.org/W2109863363","https://openalex.org/W2111366004","https://openalex.org/W2112207350","https://openalex.org/W2112969535","https://openalex.org/W2114337691","https://openalex.org/W2119717320","https://openalex.org/W2119859640","https://openalex.org/W2125218864","https://openalex.org/W2137062096","https://openalex.org/W2138657070","https://openalex.org/W2150990339","https://openalex.org/W2153708093","https://openalex.org/W2159586681","https://openalex.org/W2168162624","https://openalex.org/W2294370068","https://openalex.org/W2322420242","https://openalex.org/W2406041226","https://openalex.org/W2471272254","https://openalex.org/W2547267640","https://openalex.org/W2565334366","https://openalex.org/W2614656508","https://openalex.org/W2625924363","https://openalex.org/W2735409225","https://openalex.org/W2752340395","https://openalex.org/W2763435855","https://openalex.org/W2777305358","https://openalex.org/W2805375386","https://openalex.org/W2899241746","https://openalex.org/W2952181553","https://openalex.org/W2963336730","https://openalex.org/W3100164117","https://openalex.org/W3106010854","https://openalex.org/W3201110005","https://openalex.org/W4237492309","https://openalex.org/W4242321992","https://openalex.org/W4244488020","https://openalex.org/W4298195558","https://openalex.org/W4302984605","https://openalex.org/W6602452458"],"related_works":["https://openalex.org/W13634261","https://openalex.org/W4250462479","https://openalex.org/W56937029","https://openalex.org/W3163509751","https://openalex.org/W958050847","https://openalex.org/W2396405675","https://openalex.org/W175051304","https://openalex.org/W1548499332","https://openalex.org/W1549730417","https://openalex.org/W1994524667"],"abstract_inverted_index":{"This":[0,120],"paper":[1],"presents":[2],"a":[3,23,48,57,86,138,157,187,199,225],"novel":[4],"technique":[5,15,25,209,244],"for":[6,11,26,150,190,198,216,224,237,256],"type-guided":[7],"worst-case":[8,126,175,250],"input":[9,37,47,67],"generation":[10,38],"functional":[12],"programs.":[13],"The":[14,95,179,193],"builds":[16],"on":[17,30,186,260],"automatic":[18],"amortized":[19],"resource":[20,32,205],"analysis":[21],"(AARA),":[22],"type-based":[24],"deriving":[27],"symbolic":[28],"bounds":[29],"the":[31,61,66,75,89,93,100,104,111,115,118,125,132,142,146,153,166,173,208,243],"usage":[33],"of":[34,65,88,110,117,141,152,222,227,254],"functions.":[35],"Worst-case":[36],"is":[39,69,129,148,161,177,181,196],"performed":[40],"by":[41,92,131],"an":[42,220],"algorithm":[43,76,143,167],"that":[44,59,68,99,113,128,145,165,242],"takes":[45],"as":[46],"function,":[49],"its":[50],"resource-annotated":[51],"type":[52,133],"derivation":[53],"in":[54,78],"AARA,":[55],"and":[56,63,81,170,212,235,247,263],"skeleton":[58],"describes":[60],"shape":[62,90,116],"size":[64],"to":[70,84,124,163,211],"be":[71],"generated.":[72],"If":[73],"successful,":[74],"fills":[77],"integers,":[79],"booleans,":[80],"data":[82,233],"structures":[83],"produce":[85],"value":[87,102],"given":[91,154],"skeleton.":[94,119],"soundness":[96],"theorem":[97,160,180],"states":[98],"generated":[101],"exhibits":[103],"highest":[105],"cost":[106,121],"among":[107],"all":[108],"arguments":[109],"functions":[112],"have":[114],"corresponds":[122],"exactly":[123],"bound":[127,147,176],"established":[130],"derivation.":[134],"In":[135],"this":[136],"way,":[137],"successful":[139],"completion":[140],"proves":[144],"tight":[149],"inputs":[151,251],"shape.":[155],"Correspondingly,":[156],"relative":[158,182],"completeness":[159],"proved":[162],"show":[164],"succeeds":[168],"if":[169,172],"only":[171],"derived":[174],"tight.":[178],"because":[183],"it":[184],"depends":[185],"decision":[188],"procedure":[189],"constraint":[191],"solving.":[192],"technical":[194],"development":[195],"presented":[197],"simple":[200],"first-order":[201],"language":[202],"with":[203,229,252],"linear":[204],"bounds.":[206,239],"However,":[207],"scales":[210],"has":[213],"been":[214],"implemented":[215],"Resource":[217],"Aware":[218],"ML,":[219],"implementation":[221],"AARA":[223],"fragment":[226],"OCaml":[228],"higher-order":[230],"functions,":[231],"user-defined":[232],"types,":[234],"types":[236],"polynomial":[238],"Experiments":[240],"demonstrate":[241],"works":[245],"effectively":[246],"can":[248],"derive":[249],"hundreds":[253],"integers":[255],"sorting":[257],"algorithms,":[258],"operations":[259],"search":[261],"trees,":[262],"insertions":[264],"into":[265],"hash":[266],"tables.":[267]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":5},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":5}],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
