{"id":"https://openalex.org/W2791587639","doi":"https://doi.org/10.1145/3236799","title":"Generic zero-cost reuse for dependent types","display_name":"Generic zero-cost reuse for dependent types","publication_year":2018,"publication_date":"2018-07-30","ids":{"openalex":"https://openalex.org/W2791587639","doi":"https://doi.org/10.1145/3236799","mag":"2791587639"},"language":"en","primary_location":{"id":"doi:10.1145/3236799","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3236799","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3236799","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":"preprint","indexed_in":["arxiv","crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3236799","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5016293832","display_name":"Larry Diehl","orcid":null},"institutions":[{"id":"https://openalex.org/I126307644","display_name":"University of Iowa","ror":"https://ror.org/036jqmy94","country_code":"US","type":"education","lineage":["https://openalex.org/I126307644"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Larry Diehl","raw_affiliation_strings":["University of Iowa, USA","University of Iowa, USA >  >  >  >"],"affiliations":[{"raw_affiliation_string":"University of Iowa, USA","institution_ids":["https://openalex.org/I126307644"]},{"raw_affiliation_string":"University of Iowa, USA >  >  >  >","institution_ids":["https://openalex.org/I126307644"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5023524127","display_name":"Denis Firsov","orcid":"https://orcid.org/0000-0003-1267-7898"},"institutions":[{"id":"https://openalex.org/I126307644","display_name":"University of Iowa","ror":"https://ror.org/036jqmy94","country_code":"US","type":"education","lineage":["https://openalex.org/I126307644"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Denis Firsov","raw_affiliation_strings":["University of Iowa, USA","University of Iowa, USA >  >  >  >"],"affiliations":[{"raw_affiliation_string":"University of Iowa, USA","institution_ids":["https://openalex.org/I126307644"]},{"raw_affiliation_string":"University of Iowa, USA >  >  >  >","institution_ids":["https://openalex.org/I126307644"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5072489480","display_name":"Aaron Stump","orcid":"https://orcid.org/0000-0002-9720-0003"},"institutions":[{"id":"https://openalex.org/I126307644","display_name":"University of Iowa","ror":"https://ror.org/036jqmy94","country_code":"US","type":"education","lineage":["https://openalex.org/I126307644"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Aaron Stump","raw_affiliation_strings":["University of Iowa, USA","University of Iowa, USA >  >  >  >"],"affiliations":[{"raw_affiliation_string":"University of Iowa, USA","institution_ids":["https://openalex.org/I126307644"]},{"raw_affiliation_string":"University of Iowa, USA >  >  >  >","institution_ids":["https://openalex.org/I126307644"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5016293832"],"corresponding_institution_ids":["https://openalex.org/I126307644"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.03182046,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"2","issue":"ICFP","first_page":"1","last_page":"30"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10317","display_name":"Advanced Database Systems and Queries","score":0.9976000189781189,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/T10317","display_name":"Advanced Database Systems and Queries","score":0.9976000189781189,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/T10126","display_name":"Logic, programming, and type systems","score":0.9952999949455261,"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/T11986","display_name":"Scientific Computing and Data Management","score":0.9848999977111816,"subfield":{"id":"https://openalex.org/subfields/1802","display_name":"Information Systems and Management"},"field":{"id":"https://openalex.org/fields/18","display_name":"Decision Sciences"},"domain":{"id":"https://openalex.org/domains/2","display_name":"Social Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/code-reuse","display_name":"Code reuse","score":0.7400347590446472},{"id":"https://openalex.org/keywords/reuse","display_name":"Reuse","score":0.70389723777771},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.683928906917572},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6295573115348816},{"id":"https://openalex.org/keywords/zero","display_name":"Zero (linguistics)","score":0.5479934811592102},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5149205923080444},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.5072428584098816},{"id":"https://openalex.org/keywords/exploit","display_name":"Exploit","score":0.49726584553718567},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.4481903910636902},{"id":"https://openalex.org/keywords/identity","display_name":"Identity (music)","score":0.44723302125930786},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.44644874334335327},{"id":"https://openalex.org/keywords/term","display_name":"Term (time)","score":0.425079345703125},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3621330261230469},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.32372140884399414},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.13545024394989014},{"id":"https://openalex.org/keywords/linguistics","display_name":"Linguistics","score":0.07954877614974976},{"id":"https://openalex.org/keywords/engineering","display_name":"Engineering","score":0.06666085124015808}],"concepts":[{"id":"https://openalex.org/C2778583558","wikidata":"https://www.wikidata.org/wiki/Q771245","display_name":"Code reuse","level":3,"score":0.7400347590446472},{"id":"https://openalex.org/C206588197","wikidata":"https://www.wikidata.org/wiki/Q846574","display_name":"Reuse","level":2,"score":0.70389723777771},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.683928906917572},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6295573115348816},{"id":"https://openalex.org/C2780813799","wikidata":"https://www.wikidata.org/wiki/Q3274237","display_name":"Zero (linguistics)","level":2,"score":0.5479934811592102},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5149205923080444},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.5072428584098816},{"id":"https://openalex.org/C165696696","wikidata":"https://www.wikidata.org/wiki/Q11287","display_name":"Exploit","level":2,"score":0.49726584553718567},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.4481903910636902},{"id":"https://openalex.org/C2778355321","wikidata":"https://www.wikidata.org/wiki/Q17079427","display_name":"Identity (music)","level":2,"score":0.44723302125930786},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.44644874334335327},{"id":"https://openalex.org/C61797465","wikidata":"https://www.wikidata.org/wiki/Q1188986","display_name":"Term (time)","level":2,"score":0.425079345703125},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3621330261230469},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.32372140884399414},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.13545024394989014},{"id":"https://openalex.org/C41895202","wikidata":"https://www.wikidata.org/wiki/Q8162","display_name":"Linguistics","level":1,"score":0.07954877614974976},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.06666085124015808},{"id":"https://openalex.org/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C548081761","wikidata":"https://www.wikidata.org/wiki/Q180388","display_name":"Waste management","level":1,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","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/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C24890656","wikidata":"https://www.wikidata.org/wiki/Q82811","display_name":"Acoustics","level":1,"score":0.0},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/3236799","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3236799","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3236799","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:arXiv.org:1803.08150","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1803.08150","pdf_url":"https://arxiv.org/pdf/1803.08150","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"text"},{"id":"mag:2791587639","is_oa":true,"landing_page_url":"https://arxiv.org/pdf/1803.08150v3","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"arXiv (Cornell University)","raw_type":null},{"id":"doi:10.48550/arxiv.1803.08150","is_oa":true,"landing_page_url":"https://doi.org/10.48550/arxiv.1803.08150","pdf_url":null,"source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article"}],"best_oa_location":{"id":"doi:10.1145/3236799","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3236799","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3236799","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/16","score":0.41999998688697815,"display_name":"Peace, Justice and strong institutions"}],"awards":[{"id":"https://openalex.org/G8023920682","display_name":null,"funder_award_id":"1524519","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320333591","display_name":"Multidisciplinary University Research Initiative","ror":null}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2791587639.pdf","grobid_xml":"https://content.openalex.org/works/W2791587639.grobid-xml"},"referenced_works_count":13,"referenced_works":["https://openalex.org/W124942006","https://openalex.org/W1464569014","https://openalex.org/W1993209012","https://openalex.org/W2013149027","https://openalex.org/W2021478277","https://openalex.org/W2055372384","https://openalex.org/W2062887328","https://openalex.org/W2115699102","https://openalex.org/W2145108549","https://openalex.org/W2413556709","https://openalex.org/W2500959965","https://openalex.org/W2613133382","https://openalex.org/W2777856819"],"related_works":["https://openalex.org/W2912842069","https://openalex.org/W2128235835","https://openalex.org/W2132558197","https://openalex.org/W1985791647","https://openalex.org/W2021478277","https://openalex.org/W44613125","https://openalex.org/W2003776467","https://openalex.org/W2019388039","https://openalex.org/W2150895128","https://openalex.org/W2296612922","https://openalex.org/W2293786458","https://openalex.org/W2048536148","https://openalex.org/W2293338131","https://openalex.org/W2014995396","https://openalex.org/W2965145471","https://openalex.org/W3143492078","https://openalex.org/W2973834791","https://openalex.org/W1997354605","https://openalex.org/W2005130481","https://openalex.org/W2779172326"],"abstract_inverted_index":{"Dependently":[0],"typed":[1,86,120],"languages":[2],"are":[3,29],"well":[4],"known":[5],"for":[6,32,81],"having":[7],"a":[8,21,45,53,74,110,135],"problem":[9,83],"with":[10],"code":[11,48],"reuse.":[12],"Traditional":[13],"non-indexed":[14,34,69],"algebraic":[15],"datatypes":[16],"(e.g.":[17,26],"lists)":[18],"appear":[19],"alongside":[20],"plethora":[22],"of":[23,38,47,73,84,127],"indexed":[24,36,71],"variations":[25],"vectors).":[27],"Functions":[28],"often":[30],"rewritten":[31],"both":[33,67],"and":[35,70,102,123],"versions":[37,72],"essentially":[39],"the":[40,59,68,82,125,131],"same":[41,60],"datatype,":[42],"which":[43],"is":[44,115],"source":[46],"duplication.":[49],"We":[50],"work":[51,114],"in":[52,94,118,134],"Curry-style":[54,91,136],"dependent":[55],"type":[56,92],"theory,":[57],"where":[58],"untyped":[61],"term":[62],"may":[63],"be":[64],"classified":[65],"as":[66,130],"datatype.":[75],"Many":[76],"solutions":[77],"have":[78],"been":[79],"proposed":[80],"dependently":[85,119],"reuse,":[87],"but":[88,104],"we":[89],"exploit":[90],"theory":[93],"our":[95],"solution":[96],"to":[97],"not":[98],"only":[99],"reuse":[100,129],"data":[101],"programs,":[103],"do":[105],"so":[106],"at":[107],"zero-cost":[108,128],"(without":[109],"runtime":[111],"penalty).":[112],"Our":[113],"an":[116],"exercise":[117],"generic":[121],"programming,":[122],"internalizes":[124],"process":[126],"identity":[132],"function":[133],"theory.":[137]},"counts_by_year":[],"updated_date":"2026-03-18T14:38:29.013473","created_date":"2025-10-10T00:00:00"}
