11 #ifndef EIGEN_CXX11_TENSOR_TENSORSTORAGE_H 12 #define EIGEN_CXX11_TENSOR_TENSORSTORAGE_H 14 #ifdef EIGEN_TENSOR_STORAGE_CTOR_PLUGIN 15 #define EIGEN_INTERNAL_TENSOR_STORAGE_CTOR_PLUGIN EIGEN_TENSOR_STORAGE_CTOR_PLUGIN; 17 #define EIGEN_INTERNAL_TENSOR_STORAGE_CTOR_PLUGIN 34 template<
typename T,
typename Dimensions,
int Options_>
class TensorStorage;
38 template<
typename T,
int Options_,
typename FixedDimensions>
42 static const std::size_t Size = FixedDimensions::total_size;
69 template<
typename T,
int Options_,
typename IndexType,
int NumIndices_>
78 if (NumIndices_ == 0) {
79 m_data = internal::conditional_aligned_new_auto<T,(Options_&DontAlign)==0>(1);
88 #if EIGEN_HAS_VARIADIC_TEMPLATES 91 m_data = internal::conditional_aligned_new_auto<T,(Options_&DontAlign)==0>(
internal::array_prod(m_dimensions));
97 , m_dimensions(other.m_dimensions)
103 if (
this != &other) {
111 EIGEN_DEVICE_FUNC
void swap(Self& other)
119 if(size != currentSz)
121 internal::conditional_aligned_delete_auto<T,(Options_&DontAlign)==0>(m_data, currentSz);
123 m_data = internal::conditional_aligned_new_auto<T,(Options_&DontAlign)==0>(
size);
124 else if (NumIndices_ == 0) {
125 m_data = internal::conditional_aligned_new_auto<T,(Options_&DontAlign)==0>(1);
131 m_dimensions = nbDimensions;
146 #endif // EIGEN_CXX11_TENSOR_TENSORSTORAGE_H EIGEN_DEVICE_FUNC T * conditional_aligned_new_auto(std::size_t size)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE std::ptrdiff_t array_prod(const Sizes< Indices... > &)
#define EIGEN_STRONG_INLINE
DSizes< IndexType, NumIndices_ > Dimensions
FixedDimensions m_dimensions
array< t, n > repeat(t v)
static constexpr size_t size(Tuple< Args... > &)
Provides access to the number of elements in a tuple as a compile-time constant expression.
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const FixedDimensions & dimensions() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T * data()
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE TensorStorage()
EIGEN_DEVICE_FUNC void resize(Index size, const array< Index, NumIndices_ > &nbDimensions)
#define EIGEN_INTERNAL_TENSOR_STORAGE_CTOR_PLUGIN
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE DenseIndex size() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const Dimensions & dimensions() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const T * data() const
EIGEN_DEVICE_FUNC TensorStorage(Index size, const array< Index, NumIndices_ > &dimensions)
EIGEN_DEVICE_FUNC void smart_copy(const T *start, const T *end, T *target)
EIGEN_STRONG_INLINE void swap(T &a, T &b)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Index size() const
EIGEN_DEVICE_FUNC TensorStorage(const Self &other)
#define EIGEN_INTERNAL_DENSE_STORAGE_CTOR_PLUGIN(X)
TensorStorage< T, DSizes< IndexType, NumIndices_ >, Options_ > Self
EIGEN_DEVICE_FUNC void swap(Self &other)
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const T * data() const
EIGEN_DEFAULT_DENSE_INDEX_TYPE DenseIndex
EIGEN_DEVICE_FUNC TensorStorage()
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T * data()
EIGEN_DEVICE_FUNC ~TensorStorage()
EIGEN_DEVICE_FUNC Self & operator=(const Self &other)
EIGEN_DEVICE_FUNC TensorStorage(internal::constructor_without_unaligned_array_assert)
void swap(scoped_array< T > &a, scoped_array< T > &b)