{"id":"https://openalex.org/W4411267925","doi":"https://doi.org/10.1145/3729274","title":"Type-Constrained Code Generation with Language Models","display_name":"Type-Constrained Code Generation with Language Models","publication_year":2025,"publication_date":"2025-06-10","ids":{"openalex":"https://openalex.org/W4411267925","doi":"https://doi.org/10.1145/3729274"},"language":"en","primary_location":{"id":"doi:10.1145/3729274","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3729274","pdf_url":null,"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":"cc-by-sa","license_id":"https://openalex.org/licenses/cc-by-sa","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":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://doi.org/10.1145/3729274","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5031813611","display_name":"Niels M\u00fcndler","orcid":"https://orcid.org/0000-0003-3851-2557"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":true,"raw_author_name":"Niels M\u00fcndler","raw_affiliation_strings":["ETH Zurich, Zurich, Switzerland"],"affiliations":[{"raw_affiliation_string":"ETH Zurich, Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5101532408","display_name":"Jingxuan He","orcid":"https://orcid.org/0009-0003-9858-5640"},"institutions":[{"id":"https://openalex.org/I95457486","display_name":"University of California, Berkeley","ror":"https://ror.org/01an7q238","country_code":"US","type":"education","lineage":["https://openalex.org/I95457486"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jingxuan He","raw_affiliation_strings":["University of California at Berkeley, Berkeley, USA"],"affiliations":[{"raw_affiliation_string":"University of California at Berkeley, Berkeley, USA","institution_ids":["https://openalex.org/I95457486"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5050436818","display_name":"Hao Wang","orcid":"https://orcid.org/0000-0002-8480-8167"},"institutions":[{"id":"https://openalex.org/I95457486","display_name":"University of California, Berkeley","ror":"https://ror.org/01an7q238","country_code":"US","type":"education","lineage":["https://openalex.org/I95457486"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Hao Wang","raw_affiliation_strings":["University of California at Berkeley, Berkeley, USA"],"affiliations":[{"raw_affiliation_string":"University of California at Berkeley, Berkeley, USA","institution_ids":["https://openalex.org/I95457486"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5101569699","display_name":"Koushik Sen","orcid":"https://orcid.org/0000-0002-4539-9188"},"institutions":[{"id":"https://openalex.org/I95457486","display_name":"University of California, Berkeley","ror":"https://ror.org/01an7q238","country_code":"US","type":"education","lineage":["https://openalex.org/I95457486"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Koushik Sen","raw_affiliation_strings":["University of California at Berkeley, Berkeley, USA"],"affiliations":[{"raw_affiliation_string":"University of California at Berkeley, Berkeley, USA","institution_ids":["https://openalex.org/I95457486"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5019426968","display_name":"Dawn Song","orcid":"https://orcid.org/0000-0001-9745-6802"},"institutions":[{"id":"https://openalex.org/I95457486","display_name":"University of California, Berkeley","ror":"https://ror.org/01an7q238","country_code":"US","type":"education","lineage":["https://openalex.org/I95457486"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Dawn Song","raw_affiliation_strings":["University of California at Berkeley, Berkeley, USA"],"affiliations":[{"raw_affiliation_string":"University of California at Berkeley, Berkeley, USA","institution_ids":["https://openalex.org/I95457486"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5069901599","display_name":"Martin Vechev","orcid":"https://orcid.org/0000-0002-0054-9568"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Martin Vechev","raw_affiliation_strings":["ETH Zurich, Zurich, Switzerland"],"affiliations":[{"raw_affiliation_string":"ETH Zurich, Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":6,"corresponding_author_ids":["https://openalex.org/A5031813611"],"corresponding_institution_ids":["https://openalex.org/I35440088"],"apc_list":null,"apc_paid":null,"fwci":9.0527,"has_fulltext":false,"cited_by_count":4,"citation_normalized_percentile":{"value":0.97547016,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":96,"max":99},"biblio":{"volume":"9","issue":"PLDI","first_page":"601","last_page":"626"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T11450","display_name":"Model-Driven Software Engineering Techniques","score":0.9993000030517578,"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/T11450","display_name":"Model-Driven Software Engineering Techniques","score":0.9993000030517578,"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.9950000047683716,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9918000102043152,"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/programming-language","display_name":"Programming language","score":0.6856434345245361},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.5730074644088745},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.5172658562660217},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5027520656585693},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.07256218791007996},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.06801646947860718}],"concepts":[{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6856434345245361},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.5730074644088745},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.5172658562660217},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5027520656585693},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.07256218791007996},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.06801646947860718},{"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":4,"locations":[{"id":"doi:10.1145/3729274","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3729274","pdf_url":null,"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":"cc-by-sa","license_id":"https://openalex.org/licenses/cc-by-sa","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:arXiv.org:2504.09246","is_oa":true,"landing_page_url":"http://arxiv.org/abs/2504.09246","pdf_url":"https://arxiv.org/pdf/2504.09246","source":{"id":"https://openalex.org/S4393918464","display_name":"ArXiv.org","issn_l":"2331-8422","issn":["2331-8422"],"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,"raw_source_name":null,"raw_type":"text"},{"id":"pmh:ark:/13030/qt8xw132rt","is_oa":false,"landing_page_url":null,"pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":null},{"id":"pmh:oai:escholarship.org:ark:/13030/qt8xw132rt","is_oa":true,"landing_page_url":"https://escholarship.org/uc/item/8xw132rt","pdf_url":null,"source":{"id":"https://openalex.org/S4306400115","display_name":"eScholarship (California Digital Library)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I2801248553","host_organization_name":"California Digital Library","host_organization_lineage":["https://openalex.org/I2801248553"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Proceedings of the ACM on Programming Languages, vol 9, iss PLDI","raw_type":"article"}],"best_oa_location":{"id":"doi:10.1145/3729274","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3729274","pdf_url":null,"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":"cc-by-sa","license_id":"https://openalex.org/licenses/cc-by-sa","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":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":43,"referenced_works":["https://openalex.org/W207336988","https://openalex.org/W1487166760","https://openalex.org/W1514516864","https://openalex.org/W2013892605","https://openalex.org/W2097335450","https://openalex.org/W2157976942","https://openalex.org/W2617588282","https://openalex.org/W2911692446","https://openalex.org/W2962784628","https://openalex.org/W3098666169","https://openalex.org/W3099140684","https://openalex.org/W4288057765","https://openalex.org/W4327810158","https://openalex.org/W4366204357","https://openalex.org/W4367185264","https://openalex.org/W4379537202","https://openalex.org/W4385014449","https://openalex.org/W4386081426","https://openalex.org/W4386185625","https://openalex.org/W4386436496","https://openalex.org/W4386721614","https://openalex.org/W4388585881","https://openalex.org/W4391272793","https://openalex.org/W4394769102","https://openalex.org/W4396651321","https://openalex.org/W4399357038","https://openalex.org/W4399511946","https://openalex.org/W4400375816","https://openalex.org/W4400480075","https://openalex.org/W4400488504","https://openalex.org/W4402954209","https://openalex.org/W4403486628","https://openalex.org/W4403929277","https://openalex.org/W4405023514","https://openalex.org/W4405627314","https://openalex.org/W4405655184","https://openalex.org/W4405766390","https://openalex.org/W4406779522","https://openalex.org/W4407091141","https://openalex.org/W4407551092","https://openalex.org/W4411551908","https://openalex.org/W6893271685","https://openalex.org/W6967084484"],"related_works":["https://openalex.org/W4391375266","https://openalex.org/W2899084033","https://openalex.org/W2748952813","https://openalex.org/W2390279801","https://openalex.org/W4391913857","https://openalex.org/W2358668433","https://openalex.org/W2163672025","https://openalex.org/W2048831961","https://openalex.org/W1606349578","https://openalex.org/W4399567378"],"abstract_inverted_index":{"Large":[0],"language":[1,129],"models":[2,180],"(LLMs)":[3],"have":[4],"achieved":[5],"notable":[6],"success":[7],"in":[8,162,196],"code":[9,62,95,163,199],"generation.":[10,96],"However,":[11,58],"they":[12],"still":[13],"frequently":[14,60],"produce":[15],"uncompilable":[16],"output":[17],"because":[18],"their":[19],"next-token":[20],"inference":[21],"procedure":[22],"does":[23],"not":[24],"model":[25,175],"formal":[26,202],"aspects":[27],"of":[28,54,71,171,193,204],"code.":[29,120],"Although":[30],"constrained":[31],"decoding":[32,87],"is":[33],"a":[34,85,106,112,126],"promising":[35],"approach":[36,88,114,124,149,195],"to":[37,46,76,93,115,133,135],"alleviate":[38],"this":[39,81,98],"issue,":[40],"it":[41,132],"has":[42],"only":[43],"been":[44],"applied":[45],"handle":[47],"either":[48],"domain-specific":[49],"languages":[50],"or":[51],"syntactic":[52],"features":[53],"general-purpose":[55],"programming":[56],"languages.":[57],"LLMs":[59,170],"generate":[61],"with":[63,181,201],"typing":[64],"errors,":[65],"which":[66],"are":[67],"beyond":[68],"the":[69,141,189],"domain":[70],"syntax":[72],"and":[73,105,130,143,157,166,174,191],"generally":[74],"hard":[75],"adequately":[77],"constrain.":[78],"To":[79],"address":[80],"challenge,":[82],"we":[83,100],"introduce":[84],"type-constrained":[86],"that":[89,147],"leverages":[90],"type":[91,205],"systems":[92],"guide":[94],"For":[97],"purpose,":[99],"develop":[101],"novel":[102],"prefix":[103],"automata":[104],"search":[107],"over":[108],"inhabitable":[109],"types,":[110],"forming":[111],"sound":[113],"enforce":[116],"well-typedness":[117],"on":[118,125,140],"LLM-generated":[119],"We":[121],"formalize":[122],"our":[123,148,194],"foundational":[127],"simply-typed":[128],"extend":[131],"TypeScript":[134],"demonstrate":[136,188],"practicality.":[137],"Our":[138],"evaluation":[139],"HumanEval":[142],"MBPP":[144],"datasets":[145],"shows":[146],"reduces":[150],"compilation":[151],"errors":[152],"by":[153],"more":[154,182],"than":[155,183],"half":[156],"significantly":[158],"increases":[159],"functional":[160],"correctness":[161],"synthesis,":[164],"translation,":[165],"repair":[167],"tasks":[168],"across":[169],"various":[172],"sizes":[173],"families,":[176],"including":[177],"state-of-the-art":[178],"open-weight":[179],"30B":[184],"parameters.":[185],"The":[186],"results":[187],"generality":[190],"effectiveness":[192],"constraining":[197],"LLM":[198],"generation":[200],"rules":[203],"systems.":[206]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":3}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
