Publication:
Proving linearizability using forward simulations

dc.contributor.coauthorBouajjani, Ahmed
dc.contributor.coauthorEmmi, Michael
dc.contributor.coauthorEnea, Constantin
dc.contributor.departmentN/A
dc.contributor.kuauthorMutluergil, Süha Orhun
dc.contributor.kuprofilePhD Student
dc.contributor.schoolcollegeinstituteGraduate School of Sciences and Engineering
dc.contributor.yokidN/A
dc.date.accessioned2024-11-09T22:49:29Z
dc.date.issued2017
dc.description.abstractLinearizability is the standard correctness criterion for concurrent data structures such as stacks and queues. It allows to establish observational refinement between a concurrent implementation and an atomic reference implementation. Proving linearizability requires identifying linearization points for each method invocation along all possible computations, leading to valid sequential executions, or alternatively, establishing forward and backward simulations. In both cases, carrying out proofs is hard and complex in general. In particular, backward reasoning is difficult in the context of programs with data structures, and strategies for identifying statically linearization points cannot be defined for all existing implementations. In this paper, we show that, contrary to common belief, many such complex implementations, including, e.g., the Herlihy and Wing Queue and the Time-Stamped Stack, can be proved correct using only forward simulation arguments. This leads to simple and natural correctness proofs for these implementations that are amenable to automation.
dc.description.indexedbyWoS
dc.description.indexedbyScopus
dc.description.openaccessNO
dc.description.publisherscopeInternational
dc.description.sponsoredbyTubitakEuN/A
dc.description.volume10427
dc.identifier.doi10.1007/978-3-319-63390-9_28
dc.identifier.eissn1611-3349
dc.identifier.isbn978-3-319-63390-9
dc.identifier.isbn978-3-319-63389-3
dc.identifier.issn0302-9743
dc.identifier.quartileQ4
dc.identifier.scopus2-s2.0-85026759575
dc.identifier.urihttp://dx.doi.org/10.1007/978-3-319-63390-9_28
dc.identifier.urihttps://hdl.handle.net/20.500.14288/6511
dc.identifier.wos431900900028
dc.keywordsN/A
dc.languageEnglish
dc.sourceComputer Aided Verification (Cav 2017), Pt Ii
dc.subjectComputer Science
dc.titleProving linearizability using forward simulations
dc.typeConference proceeding
dspace.entity.typePublication
local.contributor.authoridN/A
local.contributor.kuauthorMutluergil, Süha Orhun

Files