hgt_sample.cpp 1.07 KB
Newer Older
1
#ifdef WITH_PYTHON
rusty1s's avatar
rusty1s committed
2
#include <Python.h>
3
#endif
rusty1s's avatar
rusty1s committed
4
5
6
7
8
#include <torch/script.h>

#include "cpu/hgt_sample_cpu.h"

#ifdef _WIN32
9
#ifdef WITH_PYTHON
rusty1s's avatar
rusty1s committed
10
11
12
13
14
15
#ifdef WITH_CUDA
PyMODINIT_FUNC PyInit__hgt_sample_cuda(void) { return NULL; }
#else
PyMODINIT_FUNC PyInit__hgt_sample_cpu(void) { return NULL; }
#endif
#endif
16
#endif
rusty1s's avatar
rusty1s committed
17

rusty1s's avatar
rusty1s committed
18
// Returns 'output_node_dict', 'row_dict', 'col_dict', 'output_edge_dict'
Daniel Falbel's avatar
Daniel Falbel committed
19
SPARSE_API std::tuple<c10::Dict<node_t, torch::Tensor>, c10::Dict<rel_t, torch::Tensor>,
rusty1s's avatar
rusty1s committed
20
           c10::Dict<rel_t, torch::Tensor>, c10::Dict<rel_t, torch::Tensor>>
rusty1s's avatar
update  
rusty1s committed
21
22
hgt_sample(const c10::Dict<std::string, torch::Tensor> &colptr_dict,
           const c10::Dict<std::string, torch::Tensor> &row_dict,
rusty1s's avatar
rusty1s committed
23
24
25
26
           const c10::Dict<std::string, torch::Tensor> &input_node_dict,
           const c10::Dict<std::string, std::vector<int64_t>> &num_samples_dict,
           const int64_t num_hops) {

rusty1s's avatar
update  
rusty1s committed
27
  return hgt_sample_cpu(colptr_dict, row_dict, input_node_dict,
rusty1s's avatar
rusty1s committed
28
29
30
31
32
                        num_samples_dict, num_hops);
}

static auto registry =
    torch::RegisterOperators().op("torch_sparse::hgt_sample", &hgt_sample);