Go to the documentation of this file.
10 #ifndef EIGEN_BLASUTIL_H
11 #define EIGEN_BLASUTIL_H
21 template<
typename LhsScalar,
typename RhsScalar,
typename Index,
typename DataMapper,
int mr,
int nr,
bool ConjugateLhs=false,
bool ConjugateRhs=false>
24 template<
typename Scalar,
typename Index,
typename DataMapper,
int nr,
int StorageOrder,
bool Conjugate = false,
bool PanelMode=false>
27 template<
typename Scalar,
typename Index,
typename DataMapper,
int Pack1,
int Pack2,
int StorageOrder,
bool Conjugate = false,
bool PanelMode = false>
32 typename LhsScalar,
int LhsStorageOrder,
bool ConjugateLhs,
33 typename RhsScalar,
int RhsStorageOrder,
bool ConjugateRhs,
37 template<
typename Index,
38 typename LhsScalar,
typename LhsMapper,
int LhsStorageOrder,
bool ConjugateLhs,
39 typename RhsScalar,
typename RhsMapper,
bool ConjugateRhs,
int Version=
Specialized>
56 inline const T&
pconj(
const T&
x)
const {
return x; }
60 template<
typename LhsScalar,
typename RhsScalar,
bool ConjLhs,
bool ConjRhs>
78 template<
typename RealScalar>
struct conj_helper<
std::
complex<RealScalar>, std::complex<RealScalar>, false,true>
80 typedef std::complex<RealScalar>
Scalar;
88 template<
typename RealScalar>
struct conj_helper<
std::
complex<RealScalar>, std::complex<RealScalar>, true,false>
90 typedef std::complex<RealScalar>
Scalar;
136 template<
typename Scalar,
typename Index>
144 template <
typename Packet,
int AlignmentType>
146 return ploadt<Packet, AlignmentType>(
m_data + i);
149 template <
typename Packet>
158 template<
typename Scalar,
typename Index,
int AlignmentType>
175 return ploadt<Packet, AlignmentType>(
m_data + i);
179 return ploadt<HalfPacket, AlignmentType>(
m_data + i);
183 pstoret<Scalar, Packet, AlignmentType>(
m_data + i, p);
191 template<
typename Scalar,
typename Index,
int StorageOrder,
int AlignmentType = Unaligned>
222 return ploadt<Packet, AlignmentType>(&
operator()(i, j));
226 return ploadt<HalfPacket, AlignmentType>(&
operator()(i, j));
229 template<
typename SubPacket>
231 pscatter<Scalar, SubPacket>(&
operator()(i, j), p,
m_stride);
234 template<
typename SubPacket>
236 return pgather<Scalar, SubPacket>(&
operator()(i, j),
m_stride);
255 template<
typename Scalar,
typename Index,
int StorageOrder>
279 && (
bool(XprType::IsVectorAtCompileTime)
285 typename _ExtractType::PlainObject
292 template<
typename Scalar,
typename NestedXpr>
309 template<
typename Scalar,
typename NestedXpr,
typename Plain>
318 {
return x.lhs().functor().m_other * Base::extractScalarFactor(
x.rhs()); }
320 template<
typename Scalar,
typename NestedXpr,
typename Plain>
329 {
return Base::extractScalarFactor(
x.lhs()) *
x.rhs().functor().m_other; }
331 template<
typename Scalar,
typename Plain1,
typename Plain2>
334 :
blas_traits<CwiseNullaryOp<scalar_constant_op<Scalar>,Plain1> >
338 template<
typename Scalar,
typename NestedXpr>
347 {
return - Base::extractScalarFactor(
x.nestedExpression()); }
351 template<
typename NestedXpr>
360 typedef typename conditional<bool(Base::HasUsableDirectAccess),
362 typename ExtractType::PlainObject
376 template<typename T, bool HasUsableDirectAccess=blas_traits<T>::HasUsableDirectAccess>
398 #endif // EIGEN_BLASUTIL_H
Base::ExtractType ExtractType
EIGEN_ALWAYS_INLINE const_blas_data_mapper< Scalar, Index, StorageOrder > getSubMapper(Index i, Index j) const
const AutoDiffScalar< DerType > & conj(const AutoDiffScalar< DerType > &x)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE Packet load(Index i) const
EIGEN_STRONG_INLINE Scalar pmul(const Scalar &x, const Scalar &y) const
EIGEN_STRONG_INLINE Scalar pmadd(const RealScalar &x, const Scalar &y, const Scalar &c) const
EIGEN_DEVICE_FUNC Index firstAligned(Index size) const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE SubPacket gatherPacket(Index i, Index j) const
T pconj(const T &x) const
const T::Scalar * extract_data(const T &m)
EIGEN_STRONG_INLINE Scalar pmadd(const Scalar &x, const Scalar &y, const Scalar &c) const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE VectorMapper getVectorMapper(Index i, Index j) const
Generic expression where a coefficient-wise binary operator is applied to two expressions.
EIGEN_STRONG_INLINE Scalar pmadd(const Scalar &x, const Scalar &y, const Scalar &c) const
const EIGEN_DEVICE_FUNC Index stride() const
Transpose< const typename Base::_ExtractType > _ExtractType
NumTraits< Scalar >::Real RealScalar
EIGEN_STRONG_INLINE Scalar pmadd(const Scalar &x, const RealScalar &y, const Scalar &c) const
const T & operator()(const T &x) const
Transpose< const typename Base::_ExtractType > ExtractType
const typedef XprType & ExtractType
blas_traits< NestedXpr > Base
const T & pconj(const T &x) const
Scalar *EIGEN_RESTRICT m_data
std::complex< RealScalar > Scalar
std::complex< RealScalar > Scalar
static ExtractType extract(const XprType &x)
EIGEN_STRONG_INLINE Scalar pmul(const Scalar &x, const Scalar &y) const
conditional< bool(HasUsableDirectAccess), ExtractType, typename _ExtractType::PlainObject >::type DirectLinearAccessType
static ExtractType extract(const XprType &x)
static ExtractType extract(const XprType &x)
Determines whether the given binary operation of two numeric types is allowed and what the scalar ret...
EIGEN_STRONG_INLINE Packet2cf pconj(const Packet2cf &a)
static ExtractType extract(const XprType &x)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE HalfPacket loadHalfPacket(Index i, Index j) const
blas_traits< NestedXpr > Base
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar pmadd(const Scalar &x, const Scalar &y, const Scalar &c) const
Expression of the transpose of a matrix.
const unsigned int DirectAccessBit
Generic expression of a matrix where all coefficients are defined by a functor.
Base::ExtractType ExtractType
packet_traits< Scalar >::half HalfPacket
static Scalar extractScalarFactor(const XprType &x)
std::complex< RealScalar > Scalar
const EIGEN_DEVICE_FUNC Scalar * data() const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE blas_data_mapper< Scalar, Index, StorageOrder, AlignmentType > getSubMapper(Index i, Index j) const
CwiseBinaryOp< scalar_product_op< Scalar >, NestedXpr, const CwiseNullaryOp< scalar_constant_op< Scalar >, Plain > > XprType
blas_traits< NestedXpr > Base
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE void prefetch(int i) const
conditional< bool(Base::HasUsableDirectAccess), ExtractType, typename ExtractType::PlainObject >::type DirectLinearAccessType
EIGEN_DEVICE_FUNC bool aligned(Index i) const
static const Scalar extractScalarFactor(const XprType &)
BlasLinearMapper< Scalar, Index, AlignmentType > LinearMapper
#define EIGEN_STRONG_INLINE
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE To run(const From &x)
Base::ExtractType ExtractType
EIGEN_ALWAYS_INLINE const_blas_data_mapper(const Scalar *data, Index stride)
blas_traits< NestedXpr > Base
packet_traits< Scalar >::type Packet
static ExtractType extract(const XprType &x)
const EIGEN_DEVICE_FUNC ImagReturnType imag() const
static Scalar extractScalarFactor(const XprType &x)
#define EIGEN_ALWAYS_INLINE
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE BlasVectorMapper(Scalar *data)
EIGEN_STRONG_INLINE Scalar pmul(const Scalar &x, const Scalar &y) const
traits< XprType >::Scalar Scalar
EIGEN_STRONG_INLINE Scalar pmadd(const LhsScalar &x, const RhsScalar &y, const Scalar &c) const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE Packet loadPacket(Index i) const
CwiseUnaryOp< scalar_opposite_op< Scalar >, NestedXpr > XprType
EIGEN_DEVICE_FUNC void prefetch(const Scalar *addr)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE Packet loadPacket(Index i, Index j) const
T operator()(const T &x) const
blas_traits< NestedXpr > Base
EIGEN_DEVICE_FUNC Packet pmul(const Packet &a, const Packet &b)
Base::ExtractType ExtractType
static EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE NumTraits< Scalar >::Real run(const Scalar &x)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE Scalar & operator()(Index i) const
Generic expression where a coefficient-wise unary operator is applied to an expression.
static Scalar extractScalarFactor(const XprType &x)
EIGEN_STRONG_INLINE Packet4f pmadd(const Packet4f &a, const Packet4f &b, const Packet4f &c)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE void storePacket(Index i, const Packet &p) const
EIGEN_STRONG_INLINE Scalar pmul(const RealScalar &x, const Scalar &y) const
static ExtractType extract(const XprType &x)
EIGEN_DEVICE_FUNC Packet padd(const Packet &a, const Packet &b)
static constexpr size_t size(Tuple< Args... > &)
Provides access to the number of elements in a tuple as a compile-time constant expression.
BlasVectorMapper< Scalar, Index > VectorMapper
static Index first_default_aligned(const DenseBase< Derived > &m)
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE Scalar operator()(Index i) const
std::complex< RealScalar > Scalar
ScalarBinaryOpTraits< LhsScalar, RhsScalar >::ReturnType Scalar
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE Scalar & operator()(Index i, Index j) const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE LinearMapper getLinearMapper(Index i, Index j) const
std::complex< RealScalar > Scalar
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar pmul(const Scalar &x, const Scalar &y) const
EIGEN_STRONG_INLINE Scalar pmadd(const Scalar &x, const Scalar &y, const Scalar &c) const
EIGEN_STRONG_INLINE Scalar pmul(const LhsScalar &x, const RhsScalar &y) const
static Scalar extractScalarFactor(const XprType &x)
static Scalar extractScalarFactor(const XprType &x)
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE BlasLinearMapper(Scalar *data)
EIGEN_STRONG_INLINE Scalar pmul(const Scalar &x, const RealScalar &y) const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE HalfPacket loadHalfPacket(Index i) const
packet_traits< Scalar >::type Packet
packet_traits< Scalar >::half HalfPacket
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Transpose< NestedXpr > XprType
CwiseBinaryOp< scalar_product_op< Scalar >, const CwiseNullaryOp< scalar_constant_op< Scalar >, Plain >, NestedXpr > XprType
CwiseUnaryOp< scalar_conjugate_op< Scalar >, NestedXpr > XprType
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE void scatterPacket(Index i, Index j, const SubPacket &p) const
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE blas_data_mapper(Scalar *data, Index stride)
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:05:38