{"id":"https://openalex.org/W2067195533","doi":"https://doi.org/10.1145/2804302.2804305","title":"A typechecker plugin for units of measure: domain-specific constraint solving in GHC Haskell","display_name":"A typechecker plugin for units of measure: domain-specific constraint solving in GHC Haskell","publication_year":2015,"publication_date":"2015-08-24","ids":{"openalex":"https://openalex.org/W2067195533","doi":"https://doi.org/10.1145/2804302.2804305","mag":"2067195533"},"language":"en","primary_location":{"id":"doi:10.1145/2804302.2804305","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804305","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN 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/A5108588374","display_name":"Adam Gundry","orcid":null},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Adam Gundry","raw_affiliation_strings":["Well-Typed, UK"],"affiliations":[{"raw_affiliation_string":"Well-Typed, UK","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":0,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5108588374"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":3.883,"has_fulltext":false,"cited_by_count":21,"citation_normalized_percentile":{"value":0.94080374,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"11","last_page":"22"},"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.9998000264167786,"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.9998000264167786,"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.9976999759674072,"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.9926000237464905,"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.9721566438674927},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8495639562606812},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7742034792900085},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.7473111748695374},{"id":"https://openalex.org/keywords/plug-in","display_name":"Plug-in","score":0.5943673253059387},{"id":"https://openalex.org/keywords/measure","display_name":"Measure (data warehouse)","score":0.5147387981414795},{"id":"https://openalex.org/keywords/constraint","display_name":"Constraint (computer-aided design)","score":0.4853917360305786},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.48342978954315186},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.4456261396408081},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.44503486156463623},{"id":"https://openalex.org/keywords/compile-time","display_name":"Compile time","score":0.41687339544296265},{"id":"https://openalex.org/keywords/usability","display_name":"Usability","score":0.4132496118545532},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.10969719290733337},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.09568098187446594},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.0855703055858612}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9721566438674927},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8495639562606812},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7742034792900085},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.7473111748695374},{"id":"https://openalex.org/C4924752","wikidata":"https://www.wikidata.org/wiki/Q184148","display_name":"Plug-in","level":2,"score":0.5943673253059387},{"id":"https://openalex.org/C2780009758","wikidata":"https://www.wikidata.org/wiki/Q6804172","display_name":"Measure (data warehouse)","level":2,"score":0.5147387981414795},{"id":"https://openalex.org/C2776036281","wikidata":"https://www.wikidata.org/wiki/Q48769818","display_name":"Constraint (computer-aided design)","level":2,"score":0.4853917360305786},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.48342978954315186},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.4456261396408081},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.44503486156463623},{"id":"https://openalex.org/C200833197","wikidata":"https://www.wikidata.org/wiki/Q333707","display_name":"Compile time","level":3,"score":0.41687339544296265},{"id":"https://openalex.org/C170130773","wikidata":"https://www.wikidata.org/wiki/Q216378","display_name":"Usability","level":2,"score":0.4132496118545532},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.10969719290733337},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.09568098187446594},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0855703055858612},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2804302.2804305","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804305","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":19,"referenced_works":["https://openalex.org/W775976006","https://openalex.org/W1692016514","https://openalex.org/W1971373556","https://openalex.org/W1982230416","https://openalex.org/W2042010295","https://openalex.org/W2045900383","https://openalex.org/W2046290385","https://openalex.org/W2069858276","https://openalex.org/W2093896470","https://openalex.org/W2104644663","https://openalex.org/W2106226553","https://openalex.org/W2112474400","https://openalex.org/W2118349261","https://openalex.org/W2125690388","https://openalex.org/W2129943248","https://openalex.org/W2134394225","https://openalex.org/W2145287505","https://openalex.org/W2146749715","https://openalex.org/W4213090963"],"related_works":["https://openalex.org/W2046806568","https://openalex.org/W2112263414","https://openalex.org/W1602185604","https://openalex.org/W3004782279","https://openalex.org/W2028779182","https://openalex.org/W4242678340","https://openalex.org/W2371266106","https://openalex.org/W2140654465","https://openalex.org/W2129253059","https://openalex.org/W2090337950"],"abstract_inverted_index":{"Typed":[0],"functional":[1],"programming":[2],"and":[3],"units":[4,18,78],"of":[5,30,50,79,99],"measure":[6,80],"are":[7],"a":[8,40,48,82,95],"natural":[9],"combination,":[10],"as":[11,81],"F#":[12],"ably":[13],"demonstrates.":[14],"However,":[15],"encoding":[16],"statically-checked":[17],"in":[19,60,102],"Haskell\u2019s":[20],"type":[21,83],"system":[22,84],"leads":[23],"to":[24,67,76],"inevitable":[25],"disappointment":[26],"with":[27],"the":[28,31,35,61,88,92],"usability":[29],"resulting":[32],"system.":[33],"Extending":[34],"language":[36],"itself":[37],"would":[38,46],"produce":[39],"much":[41],"better":[42],"result,":[43],"but":[44],"it":[45,74],"be":[47],"lot":[49],"work!":[51],"In":[52],"this":[53],"paper,":[54],"I":[55],"demonstrate":[56],"how":[57],"typechecker":[58],"plugins":[59],"Glasgow":[62],"Haskell":[63],"Compiler":[64],"allow":[65],"users":[66],"define":[68],"domain-specific":[69],"constraint":[70,100],"solving":[71,101],"behaviour,":[72],"making":[73],"possible":[75],"implement":[77],"extension":[85],"without":[86],"rebuilding":[87],"compiler.":[89],"This":[90],"paves":[91],"way":[93],"for":[94],"more":[96],"modular":[97],"treatment":[98],"GHC.":[103]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2023,"cited_by_count":4},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":1},{"year":2019,"cited_by_count":4},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":4},{"year":2015,"cited_by_count":2}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
