{"id":"https://openalex.org/W2071457972","doi":"https://doi.org/10.1137/s0097539794278396","title":"Shared Memory Consistency Conditions for Nonsequential Execution: Definitions and Programming Strategies","display_name":"Shared Memory Consistency Conditions for Nonsequential Execution: Definitions and Programming Strategies","publication_year":1998,"publication_date":"1998-02-01","ids":{"openalex":"https://openalex.org/W2071457972","doi":"https://doi.org/10.1137/s0097539794278396","mag":"2071457972"},"language":"en","primary_location":{"id":"doi:10.1137/s0097539794278396","is_oa":false,"landing_page_url":"https://doi.org/10.1137/s0097539794278396","pdf_url":null,"source":{"id":"https://openalex.org/S153560523","display_name":"SIAM Journal on Computing","issn_l":"0097-5397","issn":["0097-5397","1095-7111"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320508","host_organization_name":"Society for Industrial and Applied Mathematics","host_organization_lineage":["https://openalex.org/P4310320508"],"host_organization_lineage_names":["Society for Industrial and Applied Mathematics"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"SIAM Journal on Computing","raw_type":"journal-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/A5029333678","display_name":"Hagit Attiya","orcid":"https://orcid.org/0000-0002-8017-6457"},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Hagit Attiya","raw_affiliation_strings":[],"affiliations":[]},{"author_position":"middle","author":{"id":"https://openalex.org/A5060797696","display_name":"S.K. Chaudhuri","orcid":"https://orcid.org/0000-0002-6241-2428"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Soma Chaudhuri","raw_affiliation_strings":[],"affiliations":[]},{"author_position":"middle","author":{"id":"https://openalex.org/A5068251891","display_name":"Roy Friedman","orcid":"https://orcid.org/0000-0001-6460-9665"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Roy Friedman","raw_affiliation_strings":[],"affiliations":[]},{"author_position":"last","author":{"id":"https://openalex.org/A5014894919","display_name":"Jennifer L. Welch","orcid":"https://orcid.org/0000-0001-7164-1436"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Jennifer L. Welch","raw_affiliation_strings":[],"affiliations":[]}],"institutions":[],"countries_distinct_count":0,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5029333678"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.80616791,"has_fulltext":false,"cited_by_count":22,"citation_normalized_percentile":{"value":0.91040196,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":96},"biblio":{"volume":"27","issue":"1","first_page":"65","last_page":"89"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9998000264167786,"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":0.9998000264167786,"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.9998000264167786,"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/T10933","display_name":"Real-Time Systems Scheduling","score":0.9965999722480774,"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/sequential-consistency","display_name":"Sequential consistency","score":0.8952775001525879},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8691393136978149},{"id":"https://openalex.org/keywords/consistency-model","display_name":"Consistency model","score":0.8269994854927063},{"id":"https://openalex.org/keywords/cache-coherence","display_name":"Cache coherence","score":0.6601377129554749},{"id":"https://openalex.org/keywords/consistency","display_name":"Consistency (knowledge bases)","score":0.6361502408981323},{"id":"https://openalex.org/keywords/weak-consistency","display_name":"Weak consistency","score":0.5946197509765625},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.5674879550933838},{"id":"https://openalex.org/keywords/shared-memory","display_name":"Shared memory","score":0.5337183475494385},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.5252375602722168},{"id":"https://openalex.org/keywords/causal-consistency","display_name":"Causal consistency","score":0.49650102853775024},{"id":"https://openalex.org/keywords/strong-consistency","display_name":"Strong consistency","score":0.45894163846969604},{"id":"https://openalex.org/keywords/distributed-shared-memory","display_name":"Distributed shared memory","score":0.44265037775039673},{"id":"https://openalex.org/keywords/speculative-execution","display_name":"Speculative execution","score":0.4405458867549896},{"id":"https://openalex.org/keywords/memory-model","display_name":"Memory model","score":0.4294924736022949},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.4261074960231781},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.42589670419692993},{"id":"https://openalex.org/keywords/eventual-consistency","display_name":"Eventual consistency","score":0.4236133396625519},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.42149531841278076},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.3845762312412262},{"id":"https://openalex.org/keywords/memory-management","display_name":"Memory management","score":0.35930466651916504},{"id":"https://openalex.org/keywords/uniform-memory-access","display_name":"Uniform memory access","score":0.32931697368621826},{"id":"https://openalex.org/keywords/cpu-cache","display_name":"CPU cache","score":0.1418209671974182},{"id":"https://openalex.org/keywords/overlay","display_name":"Overlay","score":0.11472254991531372},{"id":"https://openalex.org/keywords/cache","display_name":"Cache","score":0.1004011332988739}],"concepts":[{"id":"https://openalex.org/C82029504","wikidata":"https://www.wikidata.org/wiki/Q4373882","display_name":"Sequential consistency","level":4,"score":0.8952775001525879},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8691393136978149},{"id":"https://openalex.org/C37279795","wikidata":"https://www.wikidata.org/wiki/Q2492305","display_name":"Consistency model","level":3,"score":0.8269994854927063},{"id":"https://openalex.org/C141917322","wikidata":"https://www.wikidata.org/wiki/Q1025017","display_name":"Cache coherence","level":5,"score":0.6601377129554749},{"id":"https://openalex.org/C2776436953","wikidata":"https://www.wikidata.org/wiki/Q5163215","display_name":"Consistency (knowledge bases)","level":2,"score":0.6361502408981323},{"id":"https://openalex.org/C122377713","wikidata":"https://www.wikidata.org/wiki/Q4422799","display_name":"Weak consistency","level":4,"score":0.5946197509765625},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.5674879550933838},{"id":"https://openalex.org/C133875982","wikidata":"https://www.wikidata.org/wiki/Q764810","display_name":"Shared memory","level":2,"score":0.5337183475494385},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.5252375602722168},{"id":"https://openalex.org/C175652121","wikidata":"https://www.wikidata.org/wiki/Q4379351","display_name":"Causal consistency","level":5,"score":0.49650102853775024},{"id":"https://openalex.org/C31388003","wikidata":"https://www.wikidata.org/wiki/Q7624548","display_name":"Strong consistency","level":3,"score":0.45894163846969604},{"id":"https://openalex.org/C39528615","wikidata":"https://www.wikidata.org/wiki/Q1229610","display_name":"Distributed shared memory","level":5,"score":0.44265037775039673},{"id":"https://openalex.org/C141331961","wikidata":"https://www.wikidata.org/wiki/Q2164465","display_name":"Speculative execution","level":2,"score":0.4405458867549896},{"id":"https://openalex.org/C12186640","wikidata":"https://www.wikidata.org/wiki/Q6815743","display_name":"Memory model","level":3,"score":0.4294924736022949},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.4261074960231781},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.42589670419692993},{"id":"https://openalex.org/C34422012","wikidata":"https://www.wikidata.org/wiki/Q6125872","display_name":"Eventual consistency","level":4,"score":0.4236133396625519},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.42149531841278076},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.3845762312412262},{"id":"https://openalex.org/C176649486","wikidata":"https://www.wikidata.org/wiki/Q2308807","display_name":"Memory management","level":3,"score":0.35930466651916504},{"id":"https://openalex.org/C51290061","wikidata":"https://www.wikidata.org/wiki/Q1936765","display_name":"Uniform memory access","level":4,"score":0.32931697368621826},{"id":"https://openalex.org/C189783530","wikidata":"https://www.wikidata.org/wiki/Q352090","display_name":"CPU cache","level":3,"score":0.1418209671974182},{"id":"https://openalex.org/C136085584","wikidata":"https://www.wikidata.org/wiki/Q910289","display_name":"Overlay","level":2,"score":0.11472254991531372},{"id":"https://openalex.org/C115537543","wikidata":"https://www.wikidata.org/wiki/Q165596","display_name":"Cache","level":2,"score":0.1004011332988739},{"id":"https://openalex.org/C38556500","wikidata":"https://www.wikidata.org/wiki/Q13404475","display_name":"Cache algorithms","level":4,"score":0.0},{"id":"https://openalex.org/C185429906","wikidata":"https://www.wikidata.org/wiki/Q1130160","display_name":"Estimator","level":2,"score":0.0},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1137/s0097539794278396","is_oa":false,"landing_page_url":"https://doi.org/10.1137/s0097539794278396","pdf_url":null,"source":{"id":"https://openalex.org/S153560523","display_name":"SIAM Journal on Computing","issn_l":"0097-5397","issn":["0097-5397","1095-7111"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320508","host_organization_name":"Society for Industrial and Applied Mathematics","host_organization_lineage":["https://openalex.org/P4310320508"],"host_organization_lineage_names":["Society for Industrial and Applied Mathematics"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"SIAM Journal on Computing","raw_type":"journal-article"}],"best_oa_location":null,"sustainable_development_goals":[{"display_name":"Quality Education","id":"https://metadata.un.org/sdg/4","score":0.5799999833106995}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":34,"referenced_works":["https://openalex.org/W84705427","https://openalex.org/W1555915743","https://openalex.org/W1556276302","https://openalex.org/W1601496654","https://openalex.org/W1738788207","https://openalex.org/W1973317281","https://openalex.org/W1984277858","https://openalex.org/W2034256728","https://openalex.org/W2035753617","https://openalex.org/W2039509099","https://openalex.org/W2040721264","https://openalex.org/W2054739713","https://openalex.org/W2061239425","https://openalex.org/W2066463092","https://openalex.org/W2071457972","https://openalex.org/W2079605740","https://openalex.org/W2088270410","https://openalex.org/W2101939036","https://openalex.org/W2107642570","https://openalex.org/W2114925953","https://openalex.org/W2116362085","https://openalex.org/W2128221687","https://openalex.org/W2131454290","https://openalex.org/W2133486861","https://openalex.org/W2144700431","https://openalex.org/W2144884804","https://openalex.org/W2147506153","https://openalex.org/W2163073407","https://openalex.org/W2170200862","https://openalex.org/W2176864362","https://openalex.org/W2295903464","https://openalex.org/W2914620247","https://openalex.org/W3137220996","https://openalex.org/W4255383975"],"related_works":["https://openalex.org/W118795575","https://openalex.org/W1946484695","https://openalex.org/W2025301734","https://openalex.org/W1979030370","https://openalex.org/W2036306661","https://openalex.org/W2108847887","https://openalex.org/W2258014168","https://openalex.org/W2034248803","https://openalex.org/W2336902627","https://openalex.org/W2232128199"],"abstract_inverted_index":{"To":[0],"enhance":[1],"performance":[2],"on":[3,51,177,237],"shared":[4,62,130],"memory":[5,17,63,71,131],"multiprocessors,":[6],"various":[7],"techniques":[8,121,159,241],"have":[9],"been":[10],"proposed":[11],"to":[12,94,144,167,185,189,202,251],"reduce":[13],"the":[14,38,46,82,85,134,146,207,227,230,238,246,252],"latency":[15],"of":[16,21,25,41,48,70,140,152,157,229,254],"accesses,":[18,22,26],"including":[19],"pipelining":[20],"out-of-order":[23],"execution":[24,69],"and":[27,84,87,102,187,221],"branch":[28],"prediction":[29],"with":[30],"speculative":[31],"execution.":[32,106],"These":[33],"optimizations":[34],"can,":[35],"however,":[36],"complicate":[37],"user's":[39],"model":[40],"memory.":[42],"This":[43,180],"paper":[44],"attacks":[45],"problem":[47],"simplifying":[49],"programming":[50,231],"two":[52],"fronts.":[53],"First,":[54],"a":[55,129,190,214],"general":[56,191],"framework":[57,91],"is":[58,80,88,92,160,182,201],"presented":[59],"for":[60,124,193,226],"defining":[61],"consistency":[64,97,109,142],"conditions":[65,77,110],"that":[66,128,132,161,245],"allows":[67],"nonsequential":[68,105],"accesses.":[72],"The":[73,90,155,170,198],"interface":[74],"at":[75],"which":[76,209],"are":[78,122,165,224],"defined":[79],"between":[81],"program":[83],"system":[86],"architecture-independent.":[89],"used":[93],"generalize":[95],"three":[96,120],"conditions---sequential":[98],"consistency,":[99,101],"hybrid":[100,141],"weak":[103],"consistency---for":[104],"Thus,":[107],"familiar":[108],"can":[111,249],"be":[112],"precisely":[113],"specified":[114],"even":[115],"in":[116,206,213],"optimized":[117],"architectures.":[118],"Second,":[119],"described":[123],"structuring":[125],"programs":[126],"so":[127],"provides":[133],"weaker":[135],"(and":[136,148],"more":[137,149],"efficient)":[138],"condition":[139,151],"appears":[143],"guarantee":[145],"stronger":[147],"costly)":[150],"sequential":[153],"consistency.":[154],"benefit":[156],"these":[158,240],"sequentially":[162],"consistent":[163],"executions":[164],"easier":[166],"reason":[168],"about.":[169],"first":[171],"technique":[172,192,200],"statically":[173],"classifies":[174],"accesses":[175],"based":[176],"their":[178],"type.":[179],"approach":[181],"extremely":[183],"simple":[184],"use":[186],"leads":[188],"writing":[194],"efficient":[195],"synchronization":[196],"code.":[197],"third":[199],"avoid":[203],"data":[204],"races":[205],"program,":[208],"was":[210],"previously":[211],"studied":[212],"somewhat":[215],"different":[216],"setting.":[217],"Precise,":[218],"yet":[219],"short":[220],"comprehensible,":[222],"proofs":[223,234],"provided":[225],"correctness":[228],"techniques.":[232,256],"Such":[233],"shed":[235],"light":[236],"reasons":[239],"work;":[242],"we":[243],"believe":[244],"insight":[247],"gained":[248],"lead":[250],"development":[253],"other":[255]},"counts_by_year":[{"year":2016,"cited_by_count":2},{"year":2015,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
