{"id":"https://openalex.org/W2979520889","doi":"https://doi.org/10.1145/3360557","title":"Refinement kinds: type-safe programming with practical type-level computation","display_name":"Refinement kinds: type-safe programming with practical type-level computation","publication_year":2019,"publication_date":"2019-10-10","ids":{"openalex":"https://openalex.org/W2979520889","doi":"https://doi.org/10.1145/3360557","mag":"2979520889"},"language":"en","primary_location":{"id":"doi:10.1145/3360557","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3360557","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3360557","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/3360557","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5019928703","display_name":"Lu\u0131\u0301s Caires","orcid":"https://orcid.org/0000-0002-3215-6734"},"institutions":[{"id":"https://openalex.org/I83558840","display_name":"Universidade Nova de Lisboa","ror":"https://ror.org/02xankh89","country_code":"PT","type":"education","lineage":["https://openalex.org/I83558840"]},{"id":"https://openalex.org/I141596103","display_name":"University of Lisbon","ror":"https://ror.org/01c27hj86","country_code":"PT","type":"education","lineage":["https://openalex.org/I141596103"]}],"countries":["PT"],"is_corresponding":true,"raw_author_name":"Lu\u00eds Caires","raw_affiliation_strings":["Nova University of Lisbon, Portugal / NOVA-LINCS, Portugal"],"affiliations":[{"raw_affiliation_string":"Nova University of Lisbon, Portugal / NOVA-LINCS, Portugal","institution_ids":["https://openalex.org/I83558840","https://openalex.org/I141596103"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5039596448","display_name":"Bernardo Toninho","orcid":"https://orcid.org/0000-0002-0746-7514"},"institutions":[{"id":"https://openalex.org/I141596103","display_name":"University of Lisbon","ror":"https://ror.org/01c27hj86","country_code":"PT","type":"education","lineage":["https://openalex.org/I141596103"]},{"id":"https://openalex.org/I83558840","display_name":"Universidade Nova de Lisboa","ror":"https://ror.org/02xankh89","country_code":"PT","type":"education","lineage":["https://openalex.org/I83558840"]}],"countries":["PT"],"is_corresponding":false,"raw_author_name":"Bernardo Toninho","raw_affiliation_strings":["Nova University of Lisbon, Portugal / NOVA-LINCS, Portugal"],"affiliations":[{"raw_affiliation_string":"Nova University of Lisbon, Portugal / NOVA-LINCS, Portugal","institution_ids":["https://openalex.org/I83558840","https://openalex.org/I141596103"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5019928703"],"corresponding_institution_ids":["https://openalex.org/I141596103","https://openalex.org/I83558840"],"apc_list":null,"apc_paid":null,"fwci":0.4335,"has_fulltext":true,"cited_by_count":4,"citation_normalized_percentile":{"value":0.72523237,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":"3","issue":"OOPSLA","first_page":"1","last_page":"30"},"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/T10639","display_name":"Advanced Software Engineering Methodologies","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/T10260","display_name":"Software Engineering Research","score":0.9962999820709229,"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/computer-science","display_name":"Computer science","score":0.8313562870025635},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.8127968311309814},{"id":"https://openalex.org/keywords/type-safety","display_name":"Type safety","score":0.7827708721160889},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.6033867001533508},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.5884764790534973},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.5392360687255859},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.5068777203559875},{"id":"https://openalex.org/keywords/domain-specific-language","display_name":"Domain-specific language","score":0.49269798398017883},{"id":"https://openalex.org/keywords/metaprogramming","display_name":"Metaprogramming","score":0.48040154576301575},{"id":"https://openalex.org/keywords/abstract-data-type","display_name":"Abstract data type","score":0.4752078950405121},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.44470348954200745},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.44134968519210815},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.43945181369781494},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.4233788847923279},{"id":"https://openalex.org/keywords/computation","display_name":"Computation","score":0.41493383049964905},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.41229328513145447},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.23525935411453247},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.09991031885147095}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8313562870025635},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8127968311309814},{"id":"https://openalex.org/C44779574","wikidata":"https://www.wikidata.org/wiki/Q736866","display_name":"Type safety","level":2,"score":0.7827708721160889},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.6033867001533508},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.5884764790534973},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.5392360687255859},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.5068777203559875},{"id":"https://openalex.org/C135257023","wikidata":"https://www.wikidata.org/wiki/Q691358","display_name":"Domain-specific language","level":2,"score":0.49269798398017883},{"id":"https://openalex.org/C35390924","wikidata":"https://www.wikidata.org/wiki/Q661075","display_name":"Metaprogramming","level":2,"score":0.48040154576301575},{"id":"https://openalex.org/C175971053","wikidata":"https://www.wikidata.org/wiki/Q827335","display_name":"Abstract data type","level":2,"score":0.4752078950405121},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.44470348954200745},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.44134968519210815},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.43945181369781494},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.4233788847923279},{"id":"https://openalex.org/C45374587","wikidata":"https://www.wikidata.org/wiki/Q12525525","display_name":"Computation","level":2,"score":0.41493383049964905},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.41229328513145447},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.23525935411453247},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.09991031885147095},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"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/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.0},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3360557","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3360557","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3360557","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"},{"id":"pmh:oai:run.unl.pt:10362/107255","is_oa":true,"landing_page_url":"http://hdl.handle.net/10362/107255","pdf_url":null,"source":{"id":"https://openalex.org/S4306400678","display_name":"Universidade Nova de Lisboa's Repository (Universidade Nova de Lisboa)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I83558840","host_organization_name":"Universidade Nova de Lisboa","host_organization_lineage":["https://openalex.org/I83558840"],"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":null,"raw_type":"article"}],"best_oa_location":{"id":"doi:10.1145/3360557","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3360557","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3360557","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/G5766540765","display_name":null,"funder_award_id":"UID/CEC/04516/2019","funder_id":"https://openalex.org/F4320331406","funder_display_name":"NOVA Laboratory for Computer Science and Informatics"}],"funders":[{"id":"https://openalex.org/F4320331406","display_name":"NOVA Laboratory for Computer Science and Informatics","ror":null}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2979520889.pdf","grobid_xml":"https://content.openalex.org/works/W2979520889.grobid-xml"},"referenced_works_count":46,"referenced_works":["https://openalex.org/W146479950","https://openalex.org/W1480909796","https://openalex.org/W1481180394","https://openalex.org/W1553136405","https://openalex.org/W1557561422","https://openalex.org/W1560253649","https://openalex.org/W1575675278","https://openalex.org/W1578113853","https://openalex.org/W1589398330","https://openalex.org/W1968424997","https://openalex.org/W1987203566","https://openalex.org/W1989916808","https://openalex.org/W2022300126","https://openalex.org/W2024914463","https://openalex.org/W2036961426","https://openalex.org/W2037575886","https://openalex.org/W2043416466","https://openalex.org/W2045900383","https://openalex.org/W2047497632","https://openalex.org/W2054969282","https://openalex.org/W2058162377","https://openalex.org/W2059895047","https://openalex.org/W2081109124","https://openalex.org/W2095136535","https://openalex.org/W2097047741","https://openalex.org/W2098095758","https://openalex.org/W2101085206","https://openalex.org/W2102866602","https://openalex.org/W2109518186","https://openalex.org/W2125995229","https://openalex.org/W2128057448","https://openalex.org/W2135322712","https://openalex.org/W2135389226","https://openalex.org/W2145287505","https://openalex.org/W2146306932","https://openalex.org/W2154005761","https://openalex.org/W2161017670","https://openalex.org/W2295923951","https://openalex.org/W2340618214","https://openalex.org/W2386500332","https://openalex.org/W2899873839","https://openalex.org/W2963384924","https://openalex.org/W2963483933","https://openalex.org/W2964853020","https://openalex.org/W4240226860","https://openalex.org/W4246691913"],"related_works":["https://openalex.org/W2157155332","https://openalex.org/W1480879962","https://openalex.org/W2112150205","https://openalex.org/W4245886278","https://openalex.org/W2151275061","https://openalex.org/W2156830909","https://openalex.org/W2964853020","https://openalex.org/W4288269312","https://openalex.org/W2118227920","https://openalex.org/W2979520889"],"abstract_inverted_index":{"This":[0],"work":[1],"introduces":[2],"the":[3,14,43,59,103,151],"novel":[4],"concept":[5],"of":[6,16,34,54,113,155,163],"kind":[7,46,50,60,67,165],"refinement":[8,66],",":[9],"which":[10,121],"we":[11],"develop":[12],"in":[13,42,58,70,125,133,137],"context":[15],"an":[17],"explicitly":[18],"polymorphic":[19],"ML-like":[20],"language":[21,72],"with":[22,92],"type-level":[23],"computation.":[24],"Just":[25],"as":[26,88],"type":[27,44,114,156,167],"refinements":[28,47],"embed":[29],"rich":[30,49],"specifications":[31,51],"by":[32,38,52,96,149],"means":[33,53],"comprehension":[35],"principles":[36],"expressed":[37],"predicates":[39,55],"over":[40,56],"values":[41],"domain,":[45],"provide":[48],"types":[57,69],"domain.":[61],"By":[62],"leveraging":[63],"our":[64,71,143,172],"powerful":[65,111],"discipline,":[68],"are":[73,122],"not":[74,130],"just":[75],"used":[76],"to":[77],"statically":[78],"classify":[79],"program":[80],"expressions":[81],"and":[82,106,118,147,158,169],"values,":[83],"but":[84,129],"also":[85],"conveniently":[86],"manipulated":[87],"tree-like":[89],"data":[90],"structures,":[91],"their":[93],"kinds":[94],"refined":[95],"logical":[97],"constraints":[98],"on":[99],"such":[100],"structures.":[101],"Remarkably,":[102],"resulting":[104],"typing":[105],"kinding":[107],"disciplines":[108],"allow":[109],"for":[110,171],"forms":[112],"reflection,":[115],"ad-hoc":[116],"polymorphism":[117],"type-directed":[119],"meta-programming,":[120],"often":[123],"found":[124],"modern":[126],"software":[127],"development,":[128],"typically":[131],"expressible":[132],"a":[134,160,164],"type-safe":[135],"manner":[136],"general":[138],"purpose":[139],"languages.":[140],"We":[141],"validate":[142],"approach":[144],"both":[145],"formally":[146],"pragmatically":[148],"establishing":[150],"standard":[152],"meta-theoretical":[153],"results":[154],"safety":[157],"via":[159],"prototype":[161],"implementation":[162],"checker,":[166],"checker":[168],"interpreter":[170],"language.":[173]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":1}],"updated_date":"2026-04-12T07:58:50.170612","created_date":"2025-10-10T00:00:00"}
