Publication | Open Access
High-Level Strategies for Parallel Shared-Memory Sparse Matrix-Vector Multiplication
71
Citations
32
References
2013
Year
Cluster ComputingComputational ScienceHigh-level StrategiesParallel EfficiencyEngineeringMassively-parallel ComputingArray ComputingParallel ProcessingComputer EngineeringComputer ArchitectureParallel ImplementationVectorizationParallel ProgrammingComputer ScienceParallel ComputingSparse Matrix-vector MultiplicationData-level ParallelismMultiple Numa Architectures
The sparse matrix-vector multiplication is an important computational kernel, but is hard to efficiently execute even in the sequential case. The problems--namely low arithmetic intensity, inefficient cache use, and limited memory bandwidth--are magnified as the core count on shared-memory parallel architectures increases. Existing techniques are discussed in detail, and categorized chiefly based on their distribution types. Based on this, new parallelization techniques are proposed. The theoretical scalability and memory usage of the various strategies are analyzed, and experiments on multiple NUMA architectures confirm the validity of the results. One of the newly proposed methods attains the best average result in experiments on a large set of matrices. In one of the experiments it obtains a parallel efficiency of 90 percent, while on average it performs close to 60 percent.
| Year | Citations | |
|---|---|---|
Page 1
Page 1