{"id":"https://openalex.org/W2996697590","doi":"https://doi.org/10.1145/3371134","title":"Decidable subtyping for path dependent types","display_name":"Decidable subtyping for path dependent types","publication_year":2019,"publication_date":"2019-12-20","ids":{"openalex":"https://openalex.org/W2996697590","doi":"https://doi.org/10.1145/3371134","mag":"2996697590"},"language":"en","primary_location":{"id":"doi:10.1145/3371134","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3371134","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3371134","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/3371134","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5072100749","display_name":"Julian Mackay","orcid":"https://orcid.org/0000-0003-3098-3901"},"institutions":[{"id":"https://openalex.org/I41156924","display_name":"Victoria University of Wellington","ror":"https://ror.org/0040r6f76","country_code":"NZ","type":"education","lineage":["https://openalex.org/I41156924"]}],"countries":["NZ"],"is_corresponding":true,"raw_author_name":"Julian Mackay","raw_affiliation_strings":["Victoria University of Wellington, New Zealand"],"affiliations":[{"raw_affiliation_string":"Victoria University of Wellington, New Zealand","institution_ids":["https://openalex.org/I41156924"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5057086547","display_name":"Alex Potanin","orcid":"https://orcid.org/0000-0002-4242-2725"},"institutions":[{"id":"https://openalex.org/I41156924","display_name":"Victoria University of Wellington","ror":"https://ror.org/0040r6f76","country_code":"NZ","type":"education","lineage":["https://openalex.org/I41156924"]}],"countries":["NZ"],"is_corresponding":false,"raw_author_name":"Alex Potanin","raw_affiliation_strings":["Victoria University of Wellington, New Zealand"],"affiliations":[{"raw_affiliation_string":"Victoria University of Wellington, New Zealand","institution_ids":["https://openalex.org/I41156924"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5091372985","display_name":"Jonathan Aldrich","orcid":"https://orcid.org/0000-0003-0631-5591"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jonathan Aldrich","raw_affiliation_strings":["Carnegie Mellon University, USA"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, USA","institution_ids":["https://openalex.org/I74973139"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5020664307","display_name":"Lindsay Groves","orcid":"https://orcid.org/0000-0002-9179-3602"},"institutions":[{"id":"https://openalex.org/I41156924","display_name":"Victoria University of Wellington","ror":"https://ror.org/0040r6f76","country_code":"NZ","type":"education","lineage":["https://openalex.org/I41156924"]}],"countries":["NZ"],"is_corresponding":false,"raw_author_name":"Lindsay Groves","raw_affiliation_strings":["Victoria University of Wellington, New Zealand"],"affiliations":[{"raw_affiliation_string":"Victoria University of Wellington, New Zealand","institution_ids":["https://openalex.org/I41156924"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5072100749"],"corresponding_institution_ids":["https://openalex.org/I41156924"],"apc_list":null,"apc_paid":null,"fwci":1.3003,"has_fulltext":true,"cited_by_count":13,"citation_normalized_percentile":{"value":0.86109557,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":97},"biblio":{"volume":"4","issue":"POPL","first_page":"1","last_page":"27"},"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.9997000098228455,"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.9997000098228455,"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.9695000052452087,"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/T11424","display_name":"Security and Verification in Computing","score":0.9634000062942505,"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/subtyping","display_name":"Subtyping","score":0.7936863899230957},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.76261305809021},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7057293653488159},{"id":"https://openalex.org/keywords/decidability","display_name":"Decidability","score":0.6578862071037292},{"id":"https://openalex.org/keywords/scala","display_name":"Scala","score":0.6472153067588806},{"id":"https://openalex.org/keywords/undecidable-problem","display_name":"Undecidable problem","score":0.6260924339294434},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.5044044256210327},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4616846442222595},{"id":"https://openalex.org/keywords/path","display_name":"Path (computing)","score":0.44353851675987244},{"id":"https://openalex.org/keywords/object-oriented-programming","display_name":"Object-oriented programming","score":0.43810731172561646},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.36187994480133057},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.20907500386238098}],"concepts":[{"id":"https://openalex.org/C83852419","wikidata":"https://www.wikidata.org/wiki/Q2713292","display_name":"Subtyping","level":2,"score":0.7936863899230957},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.76261305809021},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7057293653488159},{"id":"https://openalex.org/C153269930","wikidata":"https://www.wikidata.org/wiki/Q430001","display_name":"Decidability","level":2,"score":0.6578862071037292},{"id":"https://openalex.org/C109701466","wikidata":"https://www.wikidata.org/wiki/Q460584","display_name":"Scala","level":3,"score":0.6472153067588806},{"id":"https://openalex.org/C192034797","wikidata":"https://www.wikidata.org/wiki/Q3502995","display_name":"Undecidable problem","level":3,"score":0.6260924339294434},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.5044044256210327},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4616846442222595},{"id":"https://openalex.org/C2777735758","wikidata":"https://www.wikidata.org/wiki/Q817765","display_name":"Path (computing)","level":2,"score":0.44353851675987244},{"id":"https://openalex.org/C73752529","wikidata":"https://www.wikidata.org/wiki/Q79872","display_name":"Object-oriented programming","level":2,"score":0.43810731172561646},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.36187994480133057},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.20907500386238098},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3371134","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3371134","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3371134","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:researcharchive.vuw.ac.nz:10063/9081","is_oa":true,"landing_page_url":"http://researcharchive.vuw.ac.nz/handle/10063/9081","pdf_url":null,"source":{"id":"https://openalex.org/S4306400531","display_name":"ResearchArchive\u2013Te Puna Rangahau (Victoria University of Wellington)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I41156924","host_organization_name":"Victoria University of Wellington","host_organization_lineage":["https://openalex.org/I41156924"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Text"}],"best_oa_location":{"id":"doi:10.1145/3371134","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3371134","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3371134","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":[{"id":"https://metadata.un.org/sdg/4","display_name":"Quality Education","score":0.6000000238418579}],"awards":[{"id":"https://openalex.org/G6233772955","display_name":null,"funder_award_id":"H98230-14-C-0140","funder_id":"https://openalex.org/F4320306078","funder_display_name":"U.S. Department of Defense"}],"funders":[{"id":"https://openalex.org/F4320306078","display_name":"U.S. Department of Defense","ror":"https://ror.org/0447fe631"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2996697590.pdf","grobid_xml":"https://content.openalex.org/works/W2996697590.grobid-xml"},"referenced_works_count":15,"referenced_works":["https://openalex.org/W80700283","https://openalex.org/W1557561422","https://openalex.org/W1595372275","https://openalex.org/W1981173279","https://openalex.org/W1999662942","https://openalex.org/W2027657506","https://openalex.org/W2049773429","https://openalex.org/W2094571689","https://openalex.org/W2103094658","https://openalex.org/W2121169478","https://openalex.org/W2150101804","https://openalex.org/W2536396847","https://openalex.org/W2763459574","https://openalex.org/W2964118359","https://openalex.org/W4302984605"],"related_works":["https://openalex.org/W2972379433","https://openalex.org/W1501430220","https://openalex.org/W2989332944","https://openalex.org/W2021891065","https://openalex.org/W2583549044","https://openalex.org/W2132037187","https://openalex.org/W2119045600","https://openalex.org/W2584984136","https://openalex.org/W2962928105","https://openalex.org/W2170336571"],"abstract_inverted_index":{"Path":[0],"dependent":[1,59,99],"types":[2,60,102],"have":[3],"long":[4],"served":[5],"as":[6],"an":[7,93],"expressive":[8],"component":[9],"of":[10,20,27,52,65,85,114,125,140,147],"the":[11,18,34,63,83,128,133,137,148],"Scala":[12,149],"programming":[13,90],"language.":[14],"They":[15],"allow":[16],"for":[17,78],"modelling":[19],"both":[21,66],"bounded":[22],"polymorphism":[23,139],"and":[24,68,103],"a":[25,42,49],"degree":[26],"nominal":[28],"subtyping.":[29],"Nominality":[30],"in":[31,62],"turn":[32],"provides":[33],"ability":[35,134],"to":[36,48,135],"capture":[37],"first":[38,104],"class":[39,105],"modules.":[40,106],"Thus":[41],"single":[43],"language":[44,91,96],"feature":[45,117],"gives":[46],"rise":[47],"rich":[50],"array":[51],"expressiveness.":[53],"Recent":[54],"work":[55],"has":[56],"proven":[57],"path":[58,98],"sound":[61],"presence":[64],"intersection":[67],"recursive":[69,101],"types,":[70,100],"but":[71],"unfortunately":[72],"typing":[73],"remains":[74],"undecidable,":[75],"posing":[76],"problems":[77],"programmers":[79],"who":[80],"rely":[81],"on":[82],"results":[84],"type":[86],"checkers.":[87],"The":[88],"Wyvern":[89,115],"is":[92],"object":[94],"oriented":[95],"with":[97,121,144],"In":[107],"this":[108],"paper":[109],"we":[110],"define":[111],"two":[112],"variants":[113],"that":[116],"decidable":[118],"typing,":[119],"along":[120,143],"machine":[122],"checked":[123],"proofs":[124],"decidability.":[126],"Despite":[127],"restrictions,":[129],"our":[130],"approaches":[131],"retain":[132],"encode":[136],"parameteric":[138],"Java":[141],"generics":[142],"many":[145],"idioms":[146],"module":[150],"system.":[151]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":1},{"year":2023,"cited_by_count":2},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":3},{"year":2020,"cited_by_count":4},{"year":2019,"cited_by_count":1}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
