spmm.cpp 1.35 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
2
3
4
#include <torch/extension.h>

#define CHECK_CUDA(x) AT_ASSERTM(x.type().is_cuda(), #x " must be CUDA tensor")

rusty1s's avatar
rusty1s committed
5
6
7
at::Tensor spmm_cuda(at::Tensor rowptr, at::Tensor col,
                     at::optional<at::Tensor> val, at::Tensor mat,
                     std::string reduce);
rusty1s's avatar
rusty1s committed
8

rusty1s's avatar
rusty1s committed
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
std::tuple<at::Tensor, at::Tensor>
spmm_arg_cuda(at::Tensor rowptr, at::Tensor col, at::optional<at::Tensor> val,
              at::Tensor mat, std::string reduce);

at::Tensor spmm(at::Tensor rowptr, at::Tensor col, at::optional<at::Tensor> val,
                at::Tensor mat, std::string reduce) {
  CHECK_CUDA(rowptr);
  CHECK_CUDA(col);
  if (val.has_value())
    CHECK_CUDA(val.value());
  CHECK_CUDA(mat);
  return spmm_cuda(rowptr, col, val, mat, reduce);
}

std::tuple<at::Tensor, at::Tensor> spmm_arg(at::Tensor rowptr, at::Tensor col,
                                            at::optional<at::Tensor> val,
                                            at::Tensor mat,
                                            std::string reduce) {
rusty1s's avatar
rusty1s committed
27
28
  CHECK_CUDA(rowptr);
  CHECK_CUDA(col);
rusty1s's avatar
rusty1s committed
29
30
  if (val.has_value())
    CHECK_CUDA(val.value());
rusty1s's avatar
rusty1s committed
31
  CHECK_CUDA(mat);
rusty1s's avatar
rusty1s committed
32
  return spmm_arg_cuda(rowptr, col, val, mat, reduce);
rusty1s's avatar
rusty1s committed
33
34
35
36
}

PYBIND11_MODULE(TORCH_EXTENSION_NAME, m) {
  m.def("spmm", &spmm, "Sparse Matrix Multiplication (CUDA)");
rusty1s's avatar
rusty1s committed
37
  m.def("spmm_arg", &spmm_arg, "Sparse Matrix Multiplication With Arg (CUDA)");
rusty1s's avatar
rusty1s committed
38
}