English

Adapting Persistent Data Structures for Concurrency and Speculation

Distributed, Parallel, and Cluster Computing 2020-03-18 v1 Data Structures and Algorithms Programming Languages

Abstract

This work unifies insights from the systems and functional programming communities, in order to enable compositional reasoning about software which is nonetheless efficiently realizable in hardware. It exploits a correspondence between design goals for efficient concurrent data structures and efficient immutable persistent data structures, to produce novel implementations of mutable concurrent trees with low contention and an efficient snapshot operation to support speculative execution models. It also exploits commutativity to characterize a design space for integrating traditional high-performance concurrent data structures into Software Transactional Memory (STM) runtimes, and extends this technique to yield a novel algorithm for concurrent execution of so-called ``smart contracts'' (specialized programs which manipulate the state of blockchain ledgers).

Keywords

Cite

@article{arxiv.2003.07395,
  title  = {Adapting Persistent Data Structures for Concurrency and Speculation},
  author = {Thomas Dickerson},
  journal= {arXiv preprint arXiv:2003.07395},
  year   = {2020}
}

Comments

PhD Thesis, Brown University (2019)