Lower Bounds on the Amortized Time Complexity of Shared Objects

Hagit Attiya,Arie Fouren,Jeremy Ko
DOI: https://doi.org/10.1007/s00224-024-10184-w
IF: 0.616
2024-07-13
Theory of Computing Systems
Abstract:The amortized step complexity of an implementation measures its performance as a whole, rather than the performance of individual operations. Specifically, the amortized step complexity of an implementation is the average number of steps performed by invoked operations, in the worst case, taken over all possible executions. The point contention of an execution, denoted by , measures the maximal number of precesses simultaneously active in the execution. Ruppert (2016) showed that the amortized step complexity of known lock-free implementations for many shared data structures includes an additive factor linear in the point contention . This paper shows that there is no lock-free implementation with amortized RMR complexity of queues, stacks or heaps from reads, writes, comparison primitives (such as compare &swap ) and LL/SC , where n is the total number of the processes in the system. In addition, the paper shows a lower bound on the amortized step complexity for shared linked lists, skip lists, search trees and other pointer-based data structures. These lower bounds mean that the additive factor linear in is inherent for these implementations, provided that the point contention is small compared to the number of processes in the system (i.e. or ).
computer science, theory & methods,mathematics
What problem does this paper attempt to address?