{"id":"https://openalex.org/W2744582809","doi":"https://doi.org/10.1145/3122955.3122973","title":"Adaptive lock-free data structures in Haskell: a general method for concurrent implementation swapping","display_name":"Adaptive lock-free data structures in Haskell: a general method for concurrent implementation swapping","publication_year":2017,"publication_date":"2017-09-01","ids":{"openalex":"https://openalex.org/W2744582809","doi":"https://doi.org/10.1145/3122955.3122973","mag":"2744582809"},"language":"en","primary_location":{"id":"doi:10.1145/3122955.3122973","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122955.3122973","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":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://arxiv.org/pdf/1708.02318","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":null,"display_name":"Chao-Hong Chen","orcid":null},"institutions":[{"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":["US"],"is_corresponding":false,"raw_author_name":"Chao-Hong Chen","raw_affiliation_strings":["Indiana University, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Indiana University, USA","institution_ids":["https://openalex.org/I592451"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Vikraman Choudhury","orcid":null},"institutions":[{"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":["US"],"is_corresponding":false,"raw_author_name":"Vikraman Choudhury","raw_affiliation_strings":["Indiana University, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Indiana University, USA","institution_ids":["https://openalex.org/I592451"]}]},{"author_position":"last","author":{"id":null,"display_name":"Ryan R. Newton","orcid":null},"institutions":[{"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":["US"],"is_corresponding":false,"raw_author_name":"Ryan R. Newton","raw_affiliation_strings":["Indiana University, USA"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Indiana University, USA","institution_ids":["https://openalex.org/I592451"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.2197,"has_fulltext":true,"cited_by_count":2,"citation_normalized_percentile":{"value":0.58513641,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":94},"biblio":{"volume":null,"issue":null,"first_page":"197","last_page":"211"},"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.9990000128746033,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9941999912261963,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/data-structure","display_name":"Data structure","score":0.7544000148773193},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.6797999739646912},{"id":"https://openalex.org/keywords/concurrency","display_name":"Concurrency","score":0.5236999988555908},{"id":"https://openalex.org/keywords/concurrent-data-structure","display_name":"Concurrent data structure","score":0.47909998893737793},{"id":"https://openalex.org/keywords/snapshot","display_name":"Snapshot (computer storage)","score":0.4348999857902527},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.415800005197525},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.414000004529953},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.4081000089645386}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.798799991607666},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.7544000148773193},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.6797999739646912},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6079000234603882},{"id":"https://openalex.org/C193702766","wikidata":"https://www.wikidata.org/wiki/Q1414548","display_name":"Concurrency","level":2,"score":0.5236999988555908},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.486299991607666},{"id":"https://openalex.org/C203222032","wikidata":"https://www.wikidata.org/wiki/Q5159104","display_name":"Concurrent data structure","level":3,"score":0.47909998893737793},{"id":"https://openalex.org/C55282118","wikidata":"https://www.wikidata.org/wiki/Q252683","display_name":"Snapshot (computer storage)","level":2,"score":0.4348999857902527},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.415800005197525},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.414000004529953},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.4081000089645386},{"id":"https://openalex.org/C189950617","wikidata":"https://www.wikidata.org/wiki/Q937228","display_name":"Property (philosophy)","level":2,"score":0.39719998836517334},{"id":"https://openalex.org/C2778476105","wikidata":"https://www.wikidata.org/wiki/Q628539","display_name":"Workload","level":2,"score":0.39660000801086426},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.3828999996185303},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3278000056743622},{"id":"https://openalex.org/C47487241","wikidata":"https://www.wikidata.org/wiki/Q5227230","display_name":"Data access","level":2,"score":0.3246000111103058},{"id":"https://openalex.org/C56288433","wikidata":"https://www.wikidata.org/wiki/Q58673","display_name":"Data manipulation language","level":2,"score":0.3163999915122986},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.3066999912261963},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.2980000078678131},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.29159998893737793},{"id":"https://openalex.org/C88482812","wikidata":"https://www.wikidata.org/wiki/Q6453666","display_name":"Modular programming","level":2,"score":0.288100004196167},{"id":"https://openalex.org/C77618280","wikidata":"https://www.wikidata.org/wiki/Q1155772","display_name":"Scheme (mathematics)","level":2,"score":0.2791999876499176},{"id":"https://openalex.org/C2778029271","wikidata":"https://www.wikidata.org/wiki/Q5421931","display_name":"Extension (predicate logic)","level":2,"score":0.2777999937534332},{"id":"https://openalex.org/C2983050975","wikidata":"https://www.wikidata.org/wiki/Q88287214","display_name":"Block structure","level":3,"score":0.2694000005722046},{"id":"https://openalex.org/C888380","wikidata":"https://www.wikidata.org/wiki/Q2427787","display_name":"Persistent data structure","level":2,"score":0.26440000534057617}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3122955.3122973","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122955.3122973","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"},{"id":"pmh:oai:arXiv.org:1708.02318","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1708.02318","pdf_url":"https://arxiv.org/pdf/1708.02318","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"}],"best_oa_location":{"id":"pmh:oai:arXiv.org:1708.02318","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1708.02318","pdf_url":"https://arxiv.org/pdf/1708.02318","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":[],"awards":[{"id":"https://openalex.org/G3274046396","display_name":null,"funder_award_id":"1453508","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":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2744582809.pdf","grobid_xml":"https://content.openalex.org/works/W2744582809.grobid-xml"},"referenced_works_count":22,"referenced_works":["https://openalex.org/W193325121","https://openalex.org/W1570380538","https://openalex.org/W1993805917","https://openalex.org/W2037683502","https://openalex.org/W2048517152","https://openalex.org/W2060771324","https://openalex.org/W2084802221","https://openalex.org/W2097013380","https://openalex.org/W2101939036","https://openalex.org/W2105055683","https://openalex.org/W2128870271","https://openalex.org/W2144921123","https://openalex.org/W2145893337","https://openalex.org/W2155762556","https://openalex.org/W2162014350","https://openalex.org/W2296715995","https://openalex.org/W2301578694","https://openalex.org/W2580970781","https://openalex.org/W4230681750","https://openalex.org/W4234438627","https://openalex.org/W4244901551","https://openalex.org/W4250018168"],"related_works":[],"abstract_inverted_index":{"A":[0,21],"key":[1],"part":[2],"of":[3,72,86,112,253],"implementing":[4],"high-level":[5],"languages":[6,138],"is":[7,19,26,58,66,117,235],"providing":[8],"built-":[9],"in":[10,29,95,102,126,132,250],"and":[11,31,40,107,144,149,155,181,226,239,256],"default":[12],"data":[13,23,75,87,97,140,173,200,225,233],"structures.":[14],"Yet":[15],"selecting":[16],"good":[17],"defaults":[18],"hard.":[20],"mutable":[22,148,207],"structure\u2019s":[24,98],"workload":[25],"not":[27],"known":[28],"advance,":[30],"it":[32,65],"may":[33],"shift":[34],"over":[35],"its":[36,204],"lifetime\u2014e.g.,":[37],"between":[38,147],"read-heavy":[39],"write-":[41],"heavy,":[42],"or":[43,53,196],"from":[44],"heavy":[45],"contention":[46],"by":[47],"multiple":[48],"threads":[49],"to":[50,59,68,120,168,178,184,223],"single-":[51],"threaded":[52],"low-frequency":[54],"use.":[55],"One":[56],"idea":[57],"switch":[60,69],"implementa-":[61],"tions":[62],"adaptively,":[63],"but":[64,158],"nontrivial":[67],"the":[70,80,96,176,194,199,229,241,251],"implementation":[71],"a":[73,83,133,185,210],"concurrent":[74,84,259],"structure":[76,88,174,234],"at":[77],"runtime.":[78],"Performing":[79],"transition":[81,183],"requires":[82],"snapshot":[85],"contents,":[89],"which":[90],"normally":[91],"demands":[92],"special":[93],"engineering":[94],"de-":[99],"sign.":[100],"However,":[101],"this":[103,166,214],"paper":[104],"we":[105,216],"identify":[106],"formalize":[108],"an":[109,127,170,218,246],"relevant":[110],"property":[111],"lock-free":[113,172],"algorithms.":[114],"Namely,":[115],"lock-freedom":[116],"su":[118],"cient":[119],"guarantee":[121],"that":[122,142,228],"freezing":[123],"memory":[124],"locations":[125],"arbitrary":[128,171],"order":[129],"will":[130],"result":[131],"valid":[134],"snapshot.":[135],"Several":[136],"functional":[137],"have":[139],"structures":[141],"freeze":[143,180],"thaw,":[145],"transitioning":[146],"immutable,":[150],"such":[151],"as":[152],"Haskell":[153],"vectors":[154],"Clojure":[156],"transients,":[157],"these":[159],"enable":[160],"only":[161,202],"single-threaded":[162],"writers.":[163],"We":[164,243],"generalize":[165],"approach":[167],"augment":[169],"with":[175,209],"ability":[177],"gradually":[179],"optionally":[182],"new":[186],"representation.":[187],"This":[188],"aug-":[189],"mentation":[190],"doesn\u2019t":[191],"require":[192],"changing":[193],"algorithm":[195,219],"code":[197],"for":[198,206,220],"structure,":[201],"replacing":[203],"datatype":[205],"references":[208],"freezable":[211],"variant.":[212],"In":[213],"paper,":[215],"present":[217],"lifting":[221],"plain":[222],"adaptive":[224],"prove":[227],"resulting":[230],"hy-":[231],"brid":[232],"itself":[236],"lock-free,":[237],"linearizable,":[238],"simulates":[240],"original.":[242],"also":[244],"perform":[245],"empirical":[247],"case":[248],"study":[249],"context":[252],"heating":[254],"up":[255],"cooling":[257],"down":[258],"maps.":[260]},"counts_by_year":[{"year":2021,"cited_by_count":1},{"year":2018,"cited_by_count":1}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2017-08-17T00:00:00"}
