{"id":"https://openalex.org/W2063591933","doi":"https://doi.org/10.1145/2784731.2784736","title":"Partial aborts for transactions via first-class continuations","display_name":"Partial aborts for transactions via first-class continuations","publication_year":2015,"publication_date":"2015-08-26","ids":{"openalex":"https://openalex.org/W2063591933","doi":"https://doi.org/10.1145/2784731.2784736","mag":"2063591933"},"language":"en","primary_location":{"id":"doi:10.1145/2784731.2784736","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2784731.2784736","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th 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/A5063364645","display_name":"Matthew Le","orcid":null},"institutions":[{"id":"https://openalex.org/I155173764","display_name":"Rochester Institute of Technology","ror":"https://ror.org/00v4yb702","country_code":"US","type":"education","lineage":["https://openalex.org/I155173764"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Matthew Le","raw_affiliation_strings":["Rochester Institute of Technology, USA","Rochester Institute of Technology (USA)"],"affiliations":[{"raw_affiliation_string":"Rochester Institute of Technology, USA","institution_ids":["https://openalex.org/I155173764"]},{"raw_affiliation_string":"Rochester Institute of Technology (USA)","institution_ids":["https://openalex.org/I155173764"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5029478793","display_name":"Matthew Fluet","orcid":"https://orcid.org/0000-0002-4194-7618"},"institutions":[{"id":"https://openalex.org/I155173764","display_name":"Rochester Institute of Technology","ror":"https://ror.org/00v4yb702","country_code":"US","type":"education","lineage":["https://openalex.org/I155173764"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Matthew Fluet","raw_affiliation_strings":["Rochester Institute of Technology, USA","Rochester Institute of Technology (USA)"],"affiliations":[{"raw_affiliation_string":"Rochester Institute of Technology, USA","institution_ids":["https://openalex.org/I155173764"]},{"raw_affiliation_string":"Rochester Institute of Technology (USA)","institution_ids":["https://openalex.org/I155173764"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5063364645"],"corresponding_institution_ids":["https://openalex.org/I155173764"],"apc_list":null,"apc_paid":null,"fwci":1.051,"has_fulltext":false,"cited_by_count":8,"citation_normalized_percentile":{"value":0.8053819,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":null,"issue":null,"first_page":"230","last_page":"242"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10772","display_name":"Distributed systems and fault tolerance","score":0.9998999834060669,"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":0.9998999834060669,"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.9889000058174133,"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.9854999780654907,"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.9047404527664185},{"id":"https://openalex.org/keywords/software-transactional-memory","display_name":"Software transactional memory","score":0.8372160196304321},{"id":"https://openalex.org/keywords/concurrency","display_name":"Concurrency","score":0.5321081876754761},{"id":"https://openalex.org/keywords/continuation","display_name":"Continuation","score":0.5158631205558777},{"id":"https://openalex.org/keywords/concurrency-control","display_name":"Concurrency control","score":0.49842190742492676},{"id":"https://openalex.org/keywords/database-transaction","display_name":"Database transaction","score":0.49108242988586426},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.4342323839664459},{"id":"https://openalex.org/keywords/distributed-transaction","display_name":"Distributed transaction","score":0.4244963228702545},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.4075401723384857},{"id":"https://openalex.org/keywords/transaction-processing","display_name":"Transaction processing","score":0.4038786292076111},{"id":"https://openalex.org/keywords/transactional-memory","display_name":"Transactional memory","score":0.39787012338638306},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.3904644846916199},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.3877953886985779}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9047404527664185},{"id":"https://openalex.org/C167149655","wikidata":"https://www.wikidata.org/wiki/Q1189004","display_name":"Software transactional memory","level":4,"score":0.8372160196304321},{"id":"https://openalex.org/C193702766","wikidata":"https://www.wikidata.org/wiki/Q1414548","display_name":"Concurrency","level":2,"score":0.5321081876754761},{"id":"https://openalex.org/C88626702","wikidata":"https://www.wikidata.org/wiki/Q1128903","display_name":"Continuation","level":2,"score":0.5158631205558777},{"id":"https://openalex.org/C84511453","wikidata":"https://www.wikidata.org/wiki/Q2914952","display_name":"Concurrency control","level":3,"score":0.49842190742492676},{"id":"https://openalex.org/C75949130","wikidata":"https://www.wikidata.org/wiki/Q848010","display_name":"Database transaction","level":2,"score":0.49108242988586426},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.4342323839664459},{"id":"https://openalex.org/C25185021","wikidata":"https://www.wikidata.org/wiki/Q4053284","display_name":"Distributed transaction","level":4,"score":0.4244963228702545},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4075401723384857},{"id":"https://openalex.org/C72108876","wikidata":"https://www.wikidata.org/wiki/Q844565","display_name":"Transaction processing","level":3,"score":0.4038786292076111},{"id":"https://openalex.org/C134277064","wikidata":"https://www.wikidata.org/wiki/Q878206","display_name":"Transactional memory","level":3,"score":0.39787012338638306},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.3904644846916199},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.3877953886985779}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/2784731.2784736","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2784731.2784736","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th ACM SIGPLAN International Conference on Functional Programming","raw_type":"proceedings-article"},{"id":"pmh:oai:scholarworks.rit.edu:theses-10323","is_oa":false,"landing_page_url":"https://scholarworks.rit.edu/theses/9170","pdf_url":null,"source":{"id":"https://openalex.org/S4306402456","display_name":"RIT Scholar Works (Rochester Institute of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I155173764","host_organization_name":"Rochester Institute of Technology","host_organization_lineage":["https://openalex.org/I155173764"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Theses","raw_type":"text"},{"id":"pmh:oai:repository.rit.edu:theses-10323","is_oa":false,"landing_page_url":"https://repository.rit.edu/theses/9170","pdf_url":null,"source":{"id":"https://openalex.org/S4306402456","display_name":"RIT Scholar Works (Rochester Institute of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I155173764","host_organization_name":"Rochester Institute of Technology","host_organization_lineage":["https://openalex.org/I155173764"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Theses","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/17","score":0.4699999988079071,"display_name":"Partnerships for the goals"}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":49,"referenced_works":["https://openalex.org/W189748220","https://openalex.org/W1495087637","https://openalex.org/W1508280916","https://openalex.org/W1519496539","https://openalex.org/W1523021320","https://openalex.org/W1542975293","https://openalex.org/W1546727036","https://openalex.org/W1580664042","https://openalex.org/W1705071368","https://openalex.org/W1876545334","https://openalex.org/W1986105101","https://openalex.org/W1994257154","https://openalex.org/W1999336811","https://openalex.org/W2000729559","https://openalex.org/W2016849154","https://openalex.org/W2023761072","https://openalex.org/W2026879022","https://openalex.org/W2033675214","https://openalex.org/W2039853491","https://openalex.org/W2047869411","https://openalex.org/W2062372058","https://openalex.org/W2089020545","https://openalex.org/W2089755106","https://openalex.org/W2092911542","https://openalex.org/W2095825766","https://openalex.org/W2097279136","https://openalex.org/W2103642785","https://openalex.org/W2103933790","https://openalex.org/W2107742808","https://openalex.org/W2111534760","https://openalex.org/W2113751407","https://openalex.org/W2122621236","https://openalex.org/W2127501412","https://openalex.org/W2128585185","https://openalex.org/W2130392506","https://openalex.org/W2135430119","https://openalex.org/W2141157907","https://openalex.org/W2147112772","https://openalex.org/W2149089882","https://openalex.org/W2151792522","https://openalex.org/W2155500238","https://openalex.org/W2158161421","https://openalex.org/W2160091914","https://openalex.org/W2161318861","https://openalex.org/W2162942575","https://openalex.org/W2163654949","https://openalex.org/W2163977249","https://openalex.org/W2169347615","https://openalex.org/W2256465061"],"related_works":["https://openalex.org/W2045742725","https://openalex.org/W2120193195","https://openalex.org/W57200497","https://openalex.org/W2171499640","https://openalex.org/W2094214855","https://openalex.org/W1491227338","https://openalex.org/W2101555342","https://openalex.org/W2130926824","https://openalex.org/W2169026113","https://openalex.org/W1493646422"],"abstract_inverted_index":{"Software":[0],"transactional":[1],"memory":[2],"(STM)":[3],"has":[4,125],"proven":[5],"to":[6,31,45,50,81,101,134,203,212],"be":[7],"a":[8,25,94,103,110,173,196],"useful":[9],"abstraction":[10],"for":[11,161],"developing":[12],"concurrent":[13],"applications,":[14],"where":[15],"programmers":[16],"denote":[17],"transactions":[18,42,70,133],"with":[19,48,63,83,159],"an":[20,156,206],"atomic":[21],"construct":[22],"that":[23,40,59,97,124,184,190],"delimits":[24],"collection":[26],"of":[27,68,109,115,121,152,201,210],"reads":[28],"and":[29,71,87,141,163,177,205],"writes":[30],"shared":[32],"mutable":[33],"references.":[34],"The":[35],"runtime":[36,56],"system":[37,57],"then":[38],"guarantees":[39],"all":[41],"are":[43],"observed":[44],"execute":[46],"atomically":[47],"respect":[49],"each":[51],"other.":[52],"Traditionally,":[53],"when":[54],"the":[55,69,76,107,113,119,122,150,153],"detects":[58],"one":[60,67,189],"transaction":[61,105,123],"conflicts":[62],"another,":[64],"it":[65],"aborts":[66,187],"restarts":[72],"its":[73],"execution":[74,85,139,199],"from":[75,118],"beginning.":[77],"This":[78],"can":[79],"lead":[80],"problems":[82],"both":[84],"time":[86,140,200],"throughput.":[88,143],"In":[89,129],"this":[90,131,147],"paper,":[91],"we":[92,166,194],"present":[93],"novel":[95],"approach":[96],"uses":[98],"first-class":[99],"continuations":[100],"restart":[102],"conflicting":[104],"at":[106],"point":[108],"conflict,":[111],"avoiding":[112],"re-execution":[114],"any":[116],"work":[117],"beginning":[120],"not":[126],"been":[127],"compromised.":[128],"practice,":[130],"allows":[132],"complete":[135],"more":[136],"quickly,":[137],"decreasing":[138],"increasing":[142],"We":[144],"have":[145],"implemented":[146],"idea":[148],"in":[149,198,208],"context":[151],"Manticore":[154],"project,":[155],"ML-family":[157],"language":[158],"support":[160],"parallelism":[162],"concurrency.":[164],"Crucially,":[165],"rely":[167],"on":[168],"constant-time":[169],"continuation":[170],"capturing":[171],"via":[172],"continuation-passing-style":[174],"(CPS)":[175],"transformation":[176],"heap-allocated":[178],"continuations.":[179],"When":[180],"comparing":[181],"our":[182],"STM":[183],"performs":[185,191],"partial":[186],"against":[188],"full":[192],"aborts,":[193],"achieve":[195],"decrease":[197],"up":[202,211],"31%":[204],"increase":[207],"throughput":[209],"351%.":[213]},"counts_by_year":[{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":3}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
