{"id":"https://openalex.org/W3195525157","doi":"https://doi.org/10.1145/3473569","title":"An existential crisis resolved: type inference for first-class existential types","display_name":"An existential crisis resolved: type inference for first-class existential types","publication_year":2021,"publication_date":"2021-08-19","ids":{"openalex":"https://openalex.org/W3195525157","doi":"https://doi.org/10.1145/3473569","mag":"3195525157"},"language":"en","primary_location":{"id":"doi:10.1145/3473569","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3473569","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3473569","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","license_id":"https://openalex.org/licenses/cc-by","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/3473569","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5082913747","display_name":"Richard A. Eisenberg","orcid":"https://orcid.org/0000-0002-7669-9781"},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Richard A. Eisenberg","raw_affiliation_strings":["Tweag, France"],"affiliations":[{"raw_affiliation_string":"Tweag, France","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5015957018","display_name":"Guillaume Duboc","orcid":null},"institutions":[{"id":"https://openalex.org/I113428412","display_name":"\u00c9cole Normale Sup\u00e9rieure de Lyon","ror":"https://ror.org/04zmssz18","country_code":"FR","type":"education","lineage":["https://openalex.org/I113428412","https://openalex.org/I203339264"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"Guillaume Duboc","raw_affiliation_strings":["ENS Lyon, France / Tweag, France"],"affiliations":[{"raw_affiliation_string":"ENS Lyon, France / Tweag, France","institution_ids":["https://openalex.org/I113428412"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5049220962","display_name":"Stephanie Weirich","orcid":"https://orcid.org/0000-0002-6756-9168"},"institutions":[{"id":"https://openalex.org/I36788626","display_name":"California University of Pennsylvania","ror":"https://ror.org/01spssf70","country_code":"US","type":"education","lineage":["https://openalex.org/I36788626"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Stephanie Weirich","raw_affiliation_strings":["University of Pennsylvania, USA"],"affiliations":[{"raw_affiliation_string":"University of Pennsylvania, USA","institution_ids":["https://openalex.org/I36788626"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5100392980","display_name":"Daniel Lee","orcid":"https://orcid.org/0000-0001-9447-4175"},"institutions":[{"id":"https://openalex.org/I36788626","display_name":"California University of Pennsylvania","ror":"https://ror.org/01spssf70","country_code":"US","type":"education","lineage":["https://openalex.org/I36788626"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Daniel Lee","raw_affiliation_strings":["University of Pennsylvania, USA"],"affiliations":[{"raw_affiliation_string":"University of Pennsylvania, USA","institution_ids":["https://openalex.org/I36788626"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5082913747"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.6987,"has_fulltext":true,"cited_by_count":6,"citation_normalized_percentile":{"value":0.76281785,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":"5","issue":"ICFP","first_page":"1","last_page":"29"},"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.9994000196456909,"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.9994000196456909,"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/T10317","display_name":"Advanced Database Systems and Queries","score":0.9911999702453613,"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"}},{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9909999966621399,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.8277438879013062},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.791067361831665},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.7467482089996338},{"id":"https://openalex.org/keywords/existentialism","display_name":"Existentialism","score":0.6759442687034607},{"id":"https://openalex.org/keywords/usable","display_name":"USable","score":0.6337317228317261},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5934244990348816},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.5285821557044983},{"id":"https://openalex.org/keywords/class","display_name":"Class (philosophy)","score":0.5279005169868469},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.48176026344299316},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.455194354057312},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.41983261704444885},{"id":"https://openalex.org/keywords/natural-language-processing","display_name":"Natural language processing","score":0.33896827697753906},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.33685705065727234},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3238949179649353},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.25847238302230835}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.8277438879013062},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.791067361831665},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.7467482089996338},{"id":"https://openalex.org/C127882523","wikidata":"https://www.wikidata.org/wiki/Q38066","display_name":"Existentialism","level":2,"score":0.6759442687034607},{"id":"https://openalex.org/C2780615836","wikidata":"https://www.wikidata.org/wiki/Q2471869","display_name":"USable","level":2,"score":0.6337317228317261},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5934244990348816},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.5285821557044983},{"id":"https://openalex.org/C2777212361","wikidata":"https://www.wikidata.org/wiki/Q5127848","display_name":"Class (philosophy)","level":2,"score":0.5279005169868469},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.48176026344299316},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.455194354057312},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.41983261704444885},{"id":"https://openalex.org/C204321447","wikidata":"https://www.wikidata.org/wiki/Q30642","display_name":"Natural language processing","level":1,"score":0.33896827697753906},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.33685705065727234},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3238949179649353},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.25847238302230835},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","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},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C136764020","wikidata":"https://www.wikidata.org/wiki/Q466","display_name":"World Wide Web","level":1,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","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}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3473569","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3473569","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3473569","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","license_id":"https://openalex.org/licenses/cc-by","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/3473569","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3473569","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3473569","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","license_id":"https://openalex.org/licenses/cc-by","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/G1846149676","display_name":null,"funder_award_id":"1704041","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G7793973045","display_name":"SHF: Medium: Collaborative Research: The Theory and Practice of Dependent Types in Haskell","funder_award_id":"1703835","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G8283010556","display_name":null,"funder_award_id":"1703835 and 1704041","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"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"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W3195525157.pdf","grobid_xml":"https://content.openalex.org/works/W3195525157.grobid-xml"},"referenced_works_count":43,"referenced_works":["https://openalex.org/W80198721","https://openalex.org/W775976006","https://openalex.org/W1481770540","https://openalex.org/W1514370277","https://openalex.org/W1557561422","https://openalex.org/W1564423621","https://openalex.org/W1583295953","https://openalex.org/W1592799753","https://openalex.org/W1595372275","https://openalex.org/W1970031091","https://openalex.org/W1984514567","https://openalex.org/W1985088747","https://openalex.org/W2003131168","https://openalex.org/W2003298503","https://openalex.org/W2015256273","https://openalex.org/W2019376542","https://openalex.org/W2023970190","https://openalex.org/W2045900383","https://openalex.org/W2076653850","https://openalex.org/W2082283048","https://openalex.org/W2095136535","https://openalex.org/W2097157641","https://openalex.org/W2104204098","https://openalex.org/W2107923385","https://openalex.org/W2110196404","https://openalex.org/W2112150205","https://openalex.org/W2125690388","https://openalex.org/W2128197690","https://openalex.org/W2131067178","https://openalex.org/W2131916293","https://openalex.org/W2154044723","https://openalex.org/W2166822586","https://openalex.org/W2169148161","https://openalex.org/W2560961062","https://openalex.org/W2751791540","https://openalex.org/W2963020900","https://openalex.org/W2963937673","https://openalex.org/W2966631854","https://openalex.org/W3001202710","https://openalex.org/W3046590812","https://openalex.org/W3193360938","https://openalex.org/W4238977241","https://openalex.org/W4255950761"],"related_works":["https://openalex.org/W1886401053","https://openalex.org/W1550049051","https://openalex.org/W2095136535","https://openalex.org/W3185004093","https://openalex.org/W2113619131","https://openalex.org/W4292002158","https://openalex.org/W2137676482","https://openalex.org/W1850217788","https://openalex.org/W3177786852","https://openalex.org/W2519387135"],"abstract_inverted_index":{"Despite":[0],"the":[1,42,95],"great":[2],"success":[3],"of":[4,44],"inferring":[5],"and":[6,31,56],"programming":[7],"with":[8,28,65],"universal":[9],"types,":[10,26,30],"their":[11],"dual\u2014existential":[12],"types\u2014are":[13],"much":[14],"harder":[15],"to":[16,54,86],"work":[17],"with.":[18],"Existential":[19],"types":[20],"are":[21],"useful":[22],"in":[23,41,62],"building":[24],"abstract":[25],"working":[27],"indexed":[29],"providing":[32],"first-class":[33],"support":[34,91],"for":[35],"refinement":[36],"types.":[37],"This":[38,77],"paper,":[39],"set":[40],"context":[43],"Haskell,":[45],"presents":[46],"a":[47,74],"bidirectional":[48],"type-inference":[49],"algorithm":[50],"that":[51],"infers":[52],"where":[53],"introduce":[55],"eliminate":[57],"existentials":[58,100],"without":[59],"any":[60],"annotations":[61],"terms,":[63],"along":[64],"an":[66],"explicitly":[67],"typed,":[68],"type-safe":[69],"core":[70],"language":[71],"usable":[72],"as":[73],"compilation":[75],"target.":[76],"approach":[78],"is":[79,85],"backward":[80],"compatible.":[81],"The":[82],"key":[83],"ingredient":[84],"use":[87],"strong":[88],"existentials,":[89],"which":[90],"(lazily)":[92],"projecting":[93],"out":[94],"encapsulated":[96],"data,":[97],"not":[98],"weak":[99],"accessible":[101],"only":[102],"by":[103],"pattern-matching.":[104]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":2},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":1}],"updated_date":"2026-03-18T14:38:29.013473","created_date":"2025-10-10T00:00:00"}
