{"id":"https://openalex.org/W2918429258","doi":"https://doi.org/10.1145/3285955","title":"Practical Subtyping for Curry-Style Languages","display_name":"Practical Subtyping for Curry-Style Languages","publication_year":2019,"publication_date":"2019-02-28","ids":{"openalex":"https://openalex.org/W2918429258","doi":"https://doi.org/10.1145/3285955","mag":"2918429258"},"language":"en","primary_location":{"id":"doi:10.1145/3285955","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3285955","pdf_url":null,"source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"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":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Programming Languages and Systems","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/A5068441844","display_name":"Rodolphe Lepigre","orcid":"https://orcid.org/0000-0002-2849-5338"},"institutions":[{"id":"https://openalex.org/I70900168","display_name":"Universit\u00e9 Savoie Mont Blanc","ror":"https://ror.org/04gqg1a07","country_code":"FR","type":"education","lineage":["https://openalex.org/I70900168"]},{"id":"https://openalex.org/I277688954","display_name":"Universit\u00e9 Paris-Saclay","ror":"https://ror.org/03xjwb503","country_code":"FR","type":"education","lineage":["https://openalex.org/I277688954"]},{"id":"https://openalex.org/I1294671590","display_name":"Centre National de la Recherche Scientifique","ror":"https://ror.org/02feahw73","country_code":"FR","type":"funder","lineage":["https://openalex.org/I1294671590"]}],"countries":["FR"],"is_corresponding":true,"raw_author_name":"Rodolphe Lepigre","raw_affiliation_strings":["LAMA, CNRS, Univ. Savoie Mont Blanc and Inria, LSV, CNRS, Univ. Paris-Saclay"],"affiliations":[{"raw_affiliation_string":"LAMA, CNRS, Univ. Savoie Mont Blanc and Inria, LSV, CNRS, Univ. Paris-Saclay","institution_ids":["https://openalex.org/I70900168","https://openalex.org/I277688954","https://openalex.org/I1294671590"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5037552568","display_name":"Christophe Raffalli","orcid":null},"institutions":[{"id":"https://openalex.org/I70900168","display_name":"Universit\u00e9 Savoie Mont Blanc","ror":"https://ror.org/04gqg1a07","country_code":"FR","type":"education","lineage":["https://openalex.org/I70900168"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"Christophe Raffalli","raw_affiliation_strings":["LAMA, CNRS, Univ. Savoie Mont Blanc and IMERL, FING, UdelaR"],"affiliations":[{"raw_affiliation_string":"LAMA, CNRS, Univ. Savoie Mont Blanc and IMERL, FING, UdelaR","institution_ids":["https://openalex.org/I70900168"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5068441844"],"corresponding_institution_ids":["https://openalex.org/I1294671590","https://openalex.org/I277688954","https://openalex.org/I70900168"],"apc_list":null,"apc_paid":null,"fwci":0.7001,"has_fulltext":false,"cited_by_count":9,"citation_normalized_percentile":{"value":0.77021457,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":"41","issue":"1","first_page":"1","last_page":"58"},"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/T11567","display_name":"semigroups and automata theory","score":0.9973999857902527,"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/T10142","display_name":"Formal Methods in Verification","score":0.9973000288009644,"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/subtyping","display_name":"Subtyping","score":0.873364269733429},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8680861592292786},{"id":"https://openalex.org/keywords/curry","display_name":"Curry","score":0.6916226744651794},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.673882007598877},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.5977805852890015},{"id":"https://openalex.org/keywords/coinduction","display_name":"Coinduction","score":0.5959011316299438},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.5753298401832581},{"id":"https://openalex.org/keywords/gas-meter-prover","display_name":"Gas meter prover","score":0.5038661360740662},{"id":"https://openalex.org/keywords/separation-logic","display_name":"Separation logic","score":0.5012080669403076},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4759378433227539},{"id":"https://openalex.org/keywords/recursion","display_name":"Recursion (computer science)","score":0.4597357511520386},{"id":"https://openalex.org/keywords/fragment","display_name":"Fragment (logic)","score":0.4516420364379883},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.420302152633667},{"id":"https://openalex.org/keywords/syntax","display_name":"Syntax","score":0.41983819007873535},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.21101689338684082},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.13446038961410522},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.11111792922019958}],"concepts":[{"id":"https://openalex.org/C83852419","wikidata":"https://www.wikidata.org/wiki/Q2713292","display_name":"Subtyping","level":2,"score":0.873364269733429},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8680861592292786},{"id":"https://openalex.org/C2781029818","wikidata":"https://www.wikidata.org/wiki/Q2368856","display_name":"Curry","level":2,"score":0.6916226744651794},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.673882007598877},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.5977805852890015},{"id":"https://openalex.org/C40220748","wikidata":"https://www.wikidata.org/wiki/Q4227156","display_name":"Coinduction","level":3,"score":0.5959011316299438},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.5753298401832581},{"id":"https://openalex.org/C159718280","wikidata":"https://www.wikidata.org/wiki/Q5526353","display_name":"Gas meter prover","level":3,"score":0.5038661360740662},{"id":"https://openalex.org/C173856430","wikidata":"https://www.wikidata.org/wiki/Q3257964","display_name":"Separation logic","level":2,"score":0.5012080669403076},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4759378433227539},{"id":"https://openalex.org/C168773036","wikidata":"https://www.wikidata.org/wiki/Q264164","display_name":"Recursion (computer science)","level":2,"score":0.4597357511520386},{"id":"https://openalex.org/C2776235265","wikidata":"https://www.wikidata.org/wiki/Q18392052","display_name":"Fragment (logic)","level":2,"score":0.4516420364379883},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.420302152633667},{"id":"https://openalex.org/C60048249","wikidata":"https://www.wikidata.org/wiki/Q37437","display_name":"Syntax","level":2,"score":0.41983819007873535},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.21101689338684082},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.13446038961410522},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.11111792922019958},{"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/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/3285955","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3285955","pdf_url":null,"source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"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":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Programming Languages and Systems","raw_type":"journal-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":58,"referenced_works":["https://openalex.org/W80198721","https://openalex.org/W132160668","https://openalex.org/W159715351","https://openalex.org/W177558105","https://openalex.org/W561582471","https://openalex.org/W1485257692","https://openalex.org/W1505308924","https://openalex.org/W1556186310","https://openalex.org/W1556705528","https://openalex.org/W1556837122","https://openalex.org/W1557561422","https://openalex.org/W1572791825","https://openalex.org/W1573947311","https://openalex.org/W1575501012","https://openalex.org/W1595372275","https://openalex.org/W1802897460","https://openalex.org/W1820801715","https://openalex.org/W1883955460","https://openalex.org/W1975801890","https://openalex.org/W1975810242","https://openalex.org/W1982209843","https://openalex.org/W1993129359","https://openalex.org/W1993209012","https://openalex.org/W2004778262","https://openalex.org/W2010611844","https://openalex.org/W2029129011","https://openalex.org/W2070188769","https://openalex.org/W2072898606","https://openalex.org/W2076653850","https://openalex.org/W2080040385","https://openalex.org/W2081602857","https://openalex.org/W2085552917","https://openalex.org/W2121890673","https://openalex.org/W2123727486","https://openalex.org/W2130303109","https://openalex.org/W2131916293","https://openalex.org/W2150421116","https://openalex.org/W2161193752","https://openalex.org/W2163976959","https://openalex.org/W2165657834","https://openalex.org/W2171496589","https://openalex.org/W2190514756","https://openalex.org/W2269103951","https://openalex.org/W2276009245","https://openalex.org/W2294653671","https://openalex.org/W2336116580","https://openalex.org/W2398808383","https://openalex.org/W2538330629","https://openalex.org/W2553042017","https://openalex.org/W2563592207","https://openalex.org/W2901643300","https://openalex.org/W2963645437","https://openalex.org/W3093702553","https://openalex.org/W3098870812","https://openalex.org/W3098977388","https://openalex.org/W3180721729","https://openalex.org/W4255950761","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W2788182112","https://openalex.org/W416465950","https://openalex.org/W2886069053","https://openalex.org/W2467505627","https://openalex.org/W1516521788","https://openalex.org/W2520914166","https://openalex.org/W2911376640","https://openalex.org/W1590842522","https://openalex.org/W1606874744","https://openalex.org/W2918429258"],"abstract_inverted_index":{"We":[0,115],"present":[1],"a":[2,14,22,77,139],"new,":[3],"syntax-directed":[4],"framework":[5],"for":[6,21],"Curry-style":[7],"type":[8],"systems":[9],"with":[10,87],"subtyping.":[11],"It":[12],"supports":[13],"rich":[15],"set":[16],"of":[17,61,68,102,111,121,148],"features,":[18],"and":[19,26,34,38,41,43,93,99],"allows":[20],"reasonably":[23],"simple":[24],"theory":[25],"implementation.":[27],"The":[28,46,84],"system":[29,85],"we":[30,151],"consider":[31],"has":[32],"sum":[33],"product":[35],"types,":[36],"universal":[37],"existential":[39],"quantifiers,":[40],"inductive":[42],"coinductive":[44],"types.":[45],"latter":[47],"two":[48],"may":[49],"carry":[50],"size":[51,112],"invariants":[52],"that":[53,75,127],"can":[54,70],"be":[55,71],"used":[56],"to":[57,107],"establish":[58],"the":[59,66,103,109,119,146,149,157,161],"termination":[60,67,120],"recursive":[62],"programs.":[63],"For":[64],"example,":[65],"quicksort":[69],"derived":[72],"by":[73],"showing":[74],"partitioning":[76],"list":[78],"does":[79],"not":[80,117],"increase":[81],"its":[82],"size.":[83],"deals":[86],"complex":[88],"programs":[89,122],"involving":[90],"mixed":[91,97],"induction":[92],"coinduction,":[94],"or":[95],"even":[96],"polymorphism":[98],"(co-)induction.":[100],"One":[101],"key":[104],"ideas":[105],"is":[106,135],"separate":[108],"notion":[110],"from":[113],"recursion.":[114],"do":[116],"check":[118],"directly,":[123],"but":[124],"rather":[125],"show":[126],"their":[128],"(circular)":[129],"typing":[130],"proofs":[131],"are":[132],"well-founded.":[133],"Termination":[134],"then":[136],"obtained":[137],"using":[138],"standard":[140],"(semantic)":[141],"normalisation":[142],"proof.":[143],"To":[144],"demonstrate":[145],"practicality":[147],"system,":[150],"provide":[152],"an":[153],"implementation":[154],"accepting":[155],"all":[156],"examples":[158],"discussed":[159],"in":[160],"article.":[162]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":2},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":2},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
