{"id":"https://openalex.org/W2051555998","doi":"https://doi.org/10.1145/2814228.2814245","title":"Isolates, channels, and event streams for composable distributed programming","display_name":"Isolates, channels, and event streams for composable distributed programming","publication_year":2015,"publication_date":"2015-10-21","ids":{"openalex":"https://openalex.org/W2051555998","doi":"https://doi.org/10.1145/2814228.2814245","mag":"2051555998"},"language":"en","primary_location":{"id":"doi:10.1145/2814228.2814245","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2814228.2814245","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"2015 ACM International Symposium on New Ideas, New Paradigms, and Reflections on Programming and Software (Onward!)","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://infoscience.epfl.ch/record/254998/files/p171-prokopec.pdf","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5043562961","display_name":"Aleksandar Prokopec","orcid":"https://orcid.org/0000-0003-0260-2729"},"institutions":[{"id":"https://openalex.org/I5124864","display_name":"\u00c9cole Polytechnique F\u00e9d\u00e9rale de Lausanne","ror":"https://ror.org/02s376052","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I5124864"]},{"id":"https://openalex.org/I174424907","display_name":"Laboratoire d'Informatique Fondamentale de Lille","ror":"https://ror.org/05rhg0h08","country_code":"FR","type":"facility","lineage":["https://openalex.org/I174424907"]}],"countries":["CH","FR"],"is_corresponding":true,"raw_author_name":"Aleksandar Prokopec","raw_affiliation_strings":["EPFL, Switzerland","EPFL, SWITZERLAND"],"affiliations":[{"raw_affiliation_string":"EPFL, Switzerland","institution_ids":["https://openalex.org/I5124864"]},{"raw_affiliation_string":"EPFL, SWITZERLAND","institution_ids":["https://openalex.org/I174424907"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5085410724","display_name":"Martin Odersky","orcid":"https://orcid.org/0009-0005-3923-8993"},"institutions":[{"id":"https://openalex.org/I174424907","display_name":"Laboratoire d'Informatique Fondamentale de Lille","ror":"https://ror.org/05rhg0h08","country_code":"FR","type":"facility","lineage":["https://openalex.org/I174424907"]},{"id":"https://openalex.org/I5124864","display_name":"\u00c9cole Polytechnique F\u00e9d\u00e9rale de Lausanne","ror":"https://ror.org/02s376052","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I5124864"]}],"countries":["CH","FR"],"is_corresponding":false,"raw_author_name":"Martin Odersky","raw_affiliation_strings":["EPFL, Switzerland","EPFL, SWITZERLAND"],"affiliations":[{"raw_affiliation_string":"EPFL, Switzerland","institution_ids":["https://openalex.org/I5124864"]},{"raw_affiliation_string":"EPFL, SWITZERLAND","institution_ids":["https://openalex.org/I174424907"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5043562961"],"corresponding_institution_ids":["https://openalex.org/I174424907","https://openalex.org/I5124864"],"apc_list":null,"apc_paid":null,"fwci":3.3282,"has_fulltext":false,"cited_by_count":21,"citation_normalized_percentile":{"value":0.92916792,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"171","last_page":"182"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10772","display_name":"Distributed systems and fault tolerance","score":1.0,"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/T10772","display_name":"Distributed systems and fault tolerance","score":1.0,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9994000196456909,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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/T10101","display_name":"Cloud Computing and Resource Management","score":0.9991000294685364,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/computer-science","display_name":"Computer science","score":0.8589998483657837},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.7566103935241699},{"id":"https://openalex.org/keywords/reuse","display_name":"Reuse","score":0.611985445022583},{"id":"https://openalex.org/keywords/protocol","display_name":"Protocol (science)","score":0.5939610004425049},{"id":"https://openalex.org/keywords/event","display_name":"Event (particle physics)","score":0.5900439620018005},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.5173682570457458},{"id":"https://openalex.org/keywords/stream-processing","display_name":"Stream processing","score":0.49782586097717285},{"id":"https://openalex.org/keywords/class","display_name":"Class (philosophy)","score":0.4735493063926697},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.464947372674942},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.40373098850250244},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3727901577949524},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.13886898756027222},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.12708541750907898}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8589998483657837},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.7566103935241699},{"id":"https://openalex.org/C206588197","wikidata":"https://www.wikidata.org/wiki/Q846574","display_name":"Reuse","level":2,"score":0.611985445022583},{"id":"https://openalex.org/C2780385302","wikidata":"https://www.wikidata.org/wiki/Q367158","display_name":"Protocol (science)","level":3,"score":0.5939610004425049},{"id":"https://openalex.org/C2779662365","wikidata":"https://www.wikidata.org/wiki/Q5416694","display_name":"Event (particle physics)","level":2,"score":0.5900439620018005},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.5173682570457458},{"id":"https://openalex.org/C107027933","wikidata":"https://www.wikidata.org/wiki/Q2006448","display_name":"Stream processing","level":2,"score":0.49782586097717285},{"id":"https://openalex.org/C2777212361","wikidata":"https://www.wikidata.org/wiki/Q5127848","display_name":"Class (philosophy)","level":2,"score":0.4735493063926697},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.464947372674942},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.40373098850250244},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3727901577949524},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.13886898756027222},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.12708541750907898},{"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/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C71924100","wikidata":"https://www.wikidata.org/wiki/Q11190","display_name":"Medicine","level":0,"score":0.0},{"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/C204787440","wikidata":"https://www.wikidata.org/wiki/Q188504","display_name":"Alternative medicine","level":2,"score":0.0},{"id":"https://openalex.org/C142724271","wikidata":"https://www.wikidata.org/wiki/Q7208","display_name":"Pathology","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/2814228.2814245","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2814228.2814245","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"2015 ACM International Symposium on New Ideas, New Paradigms, and Reflections on Programming and Software (Onward!)","raw_type":"proceedings-article"},{"id":"pmh:oai:infoscience.epfl.ch:254998","is_oa":true,"landing_page_url":"http://infoscience.epfl.ch/record/254998","pdf_url":"https://infoscience.epfl.ch/record/254998/files/p171-prokopec.pdf","source":{"id":"https://openalex.org/S4306400487","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc-nd","license_id":"https://openalex.org/licenses/cc-by-nc-nd","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"conference proceedings"}],"best_oa_location":{"id":"pmh:oai:infoscience.epfl.ch:254998","is_oa":true,"landing_page_url":"http://infoscience.epfl.ch/record/254998","pdf_url":"https://infoscience.epfl.ch/record/254998/files/p171-prokopec.pdf","source":{"id":"https://openalex.org/S4306400487","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc-nd","license_id":"https://openalex.org/licenses/cc-by-nc-nd","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"conference proceedings"},"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/16","display_name":"Peace, Justice and strong institutions","score":0.6000000238418579}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2051555998.pdf"},"referenced_works_count":36,"referenced_works":["https://openalex.org/W114470091","https://openalex.org/W194315955","https://openalex.org/W1495226832","https://openalex.org/W1557561422","https://openalex.org/W1591274473","https://openalex.org/W1608714802","https://openalex.org/W1689093460","https://openalex.org/W1830949212","https://openalex.org/W1938483076","https://openalex.org/W1994718921","https://openalex.org/W2003383582","https://openalex.org/W2033819047","https://openalex.org/W2060953276","https://openalex.org/W2071858567","https://openalex.org/W2072794470","https://openalex.org/W2075854425","https://openalex.org/W2100294774","https://openalex.org/W2102407227","https://openalex.org/W2111797980","https://openalex.org/W2116746874","https://openalex.org/W2118242633","https://openalex.org/W2131975293","https://openalex.org/W2137869319","https://openalex.org/W2138247393","https://openalex.org/W2138749053","https://openalex.org/W2173213060","https://openalex.org/W2561675875","https://openalex.org/W2611515161","https://openalex.org/W2775063659","https://openalex.org/W2913756572","https://openalex.org/W3106753174","https://openalex.org/W4256363426","https://openalex.org/W4285719527","https://openalex.org/W6604734910","https://openalex.org/W6633355477","https://openalex.org/W7056210342"],"related_works":["https://openalex.org/W2000444236","https://openalex.org/W2384475851","https://openalex.org/W2353602216","https://openalex.org/W2367078749","https://openalex.org/W2381798600","https://openalex.org/W2351618306","https://openalex.org/W2016731656","https://openalex.org/W2965891118","https://openalex.org/W2011993705","https://openalex.org/W2012174814"],"abstract_inverted_index":{"The":[0,44],"actor":[1,40,97,110],"model":[2,6,41,45,98],"has":[3],"been":[4],"a":[5],"of":[7],"choice":[8],"for":[9,105],"building":[10],"reliable":[11],"distributed":[12,126],"systems.":[13],"On":[14,32],"one":[15],"hand,":[16,35],"it":[17,64],"ensures":[18],"that":[19],"message-processing":[20],"is":[21,46,57,65],"serialized":[22],"within":[23],"each":[24],"actor,":[25],"preserving":[26],"the":[27,33,39,58,96,108,130],"familiar":[28],"sequential":[29],"programming":[30],"model.":[31,132],"other":[34],"programs":[36],"written":[37],"in":[38,78,107,129],"are":[42],"location-transparent.":[43],"sufficiently":[47],"low-level":[48],"to":[49,60,67,115,122],"express":[50],"arbitrary":[51],"message":[52,71],"protocols.":[53],"Composing":[54],"these":[55],"protocols":[56,72],"key":[59],"high-level":[61],"abstractions.":[62],"Unfortunately,":[63],"difficult":[66],"reuse":[68],"or":[69],"compose":[70],"with":[73,84],"actors.":[74],"Reactive":[75],"isolates,":[76],"proposed":[77],"this":[79],"paper,":[80],"simplify":[81],"protocol":[82],"composition":[83,106],"first-class":[85],"typed":[86],"channels":[87],"and":[88,95,112],"event":[89],"streams.":[90],"We":[91,102,118],"compare":[92],"reactive":[93],"isolates":[94],"on":[99],"concrete":[100],"programs.":[101],"identify":[103],"obstacles":[104],"classic":[109],"model,":[111],"show":[113,120],"how":[114,121],"overcome":[116],"them.":[117],"then":[119],"build":[123],"reusable,":[124],"composable":[125],"computing":[127],"components":[128],"new":[131]},"counts_by_year":[{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":5},{"year":2018,"cited_by_count":4},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":4}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
