Go to the documentation of this file.
11 #ifndef EIGEN_CXX11_TENSOR_TENSOR_H
12 #define EIGEN_CXX11_TENSOR_TENSOR_H
62 template<
typename Scalar_,
int NumIndices_,
int Options_,
typename IndexType_>
89 #ifdef EIGEN_HAS_SFINAE
90 template<
typename CustomIndices>
91 struct isOfNormalIndex{
92 static const bool is_array = internal::is_base_of<array<Index, NumIndices>, CustomIndices>::value;
94 static const bool value = is_array | is_int;
113 #if EIGEN_HAS_VARIADIC_TEMPLATES
114 template<
typename... IndexTypes>
115 EIGEN_DEVICE_FUNC
inline const Scalar&
coeff(
Index firstIndex,
Index secondIndex, IndexTypes... otherIndices)
const
131 #ifdef EIGEN_HAS_SFINAE
132 template<
typename CustomIndices,
137 return coeff(internal::customIndices2Array<Index,NumIndices>(indices));
153 #if EIGEN_HAS_VARIADIC_TEMPLATES
154 template<
typename... IndexTypes>
171 #ifdef EIGEN_HAS_SFINAE
172 template<
typename CustomIndices,
177 return coeffRef(internal::customIndices2Array<Index,NumIndices>(indices));
193 #if EIGEN_HAS_VARIADIC_TEMPLATES
194 template<
typename... IndexTypes>
225 #ifdef EIGEN_HAS_SFINAE
226 template<
typename CustomIndices,
231 return coeff(internal::customIndices2Array<Index,NumIndices>(indices));
238 return coeff(indices);
260 #if EIGEN_HAS_VARIADIC_TEMPLATES
261 template<
typename... IndexTypes>
298 #ifdef EIGEN_HAS_SFINAE
299 template<
typename CustomIndices,
304 return coeffRef(internal::customIndices2Array<Index,NumIndices>(indices));
339 #if EIGEN_HAS_VARIADIC_TEMPLATES
340 template<
typename... IndexTypes>
342 :
m_storage(firstDimension, otherDimensions...)
382 template<
typename OtherDerived>
387 Assign assign(*
this, other.
derived());
391 template<
typename OtherDerived>
396 Assign assign(*
this, other.
derived());
405 Assign assign(*
this, other);
410 template<
typename OtherDerived>
415 Assign assign(*
this, other);
421 #if EIGEN_HAS_VARIADIC_TEMPLATES
422 template<
typename... IndexTypes> EIGEN_DEVICE_FUNC
423 void resize(
Index firstDimension, IndexTypes... otherDimensions)
440 #ifdef EIGEN_INITIALIZE_COEFFS
441 bool size_changed =
size != this->
size();
466 #ifdef EIGEN_HAS_SFINAE
467 template<
typename CustomDimension,
476 #ifndef EIGEN_EMULATE_CXX11_META_H
477 template <
typename std::ptrdiff_t... Indices>
487 template <std::
size_t V1, std::
size_t V2, std::
size_t V3, std::
size_t V4, std::
size_t V5>
510 array_apply_and_reduce<logical_and_op, greater_equal_zero_op>(indices) &&
527 #endif // EIGEN_CXX11_TENSOR_TENSOR_H
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar * data() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Index dimension(std::size_t n) const
EIGEN_DEVICE_FUNC void resize(const Sizes< Indices... > &dimensions)
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()() const
internal::traits< Self >::StorageKind StorageKind
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator[](Index index) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(Index dim1, Index dim2)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()(const array< Index, NumIndices > &indices)
Base::CoeffReturnType CoeffReturnType
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & coeff(const array< Index, NumIndices > &indices) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor()
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1, Index i2) const
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1, Index i2, Index i3, Index i4) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1, Index i2)
EIGEN_DEVICE_FUNC void resize(const DSizes< Index, NumIndices > &dimensions)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(Index dim1)
Eigen::internal::nested< Self >::type Nested
Tensor< Scalar_, NumIndices_, Options_, IndexType_ > Self
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & coeff() const
#define eigen_internal_assert(x)
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1, Index i2, Index i3) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator[](Index index)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE DenseIndex IndexOfRowMajor(const array< DenseIndex, NumDims > &indices) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(const Self &other)
static EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE void run(Index, Index)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Index rank() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor & operator=(const OtherDerived &other)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & coeffRef()
NumTraits< Scalar >::Real RealScalar
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()(Index index)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & coeffRef(const array< Index, NumIndices > &indices)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(const TensorBase< OtherDerived, ReadOnlyAccessors > &other)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(Index dim1, Index dim2, Index dim3)
#define EIGEN_MAX_ALIGN_BYTES
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE DenseIndex size() const
EIGEN_DEVICE_FUNC void resize(const array< Index, NumIndices > &dimensions)
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Dimensions & dimensions() const
static const int NumIndices
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(Index dim1, Index dim2, Index dim3, Index dim4)
#define EIGEN_STRONG_INLINE
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T * data()
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(const TensorBase< OtherDerived, WriteAccessors > &other)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1, Index i2, Index i3)
#define EIGEN_INITIALIZE_COEFFS_IF_THAT_OPTION_IS_ENABLED
#define EIGEN_SFINAE_ENABLE_IF(__condition__)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(const array< Index, NumIndices > &dimensions)
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()(Index i0, Index i1, Index i2, Index i3, Index i4)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE std::ptrdiff_t array_prod(const Sizes< Indices... > &)
const Self & base() const
TensorStorage< Scalar, Dimensions, Options > m_storage
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & coeffRef(Index index)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor(Index dim1, Index dim2, Index dim3, Index dim4, Index dim5)
EIGEN_DEVICE_FUNC void resize()
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & operator()()
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()(const array< Index, NumIndices > &indices) const
#define EIGEN_STATIC_ASSERT(CONDITION, MSG)
bool array_zip_and_reduce(const array< A, N > &a, const array< B, N > &b)
static EIGEN_DEVICE_FUNC void run(const Expression &expr, const Device &device=Device())
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE DenseIndex IndexOfColMajor(const array< DenseIndex, NumDims > &indices) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar * data()
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & operator()(Index index) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor & operator=(const Tensor &other)
DSizes< Index, NumIndices_ > Dimensions
A cost model used to limit the number of threads used for evaluating tensor expression.
bool checkIndexRange(const array< Index, NumIndices > &indices) const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Index size() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Index linearizedIndex(const array< Index, NumIndices > &indices) const
bool array_apply_and_reduce(const array< A, N > &a)
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Scalar & coeff(Index index) const
internal::traits< Self >::Index Index
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE FixedDimensions & dimensions() const
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
TensorBase< Tensor< Scalar_, NumIndices_, Options_, IndexType_ > > Base
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Derived & derived()
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:06:33