{"id":"https://openalex.org/W2752096750","doi":"https://doi.org/10.1145/3122955.3122968","title":"Composable network stacks and remote monads","display_name":"Composable network stacks and remote monads","publication_year":2017,"publication_date":"2017-09-01","ids":{"openalex":"https://openalex.org/W2752096750","doi":"https://doi.org/10.1145/3122955.3122968","mag":"2752096750"},"language":"en","primary_location":{"id":"doi:10.1145/3122955.3122968","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122955.3122968","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 10th ACM SIGPLAN International 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/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"],"raw_orcid":null,"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"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]},{"author_position":"last","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":false,"raw_author_name":"Andy Gill","raw_affiliation_strings":["University of Kansas, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Kansas, USA","institution_ids":["https://openalex.org/I146416000"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.2065,"has_fulltext":false,"cited_by_count":1,"citation_normalized_percentile":{"value":0.64552724,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":null,"issue":null,"first_page":"86","last_page":"97"},"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.9994999766349792,"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.9994999766349792,"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.9991000294685364,"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.9987999796867371,"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/computer-science","display_name":"Computer science","score":0.8358628153800964},{"id":"https://openalex.org/keywords/monad","display_name":"Monad (category theory)","score":0.8344020843505859},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.6836925745010376},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6479235291481018},{"id":"https://openalex.org/keywords/bundle","display_name":"Bundle","score":0.6013873815536499},{"id":"https://openalex.org/keywords/network-packet","display_name":"Network packet","score":0.57390296459198},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.5523808002471924},{"id":"https://openalex.org/keywords/dataflow","display_name":"Dataflow","score":0.47195306420326233},{"id":"https://openalex.org/keywords/functor","display_name":"Functor","score":0.4576912820339203},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.33747899532318115},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.32208937406539917},{"id":"https://openalex.org/keywords/computer-network","display_name":"Computer network","score":0.19927939772605896},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.07881373167037964}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8358628153800964},{"id":"https://openalex.org/C33959348","wikidata":"https://www.wikidata.org/wiki/Q1630568","display_name":"Monad (category theory)","level":3,"score":0.8344020843505859},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.6836925745010376},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6479235291481018},{"id":"https://openalex.org/C2778134712","wikidata":"https://www.wikidata.org/wiki/Q1047307","display_name":"Bundle","level":2,"score":0.6013873815536499},{"id":"https://openalex.org/C158379750","wikidata":"https://www.wikidata.org/wiki/Q214111","display_name":"Network packet","level":2,"score":0.57390296459198},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.5523808002471924},{"id":"https://openalex.org/C96324660","wikidata":"https://www.wikidata.org/wiki/Q205446","display_name":"Dataflow","level":2,"score":0.47195306420326233},{"id":"https://openalex.org/C156772000","wikidata":"https://www.wikidata.org/wiki/Q864475","display_name":"Functor","level":2,"score":0.4576912820339203},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.33747899532318115},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.32208937406539917},{"id":"https://openalex.org/C31258907","wikidata":"https://www.wikidata.org/wiki/Q1301371","display_name":"Computer network","level":1,"score":0.19927939772605896},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.07881373167037964},{"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/C192562407","wikidata":"https://www.wikidata.org/wiki/Q228736","display_name":"Materials science","level":0,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C159985019","wikidata":"https://www.wikidata.org/wiki/Q181790","display_name":"Composite material","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3122955.3122968","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122955.3122968","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 10th ACM SIGPLAN International Symposium on Haskell","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":27,"referenced_works":["https://openalex.org/W78774630","https://openalex.org/W114285977","https://openalex.org/W1562395121","https://openalex.org/W1795023635","https://openalex.org/W1839902311","https://openalex.org/W1883363362","https://openalex.org/W1977008535","https://openalex.org/W1997143185","https://openalex.org/W2034871280","https://openalex.org/W2055947235","https://openalex.org/W2067748597","https://openalex.org/W2068873267","https://openalex.org/W2087404516","https://openalex.org/W2104958979","https://openalex.org/W2120713972","https://openalex.org/W2140647971","https://openalex.org/W2143847610","https://openalex.org/W2145287505","https://openalex.org/W2155028447","https://openalex.org/W2163552400","https://openalex.org/W2343077824","https://openalex.org/W2397614356","https://openalex.org/W2501393023","https://openalex.org/W2763133330","https://openalex.org/W2917740275","https://openalex.org/W3104936375","https://openalex.org/W3137378848"],"related_works":["https://openalex.org/W2754859507","https://openalex.org/W2319624920","https://openalex.org/W2112263414","https://openalex.org/W1602185604","https://openalex.org/W3004782279","https://openalex.org/W1911419940","https://openalex.org/W2466718051","https://openalex.org/W2373472360","https://openalex.org/W2995031344","https://openalex.org/W154014553"],"abstract_inverted_index":{"Monads":[0],"and":[1,24,61,64,99,106],"applicative":[2,25],"functors":[3,26],"are":[4],"two":[5],"ways":[6,47],"that":[7,80],"Haskell":[8],"programmers":[9],"bundle":[10,28],"effectful":[11,14,30],"primitives":[12,101],"into":[13,87],"program":[15],"fragments.":[16],"In":[17],"this":[18,77],"paper,":[19],"we":[20],"investigate":[21],"using":[22,41],"monads":[23],"to":[27,34],"remote":[29,39,57],"primitives,":[31,53],"specifically":[32],"aiming":[33],"amortize":[35],"the":[36,50,56,100],"cost":[37],"of":[38,48,52,68,76],"communications":[40],"bundling.":[42],"We":[43],"look":[44],"at":[45],"several":[46],"maximizing":[49],"bundling":[51],"drawing":[54],"from":[55],"monad":[58],"design":[59],"pattern":[60],"Haxl":[62],"system,":[63],"provide":[65],"a":[66,94],"taxonomy":[67],"mechanism":[69],"for":[70,90],"amortization,":[71],"with":[72],"examples.":[73],"The":[74],"result":[75],"investigation":[78],"is":[79],"monadic":[81],"fragments":[82],"can":[83],"be":[84],"efficiently":[85],"bundled":[86],"packets,":[88],"almost":[89],"free,":[91],"when":[92],"given":[93],"user-supplied":[95],"packet":[96],"transportation":[97],"mechanism,":[98],"obey":[102],"some":[103],"simple":[104],"pre-":[105],"post-conditions.":[107]},"counts_by_year":[{"year":2019,"cited_by_count":1}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
