__global__ void spmv_csr_scalar_kernel( const int num_rows, const int * rowptr, const int * index, const float * value, const float * x, float * y){ int row = blockDim.x * blockIdx.x + threadIdx.x; if (row < num_rows){ int row_start = rowptr[row]; int row_end = rowptr[row+1]; for (int jj = row_start; jj < row_end ; jj++) dot += value[jj] * x[index[jj]]; y[row] += dot; } } )
data:image/s3,"s3://crabby-images/9d645/9d6450ec4e4fa78612b6bd430a1e444f882976be" alt=""
data:image/s3,"s3://crabby-images/8f657/8f657e2fb8d3a44950d5088dee12658d37e28759" alt=""