{"id":"https://openalex.org/W4294841133","doi":"https://doi.org/10.1145/3546189.3549924","title":"Open transactional actions: interacting with non-transactional resources in STM Haskell","display_name":"Open transactional actions: interacting with non-transactional resources in STM Haskell","publication_year":2022,"publication_date":"2022-09-06","ids":{"openalex":"https://openalex.org/W4294841133","doi":"https://doi.org/10.1145/3546189.3549924"},"language":"en","primary_location":{"id":"doi:10.1145/3546189.3549924","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3546189.3549924","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 15th ACM SIGPLAN International Haskell Symposium","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/A5045674724","display_name":"Jonathas Augusto de Oliveira Concei\u00e7\u00e3o","orcid":null},"institutions":[{"id":"https://openalex.org/I169248161","display_name":"Universidade Federal de Pelotas","ror":"https://ror.org/05msy9z54","country_code":"BR","type":"education","lineage":["https://openalex.org/I169248161"]}],"countries":["BR"],"is_corresponding":true,"raw_author_name":"Jonathas Augusto de Oliveira Concei\u00e7\u00e3o","raw_affiliation_strings":["Federal University of Pelotas, Brazil"],"affiliations":[{"raw_affiliation_string":"Federal University of Pelotas, Brazil","institution_ids":["https://openalex.org/I169248161"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5039149327","display_name":"Andr\u00e9 Rauber Du Bois","orcid":"https://orcid.org/0000-0002-6790-5184"},"institutions":[{"id":"https://openalex.org/I169248161","display_name":"Universidade Federal de Pelotas","ror":"https://ror.org/05msy9z54","country_code":"BR","type":"education","lineage":["https://openalex.org/I169248161"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Andr\u00e9 Rauber Du Bois","raw_affiliation_strings":["Federal University of Pelotas, Brazil"],"affiliations":[{"raw_affiliation_string":"Federal University of Pelotas, Brazil","institution_ids":["https://openalex.org/I169248161"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5008042282","display_name":"Samuel da Silva Feitosa","orcid":"https://orcid.org/0000-0002-9485-4845"},"institutions":[{"id":"https://openalex.org/I3130004620","display_name":"Universidade Federal da Fronteira Sul","ror":"https://ror.org/03z9wm572","country_code":"BR","type":"education","lineage":["https://openalex.org/I3130004620"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Samuel da Silva Feitosa","raw_affiliation_strings":["Federal University of Fronteira Sul, Brazil"],"affiliations":[{"raw_affiliation_string":"Federal University of Fronteira Sul, Brazil","institution_ids":["https://openalex.org/I3130004620"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5075219274","display_name":"Gerson Geraldo H. Cavalheiro","orcid":"https://orcid.org/0000-0002-4314-3429"},"institutions":[{"id":"https://openalex.org/I169248161","display_name":"Universidade Federal de Pelotas","ror":"https://ror.org/05msy9z54","country_code":"BR","type":"education","lineage":["https://openalex.org/I169248161"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Gerson Geraldo Homrich Cavalheiro","raw_affiliation_strings":["Federal University of Pelotas, Brazil"],"affiliations":[{"raw_affiliation_string":"Federal University of Pelotas, Brazil","institution_ids":["https://openalex.org/I169248161"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5061049872","display_name":"Rodrigo Ribeiro","orcid":"https://orcid.org/0000-0003-0131-5154"},"institutions":[{"id":"https://openalex.org/I10824318","display_name":"Universidade Federal de Ouro Preto","ror":"https://ror.org/056s65p46","country_code":"BR","type":"education","lineage":["https://openalex.org/I10824318"]}],"countries":["BR"],"is_corresponding":false,"raw_author_name":"Rodrigo Geraldo Ribeiro","raw_affiliation_strings":["Federal University of Ouro Preto, Brazil"],"affiliations":[{"raw_affiliation_string":"Federal University of Ouro Preto, Brazil","institution_ids":["https://openalex.org/I10824318"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5045674724"],"corresponding_institution_ids":["https://openalex.org/I169248161"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":false,"cited_by_count":0,"citation_normalized_percentile":{"value":0.10903658,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":null,"issue":null,"first_page":"54","last_page":"65"},"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/T10126","display_name":"Logic, programming, and type systems","score":0.9947999715805054,"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.9944000244140625,"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/transactional-memory","display_name":"Transactional memory","score":0.8664710521697998},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8369115591049194},{"id":"https://openalex.org/keywords/software-transactional-memory","display_name":"Software transactional memory","score":0.8021509647369385},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.7400365471839905},{"id":"https://openalex.org/keywords/commit","display_name":"Commit","score":0.7054028511047363},{"id":"https://openalex.org/keywords/undo","display_name":"Undo","score":0.6666606068611145},{"id":"https://openalex.org/keywords/transactional-leadership","display_name":"Transactional leadership","score":0.6138873100280762},{"id":"https://openalex.org/keywords/transaction-processing","display_name":"Transaction processing","score":0.5809611082077026},{"id":"https://openalex.org/keywords/compensating-transaction","display_name":"Compensating transaction","score":0.5079966187477112},{"id":"https://openalex.org/keywords/database-transaction","display_name":"Database transaction","score":0.4442847967147827},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.4189188480377197},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.4081021547317505},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.3539257049560547},{"id":"https://openalex.org/keywords/distributed-transaction","display_name":"Distributed transaction","score":0.31133997440338135},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.24971875548362732},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.22695541381835938}],"concepts":[{"id":"https://openalex.org/C134277064","wikidata":"https://www.wikidata.org/wiki/Q878206","display_name":"Transactional memory","level":3,"score":0.8664710521697998},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8369115591049194},{"id":"https://openalex.org/C167149655","wikidata":"https://www.wikidata.org/wiki/Q1189004","display_name":"Software transactional memory","level":4,"score":0.8021509647369385},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.7400365471839905},{"id":"https://openalex.org/C153180980","wikidata":"https://www.wikidata.org/wiki/Q19776675","display_name":"Commit","level":2,"score":0.7054028511047363},{"id":"https://openalex.org/C2780154230","wikidata":"https://www.wikidata.org/wiki/Q513420","display_name":"Undo","level":2,"score":0.6666606068611145},{"id":"https://openalex.org/C68489960","wikidata":"https://www.wikidata.org/wiki/Q2370659","display_name":"Transactional leadership","level":2,"score":0.6138873100280762},{"id":"https://openalex.org/C72108876","wikidata":"https://www.wikidata.org/wiki/Q844565","display_name":"Transaction processing","level":3,"score":0.5809611082077026},{"id":"https://openalex.org/C155951066","wikidata":"https://www.wikidata.org/wiki/Q5156254","display_name":"Compensating transaction","level":5,"score":0.5079966187477112},{"id":"https://openalex.org/C75949130","wikidata":"https://www.wikidata.org/wiki/Q848010","display_name":"Database transaction","level":2,"score":0.4442847967147827},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.4189188480377197},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.4081021547317505},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.3539257049560547},{"id":"https://openalex.org/C25185021","wikidata":"https://www.wikidata.org/wiki/Q4053284","display_name":"Distributed transaction","level":4,"score":0.31133997440338135},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.24971875548362732},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.22695541381835938},{"id":"https://openalex.org/C77805123","wikidata":"https://www.wikidata.org/wiki/Q161272","display_name":"Social psychology","level":1,"score":0.0},{"id":"https://openalex.org/C15744967","wikidata":"https://www.wikidata.org/wiki/Q9418","display_name":"Psychology","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3546189.3549924","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3546189.3549924","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 15th ACM SIGPLAN International Haskell Symposium","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":12,"referenced_works":["https://openalex.org/W195802685","https://openalex.org/W1553372926","https://openalex.org/W1959322244","https://openalex.org/W2015193657","https://openalex.org/W2023761072","https://openalex.org/W2108287664","https://openalex.org/W2120797071","https://openalex.org/W2129458440","https://openalex.org/W2169093943","https://openalex.org/W2405895187","https://openalex.org/W2824641430","https://openalex.org/W4243534587"],"related_works":["https://openalex.org/W2350635641","https://openalex.org/W2111271503","https://openalex.org/W2132484060","https://openalex.org/W2171499640","https://openalex.org/W2149473197","https://openalex.org/W2416173640","https://openalex.org/W57200497","https://openalex.org/W4294841133","https://openalex.org/W1608184500","https://openalex.org/W2013953807"],"abstract_inverted_index":{"This":[0],"paper":[1],"addresses":[2],"the":[3,42,61,67,79,85,88,104],"problem":[4],"of":[5,160],"accessing":[6],"external":[7],"resources":[8,35,46,70],"from":[9,50],"inside":[10,51],"transactions":[11,74],"in":[12,36,84,185],"STM":[13,183],"Haskell,":[14],"and":[15,53,58,78,120,142,173],"for":[16,32],"that":[17,28,111,129,165,178],"purpose":[18],"introduces":[19],"a":[20,30,37,113,146,158],"new":[21],"abstraction":[22],"called":[23],"Open":[24],"Transactional":[25],"Actions":[26],"(OTAs)":[27],"provides":[29],"framework":[31],"wrapping":[33],"non-transactional":[34],"transactional":[38,147,155,170,174],"layer.":[39],"OTAs":[40,130,167],"allow":[41],"programmer":[43],"to":[44,55,65,69,72,81,91,99,137,144,149,168],"access":[45,172],"through":[47],"IO":[48],"actions,":[49],"transactions,":[52],"also":[54,143],"register":[56],"commit":[57,76,119],"abort":[59,121],"handlers:":[60],"former":[62],"are":[63,97,179],"used":[64,133],"make":[66],"accesses":[68],"visible":[71],"other":[73],"at":[75],"time,":[77],"latter":[80],"undo":[82],"changes":[83],"resource":[86,114],"if":[87,112],"transaction":[89,106],"has":[90],"roll":[92],"back.":[93],"OTAs,":[94],"once":[95],"started,":[96],"guaranteed":[98],"be":[100,108,124,132],"executed":[101],"completely":[102],"before":[103],"hosting":[105],"can":[107],"aborted,":[109],"guarantying":[110],"is":[115],"accessed,":[116],"its":[117],"respective":[118],"actions":[122],"will":[123],"properly":[125],"registered.":[126],"We":[127],"believe":[128],"could":[131],"by":[134],"expert":[135],"programmers":[136],"implement":[138,169],"useful":[139],"system":[140],"libraries":[141],"give":[145],"semantics":[148],"fast":[150],"linearizable":[151],"data":[152,176],"structures,":[153],"i.e.,":[154],"boosting.":[156],"As":[157],"proof":[159],"concept,":[161],"we":[162],"present":[163],"examples":[164],"use":[166],"file":[171],"boosted":[175],"types":[177],"faster":[180],"than":[181],"pure":[182],"Haskell":[184],"most":[186],"cases.":[187]},"counts_by_year":[],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
