{"id":"https://openalex.org/W2960903742","doi":"https://doi.org/10.1145/3408993","title":"Recovering purity with comonads and capabilities","display_name":"Recovering purity with comonads and capabilities","publication_year":2020,"publication_date":"2020-08-02","ids":{"openalex":"https://openalex.org/W2960903742","doi":"https://doi.org/10.1145/3408993","mag":"2960903742"},"language":"en","primary_location":{"id":"doi:10.1145/3408993","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3408993","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3408993","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":["arxiv","crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3408993","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5070491904","display_name":"Vikraman Choudhury","orcid":"https://orcid.org/0000-0003-2030-8056"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]},{"id":"https://openalex.org/I592451","display_name":"Indiana University","ror":"https://ror.org/01kg8sb98","country_code":"US","type":"education","lineage":["https://openalex.org/I592451"]}],"countries":["GB","US"],"is_corresponding":false,"raw_author_name":"Vikraman Choudhury","raw_affiliation_strings":["Indiana University, USA / University of Cambridge, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Indiana University, USA / University of Cambridge, UK","institution_ids":["https://openalex.org/I592451","https://openalex.org/I241749"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5085047206","display_name":"Neel Krishnaswami","orcid":"https://orcid.org/0000-0003-2838-5865"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Neel Krishnaswami","raw_affiliation_strings":["University of Cambridge, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Cambridge, UK","institution_ids":["https://openalex.org/I241749"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":2,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.9479,"has_fulltext":true,"cited_by_count":11,"citation_normalized_percentile":{"value":0.80276626,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":"4","issue":"ICFP","first_page":"1","last_page":"28"},"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.9965000152587891,"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.9933000206947327,"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/simply-typed-lambda-calculus","display_name":"Simply typed lambda calculus","score":0.6780372262001038},{"id":"https://openalex.org/keywords/soundness","display_name":"Soundness","score":0.6564823389053345},{"id":"https://openalex.org/keywords/system-f","display_name":"System F","score":0.5841750502586365},{"id":"https://openalex.org/keywords/axiom","display_name":"Axiom","score":0.5755465626716614},{"id":"https://openalex.org/keywords/calculus","display_name":"Calculus (dental)","score":0.5616137385368347},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.5419635772705078},{"id":"https://openalex.org/keywords/typed-lambda-calculus","display_name":"Typed lambda calculus","score":0.48328760266304016},{"id":"https://openalex.org/keywords/church-encoding","display_name":"Church encoding","score":0.4450169503688812},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.43507906794548035},{"id":"https://openalex.org/keywords/operational-semantics","display_name":"Operational semantics","score":0.4122595489025116},{"id":"https://openalex.org/keywords/lambda-calculus","display_name":"Lambda calculus","score":0.39965763688087463},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.3974868059158325},{"id":"https://openalex.org/keywords/algebra-over-a-field","display_name":"Algebra over a field","score":0.36934950947761536},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.3677256107330322},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.267976313829422},{"id":"https://openalex.org/keywords/pure-mathematics","display_name":"Pure mathematics","score":0.2024935483932495}],"concepts":[{"id":"https://openalex.org/C61237538","wikidata":"https://www.wikidata.org/wiki/Q855192","display_name":"Simply typed lambda calculus","level":4,"score":0.6780372262001038},{"id":"https://openalex.org/C39920170","wikidata":"https://www.wikidata.org/wiki/Q693083","display_name":"Soundness","level":2,"score":0.6564823389053345},{"id":"https://openalex.org/C55128367","wikidata":"https://www.wikidata.org/wiki/Q2552799","display_name":"System F","level":3,"score":0.5841750502586365},{"id":"https://openalex.org/C167729594","wikidata":"https://www.wikidata.org/wiki/Q17736","display_name":"Axiom","level":2,"score":0.5755465626716614},{"id":"https://openalex.org/C2777686260","wikidata":"https://www.wikidata.org/wiki/Q144037","display_name":"Calculus (dental)","level":2,"score":0.5616137385368347},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.5419635772705078},{"id":"https://openalex.org/C142156749","wikidata":"https://www.wikidata.org/wiki/Q2607208","display_name":"Typed lambda calculus","level":3,"score":0.48328760266304016},{"id":"https://openalex.org/C77736955","wikidata":"https://www.wikidata.org/wiki/Q1089708","display_name":"Church encoding","level":5,"score":0.4450169503688812},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.43507906794548035},{"id":"https://openalex.org/C156325763","wikidata":"https://www.wikidata.org/wiki/Q1930895","display_name":"Operational semantics","level":3,"score":0.4122595489025116},{"id":"https://openalex.org/C135790938","wikidata":"https://www.wikidata.org/wiki/Q242028","display_name":"Lambda calculus","level":2,"score":0.39965763688087463},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.3974868059158325},{"id":"https://openalex.org/C136119220","wikidata":"https://www.wikidata.org/wiki/Q1000660","display_name":"Algebra over a field","level":2,"score":0.36934950947761536},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.3677256107330322},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.267976313829422},{"id":"https://openalex.org/C202444582","wikidata":"https://www.wikidata.org/wiki/Q837863","display_name":"Pure mathematics","level":1,"score":0.2024935483932495},{"id":"https://openalex.org/C199343813","wikidata":"https://www.wikidata.org/wiki/Q12128","display_name":"Dentistry","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},{"id":"https://openalex.org/C71924100","wikidata":"https://www.wikidata.org/wiki/Q11190","display_name":"Medicine","level":0,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/3408993","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3408993","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3408993","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:1907.07283","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1907.07283","pdf_url":"https://arxiv.org/pdf/1907.07283","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:www.repository.cam.ac.uk:1810/310366","is_oa":true,"landing_page_url":"https://www.repository.cam.ac.uk/handle/1810/310366","pdf_url":null,"source":{"id":"https://openalex.org/S4306401777","display_name":"Apollo (University of Cambridge)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I241749","host_organization_name":"University of Cambridge","host_organization_lineage":["https://openalex.org/I241749"],"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":null,"raw_type":"Article"},{"id":"doi:10.17863/cam.57460","is_oa":true,"landing_page_url":"https://doi.org/10.17863/cam.57460","pdf_url":null,"source":{"id":"https://openalex.org/S7407050737","display_name":"Apollo","issn_l":null,"issn":[],"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"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-journal"}],"best_oa_location":{"id":"doi:10.1145/3408993","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3408993","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3408993","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":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2960903742.pdf","grobid_xml":"https://content.openalex.org/works/W2960903742.grobid-xml"},"referenced_works_count":43,"referenced_works":["https://openalex.org/W111511002","https://openalex.org/W159715351","https://openalex.org/W1520961854","https://openalex.org/W1539123436","https://openalex.org/W1552367747","https://openalex.org/W1558848517","https://openalex.org/W1596682622","https://openalex.org/W1773735832","https://openalex.org/W1876875653","https://openalex.org/W1971906578","https://openalex.org/W1988824860","https://openalex.org/W1997143185","https://openalex.org/W2008132476","https://openalex.org/W2010059824","https://openalex.org/W2013654056","https://openalex.org/W2021982406","https://openalex.org/W2031491316","https://openalex.org/W2037671236","https://openalex.org/W2048921878","https://openalex.org/W2070983411","https://openalex.org/W2084684966","https://openalex.org/W2084804301","https://openalex.org/W2113350481","https://openalex.org/W2127490568","https://openalex.org/W2137282578","https://openalex.org/W2137628566","https://openalex.org/W2139695229","https://openalex.org/W2140508184","https://openalex.org/W2141796169","https://openalex.org/W2145101842","https://openalex.org/W2156876717","https://openalex.org/W2157514610","https://openalex.org/W2166159458","https://openalex.org/W2169907127","https://openalex.org/W2208923056","https://openalex.org/W2400216756","https://openalex.org/W2491912653","https://openalex.org/W2765937481","https://openalex.org/W2911865844","https://openalex.org/W2964755768","https://openalex.org/W4238056673","https://openalex.org/W4249212548","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W3123171335","https://openalex.org/W2761902706","https://openalex.org/W2114151019","https://openalex.org/W2189323991","https://openalex.org/W4205386752","https://openalex.org/W2153353244","https://openalex.org/W1595139175","https://openalex.org/W2112776683","https://openalex.org/W1983748102","https://openalex.org/W1762925969"],"abstract_inverted_index":{"In":[0],"this":[1,185],"paper,":[2],"we":[3,82,188],"take":[4],"a":[5,48,64,77,109,115,129,152,190],"pervasively":[6],"effectful":[7],"(in":[8],"the":[9,36,70,84,91,98,136,141,168,175,193,213,218,222],"style":[10],"of":[11,72,192,221],"ML)":[12],"typed":[13,54],"lambda":[14,39,55,177,196],"calculus,":[15,178,202,224],"and":[16,113,146,167,171,179,203],"show":[17,180,204],"how":[18],"to":[19,22,44,60,94,100,108,150,184],"extend":[20],"it":[21,120,125],"permit":[23],"capturing":[24],"pure":[25,37,194,227],"expressions":[26],"with":[27,47,63],"types.":[28],"Our":[29,88],"key":[30],"observation":[31],"is":[32,117],"that,":[33],"just":[34],"as":[35],"simply-typed":[38,195],"calculus":[40,56,197],"can":[41,57,229],"be":[42,58,104,230],"extended":[43,59],"support":[45,61],"effects":[46,102,123],"monadic":[49],"type":[50,66,74,158],"discipline,":[51],"an":[52,163,233],"impure":[53],"purity":[62],"comonadic":[65,157,200,223],"discipline.":[67],"We":[68,133,160],"establish":[69],"correctness":[71],"our":[73,156,199,237],"system":[75],"via":[76,106],"simple":[78],"denotational":[79],"model,":[80],"which":[81,209],"call":[83],"capability":[85,131,142],"space":[86,143],"model.":[87],"model":[89,144],"formalises":[90],"intuition":[92],"common":[93],"systems":[95],"programmers":[96],"that":[97,114,124,140,205,226],"ability":[99],"perform":[101],"should":[103],"controlled":[105],"access":[107],"permission":[110],"or":[111],"capability,":[112],"program":[116],"capability-safe":[118],"if":[119],"performs":[121],"no":[122],"does":[126],"not":[127],"have":[128],"runtime":[130],"for.":[132],"then":[134,161],"identify":[135],"axiomatic":[137],"categorical":[138,153],"structure":[139],"validates,":[145],"use":[147],"these":[148],"axioms":[149],"give":[151,162,189],"semantics":[154],"for":[155,174],"system.":[159],"equational":[164,219],"theory":[165,220],"(substitution":[166],"call-by-value":[169],"\u03b2":[170],"\u03b7":[172],"laws)":[173],"imperative":[176,201,238],"its":[181],"soundness":[182],"relative":[183],"semantics.":[186],"Finally,":[187],"translation":[191],"into":[198,236],"any":[206],"two":[207],"terms":[208],"are":[210,215],"\u03b2\u03b7-equal":[211],"in":[212,217,232],"STLC":[214],"equal":[216],"establishing":[225],"programs":[228],"mapped":[231],"equation-preserving":[234],"way":[235],"calculus.":[239]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":3},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":4},{"year":2021,"cited_by_count":2}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
