Distributed-Memory Randomized Algorithms for Sparse Tensor CP Decomposition
Vivek Bharadwaj, Osman Asif Malik, Riley Murray, Aydin Buluç, James Demmel
TL;DR
The paper develops scalable distributed-memory randomized CP decomposition for billion-scale sparse tensors, introducing two algorithms, CP-ARLS-LEV and STS-CP, that leverage leverage-score sampling to accelerate ALS-like updates. It presents novel distributed sampling procedures, a communication-optimized MTTKRP schedule, and a tailored local tensor storage format, achieving substantial speedups (up to about 11x) over state-of-the-art SPLATT on real-world tensors. Experiments show that the methods maintain accuracy comparable to non-randomized ALS while delivering strong scaling on thousands of CPU cores, with tradeoffs between speed and precision controlled by the sample count $J$. The work significantly improves practical feasibility of large-scale sparse tensor CP decomposition, enabling faster insights from massive multidimensional data in domains such as social networks, text corpora, and knowledge graphs.
Abstract
Candecomp / PARAFAC (CP) decomposition, a generalization of the matrix singular value decomposition to higher-dimensional tensors, is a popular tool for analyzing multidimensional sparse data. On tensors with billions of nonzero entries, computing a CP decomposition is a computationally intensive task. We propose the first distributed-memory implementations of two randomized CP decomposition algorithms, CP-ARLS-LEV and STS-CP, that offer nearly an order-of-magnitude speedup at high decomposition ranks over well-tuned non-randomized decomposition packages. Both algorithms rely on leverage score sampling and enjoy strong theoretical guarantees, each with varying time and accuracy tradeoffs. We tailor the communication schedule for our random sampling algorithms, eliminating expensive reduction collectives and forcing communication costs to scale with the random sample count. Finally, we optimize the local storage format for our methods, switching between analogues of compressed sparse column and compressed sparse row formats. Experiments show that our methods are fast and scalable, producing 11x speedup over SPLATT by decomposing the billion-scale Reddit tensor on 512 CPU cores in under two minutes.
