{"id":"https://openalex.org/W2156926516","doi":"https://doi.org/10.1017/s0956796800001325","title":"Type Reconstruction for Type Classes","display_name":"Type Reconstruction for Type Classes","publication_year":1995,"publication_date":"1995-04-01","ids":{"openalex":"https://openalex.org/W2156926516","doi":"https://doi.org/10.1017/s0956796800001325","mag":"2156926516"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796800001325","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s0956796800001325","pdf_url":null,"source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-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/A5062636889","display_name":"Tobias Nipkow","orcid":"https://orcid.org/0000-0003-0730-515X"},"institutions":[{"id":"https://openalex.org/I62916508","display_name":"Technical University of Munich","ror":"https://ror.org/02kkvpp62","country_code":"DE","type":"education","lineage":["https://openalex.org/I62916508"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Tobias Nipkow","raw_affiliation_strings":["Institut f\u00fcr Informatik, Technische Universit\u00e4t M\u00fcnchen, 80290 M\u00fcnchen, Germany"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Institut f\u00fcr Informatik, Technische Universit\u00e4t M\u00fcnchen, 80290 M\u00fcnchen, Germany","institution_ids":["https://openalex.org/I62916508"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5063111123","display_name":"Christian Prehofer","orcid":null},"institutions":[{"id":"https://openalex.org/I62916508","display_name":"Technical University of Munich","ror":"https://ror.org/02kkvpp62","country_code":"DE","type":"education","lineage":["https://openalex.org/I62916508"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Christian Prehofer","raw_affiliation_strings":["Institut f\u00fcr Informatik, Technische Universit\u00e4t M\u00fcnchen, 80290 M\u00fcnchen, Germany"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Institut f\u00fcr Informatik, Technische Universit\u00e4t M\u00fcnchen, 80290 M\u00fcnchen, Germany","institution_ids":["https://openalex.org/I62916508"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5062636889"],"corresponding_institution_ids":["https://openalex.org/I62916508"],"apc_list":null,"apc_paid":null,"fwci":7.0718,"has_fulltext":false,"cited_by_count":45,"citation_normalized_percentile":{"value":0.96959398,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":"5","issue":"2","first_page":"201","last_page":"224"},"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/T10142","display_name":"Formal Methods in Verification","score":0.9898999929428101,"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"}},{"id":"https://openalex.org/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.9883999824523926,"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/type-inference","display_name":"Type inference","score":0.9069859981536865},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8134090900421143},{"id":"https://openalex.org/keywords/unification","display_name":"Unification","score":0.7724902629852295},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.7330662608146667},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.6146384477615356},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6088500618934631},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.5284438133239746},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.4511321485042572},{"id":"https://openalex.org/keywords/extension","display_name":"Extension (predicate logic)","score":0.4466877579689026},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3809089660644531},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3449389338493347},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.2649351954460144}],"concepts":[{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.9069859981536865},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8134090900421143},{"id":"https://openalex.org/C96146094","wikidata":"https://www.wikidata.org/wiki/Q609057","display_name":"Unification","level":2,"score":0.7724902629852295},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.7330662608146667},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.6146384477615356},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6088500618934631},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.5284438133239746},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.4511321485042572},{"id":"https://openalex.org/C2778029271","wikidata":"https://www.wikidata.org/wiki/Q5421931","display_name":"Extension (predicate logic)","level":2,"score":0.4466877579689026},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3809089660644531},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3449389338493347},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.2649351954460144},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","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":4,"locations":[{"id":"doi:10.1017/s0956796800001325","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s0956796800001325","pdf_url":null,"source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.3.6027","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.3.6027","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www4.in.tum.de/publ/papers/NipkowPrehofer_TRfT1995.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.387.2160","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.387.2160","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://belle.sourceforge.net/doc/jfp95.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.43.1158","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.43.1158","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www4.informatik.tu-muenchen.de/papers/NipkowPrehofer_TRfT1995.ps.gz","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":10,"referenced_works":["https://openalex.org/W1506492451","https://openalex.org/W1551706119","https://openalex.org/W1554432400","https://openalex.org/W1829244603","https://openalex.org/W2009825892","https://openalex.org/W2062090834","https://openalex.org/W2062950667","https://openalex.org/W2094945667","https://openalex.org/W2166822586","https://openalex.org/W3008255804"],"related_works":["https://openalex.org/W2095136535","https://openalex.org/W2398885444","https://openalex.org/W3036964893","https://openalex.org/W2005083846","https://openalex.org/W1601811574","https://openalex.org/W1575522358","https://openalex.org/W4243145104","https://openalex.org/W4251916054","https://openalex.org/W1886401053","https://openalex.org/W1550049051"],"abstract_inverted_index":{"Abstract":[0],"We":[1,30],"study":[2],"the":[3,15,42],"type":[4,11,43,53],"inference":[5,54],"problem":[6],"for":[7,62],"a":[8,38,46,68],"system":[9],"with":[10,28,79],"classes":[12,21],"as":[13],"in":[14,45],"functional":[16],"programming":[17],"language":[18],"Haskell.":[19],"Type":[20],"are":[22],"an":[23,74,89],"extension":[24,75],"of":[25,76,84,91],"ML-style":[26],"polymorphism":[27,35],"overloading.":[29],"generalize":[31],"Milner's":[32],"work":[33],"on":[34],"by":[36],"introducing":[37],"separate":[39],"context":[40],"constraining":[41],"variables":[44],"typing":[47],"judgement.":[48],"This":[49],"leads":[50],"to":[51],"simple":[52],"systems":[55],"and":[56],"algorithms":[57],"which":[58,72],"closely":[59],"resemble":[60],"those":[61],"ML.":[63],"In":[64],"particular,":[65],"we":[66],"present":[67],"new":[69],"unification":[70,78,93],"algorithm":[71],"is":[73],"syntactic":[77],"constraint":[80],"solving.":[81],"The":[82],"existence":[83],"principal":[85],"types":[86],"follows":[87],"from":[88],"analysis":[90],"this":[92],"algorithm.":[94]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":5},{"year":2020,"cited_by_count":1},{"year":2016,"cited_by_count":1}],"updated_date":"2026-05-21T09:19:25.381259","created_date":"2025-10-10T00:00:00"}
