{"id":"https://openalex.org/W2115968584","doi":"https://doi.org/10.1145/1007912.1007933","title":"On-the-fly maintenance of series-parallel relationships in fork-join multithreaded programs","display_name":"On-the-fly maintenance of series-parallel relationships in fork-join multithreaded programs","publication_year":2004,"publication_date":"2004-06-27","ids":{"openalex":"https://openalex.org/W2115968584","doi":"https://doi.org/10.1145/1007912.1007933","mag":"2115968584"},"language":"en","primary_location":{"id":"doi:10.1145/1007912.1007933","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1007912.1007933","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the sixteenth annual ACM symposium on Parallelism in algorithms and architectures","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"http://hdl.handle.net/1721.1/7430","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5068761590","display_name":"Michael A. Bender","orcid":"https://orcid.org/0000-0001-7639-530X"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Michael A. Bender","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA","Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA","institution_ids":["https://openalex.org/I63966007"]},{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5011772692","display_name":"Jeremy T. Fineman","orcid":"https://orcid.org/0009-0000-7483-4532"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jeremy T. Fineman","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA","Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA","institution_ids":["https://openalex.org/I63966007"]},{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5042520814","display_name":"Seth Gilbert","orcid":"https://orcid.org/0000-0003-3298-7412"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Seth Gilbert","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA","Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA","institution_ids":["https://openalex.org/I63966007"]},{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5027618658","display_name":"Charles E. Leiserson","orcid":"https://orcid.org/0000-0001-6386-5552"},"institutions":[{"id":"https://openalex.org/I63966007","display_name":"Massachusetts Institute of Technology","ror":"https://ror.org/042nb2s44","country_code":"US","type":"education","lineage":["https://openalex.org/I63966007"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Charles E. Leiserson","raw_affiliation_strings":["Massachusetts Institute of Technology, Cambridge, MA","Massachusetts Institute of Technology, Cambridge, MA,"],"affiliations":[{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA","institution_ids":["https://openalex.org/I63966007"]},{"raw_affiliation_string":"Massachusetts Institute of Technology, Cambridge, MA,","institution_ids":["https://openalex.org/I63966007"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5068761590"],"corresponding_institution_ids":["https://openalex.org/I63966007"],"apc_list":null,"apc_paid":null,"fwci":0.7923,"has_fulltext":false,"cited_by_count":60,"citation_normalized_percentile":{"value":0.72407904,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"133","last_page":"144"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":1.0,"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"}},"topics":[{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":1.0,"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.9986000061035156,"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/T11181","display_name":"Advanced Data Storage Technologies","score":0.9984999895095825,"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.733010470867157},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.6616778373718262},{"id":"https://openalex.org/keywords/fork","display_name":"Fork (system call)","score":0.5957541465759277},{"id":"https://openalex.org/keywords/parallel-algorithm","display_name":"Parallel algorithm","score":0.468352735042572},{"id":"https://openalex.org/keywords/series-and-parallel-circuits","display_name":"Series and parallel circuits","score":0.46074429154396057},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.4487440288066864},{"id":"https://openalex.org/keywords/thread","display_name":"Thread (computing)","score":0.4303537905216217},{"id":"https://openalex.org/keywords/fork\u2013join-queue","display_name":"Fork\u2013join queue","score":0.4207099974155426},{"id":"https://openalex.org/keywords/identifier","display_name":"Identifier","score":0.41609811782836914},{"id":"https://openalex.org/keywords/debugging","display_name":"Debugging","score":0.41326022148132324},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.1941104531288147},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.13887718319892883},{"id":"https://openalex.org/keywords/queue","display_name":"Queue","score":0.09108588099479675}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.733010470867157},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.6616778373718262},{"id":"https://openalex.org/C40523978","wikidata":"https://www.wikidata.org/wiki/Q14675","display_name":"Fork (system call)","level":2,"score":0.5957541465759277},{"id":"https://openalex.org/C120373497","wikidata":"https://www.wikidata.org/wiki/Q1087987","display_name":"Parallel algorithm","level":2,"score":0.468352735042572},{"id":"https://openalex.org/C95023266","wikidata":"https://www.wikidata.org/wiki/Q55738334","display_name":"Series and parallel circuits","level":3,"score":0.46074429154396057},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.4487440288066864},{"id":"https://openalex.org/C138101251","wikidata":"https://www.wikidata.org/wiki/Q213092","display_name":"Thread (computing)","level":2,"score":0.4303537905216217},{"id":"https://openalex.org/C124444977","wikidata":"https://www.wikidata.org/wiki/Q4025962","display_name":"Fork\u2013join queue","level":4,"score":0.4207099974155426},{"id":"https://openalex.org/C154504017","wikidata":"https://www.wikidata.org/wiki/Q853614","display_name":"Identifier","level":2,"score":0.41609811782836914},{"id":"https://openalex.org/C168065819","wikidata":"https://www.wikidata.org/wiki/Q845566","display_name":"Debugging","level":2,"score":0.41326022148132324},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.1941104531288147},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.13887718319892883},{"id":"https://openalex.org/C160403385","wikidata":"https://www.wikidata.org/wiki/Q220543","display_name":"Queue","level":2,"score":0.09108588099479675},{"id":"https://openalex.org/C128220111","wikidata":"https://www.wikidata.org/wiki/Q4531011","display_name":"Queue management system","level":3,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0},{"id":"https://openalex.org/C165801399","wikidata":"https://www.wikidata.org/wiki/Q25428","display_name":"Voltage","level":2,"score":0.0}],"mesh":[],"locations_count":5,"locations":[{"id":"doi:10.1145/1007912.1007933","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1007912.1007933","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the sixteenth annual ACM symposium on Parallelism in algorithms and architectures","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.142.213","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.142.213","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://theory.csail.mit.edu/~jfineman/sporder.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.3.3581","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.3.3581","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.sunysb.edu/~bender/pub/SPAA2004-sporder.ps","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.93.8532","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.93.8532","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://supertech.csail.mit.edu/papers/sporder.pdf","raw_type":"text"},{"id":"pmh:oai:dspace.mit.edu:1721.1/7430","is_oa":true,"landing_page_url":"http://hdl.handle.net/1721.1/7430","pdf_url":null,"source":{"id":"https://openalex.org/S4306400425","display_name":"DSpace@MIT (Massachusetts Institute of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I63966007","host_organization_name":"Massachusetts Institute of Technology","host_organization_lineage":["https://openalex.org/I63966007"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc","license_id":"https://openalex.org/licenses/cc-by-nc","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"Article"}],"best_oa_location":{"id":"pmh:oai:dspace.mit.edu:1721.1/7430","is_oa":true,"landing_page_url":"http://hdl.handle.net/1721.1/7430","pdf_url":null,"source":{"id":"https://openalex.org/S4306400425","display_name":"DSpace@MIT (Massachusetts Institute of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I63966007","host_organization_name":"Massachusetts Institute of Technology","host_organization_lineage":["https://openalex.org/I63966007"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc","license_id":"https://openalex.org/licenses/cc-by-nc","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"Article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":39,"referenced_works":["https://openalex.org/W1513400187","https://openalex.org/W1518873433","https://openalex.org/W1624393875","https://openalex.org/W1676865579","https://openalex.org/W1768637848","https://openalex.org/W1965708711","https://openalex.org/W1976316756","https://openalex.org/W1976392304","https://openalex.org/W1981272925","https://openalex.org/W1986022261","https://openalex.org/W1990376056","https://openalex.org/W1990754477","https://openalex.org/W1996578733","https://openalex.org/W2001326908","https://openalex.org/W2002364208","https://openalex.org/W2016559894","https://openalex.org/W2019611783","https://openalex.org/W2023658462","https://openalex.org/W2026511056","https://openalex.org/W2027181837","https://openalex.org/W2042611354","https://openalex.org/W2043003055","https://openalex.org/W2057994027","https://openalex.org/W2064396635","https://openalex.org/W2064750939","https://openalex.org/W2065808229","https://openalex.org/W2066952803","https://openalex.org/W2072725684","https://openalex.org/W2073193966","https://openalex.org/W2086812946","https://openalex.org/W2098147619","https://openalex.org/W2104861744","https://openalex.org/W2139539283","https://openalex.org/W2170200862","https://openalex.org/W2788695972","https://openalex.org/W3141930102","https://openalex.org/W3145128584","https://openalex.org/W4235499171","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W618449037","https://openalex.org/W2004812593","https://openalex.org/W2093074882","https://openalex.org/W2004439486","https://openalex.org/W2315975353","https://openalex.org/W2516172998","https://openalex.org/W2369103189","https://openalex.org/W4221031485","https://openalex.org/W2379380911","https://openalex.org/W3127886951"],"abstract_inverted_index":{"A":[0],"key":[1],"capability":[2],"of":[3,77,185,237],"data-race":[4,146],"detectors":[5],"is":[6,71,232],"to":[7,36,73,89],"determine":[8],"whether":[9,19],"one":[10,31,34],"thread":[11],"executes":[12],"logically":[13],"in":[14,24,53,100,117,133,197],"parallel":[15,166],"with":[16,156],"another":[17],"or":[18],"the":[20,42,61,128,209,230],"threads":[21],"must":[22],"operate":[23],"series.":[25],"This":[26],"paper":[27],"provides":[28],"two":[29],"algorithms,":[30],"serial":[32,49,160],"and":[33,158,181],"parallel,":[35],"maintain":[37],"series-parallel":[38],"(SP)":[39],"relationships":[40],"\"on":[41],"fly\"":[43],"for":[44,130,143,148],"fork-join":[45,114,174],"multithreaded":[46],"programs.":[47],"The":[48],"SP-order":[50,80,155],"algorithm":[51,64],"runs":[52,196],"O(1)":[54],"amortized":[55],"time":[56,67,119],"per":[57,68],"operation.":[58],"In":[59,111,221],"contrast,":[60,222],"previously":[62],"best":[63],"requires":[65],"a":[66,91,121,165,173,182,216,235],"operation":[69],"that":[70,86,151,172,194,208],"proportional":[72],"Tarjan's":[74],"functional":[75],"inverse":[76],"Ackermann's":[78],"function.":[79],"employs":[81],"an":[82,107],"order-maintenance":[83],"data":[84],"structure":[85],"allows":[87],"us":[88],"implement":[90],"more":[92,144],"efficient":[93],"\"English-Hebrew\"":[94],"labeling":[95],"scheme":[96],"than":[97],"was":[98],"used":[99],"earlier":[101],"race":[102],"detectors,":[103,147],"which":[104],"immediately":[105],"yields":[106],"improved":[108,137],"determinacy-race":[109],"detector.":[110],"particular,":[112],"any":[113],"program":[115,175,211],"running":[116],"T1":[118,179],"on":[120,127,189],"single":[122],"processor":[123],"can":[124,139],"be":[125,141],"checked":[126],"fly":[129],"determinacy":[131],"races":[132],"O(T1)":[134],"time.":[135,202],"Corresponding":[136],"bounds":[138],"also":[140],"obtained":[142],"sophisticated":[145],"example,":[149],"those":[150],"use":[152],"locks.By":[153],"combining":[154],"Feng":[157],"Leiserson's":[159],"SP-bags":[161],"algorithm,":[162,168],"we":[163,192],"obtain":[164],"SP-maintenance":[167],"called":[169],"SP-hybrid.":[170],"Suppose":[171],"has":[176],"n":[177],"threads,":[178],"work,":[180],"critical-path":[183],"length":[184],"T\u221e.":[186],"When":[187],"executed":[188],"P":[190],"processors,":[191],"prove":[193],"SP-hybrid":[195,223],"O((T1/P":[198],"+PT,/i>\u221e)lg":[199],"<i.n)":[200],"expected":[201],"To":[203],"understand":[204],"this":[205],"bound,":[206],"consider":[207],"original":[210],"obtains":[212,224],"linear":[213,225],"speed-up":[214,226],"over":[215],"1-processor":[217],"execution":[218],"when":[219,227],"P=O(T1T\u221e).":[220],"P=O(\u221aT1T\u221e),":[228],"but":[229],"work":[231],"increased":[233],"by":[234],"factor":[236],"O(lg":[238],"n).":[239]},"counts_by_year":[{"year":2024,"cited_by_count":3},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":4},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":7},{"year":2017,"cited_by_count":5},{"year":2016,"cited_by_count":3},{"year":2015,"cited_by_count":3},{"year":2014,"cited_by_count":3},{"year":2013,"cited_by_count":4},{"year":2012,"cited_by_count":9}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
