dmlc/dgl

[Performance][Sampling] Parallelize CSRSliceRows() on the CPU with multiple threads.

Open

#3,400 opened on Oct 7, 2021

View on GitHub
聽(1 comment)聽(0 reactions)聽(0 assignees)Python聽(12,665 stars)聽(2,928 forks)batch import
help wanted

Description

馃殌 Feature

The function CSRSliceRows() on the CPU currently is not parallelized (https://github.com/dmlc/dgl/blob/master/src/array/cpu/spmat_op_impl_csr.cc#L361), and as a result makes MultiLayerFullNeighborSampler quite slow.

Motivation

It's currently faster to use a MultiLayerNeighborSampler with fanouts equal to the maximum degree in the graph (when memory is sufficient), than to use MultiLayerFullNeighborSampler, despite the fact that no selection or random number generation needs to be performed. As full neighbor sampling is quite slow to begin with, this is problematic.

When sampling on the CPU and performing to_block() on the GPU, no sampling workers can be used, and this lack of parallelism hurts performance quite a bit.

Pitch

It could be parallelized similar to uniform sampling https://github.com/dmlc/dgl/blob/master/src/array/cpu/rowwise_pick.h#L72, with the caveat that we would need to wait until the global_prefix is calculated (https://github.com/dmlc/dgl/blob/master/src/array/cpu/rowwise_pick.h#L147), before allocating the output arrays in order to know the total number of edges in the subgraph.

Contributor guide

[Performance][Sampling] Parallelize CSRSliceRows() on the CPU with multiple threads. 路 dmlc/dgl#3400 | Good First Issue