team-10/venv/Lib/site-packages/torch/include/ATen/ops/roll.h
2025-08-02 02:00:33 +02:00

92 lines
3.9 KiB
C++

#pragma once
// @generated by torchgen/gen.py from Function.h
#include <ATen/Context.h>
#include <ATen/DeviceGuard.h>
#include <ATen/TensorUtils.h>
#include <ATen/TracerMode.h>
#include <ATen/core/Generator.h>
#include <ATen/core/Reduction.h>
#include <ATen/core/Tensor.h>
#include <c10/core/Scalar.h>
#include <c10/core/Storage.h>
#include <c10/core/TensorOptions.h>
#include <c10/util/Deprecated.h>
#include <optional>
#include <string_view>
#include <ATen/ops/roll_ops.h>
namespace at {
// aten::roll(Tensor self, SymInt[1] shifts, int[1] dims=[]) -> Tensor
inline at::Tensor roll(const at::Tensor & self, at::IntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll::call(self, c10::fromIntArrayRefSlow(shifts), dims);
}
namespace symint {
template <typename T, typename = std::enable_if_t<std::is_same_v<T, int64_t>>>
at::Tensor roll(const at::Tensor & self, at::IntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll::call(self, c10::fromIntArrayRefSlow(shifts), dims);
}
}
// aten::roll(Tensor self, SymInt[1] shifts, int[1] dims=[]) -> Tensor
inline at::Tensor roll_symint(const at::Tensor & self, c10::SymIntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll::call(self, shifts, dims);
}
namespace symint {
template <typename T, typename = std::enable_if_t<std::is_same_v<T, c10::SymInt>>>
at::Tensor roll(const at::Tensor & self, c10::SymIntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll::call(self, shifts, dims);
}
}
// aten::roll.out(Tensor self, SymInt[1] shifts, int[1] dims=[], *, Tensor(a!) out) -> Tensor(a!)
inline at::Tensor & roll_out(at::Tensor & out, const at::Tensor & self, at::IntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll_out::call(self, c10::fromIntArrayRefSlow(shifts), dims, out);
}
namespace symint {
template <typename T, typename = std::enable_if_t<std::is_same_v<T, int64_t>>>
at::Tensor & roll_out(at::Tensor & out, const at::Tensor & self, at::IntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll_out::call(self, c10::fromIntArrayRefSlow(shifts), dims, out);
}
}
// aten::roll.out(Tensor self, SymInt[1] shifts, int[1] dims=[], *, Tensor(a!) out) -> Tensor(a!)
inline at::Tensor & roll_outf(const at::Tensor & self, at::IntArrayRef shifts, at::IntArrayRef dims, at::Tensor & out) {
return at::_ops::roll_out::call(self, c10::fromIntArrayRefSlow(shifts), dims, out);
}
namespace symint {
template <typename T, typename = std::enable_if_t<std::is_same_v<T, int64_t>>>
at::Tensor & roll_outf(const at::Tensor & self, at::IntArrayRef shifts, at::IntArrayRef dims, at::Tensor & out) {
return at::_ops::roll_out::call(self, c10::fromIntArrayRefSlow(shifts), dims, out);
}
}
// aten::roll.out(Tensor self, SymInt[1] shifts, int[1] dims=[], *, Tensor(a!) out) -> Tensor(a!)
inline at::Tensor & roll_symint_out(at::Tensor & out, const at::Tensor & self, c10::SymIntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll_out::call(self, shifts, dims, out);
}
namespace symint {
template <typename T, typename = std::enable_if_t<std::is_same_v<T, c10::SymInt>>>
at::Tensor & roll_out(at::Tensor & out, const at::Tensor & self, c10::SymIntArrayRef shifts, at::IntArrayRef dims={}) {
return at::_ops::roll_out::call(self, shifts, dims, out);
}
}
// aten::roll.out(Tensor self, SymInt[1] shifts, int[1] dims=[], *, Tensor(a!) out) -> Tensor(a!)
inline at::Tensor & roll_symint_outf(const at::Tensor & self, c10::SymIntArrayRef shifts, at::IntArrayRef dims, at::Tensor & out) {
return at::_ops::roll_out::call(self, shifts, dims, out);
}
namespace symint {
template <typename T, typename = std::enable_if_t<std::is_same_v<T, c10::SymInt>>>
at::Tensor & roll_outf(const at::Tensor & self, c10::SymIntArrayRef shifts, at::IntArrayRef dims, at::Tensor & out) {
return at::_ops::roll_out::call(self, shifts, dims, out);
}
}
}