{"id":"https://openalex.org/W3195140243","doi":"https://doi.org/10.1145/3471874.3472982","title":"Haskell\u207b\u00b9: automatic function inversion in Haskell","display_name":"Haskell\u207b\u00b9: automatic function inversion in Haskell","publication_year":2021,"publication_date":"2021-08-18","ids":{"openalex":"https://openalex.org/W3195140243","doi":"https://doi.org/10.1145/3471874.3472982","mag":"3195140243"},"language":"en","primary_location":{"id":"doi:10.1145/3471874.3472982","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3471874.3472982","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 14th ACM SIGPLAN International Symposium on Haskell","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5048555021","display_name":"Finn Teegen","orcid":"https://orcid.org/0000-0002-7905-3804"},"institutions":[{"id":"https://openalex.org/I32021983","display_name":"Christian-Albrechts-Universit\u00e4t zu Kiel","ror":"https://ror.org/04v76ef78","country_code":"DE","type":"education","lineage":["https://openalex.org/I32021983"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Finn Teegen","raw_affiliation_strings":["University of Kiel, Germany"],"raw_orcid":"https://orcid.org/0000-0002-7905-3804","affiliations":[{"raw_affiliation_string":"University of Kiel, Germany","institution_ids":["https://openalex.org/I32021983"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5007853080","display_name":"Kai-Oliver Prott","orcid":"https://orcid.org/0000-0002-5795-6308"},"institutions":[{"id":"https://openalex.org/I32021983","display_name":"Christian-Albrechts-Universit\u00e4t zu Kiel","ror":"https://ror.org/04v76ef78","country_code":"DE","type":"education","lineage":["https://openalex.org/I32021983"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Kai-Oliver Prott","raw_affiliation_strings":["University of Kiel, Germany"],"raw_orcid":"https://orcid.org/0000-0002-5795-6308","affiliations":[{"raw_affiliation_string":"University of Kiel, Germany","institution_ids":["https://openalex.org/I32021983"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5028068316","display_name":"Niels Bunkenburg","orcid":"https://orcid.org/0000-0003-1288-2330"},"institutions":[{"id":"https://openalex.org/I32021983","display_name":"Christian-Albrechts-Universit\u00e4t zu Kiel","ror":"https://ror.org/04v76ef78","country_code":"DE","type":"education","lineage":["https://openalex.org/I32021983"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Niels Bunkenburg","raw_affiliation_strings":["University of Kiel, Germany"],"raw_orcid":"https://orcid.org/0000-0003-1288-2330","affiliations":[{"raw_affiliation_string":"University of Kiel, Germany","institution_ids":["https://openalex.org/I32021983"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.6997,"has_fulltext":false,"cited_by_count":5,"citation_normalized_percentile":{"value":0.76426416,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"41","last_page":"55"},"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.9998999834060669,"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.9998999834060669,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9988999962806702,"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/T10142","display_name":"Formal Methods in Verification","score":0.9973000288009644,"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/haskell","display_name":"Haskell","score":0.9970970153808594},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8022859692573547},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.7684612274169922},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6989083290100098},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6284986734390259},{"id":"https://openalex.org/keywords/extension","display_name":"Extension (predicate logic)","score":0.5145747065544128},{"id":"https://openalex.org/keywords/pattern-matching","display_name":"Pattern matching","score":0.4570486843585968},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.35545384883880615}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9970970153808594},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8022859692573547},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.7684612274169922},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6989083290100098},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6284986734390259},{"id":"https://openalex.org/C2778029271","wikidata":"https://www.wikidata.org/wiki/Q5421931","display_name":"Extension (predicate logic)","level":2,"score":0.5145747065544128},{"id":"https://openalex.org/C68859911","wikidata":"https://www.wikidata.org/wiki/Q1503724","display_name":"Pattern matching","level":2,"score":0.4570486843585968},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.35545384883880615}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3471874.3472982","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3471874.3472982","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 14th ACM SIGPLAN International Symposium on Haskell","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":52,"referenced_works":["https://openalex.org/W175712399","https://openalex.org/W1484598194","https://openalex.org/W1492124994","https://openalex.org/W1499136777","https://openalex.org/W1543641760","https://openalex.org/W1551531572","https://openalex.org/W1560248234","https://openalex.org/W1563548877","https://openalex.org/W1564423621","https://openalex.org/W1596289178","https://openalex.org/W1650673748","https://openalex.org/W1801920691","https://openalex.org/W1977140313","https://openalex.org/W1977760557","https://openalex.org/W2009775190","https://openalex.org/W2044417921","https://openalex.org/W2047428963","https://openalex.org/W2059895047","https://openalex.org/W2067005178","https://openalex.org/W2083302545","https://openalex.org/W2086127849","https://openalex.org/W2100883156","https://openalex.org/W2101398694","https://openalex.org/W2105450475","https://openalex.org/W2112087718","https://openalex.org/W2112150205","https://openalex.org/W2112474400","https://openalex.org/W2113562776","https://openalex.org/W2114980032","https://openalex.org/W2118351936","https://openalex.org/W2123396057","https://openalex.org/W2126693002","https://openalex.org/W2127844749","https://openalex.org/W2134394225","https://openalex.org/W2136765833","https://openalex.org/W2140647971","https://openalex.org/W2141576692","https://openalex.org/W2148275616","https://openalex.org/W2149935768","https://openalex.org/W2157592151","https://openalex.org/W2182283312","https://openalex.org/W2295914203","https://openalex.org/W2468080012","https://openalex.org/W2555814573","https://openalex.org/W2681883877","https://openalex.org/W2889050876","https://openalex.org/W3011921014","https://openalex.org/W3031673955","https://openalex.org/W3047089539","https://openalex.org/W3101427607","https://openalex.org/W4213090963","https://openalex.org/W4243125208"],"related_works":["https://openalex.org/W1757338326","https://openalex.org/W2192862863","https://openalex.org/W2098374496","https://openalex.org/W1583431014","https://openalex.org/W4246781209","https://openalex.org/W1573380057","https://openalex.org/W2129129872","https://openalex.org/W4297749046","https://openalex.org/W1650673748","https://openalex.org/W1601811574"],"abstract_inverted_index":{"We":[0,29],"present":[1],"an":[2,18],"approach":[3],"for":[4,61,78],"automatic":[5],"function":[6],"inversion":[7],"in":[8,70],"Haskell.":[9],"The":[10],"inverse":[11,47],"functions":[12,42],"we":[13,49,74],"generate":[14],"are":[15],"based":[16],"on":[17],"extension":[19,34],"of":[20,35,41,96],"Haskell's":[21,53],"computational":[22],"model":[23],"with":[24,59],"non-determinism":[25],"and":[26,43,87],"free":[27],"variables.":[28],"implement":[30],"this":[31],"functional":[32,62,88],"logic":[33],"Haskell":[36,81],"via":[37],"a":[38,76],"monadic":[39],"lifting":[40],"type":[44],"declarations.":[45],"Using":[46],"functions,":[48],"additionally":[50],"show":[51],"how":[52],"pattern":[54,68],"matching":[55,69],"can":[56],"be":[57],"augmented":[58],"support":[60],"patterns,":[63],"which":[64],"enable":[65],"arbitrarily":[66],"deep":[67],"data":[71],"structures.":[72],"Finally,":[73],"provide":[75],"plugin":[77],"the":[79,91,97],"Glasgow":[80],"Compiler":[82],"to":[83],"seamlessly":[84],"integrate":[85],"inverses":[86],"patterns":[89],"into":[90],"language,":[92],"covering":[93],"almost":[94],"all":[95],"Haskell2010":[98],"language":[99],"standard.":[100]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":1}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
