split_copy.h 3.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #pragma once
  2. // @generated by torchgen/gen.py from Function.h
  3. #include <ATen/Context.h>
  4. #include <ATen/DeviceGuard.h>
  5. #include <ATen/TensorUtils.h>
  6. #include <ATen/TracerMode.h>
  7. #include <ATen/core/Generator.h>
  8. #include <ATen/core/Reduction.h>
  9. #include <ATen/core/Tensor.h>
  10. #include <c10/core/Scalar.h>
  11. #include <c10/core/Storage.h>
  12. #include <c10/core/TensorOptions.h>
  13. #include <c10/util/Deprecated.h>
  14. #include <c10/util/Optional.h>
  15. #include <ATen/ops/split_copy_ops.h>
  16. namespace at {
  17. // aten::split_copy.Tensor(Tensor self, SymInt split_size, int dim=0) -> Tensor[]
  18. inline ::std::vector<at::Tensor> split_copy(const at::Tensor & self, int64_t split_size, int64_t dim=0) {
  19. return at::_ops::split_copy_Tensor::call(self, split_size, dim);
  20. }
  21. namespace symint {
  22. template <typename T, typename = std::enable_if_t<std::is_same<T, int64_t>::value>>
  23. ::std::vector<at::Tensor> split_copy(const at::Tensor & self, int64_t split_size, int64_t dim=0) {
  24. return at::_ops::split_copy_Tensor::call(self, split_size, dim);
  25. }
  26. }
  27. // aten::split_copy.Tensor(Tensor self, SymInt split_size, int dim=0) -> Tensor[]
  28. inline ::std::vector<at::Tensor> split_copy_symint(const at::Tensor & self, c10::SymInt split_size, int64_t dim=0) {
  29. return at::_ops::split_copy_Tensor::call(self, split_size, dim);
  30. }
  31. namespace symint {
  32. template <typename T, typename = std::enable_if_t<std::is_same<T, c10::SymInt>::value>>
  33. ::std::vector<at::Tensor> split_copy(const at::Tensor & self, c10::SymInt split_size, int64_t dim=0) {
  34. return at::_ops::split_copy_Tensor::call(self, split_size, dim);
  35. }
  36. }
  37. // aten::split_copy.Tensor_out(Tensor self, SymInt split_size, int dim=0, *, Tensor(a!)[] out) -> ()
  38. inline void split_copy_out(at::TensorList out, const at::Tensor & self, int64_t split_size, int64_t dim=0) {
  39. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  40. }
  41. namespace symint {
  42. template <typename T, typename = std::enable_if_t<std::is_same<T, int64_t>::value>>
  43. void split_copy_out(at::TensorList out, const at::Tensor & self, int64_t split_size, int64_t dim=0) {
  44. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  45. }
  46. }
  47. // aten::split_copy.Tensor_out(Tensor self, SymInt split_size, int dim=0, *, Tensor(a!)[] out) -> ()
  48. inline void split_copy_outf(const at::Tensor & self, int64_t split_size, int64_t dim, at::TensorList out) {
  49. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  50. }
  51. namespace symint {
  52. template <typename T, typename = std::enable_if_t<std::is_same<T, int64_t>::value>>
  53. void split_copy_outf(const at::Tensor & self, int64_t split_size, int64_t dim, at::TensorList out) {
  54. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  55. }
  56. }
  57. // aten::split_copy.Tensor_out(Tensor self, SymInt split_size, int dim=0, *, Tensor(a!)[] out) -> ()
  58. inline void split_copy_symint_out(at::TensorList out, const at::Tensor & self, c10::SymInt split_size, int64_t dim=0) {
  59. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  60. }
  61. namespace symint {
  62. template <typename T, typename = std::enable_if_t<std::is_same<T, c10::SymInt>::value>>
  63. void split_copy_out(at::TensorList out, const at::Tensor & self, c10::SymInt split_size, int64_t dim=0) {
  64. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  65. }
  66. }
  67. // aten::split_copy.Tensor_out(Tensor self, SymInt split_size, int dim=0, *, Tensor(a!)[] out) -> ()
  68. inline void split_copy_symint_outf(const at::Tensor & self, c10::SymInt split_size, int64_t dim, at::TensorList out) {
  69. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  70. }
  71. namespace symint {
  72. template <typename T, typename = std::enable_if_t<std::is_same<T, c10::SymInt>::value>>
  73. void split_copy_outf(const at::Tensor & self, c10::SymInt split_size, int64_t dim, at::TensorList out) {
  74. return at::_ops::split_copy_Tensor_out::call(self, split_size, dim, out);
  75. }
  76. }
  77. }