{"id":"https://openalex.org/W2119964141","doi":"https://doi.org/10.1145/1086365.1086378","title":"AtomCaml","display_name":"AtomCaml","publication_year":2005,"publication_date":"2005-09-12","ids":{"openalex":"https://openalex.org/W2119964141","doi":"https://doi.org/10.1145/1086365.1086378","mag":"2119964141"},"language":"en","primary_location":{"id":"doi:10.1145/1086365.1086378","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1086365.1086378","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the tenth ACM SIGPLAN international conference on Functional programming","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/A5017701246","display_name":"Michael F. Ringenburg","orcid":"https://orcid.org/0000-0001-5119-0754"},"institutions":[{"id":"https://openalex.org/I201448701","display_name":"University of Washington","ror":"https://ror.org/00cvxb145","country_code":"US","type":"education","lineage":["https://openalex.org/I201448701"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Michael F. Ringenburg","raw_affiliation_strings":["University of Washington, Seattle, WA","University Of Washington (Seattle, WA)"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Washington, Seattle, WA","institution_ids":["https://openalex.org/I201448701"]},{"raw_affiliation_string":"University Of Washington (Seattle, WA)","institution_ids":["https://openalex.org/I201448701"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5103045316","display_name":"Dan Grossman","orcid":null},"institutions":[{"id":"https://openalex.org/I201448701","display_name":"University of Washington","ror":"https://ror.org/00cvxb145","country_code":"US","type":"education","lineage":["https://openalex.org/I201448701"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Dan Grossman","raw_affiliation_strings":["University of Washington, Seattle, WA","University Of Washington (Seattle, WA)"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Washington, Seattle, WA","institution_ids":["https://openalex.org/I201448701"]},{"raw_affiliation_string":"University Of Washington (Seattle, WA)","institution_ids":["https://openalex.org/I201448701"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":16.4367,"has_fulltext":false,"cited_by_count":100,"citation_normalized_percentile":{"value":0.9913667,"is_in_top_1_percent":true,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"92","last_page":"104"},"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.9994999766349792,"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/T11181","display_name":"Advanced Data Storage Technologies","score":0.9977999925613403,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.9002090692520142},{"id":"https://openalex.org/keywords/atomicity","display_name":"Atomicity","score":0.8408474326133728},{"id":"https://openalex.org/keywords/thread","display_name":"Thread (computing)","score":0.7582124471664429},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6375144720077515},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5371497273445129},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.4878714084625244},{"id":"https://openalex.org/keywords/uniprocessor-system","display_name":"Uniprocessor system","score":0.457931786775589},{"id":"https://openalex.org/keywords/posix-threads","display_name":"POSIX Threads","score":0.43826013803482056},{"id":"https://openalex.org/keywords/multithreading","display_name":"Multithreading","score":0.436939001083374},{"id":"https://openalex.org/keywords/runtime-system","display_name":"Runtime system","score":0.43433475494384766},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.370791494846344},{"id":"https://openalex.org/keywords/database-transaction","display_name":"Database transaction","score":0.2791496515274048}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9002090692520142},{"id":"https://openalex.org/C188045909","wikidata":"https://www.wikidata.org/wiki/Q3306359","display_name":"Atomicity","level":3,"score":0.8408474326133728},{"id":"https://openalex.org/C138101251","wikidata":"https://www.wikidata.org/wiki/Q213092","display_name":"Thread (computing)","level":2,"score":0.7582124471664429},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6375144720077515},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5371497273445129},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4878714084625244},{"id":"https://openalex.org/C79189994","wikidata":"https://www.wikidata.org/wiki/Q3488021","display_name":"Uniprocessor system","level":3,"score":0.457931786775589},{"id":"https://openalex.org/C41138395","wikidata":"https://www.wikidata.org/wiki/Q928112","display_name":"POSIX Threads","level":3,"score":0.43826013803482056},{"id":"https://openalex.org/C201410400","wikidata":"https://www.wikidata.org/wiki/Q1064412","display_name":"Multithreading","level":3,"score":0.436939001083374},{"id":"https://openalex.org/C2780870223","wikidata":"https://www.wikidata.org/wiki/Q1004415","display_name":"Runtime system","level":2,"score":0.43433475494384766},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.370791494846344},{"id":"https://openalex.org/C75949130","wikidata":"https://www.wikidata.org/wiki/Q848010","display_name":"Database transaction","level":2,"score":0.2791496515274048},{"id":"https://openalex.org/C4822641","wikidata":"https://www.wikidata.org/wiki/Q846651","display_name":"Multiprocessing","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/1086365.1086378","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1086365.1086378","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the tenth ACM SIGPLAN international conference on Functional programming","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16","score":0.75}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":43,"referenced_works":["https://openalex.org/W176746981","https://openalex.org/W1486694616","https://openalex.org/W1495087637","https://openalex.org/W1698939026","https://openalex.org/W1972544179","https://openalex.org/W1980895171","https://openalex.org/W1985527344","https://openalex.org/W1993836075","https://openalex.org/W2002179840","https://openalex.org/W2009712165","https://openalex.org/W2021018584","https://openalex.org/W2027620096","https://openalex.org/W2046317364","https://openalex.org/W2066952803","https://openalex.org/W2072062729","https://openalex.org/W2082766667","https://openalex.org/W2102640269","https://openalex.org/W2103957752","https://openalex.org/W2105055683","https://openalex.org/W2105772643","https://openalex.org/W2108204150","https://openalex.org/W2108287664","https://openalex.org/W2109052065","https://openalex.org/W2109875364","https://openalex.org/W2129990308","https://openalex.org/W2134997781","https://openalex.org/W2135304718","https://openalex.org/W2138816337","https://openalex.org/W2148186799","https://openalex.org/W2148303633","https://openalex.org/W2152085994","https://openalex.org/W2155814128","https://openalex.org/W2156428492","https://openalex.org/W2161600851","https://openalex.org/W2165025784","https://openalex.org/W2165825461","https://openalex.org/W2169000705","https://openalex.org/W2172255864","https://openalex.org/W2769656678","https://openalex.org/W4235116491","https://openalex.org/W4242949098","https://openalex.org/W6674041293","https://openalex.org/W6679976679"],"related_works":["https://openalex.org/W4294310504","https://openalex.org/W2070906137","https://openalex.org/W2338363223","https://openalex.org/W4236242523","https://openalex.org/W2013290259","https://openalex.org/W4230098690","https://openalex.org/W2970429960","https://openalex.org/W1921012695","https://openalex.org/W2162569153","https://openalex.org/W2158978940"],"abstract_inverted_index":{"We":[0,121],"have":[1,122],"designed,":[2],"implemented,":[3],"and":[4,55,65,83,99,126,133,139,164],"evaluated":[5,123],"AtomCaml,":[6],"an":[7,146],"extension":[8],"to":[9,68,105,172],"Objective":[10,61,101],"Caml":[11,62,97,102],"that":[12],"provides":[13],"a":[14,106,136],"synchronization":[15,162],"primitive":[16,25],"for":[17],"atomic":[18,78,159,174],"(transactional)":[19],"execution":[20,108],"of":[21,27,95,128],"code.":[22],"A":[23,71],"first-class":[24],"function":[26],"type":[28],"(unit->'a)->'a":[29],"evaluates":[30],"its":[31],"argument":[32],"(which":[33],"may":[34],"call":[35],"other":[36,45],"functions,":[37],"even":[38],"external":[39],"C":[40],"functions)":[41],"as":[42,167],"though":[43],"no":[44],"thread":[46,81,88],"has":[47],"interleaved":[48],"execution.":[49],"Our":[50,57,151],"design":[51],"ensures":[52],"fair":[53],"scheduling":[54],"obstruction-freedom.":[56],"implementation":[58],"extends":[59],"the":[60,87,96,100,124,154,173],"bytecode":[63],"compiler":[64],"run-time":[66],"system":[67],"support":[69],"atomicity.":[70],"logging-and-rollback":[72],"approach":[73],"lets":[74],"us":[75],"undo":[76],"uncompleted":[77],"blocks":[79],"upon":[80],"pre-emption,":[82],"retry":[84],"them":[85],"when":[86],"is":[89,157],"rescheduled.":[90],"The":[91],"mostly":[92],"functional":[93],"nature":[94],"language":[98],"implementation's":[103],"commitment":[104],"uniprocessor":[107],"model":[109],"(i.e.,":[110],"threads":[111],"are":[112],"interleaved,":[113],"not":[114],"executed":[115],"simultaneously)":[116],"allow":[117],"particularly":[118],"efficient":[119],"logging.":[120],"efficiency":[125],"ease-of-use":[127],"AtomCaml":[129],"by":[130],"writing":[131,135],"libraries":[132],"microbenchmarks,":[134],"small":[137],"application,":[138],"replacing":[140],"all":[141],"locking":[142],"with":[143],"atomicity":[144],"in":[145],"existing,":[147],"large":[148],"multithreaded":[149],"application.":[150],"experience":[152],"indicates":[153],"performance":[155],"overhead":[156],"negligible,":[158],"helps":[160],"avoid":[161],"mistakes,":[163],"idioms":[165],"such":[166],"condition":[168],"variables":[169],"adapt":[170],"reasonably":[171],"approach.":[175]},"counts_by_year":[{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":1},{"year":2014,"cited_by_count":2},{"year":2013,"cited_by_count":5},{"year":2012,"cited_by_count":3}],"updated_date":"2026-06-19T17:40:00.097472","created_date":"2016-06-24T00:00:00"}
