{"id":"https://openalex.org/W2034871280","doi":"https://doi.org/10.1145/2804302.2804311","title":"The remote monad design pattern","display_name":"The remote monad design pattern","publication_year":2015,"publication_date":"2015-08-24","ids":{"openalex":"https://openalex.org/W2034871280","doi":"https://doi.org/10.1145/2804302.2804311","mag":"2034871280"},"language":"en","primary_location":{"id":"doi:10.1145/2804302.2804311","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804311","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","raw_type":"proceedings-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/A5029124439","display_name":"Andy Gill","orcid":null},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Andy Gill","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5078273982","display_name":"Neil Sculthorpe","orcid":"https://orcid.org/0000-0002-7244-0916"},"institutions":[{"id":"https://openalex.org/I39586589","display_name":"Swansea University","ror":"https://ror.org/053fq8t95","country_code":"GB","type":"education","lineage":["https://openalex.org/I39586589"]},{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["GB","US"],"is_corresponding":false,"raw_author_name":"Neil Sculthorpe","raw_affiliation_strings":["University of Kansas, USA / Swansea University, UK"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA / Swansea University, UK","institution_ids":["https://openalex.org/I39586589","https://openalex.org/I146416000"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5058747163","display_name":"Justin Dawson","orcid":null},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Justin Dawson","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5090661177","display_name":"Aleksander Eskilson","orcid":null},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Aleksander Eskilson","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5077194053","display_name":"Andrew Farmer","orcid":"https://orcid.org/0000-0002-4224-2433"},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Andrew Farmer","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5068433140","display_name":"Mark Grebe","orcid":null},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Mark Grebe","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5007501941","display_name":"Jeffrey Rosenbluth","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Jeffrey Rosenbluth","raw_affiliation_strings":["n.n., n.n"],"affiliations":[{"raw_affiliation_string":"n.n., n.n","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5024198980","display_name":"Ryan G. Scott","orcid":"https://orcid.org/0009-0006-5642-5667"},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ryan Scott","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5056265204","display_name":"James B. Stanton","orcid":"https://orcid.org/0000-0002-7661-2631"},"institutions":[{"id":"https://openalex.org/I146416000","display_name":"University of Kansas","ror":"https://ror.org/001tmjg57","country_code":"US","type":"education","lineage":["https://openalex.org/I146416000"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"James Stanton","raw_affiliation_strings":["University of Kansas, USA"],"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":9,"corresponding_author_ids":["https://openalex.org/A5029124439"],"corresponding_institution_ids":["https://openalex.org/I146416000"],"apc_list":null,"apc_paid":null,"fwci":4.4509,"has_fulltext":false,"cited_by_count":14,"citation_normalized_percentile":{"value":0.94823851,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"59","last_page":"70"},"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.9976000189781189,"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.9976000189781189,"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/T11424","display_name":"Security and Verification in Computing","score":0.996999979019165,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9965999722480774,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.9832862615585327},{"id":"https://openalex.org/keywords/monad","display_name":"Monad (category theory)","score":0.8872562646865845},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8173902034759521},{"id":"https://openalex.org/keywords/javascript","display_name":"JavaScript","score":0.8170892000198364},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5058391094207764},{"id":"https://openalex.org/keywords/interface","display_name":"Interface (matter)","score":0.4876388609409332},{"id":"https://openalex.org/keywords/remote-procedure-call","display_name":"Remote procedure call","score":0.4314807951450348},{"id":"https://openalex.org/keywords/design-pattern","display_name":"Design pattern","score":0.42920389771461487},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.3921681344509125},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.36706045269966125}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9832862615585327},{"id":"https://openalex.org/C33959348","wikidata":"https://www.wikidata.org/wiki/Q1630568","display_name":"Monad (category theory)","level":3,"score":0.8872562646865845},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8173902034759521},{"id":"https://openalex.org/C544833334","wikidata":"https://www.wikidata.org/wiki/Q2005","display_name":"JavaScript","level":2,"score":0.8170892000198364},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5058391094207764},{"id":"https://openalex.org/C113843644","wikidata":"https://www.wikidata.org/wiki/Q901882","display_name":"Interface (matter)","level":4,"score":0.4876388609409332},{"id":"https://openalex.org/C172086080","wikidata":"https://www.wikidata.org/wiki/Q62270","display_name":"Remote procedure call","level":2,"score":0.4314807951450348},{"id":"https://openalex.org/C14501506","wikidata":"https://www.wikidata.org/wiki/Q5253831","display_name":"Design pattern","level":2,"score":0.42920389771461487},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.3921681344509125},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.36706045269966125},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.0},{"id":"https://openalex.org/C156772000","wikidata":"https://www.wikidata.org/wiki/Q864475","display_name":"Functor","level":2,"score":0.0},{"id":"https://openalex.org/C157915830","wikidata":"https://www.wikidata.org/wiki/Q2928001","display_name":"Bubble","level":2,"score":0.0},{"id":"https://openalex.org/C129307140","wikidata":"https://www.wikidata.org/wiki/Q6795880","display_name":"Maximum bubble pressure method","level":3,"score":0.0},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/2804302.2804311","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2804302.2804311","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN Symposium on Haskell","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.704.4060","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.704.4060","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.swan.ac.uk/%7Ecsnas/papers_and_talks/remote-monad.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G5963503396","display_name":null,"funder_award_id":"1117569 and 1350901","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"}],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":30,"referenced_works":["https://openalex.org/W1514995960","https://openalex.org/W1649645444","https://openalex.org/W1659340666","https://openalex.org/W1839902311","https://openalex.org/W1968464751","https://openalex.org/W1979811002","https://openalex.org/W2000063321","https://openalex.org/W2013260261","https://openalex.org/W2055947235","https://openalex.org/W2057052623","https://openalex.org/W2068873267","https://openalex.org/W2070811535","https://openalex.org/W2088727454","https://openalex.org/W2097237476","https://openalex.org/W2100883156","https://openalex.org/W2106035061","https://openalex.org/W2107352271","https://openalex.org/W2116813111","https://openalex.org/W2123092976","https://openalex.org/W2141576692","https://openalex.org/W2143847610","https://openalex.org/W2145287505","https://openalex.org/W2156876717","https://openalex.org/W2199054643","https://openalex.org/W2295914203","https://openalex.org/W2528758927","https://openalex.org/W2729229260","https://openalex.org/W4243196605","https://openalex.org/W6638767560","https://openalex.org/W6683097175"],"related_works":["https://openalex.org/W2754859507","https://openalex.org/W2965966430","https://openalex.org/W2319624920","https://openalex.org/W1911419940","https://openalex.org/W2466718051","https://openalex.org/W2373472360","https://openalex.org/W2995031344","https://openalex.org/W154014553","https://openalex.org/W2913635267","https://openalex.org/W3026363978"],"abstract_inverted_index":{"Remote":[0],"Procedure":[1],"Calls":[2],"are":[3,43],"expensive.":[4],"This":[5,33],"paper":[6],"demonstrates":[7],"how":[8],"to":[9,39,112],"reduce":[10],"the":[11,21,28,35,54,79,91,113,123],"cost":[12,29],"of":[13,30,62,70,93,122],"calling":[14],"remote":[15,22,31,40,55,63,86,124],"procedures":[16],"from":[17],"Haskell":[18,36,104,130],"by":[19,84],"using":[20,66],"monad":[23,56,125],"design":[24,57,126],"pattern,":[25],"which":[26],"amortizes":[27],"calls.":[32],"gives":[34],"community":[37],"access":[38],"capabilities":[41],"that":[42,106],"not":[44],"directly":[45],"supported,":[46],"at":[47],"a":[48,67,74,99,103,108],"surprisingly":[49],"inexpensive":[50],"cost.":[51],"We":[52,77,96],"explore":[53],"pattern":[58,127],"through":[59],"six":[60],"models":[61],"execution":[64,87],"patterns,":[65],"simulated":[68],"Internet":[69],"Things":[71],"toaster":[72],"as":[73],"running":[75],"example.":[76],"consider":[78],"expressiveness":[80],"and":[81,89],"optimizations":[82],"enabled":[83],"each":[85],"model,":[88],"assess":[90],"feasibility":[92],"our":[94],"approach.":[95],"then":[97],"present":[98],"full-scale":[100],"case":[101],"study:":[102],"library":[105],"provides":[107],"Foreign":[109],"Function":[110],"Interface":[111],"JavaScript":[114],"Canvas":[115],"API.":[116],"Finally,":[117],"we":[118],"discuss":[119],"existing":[120],"instances":[121],"found":[128],"in":[129],"libraries.":[131]},"counts_by_year":[{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":1},{"year":2017,"cited_by_count":7},{"year":2016,"cited_by_count":2}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
