{"id":"https://openalex.org/W2074096153","doi":"https://doi.org/10.1145/2784731.2784748","title":"GADTs meet their match: pattern-matching warnings that account for GADTs, guards, and laziness","display_name":"GADTs meet their match: pattern-matching warnings that account for GADTs, guards, and laziness","publication_year":2015,"publication_date":"2015-08-26","ids":{"openalex":"https://openalex.org/W2074096153","doi":"https://doi.org/10.1145/2784731.2784748","mag":"2074096153"},"language":"en","primary_location":{"id":"doi:10.1145/2784731.2784748","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2784731.2784748","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th ACM SIGPLAN International Conference on Functional Programming","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://lirias.kuleuven.be/retrieve/d94bda42-b488-4892-9aa4-5dc34dea182a","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5061379472","display_name":"Georgios Karachalias","orcid":null},"institutions":[{"id":"https://openalex.org/I2801227569","display_name":"Ghent University Hospital","ror":"https://ror.org/00xmkp704","country_code":"BE","type":"healthcare","lineage":["https://openalex.org/I2801227569"]}],"countries":["BE"],"is_corresponding":true,"raw_author_name":"Georgios Karachalias","raw_affiliation_strings":["Ghent University, Belgium"],"affiliations":[{"raw_affiliation_string":"Ghent University, Belgium","institution_ids":["https://openalex.org/I2801227569"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5050247934","display_name":"Tom Schrijvers","orcid":"https://orcid.org/0000-0001-8771-5559"},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"Tom Schrijvers","raw_affiliation_strings":["KU Leuven, Belgium"],"affiliations":[{"raw_affiliation_string":"KU Leuven, Belgium","institution_ids":["https://openalex.org/I99464096"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5029108294","display_name":"Dimitrios Vytiniotis","orcid":null},"institutions":[{"id":"https://openalex.org/I1290206253","display_name":"Microsoft (United States)","ror":"https://ror.org/00d0nc645","country_code":"US","type":"company","lineage":["https://openalex.org/I1290206253"]},{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB","US"],"is_corresponding":false,"raw_author_name":"Dimitrios Vytiniotis","raw_affiliation_strings":["Microsoft Research, UK","[Microsoft Research, UK]"],"affiliations":[{"raw_affiliation_string":"Microsoft Research, UK","institution_ids":["https://openalex.org/I4210164937"]},{"raw_affiliation_string":"[Microsoft Research, UK]","institution_ids":["https://openalex.org/I1290206253"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5027817074","display_name":"Simon Peyton Jones","orcid":"https://orcid.org/0000-0002-6085-1435"},"institutions":[{"id":"https://openalex.org/I1290206253","display_name":"Microsoft (United States)","ror":"https://ror.org/00d0nc645","country_code":"US","type":"company","lineage":["https://openalex.org/I1290206253"]},{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB","US"],"is_corresponding":false,"raw_author_name":"Simon Peyton Jones","raw_affiliation_strings":["Microsoft Research, UK","[Microsoft Research, UK]"],"affiliations":[{"raw_affiliation_string":"Microsoft Research, UK","institution_ids":["https://openalex.org/I4210164937"]},{"raw_affiliation_string":"[Microsoft Research, UK]","institution_ids":["https://openalex.org/I1290206253"]}]}],"institutions":[],"countries_distinct_count":3,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5061379472"],"corresponding_institution_ids":["https://openalex.org/I2801227569"],"apc_list":null,"apc_paid":null,"fwci":1.3193,"has_fulltext":true,"cited_by_count":12,"citation_normalized_percentile":{"value":0.80723724,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":null,"issue":null,"first_page":"424","last_page":"436"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9975000023841858,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9975000023841858,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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.996399998664856,"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/T11424","display_name":"Security and Verification in Computing","score":0.995199978351593,"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/laziness","display_name":"Laziness","score":0.9494767189025879},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.9085607528686523},{"id":"https://openalex.org/keywords/programmer","display_name":"Programmer","score":0.9066545963287354},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8486357927322388},{"id":"https://openalex.org/keywords/pattern-matching","display_name":"Pattern matching","score":0.7062816619873047},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6861597895622253},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.656037449836731},{"id":"https://openalex.org/keywords/matching","display_name":"Matching (statistics)","score":0.599686861038208},{"id":"https://openalex.org/keywords/obfuscation","display_name":"Obfuscation","score":0.49355924129486084},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.4873219430446625},{"id":"https://openalex.org/keywords/function","display_name":"Function (biology)","score":0.4323587417602539},{"id":"https://openalex.org/keywords/computer-security","display_name":"Computer security","score":0.3859192132949829},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.3304693102836609},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.06420814990997314}],"concepts":[{"id":"https://openalex.org/C2776447739","wikidata":"https://www.wikidata.org/wiki/Q484","display_name":"Laziness","level":2,"score":0.9494767189025879},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9085607528686523},{"id":"https://openalex.org/C2778514511","wikidata":"https://www.wikidata.org/wiki/Q1374194","display_name":"Programmer","level":2,"score":0.9066545963287354},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8486357927322388},{"id":"https://openalex.org/C68859911","wikidata":"https://www.wikidata.org/wiki/Q1503724","display_name":"Pattern matching","level":2,"score":0.7062816619873047},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6861597895622253},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.656037449836731},{"id":"https://openalex.org/C165064840","wikidata":"https://www.wikidata.org/wiki/Q1321061","display_name":"Matching (statistics)","level":2,"score":0.599686861038208},{"id":"https://openalex.org/C40305131","wikidata":"https://www.wikidata.org/wiki/Q2616305","display_name":"Obfuscation","level":2,"score":0.49355924129486084},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.4873219430446625},{"id":"https://openalex.org/C14036430","wikidata":"https://www.wikidata.org/wiki/Q3736076","display_name":"Function (biology)","level":2,"score":0.4323587417602539},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.3859192132949829},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.3304693102836609},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.06420814990997314},{"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/C15744967","wikidata":"https://www.wikidata.org/wiki/Q9418","display_name":"Psychology","level":0,"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/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","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},{"id":"https://openalex.org/C118552586","wikidata":"https://www.wikidata.org/wiki/Q7867","display_name":"Psychiatry","level":1,"score":0.0},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0}],"mesh":[],"locations_count":6,"locations":[{"id":"doi:10.1145/2784731.2784748","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2784731.2784748","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th ACM SIGPLAN International Conference on Functional Programming","raw_type":"proceedings-article"},{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/647999","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/647999","pdf_url":"https://lirias.kuleuven.be/retrieve/d94bda42-b488-4892-9aa4-5dc34dea182a","source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"20th ACM SIGPLAN International Conference on Functional Programming (ICFP), CANADA, Vancouver, 31 August - 2 September 2015","raw_type":"info:eu-repo/semantics/publishedVersion"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.1009.7540","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.1009.7540","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://research.microsoft.com/en-us/um/people/simonpj/papers/pattern-matching/gadtpm-acm.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.716.453","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.716.453","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://people.cs.kuleuven.be/%7Egeorge.karachalias/papers/p424-karachalias.pdf","raw_type":"text"},{"id":"pmh:oai:archive.ugent.be:7060021","is_oa":false,"landing_page_url":"http://hdl.handle.net/1854/LU-7060021","pdf_url":null,"source":{"id":"https://openalex.org/S4306400478","display_name":"Ghent University Academic Bibliography (Ghent University)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I32597200","host_organization_name":"Ghent University","host_organization_lineage":["https://openalex.org/I32597200"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"ISBN: 978-1-4503-3669-7","raw_type":"info:eu-repo/semantics/publishedVersion"},{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/512439","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/512439","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"ACM SIGPLAN Notices, vol. 50 (9), (424-436)","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/647999","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/647999","pdf_url":"https://lirias.kuleuven.be/retrieve/d94bda42-b488-4892-9aa4-5dc34dea182a","source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"20th ACM SIGPLAN International Conference on Functional Programming (ICFP), CANADA, Vancouver, 31 August - 2 September 2015","raw_type":"info:eu-repo/semantics/publishedVersion"},"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16","score":0.5400000214576721}],"awards":[],"funders":[{"id":"https://openalex.org/F4320321730","display_name":"Fonds Wetenschappelijk Onderzoek","ror":"https://ror.org/03qtxy027"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2074096153.pdf","grobid_xml":"https://content.openalex.org/works/W2074096153.grobid-xml"},"referenced_works_count":40,"referenced_works":["https://openalex.org/W123460044","https://openalex.org/W174956004","https://openalex.org/W1500745543","https://openalex.org/W1501891810","https://openalex.org/W1568140005","https://openalex.org/W1575675278","https://openalex.org/W1589985025","https://openalex.org/W1596289178","https://openalex.org/W1827112781","https://openalex.org/W1965664509","https://openalex.org/W1973676520","https://openalex.org/W1977140313","https://openalex.org/W1984514567","https://openalex.org/W2005192022","https://openalex.org/W2014294283","https://openalex.org/W2029916142","https://openalex.org/W2045900383","https://openalex.org/W2057405511","https://openalex.org/W2059703978","https://openalex.org/W2062887328","https://openalex.org/W2075623758","https://openalex.org/W2076578036","https://openalex.org/W2099741881","https://openalex.org/W2109326210","https://openalex.org/W2112474400","https://openalex.org/W2114980032","https://openalex.org/W2120171626","https://openalex.org/W2129256695","https://openalex.org/W2138164781","https://openalex.org/W2140647971","https://openalex.org/W2145108549","https://openalex.org/W2154390633","https://openalex.org/W2164474969","https://openalex.org/W2295923951","https://openalex.org/W2561675875","https://openalex.org/W4285719527","https://openalex.org/W6630073763","https://openalex.org/W6638774856","https://openalex.org/W6644631812","https://openalex.org/W6680258913"],"related_works":["https://openalex.org/W4230063905","https://openalex.org/W146455592","https://openalex.org/W4296940447","https://openalex.org/W2115866888","https://openalex.org/W1975054464","https://openalex.org/W2112263414","https://openalex.org/W2112632506","https://openalex.org/W2489038392","https://openalex.org/W2474047139","https://openalex.org/W52864878"],"abstract_inverted_index":{"For":[0],"ML":[1],"and":[2,59],"Haskell,":[3],"accurate":[4],"warnings":[5,23],"when":[6,24],"a":[7,49],"function":[8],"definition":[9],"has":[10],"redundant":[11],"or":[12,35],"missing":[13],"patterns":[14],"are":[15],"mission":[16],"critical.":[17],"But":[18],"today's":[19],"compilers":[20],"generate":[21],"bogus":[22],"the":[25,40],"programmer":[26],"uses":[27],"guards":[28],"(even":[29],"simple":[30],"ones),":[31],"GADTs,":[32],"pattern":[33],"guards,":[34],"view":[36],"patterns.":[37],"We":[38],"give":[39],"first":[41],"algorithm":[42],"that":[43],"handles":[44],"all":[45],"these":[46],"cases":[47],"in":[48,57,64],"single,":[50],"uniform":[51],"framework,":[52],"together":[53],"with":[54],"an":[55],"implementation":[56],"GHC,":[58],"evidence":[60],"of":[61],"its":[62],"utility":[63],"practice.":[65]},"counts_by_year":[{"year":2023,"cited_by_count":2},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":2}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
