pytorch/torch/csrc/utils/tensor_layouts.cpp
Sameer Deshmukh 5fb1142702 Add CSR (compressed sparse row) layout for sparse tensors (#50937)
Summary:
Implement compressed sparse row format. Derived from the GCS implementation at https://github.com/pytorch/pytorch/pull/44190

Pull Request resolved: https://github.com/pytorch/pytorch/pull/50937

Reviewed By: mrshenli

Differential Revision: D27439865

Pulled By: ezyang

fbshipit-source-id: 3ba3dcb9679505b980ff6a5f513e913bbae2fb1d
2021-04-12 10:09:12 -07:00

47 lines
1.6 KiB
C++

#include <ATen/Layout.h>
#include <c10/core/ScalarType.h>
#include <torch/csrc/DynamicTypes.h>
#include <torch/csrc/Exceptions.h>
#include <torch/csrc/Layout.h>
#include <torch/csrc/python_headers.h>
#include <torch/csrc/utils/object_ptr.h>
#include <torch/csrc/utils/tensor_layouts.h>
namespace torch { namespace utils {
void initializeLayouts() {
auto torch_module = THPObjectPtr(PyImport_ImportModule("torch"));
if (!torch_module) throw python_error();
PyObject* strided_layout = THPLayout_New(at::Layout::Strided, "torch.strided");
Py_INCREF(strided_layout);
if (PyModule_AddObject(torch_module, "strided", strided_layout) != 0) {
throw python_error();
}
registerLayoutObject((THPLayout*)strided_layout, at::Layout::Strided);
PyObject* sparse_coo_layout = THPLayout_New(at::Layout::Sparse, "torch.sparse_coo");
Py_INCREF(sparse_coo_layout);
if (PyModule_AddObject(torch_module, "sparse_coo", sparse_coo_layout) != 0) {
throw python_error();
}
registerLayoutObject((THPLayout*)sparse_coo_layout, at::Layout::Sparse);
PyObject* sparse_csr_layout =
THPLayout_New(at::Layout::SparseCsr, "torch.sparse_csr");
Py_INCREF(sparse_csr_layout);
if (PyModule_AddObject(torch_module, "sparse_csr", sparse_csr_layout) != 0) {
throw python_error();
}
registerLayoutObject((THPLayout*)sparse_csr_layout, at::Layout::SparseCsr);
PyObject* mkldnn_layout = THPLayout_New(at::Layout::Mkldnn, "torch._mkldnn");
Py_INCREF(mkldnn_layout);
if (PyModule_AddObject(torch_module, "_mkldnn", mkldnn_layout) != 0) {
throw python_error();
}
registerLayoutObject((THPLayout*)mkldnn_layout, at::Layout::Mkldnn);
}
}} // namespace torch::utils