{"id":"https://openalex.org/W2510433231","doi":"https://doi.org/10.1145/2951913.2951925","title":"The best of both worlds: linear functional programming without compromise","display_name":"The best of both worlds: linear functional programming without compromise","publication_year":2016,"publication_date":"2016-08-29","ids":{"openalex":"https://openalex.org/W2510433231","doi":"https://doi.org/10.1145/2951913.2951925","mag":"2510433231"},"language":"en","primary_location":{"id":"doi:10.1145/2951913.2951925","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2951913.2951925","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 21st ACM SIGPLAN International Conference on Functional Programming","raw_type":"proceedings-article"},"type":"preprint","indexed_in":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://arxiv.org/pdf/1612.06633","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5067671067","display_name":"J. Garrett Morris","orcid":"https://orcid.org/0000-0002-3992-1080"},"institutions":[{"id":"https://openalex.org/I98677209","display_name":"University of Edinburgh","ror":"https://ror.org/01nrxwf90","country_code":"GB","type":"education","lineage":["https://openalex.org/I98677209"]}],"countries":["GB"],"is_corresponding":true,"raw_author_name":"J. Garrett Morris","raw_affiliation_strings":["University of Edinburgh, UK"],"affiliations":[{"raw_affiliation_string":"University of Edinburgh, UK","institution_ids":["https://openalex.org/I98677209"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5067671067"],"corresponding_institution_ids":["https://openalex.org/I98677209"],"apc_list":null,"apc_paid":null,"fwci":3.38252255,"has_fulltext":false,"cited_by_count":25,"citation_normalized_percentile":{"value":0.96543668,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"448","last_page":"461"},"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.9998999834060669,"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.9998999834060669,"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/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.9991000294685364,"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.9916999936103821,"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/functional-programming","display_name":"Functional programming","score":0.8431581258773804},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.7238361239433289},{"id":"https://openalex.org/keywords/combinatory-logic","display_name":"Combinatory logic","score":0.7189997434616089},{"id":"https://openalex.org/keywords/decidability","display_name":"Decidability","score":0.6937601566314697},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.6757085919380188},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6020843982696533},{"id":"https://openalex.org/keywords/linear-form","display_name":"Linear form","score":0.5919660329818726},{"id":"https://openalex.org/keywords/linear-logic","display_name":"Linear logic","score":0.5321466326713562},{"id":"https://openalex.org/keywords/linear-programming","display_name":"Linear programming","score":0.5307908654212952},{"id":"https://openalex.org/keywords/basis","display_name":"Basis (linear algebra)","score":0.5044773817062378},{"id":"https://openalex.org/keywords/class","display_name":"Class (philosophy)","score":0.5010673999786377},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4867803752422333},{"id":"https://openalex.org/keywords/conservative-extension","display_name":"Conservative extension","score":0.46667397022247314},{"id":"https://openalex.org/keywords/functional-principal-component-analysis","display_name":"Functional principal component analysis","score":0.4483727216720581},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.43482452630996704},{"id":"https://openalex.org/keywords/algebra-over-a-field","display_name":"Algebra over a field","score":0.3883126378059387},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.3464551568031311},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.33393409848213196},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3216164708137512},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.2866075932979584},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.21747153997421265},{"id":"https://openalex.org/keywords/principal-component-analysis","display_name":"Principal component analysis","score":0.1707182228565216},{"id":"https://openalex.org/keywords/pure-mathematics","display_name":"Pure mathematics","score":0.10814142227172852}],"concepts":[{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.8431581258773804},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.7238361239433289},{"id":"https://openalex.org/C79678938","wikidata":"https://www.wikidata.org/wiki/Q1481571","display_name":"Combinatory logic","level":2,"score":0.7189997434616089},{"id":"https://openalex.org/C153269930","wikidata":"https://www.wikidata.org/wiki/Q430001","display_name":"Decidability","level":2,"score":0.6937601566314697},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.6757085919380188},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6020843982696533},{"id":"https://openalex.org/C20050597","wikidata":"https://www.wikidata.org/wiki/Q261527","display_name":"Linear form","level":2,"score":0.5919660329818726},{"id":"https://openalex.org/C28077239","wikidata":"https://www.wikidata.org/wiki/Q841728","display_name":"Linear logic","level":2,"score":0.5321466326713562},{"id":"https://openalex.org/C41045048","wikidata":"https://www.wikidata.org/wiki/Q202843","display_name":"Linear programming","level":2,"score":0.5307908654212952},{"id":"https://openalex.org/C12426560","wikidata":"https://www.wikidata.org/wiki/Q189569","display_name":"Basis (linear algebra)","level":2,"score":0.5044773817062378},{"id":"https://openalex.org/C2777212361","wikidata":"https://www.wikidata.org/wiki/Q5127848","display_name":"Class (philosophy)","level":2,"score":0.5010673999786377},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4867803752422333},{"id":"https://openalex.org/C2780432614","wikidata":"https://www.wikidata.org/wiki/Q864213","display_name":"Conservative extension","level":2,"score":0.46667397022247314},{"id":"https://openalex.org/C71176878","wikidata":"https://www.wikidata.org/wiki/Q17014987","display_name":"Functional principal component analysis","level":3,"score":0.4483727216720581},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.43482452630996704},{"id":"https://openalex.org/C136119220","wikidata":"https://www.wikidata.org/wiki/Q1000660","display_name":"Algebra over a field","level":2,"score":0.3883126378059387},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.3464551568031311},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.33393409848213196},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3216164708137512},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.2866075932979584},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.21747153997421265},{"id":"https://openalex.org/C27438332","wikidata":"https://www.wikidata.org/wiki/Q2873","display_name":"Principal component analysis","level":2,"score":0.1707182228565216},{"id":"https://openalex.org/C202444582","wikidata":"https://www.wikidata.org/wiki/Q837863","display_name":"Pure mathematics","level":1,"score":0.10814142227172852},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"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/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"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":4,"locations":[{"id":"doi:10.1145/2951913.2951925","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2951913.2951925","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 21st ACM SIGPLAN International Conference on Functional Programming","raw_type":"proceedings-article"},{"id":"pmh:oai:arXiv.org:1612.06633","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1612.06633","pdf_url":"https://arxiv.org/pdf/1612.06633","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":null,"raw_type":"text"},{"id":"pmh:oai:pure.ed.ac.uk:openaire/e6b9902e-441b-4dec-a4b4-654b5c45812d","is_oa":true,"landing_page_url":"https://www.research.ed.ac.uk/en/publications/e6b9902e-441b-4dec-a4b4-654b5c45812d","pdf_url":null,"source":null,"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Morris, J G 2016, The Best of Both Worlds : Linear Functional Programming without Compromise. in ICFP 2016 Proceedings of the 21st ACM SIGPLAN International Conference on Functional Programming. ACM SIGPLAN Notices, no. 9, vol. 51, Nara, Japan, pp. 448-461, 21st ACM SIGPLAN International Conference on Functional Programming, Nara, Japan, 18/09/16. https://doi.org/10.1145/2951913.2951925","raw_type":"contributionToPeriodical"},{"id":"pmh:oai:pure.ed.ac.uk:publications/e6b9902e-441b-4dec-a4b4-654b5c45812d","is_oa":false,"landing_page_url":"http://dl.acm.org/citation.cfm?id=2951925","pdf_url":null,"source":{"id":"https://openalex.org/S4306400320","display_name":"Edinburgh Research Explorer (University of Edinburgh)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I98677209","host_organization_name":"University of Edinburgh","host_organization_lineage":["https://openalex.org/I98677209"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":""}],"best_oa_location":{"id":"pmh:oai:arXiv.org:1612.06633","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1612.06633","pdf_url":"https://arxiv.org/pdf/1612.06633","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":null,"raw_type":"text"},"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","score":0.6200000047683716,"id":"https://metadata.un.org/sdg/16"}],"awards":[{"id":"https://openalex.org/G1798638720","display_name":"From Data Types to Session Types---A Basis for Concurrency and Distribution","funder_award_id":"EP/K034413/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G7918631928","display_name":null,"funder_award_id":"EP/K034413/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"}],"funders":[{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":47,"referenced_works":["https://openalex.org/W20138908","https://openalex.org/W1534185537","https://openalex.org/W1543368493","https://openalex.org/W1551706119","https://openalex.org/W1553136405","https://openalex.org/W1594279870","https://openalex.org/W1607623316","https://openalex.org/W1773735832","https://openalex.org/W1861989620","https://openalex.org/W1941373452","https://openalex.org/W1967925712","https://openalex.org/W1971591193","https://openalex.org/W2008132476","https://openalex.org/W2031705219","https://openalex.org/W2033683103","https://openalex.org/W2039211229","https://openalex.org/W2054670810","https://openalex.org/W2070111977","https://openalex.org/W2093349705","https://openalex.org/W2105716349","https://openalex.org/W2116293853","https://openalex.org/W2116508343","https://openalex.org/W2118671630","https://openalex.org/W2124126159","https://openalex.org/W2137282578","https://openalex.org/W2138552902","https://openalex.org/W2142837069","https://openalex.org/W2143661661","https://openalex.org/W2145029935","https://openalex.org/W2149539253","https://openalex.org/W2152534261","https://openalex.org/W2155397441","https://openalex.org/W2168280960","https://openalex.org/W2169907127","https://openalex.org/W2293728411","https://openalex.org/W2510433231","https://openalex.org/W2561675875","https://openalex.org/W2911227993","https://openalex.org/W2911865844","https://openalex.org/W2914468402","https://openalex.org/W3141365533","https://openalex.org/W4242423436","https://openalex.org/W4252649616","https://openalex.org/W4311816262","https://openalex.org/W6697263422","https://openalex.org/W6758056613","https://openalex.org/W6791716416"],"related_works":["https://openalex.org/W2551794739","https://openalex.org/W4237113426","https://openalex.org/W2494122154","https://openalex.org/W2056592727","https://openalex.org/W2057943413","https://openalex.org/W2953724743","https://openalex.org/W585328639","https://openalex.org/W2130764601","https://openalex.org/W2510433231","https://openalex.org/W4238949052"],"abstract_inverted_index":{"We":[0,88],"present":[1],"a":[2,97,125,144],"linear":[3,13,31,40,45,68,84],"functional":[4,25,34,55,149],"calculus":[5],"with":[6,12,96],"both":[7,83],"the":[8,16,39,51,54,90,93,106,110],"safety":[9],"guarantees":[10],"expressible":[11],"types":[14,117],"and":[15,21,33,69,79,85,118,139],"rich":[17],"language":[18,142],"of":[19,30,50,65,92,100,109,112,131,147],"combinators":[20],"composition":[22],"provided":[23],"by":[24,133],"programming.":[26],"Unlike":[27],"previous":[28],"combinations":[29],"typing":[32,91],"programming,":[35],"we":[36,59,75,123],"compromise":[37],"neither":[38],"side":[41,56],"(for":[42,57],"example,":[43,58],"our":[44,129,141],"values":[46],"are":[47],"first-class":[48],"citizens":[49],"language)":[52],"nor":[53],"do":[60,73],"not":[61],"require":[62],"duplicate":[63],"definitions":[64],"compositions":[66],"for":[67,128],"unrestricted":[70,86],"functions).":[71],"To":[72],"so,":[74],"must":[76],"generalize":[77],"abstraction":[78],"application":[80],"to":[81],"encompass":[82],"functions.":[87],"capture":[89],"generalized":[94],"constructs":[95],"novel":[98],"use":[99],"qualified":[101,113],"types.":[102],"Our":[103],"system":[104],"maintains":[105],"metatheoretic":[107],"properties":[108],"theory":[111],"types,":[114],"including":[115],"principal":[116],"decidable":[119],"type":[120],"inference.":[121],"Finally,":[122],"give":[124],"formal":[126],"basis":[127],"claims":[130],"expressiveness,":[132],"showing":[134],"that":[135,140],"evaluation":[136],"respects":[137],"linearity,":[138],"is":[143],"conservative":[145],"extension":[146],"existing":[148],"calculi.":[150]},"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":4},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":3},{"year":2019,"cited_by_count":4},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":4},{"year":2016,"cited_by_count":2}],"updated_date":"2026-02-09T09:26:11.010843","created_date":"2020-11-23T00:00:00"}
