Small refinements to the dam can have big consequences for data-structure design

Michael A. Bender, William Jannen, Eric Knorr, Prashant Pandey, Alex Conway, Yizheng Jiao, Sara McAllister, Donald E. Porter, Yang Zhan, Martín Farach-Colton, Rob Johnson, Nirjhar Mukherjee, Jun Yuan

    Research output: Chapter in Book/Report/Conference proceedingConference contribution

    Abstract

    Storage devices have complex performance profiles, including costs to initiate IOs (e.g., seek times in hard drives), parallelism and bank conflicts (in SSDs), costs to transfer data, and firmware-internal operations. The Disk-Access Machine (DAM) model simplifies reality by assuming that storage devices transfer data in blocks of size B and that all transfers have unit cost. Despite its simplifications, the DAM model is reasonably accurate. In fact, if B is set to the half-bandwidth point, where the latency and bandwidth of the hardware are equal, the DAM approximates the IO cost on any hardware to within a factor of 2. Furthermore, the DAM explains the popularity of B-trees in the 70s and the current popularity of Bε-trees and log-structured merge trees. But it fails to explain why some B-trees use small nodes, whereas all Bε-trees use large nodes. In a DAM, all IOs, and hence all nodes, are the same size. In this paper, we show that the affine and PDAM models, which are small refinements of the DAM model, yield a surprisingly large improvement in predictability without sacrificing ease of use. We present benchmarks on a large collection of storage devices showing that the affine and PDAM models give good approximations of the performance characteristics of hard drives and SSDs, respectively. We show that the affine model explains node-size choices in B-trees and Bε -trees. Furthermore, the models predict that the B-tree is highly sensitive to variations in the node size whereas Bε -trees are much less sensitive. These predictions are born out empirically. Finally, we show that in both the affine and PDAM models, it pays to organize data structures to exploit varying IO size. In the affine model, Bε -trees can be optimized so that all operations are simultaneously optimal, even up to lower order terms. In the PDAM model, Bε -trees (or B-trees) can be organized so that both sequential and concurrent workloads are handled efficiently. We conclude that the DAM model is useful as a first cut when designing or analyzing an algorithm or data structure but the affine and PDAM models enable the algorithm designer to optimize parameter choices and fill in design details.

    Original languageEnglish (US)
    Title of host publicationSPAA 2019 - Proceedings of the 31st ACM Symposium on Parallelism in Algorithms and Architectures
    PublisherAssociation for Computing Machinery
    Pages265-274
    Number of pages10
    ISBN (Electronic)9781450361842
    DOIs
    StatePublished - Jun 17 2019
    Event31st ACM Symposium on Parallelism in Algorithms and Architectures, SPAA 2019 - Phoenix, United States
    Duration: Jun 22 2019Jun 24 2019

    Publication series

    NameAnnual ACM Symposium on Parallelism in Algorithms and Architectures

    Conference

    Conference31st ACM Symposium on Parallelism in Algorithms and Architectures, SPAA 2019
    Country/TerritoryUnited States
    CityPhoenix
    Period6/22/196/24/19

    ASJC Scopus subject areas

    • Software
    • Theoretical Computer Science
    • Hardware and Architecture

    Fingerprint

    Dive into the research topics of 'Small refinements to the dam can have big consequences for data-structure design'. Together they form a unique fingerprint.

    Cite this