{"id":"https://openalex.org/W2953958793","doi":"https://doi.org/10.1145/3314221.3314618","title":"Lazy counterfactual symbolic execution","display_name":"Lazy counterfactual symbolic execution","publication_year":2019,"publication_date":"2019-06-07","ids":{"openalex":"https://openalex.org/W2953958793","doi":"https://doi.org/10.1145/3314221.3314618","mag":"2953958793"},"language":"en","primary_location":{"id":"doi:10.1145/3314221.3314618","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3314221.3314618","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314618","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"gold","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314618","any_repository_has_fulltext":null},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5001928568","display_name":"William T. Hallahan","orcid":"https://orcid.org/0000-0003-4925-3861"},"institutions":[{"id":"https://openalex.org/I32971472","display_name":"Yale University","ror":"https://ror.org/03v76x132","country_code":"US","type":"education","lineage":["https://openalex.org/I32971472"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"William T. Hallahan","raw_affiliation_strings":["Yale University, USA"],"affiliations":[{"raw_affiliation_string":"Yale University, USA","institution_ids":["https://openalex.org/I32971472"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5080637066","display_name":"Anton Xue","orcid":null},"institutions":[{"id":"https://openalex.org/I32971472","display_name":"Yale University","ror":"https://ror.org/03v76x132","country_code":"US","type":"education","lineage":["https://openalex.org/I32971472"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Anton Xue","raw_affiliation_strings":["Yale University, USA"],"affiliations":[{"raw_affiliation_string":"Yale University, USA","institution_ids":["https://openalex.org/I32971472"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5008175675","display_name":"Maxwell Bland","orcid":null},"institutions":[{"id":"https://openalex.org/I36258959","display_name":"University of California, San Diego","ror":"https://ror.org/0168r3w48","country_code":"US","type":"education","lineage":["https://openalex.org/I36258959"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Maxwell Troy Bland","raw_affiliation_strings":["University of California at San Diego, USA"],"affiliations":[{"raw_affiliation_string":"University of California at San Diego, USA","institution_ids":["https://openalex.org/I36258959"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5002412544","display_name":"Ranjit Jhala","orcid":"https://orcid.org/0000-0002-1802-9421"},"institutions":[{"id":"https://openalex.org/I36258959","display_name":"University of California, San Diego","ror":"https://ror.org/0168r3w48","country_code":"US","type":"education","lineage":["https://openalex.org/I36258959"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ranjit Jhala","raw_affiliation_strings":["University of California at San Diego, USA"],"affiliations":[{"raw_affiliation_string":"University of California at San Diego, USA","institution_ids":["https://openalex.org/I36258959"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5045794652","display_name":"Ru\u017eica Piska\u010d","orcid":"https://orcid.org/0000-0002-3267-0776"},"institutions":[{"id":"https://openalex.org/I32971472","display_name":"Yale University","ror":"https://ror.org/03v76x132","country_code":"US","type":"education","lineage":["https://openalex.org/I32971472"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ruzica Piskac","raw_affiliation_strings":["Yale University, USA"],"affiliations":[{"raw_affiliation_string":"Yale University, USA","institution_ids":["https://openalex.org/I32971472"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5001928568"],"corresponding_institution_ids":["https://openalex.org/I32971472"],"apc_list":null,"apc_paid":null,"fwci":2.9649,"has_fulltext":true,"cited_by_count":18,"citation_normalized_percentile":{"value":0.91094308,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":97},"biblio":{"volume":null,"issue":null,"first_page":"411","last_page":"424"},"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.9995999932289124,"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.9995999932289124,"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/T10260","display_name":"Software Engineering Research","score":0.9994000196456909,"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/T11424","display_name":"Security and Verification in Computing","score":0.9980000257492065,"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/haskell","display_name":"Haskell","score":0.9129239916801453},{"id":"https://openalex.org/keywords/symbolic-execution","display_name":"Symbolic execution","score":0.8849045634269714},{"id":"https://openalex.org/keywords/counterfactual-thinking","display_name":"Counterfactual thinking","score":0.8424733877182007},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8238039612770081},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6357742547988892},{"id":"https://openalex.org/keywords/counterexample","display_name":"Counterexample","score":0.5959856510162354},{"id":"https://openalex.org/keywords/lazy-evaluation","display_name":"Lazy evaluation","score":0.4920456111431122},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.40151846408843994},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.39700907468795776},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.12030044198036194},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.11134135723114014},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.09186339378356934}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9129239916801453},{"id":"https://openalex.org/C2779639559","wikidata":"https://www.wikidata.org/wiki/Q7661178","display_name":"Symbolic execution","level":3,"score":0.8849045634269714},{"id":"https://openalex.org/C108650721","wikidata":"https://www.wikidata.org/wiki/Q1783253","display_name":"Counterfactual thinking","level":2,"score":0.8424733877182007},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8238039612770081},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6357742547988892},{"id":"https://openalex.org/C162838799","wikidata":"https://www.wikidata.org/wiki/Q596077","display_name":"Counterexample","level":2,"score":0.5959856510162354},{"id":"https://openalex.org/C128099668","wikidata":"https://www.wikidata.org/wiki/Q573952","display_name":"Lazy evaluation","level":3,"score":0.4920456111431122},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.40151846408843994},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.39700907468795776},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.12030044198036194},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.11134135723114014},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.09186339378356934},{"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}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3314221.3314618","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3314221.3314618","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314618","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"}],"best_oa_location":{"id":"doi:10.1145/3314221.3314618","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3314221.3314618","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3314221.3314618","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th ACM SIGPLAN Conference on Programming Language Design and Implementation","raw_type":"proceedings-article"},"sustainable_development_goals":[{"score":0.550000011920929,"id":"https://metadata.un.org/sdg/16","display_name":"Peace, Justice and strong institutions"}],"awards":[{"id":"https://openalex.org/G1506952784","display_name":"CAREER:  Synthesis in a Live Programming Environment","funder_award_id":"1553168","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G3743283427","display_name":"TWC: Small: New Foundations for Secure JavaScript","funder_award_id":"1223850","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G5234564298","display_name":null,"funder_award_id":"CCF-1553168, CCF-1302230, CCF-1422471, CCF-1223850, CCF-1218344, CCF-1763814","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G5402090779","display_name":null,"funder_award_id":"F-130","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G6605146565","display_name":"SHF: Medium: Collaborative Research: FRP for Real","funder_award_id":"1302230","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G6644523292","display_name":null,"funder_award_id":"CCF-121834","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G8154076970","display_name":"SHF: Small: Next-Generation, Dependent Type-based Software Model Checking for C","funder_award_id":"1218344","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G8610864570","display_name":"SHF: Medium: Collaborative Research: Program Analytics: Using Trace Data for Localization, Explanation and Synthesis","funder_award_id":"1763814","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G8826023445","display_name":"SHF: Small: Refinement Types For Verified Web Frameworks and Applications","funder_award_id":"1422471","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/F4320308943","display_name":"Microsoft Research","ror":"https://ror.org/00d0nc645"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2953958793.pdf","grobid_xml":"https://content.openalex.org/works/W2953958793.grobid-xml"},"referenced_works_count":51,"referenced_works":["https://openalex.org/W1507006488","https://openalex.org/W1552909716","https://openalex.org/W1556536463","https://openalex.org/W1558109178","https://openalex.org/W1583869287","https://openalex.org/W1710734607","https://openalex.org/W1720848645","https://openalex.org/W1973676520","https://openalex.org/W1993836075","https://openalex.org/W2005192022","https://openalex.org/W2009489720","https://openalex.org/W2011367000","https://openalex.org/W2029976661","https://openalex.org/W2042033151","https://openalex.org/W2044280934","https://openalex.org/W2045900383","https://openalex.org/W2057156093","https://openalex.org/W2059703978","https://openalex.org/W2063019130","https://openalex.org/W2078988604","https://openalex.org/W2088263927","https://openalex.org/W2095621310","https://openalex.org/W2096449544","https://openalex.org/W2101512909","https://openalex.org/W2103279048","https://openalex.org/W2107147876","https://openalex.org/W2110311336","https://openalex.org/W2115261880","https://openalex.org/W2119717320","https://openalex.org/W2120171626","https://openalex.org/W2123307082","https://openalex.org/W2124354055","https://openalex.org/W2130427425","https://openalex.org/W2131239152","https://openalex.org/W2153036969","https://openalex.org/W2163671349","https://openalex.org/W2166708428","https://openalex.org/W2215196193","https://openalex.org/W2267469130","https://openalex.org/W2486375282","https://openalex.org/W2612371455","https://openalex.org/W2949105534","https://openalex.org/W2949799707","https://openalex.org/W3005608680","https://openalex.org/W3010081385","https://openalex.org/W3017092265","https://openalex.org/W4229527230","https://openalex.org/W4238823939","https://openalex.org/W4239433846","https://openalex.org/W4241135032","https://openalex.org/W4243882797"],"related_works":["https://openalex.org/W2392016641","https://openalex.org/W2521829344","https://openalex.org/W2466718051","https://openalex.org/W1734457603","https://openalex.org/W2116323891","https://openalex.org/W2764317176","https://openalex.org/W2168393711","https://openalex.org/W4399796684","https://openalex.org/W2201673571","https://openalex.org/W2028779182"],"abstract_inverted_index":{"We":[0,89,119],"present":[1],"counterfactual":[2,49,75],"symbolic":[3,26,37,76,97],"execution,":[4],"a":[5,23,51,94,105],"new":[6,52,95],"approach":[7,92],"that":[8,11,121,134],"produces":[9],"counterexamples":[10,133],"localize":[12,79],"the":[13,114,137],"causes":[14],"of":[15,17,25,107,113,124],"failure":[16],"static":[18],"verification.":[19,146],"First,":[20],"we":[21,47,70],"develop":[22],"notion":[24],"weak":[27],"head":[28],"normal":[29],"form":[30],"and":[31,101],"use":[32,74],"it":[33,103],"to":[34,54,61,66,73,78,130,144],"define":[35],"lazy":[36],"execution":[38,77,98],"reduction":[39],"rules":[40],"for":[41,122],"non-strict":[42],"languages":[43],"like":[44],"Haskell.":[45],"Second,":[46],"introduce":[48],"branching,":[50],"method":[53],"identify":[55],"places":[56],"where":[57],"verification":[58],"fails":[59],"due":[60],"imprecise":[62],"specifications":[63,140],"(as":[64],"opposed":[65],"incorrect":[67],"code).":[68],"Third,":[69],"show":[71,120,135],"how":[72,136],"refinement":[80,85,116],"type":[81,117],"errors,":[82,126],"by":[83],"translating":[84],"types":[86],"into":[87],"assertions.":[88],"implement":[90],"our":[91],"in":[93],"Haskell":[96],"engine,":[99],"G2,":[100],"evaluate":[102],"on":[104],"corpus":[106],"7550":[108],"errors":[109],"gathered":[110],"from":[111],"users":[112],"LiquidHaskell":[115],"system.":[118],"97.7%":[123],"these":[125],"G2":[127],"is":[128],"able":[129],"quickly":[131],"find":[132],"code":[138],"or":[139],"must":[141],"be":[142],"fixed":[143],"enable":[145]},"counts_by_year":[{"year":2025,"cited_by_count":3},{"year":2024,"cited_by_count":3},{"year":2023,"cited_by_count":3},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":3},{"year":2019,"cited_by_count":3}],"updated_date":"2026-04-21T08:09:41.155169","created_date":"2025-10-10T00:00:00"}
