Improving Authenticated Dynamic Dictionaries, with Applications to Cryptocurrencies

Leonid Reyzin, Dmitry Meshkov, Alexander Chepurnoy, and Sasha Ivanov

Abstract

We improve the design and implementation of two-party and three-party authenticated dynamic dictionaries and apply these dictionaries to cryptocurrency ledgers. A public ledger (blockchain) in a cryptocurrency needs to be easily verifiable. However, maintaining a data structure of all account balances, in order to verify whether a transaction is valid, can be quite burdensome: a verifier who does not have the large amount of RAM required for the data structure will perform slowly because of the need to continually access secondary storage. We demonstrate experimentally that authenticated dynamic dictionaries can considerably reduce verifier load. On the other hand, per-transaction proofs generated by authenticated dictionaries increase the size of the blockchain, which motivates us to find a solution with most compact proofs. Our improvements to the design of authenticated dictionaries reduce proof size and speed up verification by 1.4-2.5 times, making them better suited for the cryptocurrency application. We further show that proofs for multiple transactions in a single block can compressed together, reducing their total length by approximately an additional factor of 2. We simulate blockchain verification, and show that our verifier can be about 20 times faster than a disk-bound verifier under a realistic transaction load.

Note: Added more details on deletions and on guaranteed verifier efficiency.

Available format(s)
Category
Implementation
Publication info
Published elsewhere. MINOR revision.Financial Cryptography 2017
Keywords
authenticated data structuresMerkle treesblockchains
Contact author(s)
reyzin @ bu edu
History
2017-04-02: last of 4 revisions
See all versions
Short URL
https://ia.cr/2016/994

CC BY

BibTeX

@misc{cryptoeprint:2016/994,
author = {Leonid Reyzin and Dmitry Meshkov and Alexander Chepurnoy and Sasha Ivanov},
title = {Improving Authenticated Dynamic Dictionaries, with Applications to Cryptocurrencies},
howpublished = {Cryptology ePrint Archive, Paper 2016/994},
year = {2016},
note = {\url{https://eprint.iacr.org/2016/994}},
url = {https://eprint.iacr.org/2016/994}
}

Note: In order to protect the privacy of readers, eprint.iacr.org does not use cookies or embedded third party content.