mirror of
https://gitlab.com/libeigen/eigen.git
synced 2025-04-29 07:14:12 +08:00
Replace instances of EIGEN_NOEXCEPT macros
This commit is contained in:
parent
d2dce37767
commit
619be0deb6
@ -230,8 +230,8 @@ class LDLT : public SolverBase<LDLT<MatrixType_, UpLo_> > {
|
|||||||
*/
|
*/
|
||||||
const LDLT& adjoint() const { return *this; }
|
const LDLT& adjoint() const { return *this; }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
/** \brief Reports whether previous computation was successful.
|
/** \brief Reports whether previous computation was successful.
|
||||||
*
|
*
|
||||||
|
@ -182,10 +182,10 @@ class LLT : public SolverBase<LLT<MatrixType_, UpLo_> > {
|
|||||||
* This method is provided for compatibility with other matrix decompositions, thus enabling generic code such as:
|
* This method is provided for compatibility with other matrix decompositions, thus enabling generic code such as:
|
||||||
* \code x = decomposition.adjoint().solve(b) \endcode
|
* \code x = decomposition.adjoint().solve(b) \endcode
|
||||||
*/
|
*/
|
||||||
const LLT& adjoint() const EIGEN_NOEXCEPT { return *this; }
|
const LLT& adjoint() const noexcept { return *this; }
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
template <typename VectorType>
|
template <typename VectorType>
|
||||||
LLT& rankUpdate(const VectorType& vec, const RealScalar& sigma = 1);
|
LLT& rankUpdate(const VectorType& vec, const RealScalar& sigma = 1);
|
||||||
|
@ -129,7 +129,7 @@ class Array : public PlainObjectBase<Array<Scalar_, Rows_, Cols_, Options_, MaxR
|
|||||||
#endif
|
#endif
|
||||||
/** \brief Move constructor */
|
/** \brief Move constructor */
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Array(Array&&) = default;
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Array(Array&&) = default;
|
||||||
EIGEN_DEVICE_FUNC Array& operator=(Array&& other) EIGEN_NOEXCEPT_IF(std::is_nothrow_move_assignable<Scalar>::value) {
|
EIGEN_DEVICE_FUNC Array& operator=(Array&& other) noexcept(std::is_nothrow_move_assignable<Scalar>::value) {
|
||||||
Base::operator=(std::move(other));
|
Base::operator=(std::move(other));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
@ -253,8 +253,8 @@ class Array : public PlainObjectBase<Array<Scalar_, Rows_, Cols_, Options_, MaxR
|
|||||||
PrivateType())
|
PrivateType())
|
||||||
: Base(other.derived()) {}
|
: Base(other.derived()) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return 1; }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return 1; }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return this->innerSize(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return this->innerSize(); }
|
||||||
|
|
||||||
#ifdef EIGEN_ARRAY_PLUGIN
|
#ifdef EIGEN_ARRAY_PLUGIN
|
||||||
#include EIGEN_ARRAY_PLUGIN
|
#include EIGEN_ARRAY_PLUGIN
|
||||||
|
@ -56,10 +56,10 @@ class ArrayWrapper : public ArrayBase<ArrayWrapper<ExpressionType> > {
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit EIGEN_STRONG_INLINE ArrayWrapper(ExpressionType& matrix) : m_expression(matrix) {}
|
EIGEN_DEVICE_FUNC explicit EIGEN_STRONG_INLINE ArrayWrapper(ExpressionType& matrix) : m_expression(matrix) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_expression.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_expression.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_expression.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_expression.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return m_expression.outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return m_expression.outerStride(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return m_expression.innerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return m_expression.innerStride(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr ScalarWithConstIfNotLvalue* data() { return m_expression.data(); }
|
EIGEN_DEVICE_FUNC constexpr ScalarWithConstIfNotLvalue* data() { return m_expression.data(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr const Scalar* data() const { return m_expression.data(); }
|
EIGEN_DEVICE_FUNC constexpr const Scalar* data() const { return m_expression.data(); }
|
||||||
@ -131,10 +131,10 @@ class MatrixWrapper : public MatrixBase<MatrixWrapper<ExpressionType> > {
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit inline MatrixWrapper(ExpressionType& matrix) : m_expression(matrix) {}
|
EIGEN_DEVICE_FUNC explicit inline MatrixWrapper(ExpressionType& matrix) : m_expression(matrix) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_expression.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_expression.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_expression.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_expression.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return m_expression.outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return m_expression.outerStride(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return m_expression.innerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return m_expression.innerStride(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr ScalarWithConstIfNotLvalue* data() { return m_expression.data(); }
|
EIGEN_DEVICE_FUNC constexpr ScalarWithConstIfNotLvalue* data() { return m_expression.data(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr const Scalar* data() const { return m_expression.data(); }
|
EIGEN_DEVICE_FUNC constexpr const Scalar* data() const { return m_expression.data(); }
|
||||||
|
@ -674,15 +674,15 @@ class generic_dense_assignment_kernel {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index size() const EIGEN_NOEXCEPT { return m_dstExpr.size(); }
|
EIGEN_DEVICE_FUNC constexpr Index size() const noexcept { return m_dstExpr.size(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerSize() const EIGEN_NOEXCEPT { return m_dstExpr.innerSize(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerSize() const noexcept { return m_dstExpr.innerSize(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerSize() const EIGEN_NOEXCEPT { return m_dstExpr.outerSize(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerSize() const noexcept { return m_dstExpr.outerSize(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_dstExpr.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_dstExpr.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_dstExpr.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_dstExpr.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return m_dstExpr.outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return m_dstExpr.outerStride(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC DstEvaluatorType& dstEvaluator() EIGEN_NOEXCEPT { return m_dst; }
|
EIGEN_DEVICE_FUNC DstEvaluatorType& dstEvaluator() noexcept { return m_dst; }
|
||||||
EIGEN_DEVICE_FUNC const SrcEvaluatorType& srcEvaluator() const EIGEN_NOEXCEPT { return m_src; }
|
EIGEN_DEVICE_FUNC const SrcEvaluatorType& srcEvaluator() const noexcept { return m_src; }
|
||||||
|
|
||||||
/// Assign src(row,col) to dst(row,col) through the assignment functor.
|
/// Assign src(row,col) to dst(row,col) through the assignment functor.
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr void assignCoeff(Index row, Index col) {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr void assignCoeff(Index row, Index col) {
|
||||||
|
@ -289,13 +289,9 @@ class BlockImpl_dense : public internal::dense_xpr_base<Block<XprType, BlockRows
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE XprType& nestedExpression() { return m_xpr; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE XprType& nestedExpression() { return m_xpr; }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startRow() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startRow() const noexcept { return m_startRow.value(); }
|
||||||
return m_startRow.value();
|
|
||||||
}
|
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startCol() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startCol() const noexcept { return m_startCol.value(); }
|
||||||
return m_startCol.value();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
XprTypeNested m_xpr;
|
XprTypeNested m_xpr;
|
||||||
@ -377,30 +373,25 @@ class BlockImpl_dense<XprType, BlockRows, BlockCols, InnerPanel, true>
|
|||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const internal::remove_all_t<XprTypeNested>& nestedExpression() const
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const internal::remove_all_t<XprTypeNested>& nestedExpression() const noexcept {
|
||||||
EIGEN_NOEXCEPT {
|
|
||||||
return m_xpr;
|
return m_xpr;
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE XprType& nestedExpression() { return m_xpr; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE XprType& nestedExpression() { return m_xpr; }
|
||||||
|
|
||||||
/** \sa MapBase::innerStride() */
|
/** \sa MapBase::innerStride() */
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index innerStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index innerStride() const noexcept {
|
||||||
return internal::traits<BlockType>::HasSameStorageOrderAsXprType ? m_xpr.innerStride() : m_xpr.outerStride();
|
return internal::traits<BlockType>::HasSameStorageOrderAsXprType ? m_xpr.innerStride() : m_xpr.outerStride();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** \sa MapBase::outerStride() */
|
/** \sa MapBase::outerStride() */
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index outerStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index outerStride() const noexcept {
|
||||||
return internal::traits<BlockType>::HasSameStorageOrderAsXprType ? m_xpr.outerStride() : m_xpr.innerStride();
|
return internal::traits<BlockType>::HasSameStorageOrderAsXprType ? m_xpr.outerStride() : m_xpr.innerStride();
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startRow() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startRow() const noexcept { return m_startRow.value(); }
|
||||||
return m_startRow.value();
|
|
||||||
}
|
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startCol() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr StorageIndex startCol() const noexcept { return m_startCol.value(); }
|
||||||
return m_startCol.value();
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef __SUNPRO_CC
|
#ifndef __SUNPRO_CC
|
||||||
// FIXME sunstudio is not friendly with the above friend...
|
// FIXME sunstudio is not friendly with the above friend...
|
||||||
|
@ -90,13 +90,7 @@ struct CommaInitializer {
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC inline ~CommaInitializer()
|
EIGEN_DEVICE_FUNC inline ~CommaInitializer() { finished(); }
|
||||||
#if defined VERIFY_RAISES_ASSERT && (!defined EIGEN_NO_ASSERTION_CHECKING) && defined EIGEN_EXCEPTIONS
|
|
||||||
EIGEN_EXCEPTION_SPEC(Eigen::eigen_assert_exception)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
finished();
|
|
||||||
}
|
|
||||||
|
|
||||||
/** \returns the built matrix once all its coefficients have been set.
|
/** \returns the built matrix once all its coefficients have been set.
|
||||||
* Calling finished is 100% optional. Its purpose is to write expressions
|
* Calling finished is 100% optional. Its purpose is to write expressions
|
||||||
|
@ -149,7 +149,7 @@ class plainobjectbase_evaluator_data {
|
|||||||
#endif
|
#endif
|
||||||
eigen_internal_assert(outerStride == OuterStride);
|
eigen_internal_assert(outerStride == OuterStride);
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index outerStride() const EIGEN_NOEXCEPT { return OuterStride; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index outerStride() const noexcept { return OuterStride; }
|
||||||
const Scalar* data;
|
const Scalar* data;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1296,10 +1296,10 @@ struct mapbase_evaluator : evaluator_base<Derived> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rowStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rowStride() const noexcept {
|
||||||
return XprType::IsRowMajor ? m_outerStride.value() : m_innerStride.value();
|
return XprType::IsRowMajor ? m_outerStride.value() : m_innerStride.value();
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index colStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index colStride() const noexcept {
|
||||||
return XprType::IsRowMajor ? m_innerStride.value() : m_outerStride.value();
|
return XprType::IsRowMajor ? m_innerStride.value() : m_outerStride.value();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2017,9 +2017,9 @@ class EvalToTemp : public dense_xpr_base<EvalToTemp<ArgType>>::type {
|
|||||||
|
|
||||||
const ArgType& arg() const { return m_arg; }
|
const ArgType& arg() const { return m_arg; }
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_arg.rows(); }
|
constexpr Index rows() const noexcept { return m_arg.rows(); }
|
||||||
|
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_arg.cols(); }
|
constexpr Index cols() const noexcept { return m_arg.cols(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const ArgType& m_arg;
|
const ArgType& m_arg;
|
||||||
|
@ -108,12 +108,12 @@ class CwiseBinaryOp : public CwiseBinaryOpImpl<BinaryOp, LhsType, RhsType,
|
|||||||
eigen_assert(aLhs.rows() == aRhs.rows() && aLhs.cols() == aRhs.cols());
|
eigen_assert(aLhs.rows() == aRhs.rows() && aLhs.cols() == aRhs.cols());
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const noexcept {
|
||||||
// return the fixed size type if available to enable compile time optimizations
|
// return the fixed size type if available to enable compile time optimizations
|
||||||
return internal::traits<internal::remove_all_t<LhsNested>>::RowsAtCompileTime == Dynamic ? m_rhs.rows()
|
return internal::traits<internal::remove_all_t<LhsNested>>::RowsAtCompileTime == Dynamic ? m_rhs.rows()
|
||||||
: m_lhs.rows();
|
: m_lhs.rows();
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const noexcept {
|
||||||
// return the fixed size type if available to enable compile time optimizations
|
// return the fixed size type if available to enable compile time optimizations
|
||||||
return internal::traits<internal::remove_all_t<LhsNested>>::ColsAtCompileTime == Dynamic ? m_rhs.cols()
|
return internal::traits<internal::remove_all_t<LhsNested>>::ColsAtCompileTime == Dynamic ? m_rhs.cols()
|
||||||
: m_lhs.cols();
|
: m_lhs.cols();
|
||||||
|
@ -60,8 +60,8 @@ class CwiseUnaryOp : public CwiseUnaryOpImpl<UnaryOp, XprType, typename internal
|
|||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE explicit CwiseUnaryOp(const XprType& xpr, const UnaryOp& func = UnaryOp())
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE explicit CwiseUnaryOp(const XprType& xpr, const UnaryOp& func = UnaryOp())
|
||||||
: m_xpr(xpr), m_functor(func) {}
|
: m_xpr(xpr), m_functor(func) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const EIGEN_NOEXCEPT { return m_xpr.rows(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const noexcept { return m_xpr.rows(); }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const EIGEN_NOEXCEPT { return m_xpr.cols(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const noexcept { return m_xpr.cols(); }
|
||||||
|
|
||||||
/** \returns the functor representing the unary operation */
|
/** \returns the functor representing the unary operation */
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const UnaryOp& functor() const { return m_functor; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const UnaryOp& functor() const { return m_functor; }
|
||||||
|
@ -145,8 +145,8 @@ class CwiseUnaryView : public internal::CwiseUnaryViewImpl<ViewOp, MatrixType, S
|
|||||||
|
|
||||||
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(CwiseUnaryView)
|
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(CwiseUnaryView)
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
/** \returns the functor representing unary operation */
|
/** \returns the functor representing unary operation */
|
||||||
EIGEN_DEVICE_FUNC const ViewOp& functor() const { return m_functor; }
|
EIGEN_DEVICE_FUNC const ViewOp& functor() const { return m_functor; }
|
||||||
|
@ -473,25 +473,23 @@ class DenseCoeffsBase<Derived, DirectWriteAccessors> : public DenseCoeffsBase<De
|
|||||||
*
|
*
|
||||||
* \sa outerStride(), rowStride(), colStride()
|
* \sa outerStride(), rowStride(), colStride()
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return derived().innerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return derived().innerStride(); }
|
||||||
|
|
||||||
/** \returns the pointer increment between two consecutive inner slices (for example, between two consecutive columns
|
/** \returns the pointer increment between two consecutive inner slices (for example, between two consecutive columns
|
||||||
* in a column-major matrix).
|
* in a column-major matrix).
|
||||||
*
|
*
|
||||||
* \sa innerStride(), rowStride(), colStride()
|
* \sa innerStride(), rowStride(), colStride()
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return derived().outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return derived().outerStride(); }
|
||||||
|
|
||||||
// FIXME shall we remove it ?
|
// FIXME shall we remove it ?
|
||||||
constexpr Index stride() const EIGEN_NOEXCEPT {
|
constexpr Index stride() const noexcept { return Derived::IsVectorAtCompileTime ? innerStride() : outerStride(); }
|
||||||
return Derived::IsVectorAtCompileTime ? innerStride() : outerStride();
|
|
||||||
}
|
|
||||||
|
|
||||||
/** \returns the pointer increment between two consecutive rows.
|
/** \returns the pointer increment between two consecutive rows.
|
||||||
*
|
*
|
||||||
* \sa innerStride(), outerStride(), colStride()
|
* \sa innerStride(), outerStride(), colStride()
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rowStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index rowStride() const noexcept {
|
||||||
return Derived::IsRowMajor ? outerStride() : innerStride();
|
return Derived::IsRowMajor ? outerStride() : innerStride();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -499,7 +497,7 @@ class DenseCoeffsBase<Derived, DirectWriteAccessors> : public DenseCoeffsBase<De
|
|||||||
*
|
*
|
||||||
* \sa innerStride(), outerStride(), rowStride()
|
* \sa innerStride(), outerStride(), rowStride()
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index colStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index colStride() const noexcept {
|
||||||
return Derived::IsRowMajor ? innerStride() : outerStride();
|
return Derived::IsRowMajor ? innerStride() : outerStride();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -508,7 +506,7 @@ namespace internal {
|
|||||||
|
|
||||||
template <int Alignment, typename Derived, bool JustReturnZero>
|
template <int Alignment, typename Derived, bool JustReturnZero>
|
||||||
struct first_aligned_impl {
|
struct first_aligned_impl {
|
||||||
static constexpr Index run(const Derived&) EIGEN_NOEXCEPT { return 0; }
|
static constexpr Index run(const Derived&) noexcept { return 0; }
|
||||||
};
|
};
|
||||||
|
|
||||||
template <int Alignment, typename Derived>
|
template <int Alignment, typename Derived>
|
||||||
|
@ -83,11 +83,11 @@ class Diagonal : public internal::dense_xpr_base<Diagonal<MatrixType, DiagIndex_
|
|||||||
: numext::mini<Index>(m_matrix.rows(), m_matrix.cols() - m_index.value());
|
: numext::mini<Index>(m_matrix.rows(), m_matrix.cols() - m_index.value());
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return 1; }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return 1; }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return m_matrix.outerStride() + 1; }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return m_matrix.outerStride() + 1; }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return 0; }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return 0; }
|
||||||
|
|
||||||
typedef std::conditional_t<internal::is_lvalue<MatrixType>::value, Scalar, const Scalar> ScalarWithConstIfNotLvalue;
|
typedef std::conditional_t<internal::is_lvalue<MatrixType>::value, Scalar, const Scalar> ScalarWithConstIfNotLvalue;
|
||||||
|
|
||||||
@ -132,13 +132,13 @@ class Diagonal : public internal::dense_xpr_base<Diagonal<MatrixType, DiagIndex_
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
// some compilers may fail to optimize std::max etc in case of compile-time constants...
|
// some compilers may fail to optimize std::max etc in case of compile-time constants...
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index absDiagIndex() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index absDiagIndex() const noexcept {
|
||||||
return m_index.value() > 0 ? m_index.value() : -m_index.value();
|
return m_index.value() > 0 ? m_index.value() : -m_index.value();
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rowOffset() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rowOffset() const noexcept {
|
||||||
return m_index.value() > 0 ? 0 : -m_index.value();
|
return m_index.value() > 0 ? 0 : -m_index.value();
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index colOffset() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index colOffset() const noexcept {
|
||||||
return m_index.value() > 0 ? m_index.value() : 0;
|
return m_index.value() > 0 ? m_index.value() : 0;
|
||||||
}
|
}
|
||||||
// trigger a compile-time error if someone try to call packet
|
// trigger a compile-time error if someone try to call packet
|
||||||
|
@ -56,12 +56,12 @@ struct EigenBase {
|
|||||||
EIGEN_DEVICE_FUNC inline const Derived& const_derived() const { return *static_cast<const Derived*>(this); }
|
EIGEN_DEVICE_FUNC inline const Derived& const_derived() const { return *static_cast<const Derived*>(this); }
|
||||||
|
|
||||||
/** \returns the number of rows. \sa cols(), RowsAtCompileTime */
|
/** \returns the number of rows. \sa cols(), RowsAtCompileTime */
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return derived().rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return derived().rows(); }
|
||||||
/** \returns the number of columns. \sa rows(), ColsAtCompileTime*/
|
/** \returns the number of columns. \sa rows(), ColsAtCompileTime*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return derived().cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return derived().cols(); }
|
||||||
/** \returns the number of coefficients, which is rows()*cols().
|
/** \returns the number of coefficients, which is rows()*cols().
|
||||||
* \sa rows(), cols(), SizeAtCompileTime. */
|
* \sa rows(), cols(), SizeAtCompileTime. */
|
||||||
EIGEN_DEVICE_FUNC constexpr Index size() const EIGEN_NOEXCEPT { return rows() * cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index size() const noexcept { return rows() * cols(); }
|
||||||
|
|
||||||
/** \internal Don't use it, but do the equivalent: \code dst = *this; \endcode */
|
/** \internal Don't use it, but do the equivalent: \code dst = *this; \endcode */
|
||||||
template <typename Dest>
|
template <typename Dest>
|
||||||
|
@ -41,10 +41,10 @@ class ForceAlignedAccess : public internal::dense_xpr_base<ForceAlignedAccess<Ex
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit inline ForceAlignedAccess(const ExpressionType& matrix) : m_expression(matrix) {}
|
EIGEN_DEVICE_FUNC explicit inline ForceAlignedAccess(const ExpressionType& matrix) : m_expression(matrix) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_expression.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_expression.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_expression.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_expression.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return m_expression.outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return m_expression.outerStride(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return m_expression.innerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return m_expression.innerStride(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC inline const CoeffReturnType coeff(Index row, Index col) const {
|
EIGEN_DEVICE_FUNC inline const CoeffReturnType coeff(Index row, Index col) const {
|
||||||
return m_expression.coeff(row, col);
|
return m_expression.coeff(row, col);
|
||||||
|
@ -225,14 +225,14 @@ class IndexedViewImpl<XprType, RowIndices, ColIndices, StorageKind, true>
|
|||||||
return this->nestedExpression().data() + row_offset + col_offset;
|
return this->nestedExpression().data() + row_offset + col_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept {
|
||||||
if (traits<Derived>::InnerStrideAtCompileTime != Dynamic) {
|
if (traits<Derived>::InnerStrideAtCompileTime != Dynamic) {
|
||||||
return traits<Derived>::InnerStrideAtCompileTime;
|
return traits<Derived>::InnerStrideAtCompileTime;
|
||||||
}
|
}
|
||||||
return innerIncrement() * this->nestedExpression().innerStride();
|
return innerIncrement() * this->nestedExpression().innerStride();
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept {
|
||||||
if (traits<Derived>::OuterStrideAtCompileTime != Dynamic) {
|
if (traits<Derived>::OuterStrideAtCompileTime != Dynamic) {
|
||||||
return traits<Derived>::OuterStrideAtCompileTime;
|
return traits<Derived>::OuterStrideAtCompileTime;
|
||||||
}
|
}
|
||||||
|
@ -51,8 +51,8 @@ class Inverse : public InverseImpl<XprType, typename internal::traits<XprType>::
|
|||||||
|
|
||||||
explicit EIGEN_DEVICE_FUNC Inverse(const XprType& xpr) : m_xpr(xpr) {}
|
explicit EIGEN_DEVICE_FUNC Inverse(const XprType& xpr) : m_xpr(xpr) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_xpr.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_xpr.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_xpr.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_xpr.rows(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC const XprTypeNestedCleaned& nestedExpression() const { return m_xpr; }
|
EIGEN_DEVICE_FUNC const XprTypeNestedCleaned& nestedExpression() const { return m_xpr; }
|
||||||
|
|
||||||
|
@ -84,9 +84,9 @@ class MapBase<Derived, ReadOnlyAccessors> : public internal::dense_xpr_base<Deri
|
|||||||
typedef typename Base::CoeffReturnType CoeffReturnType;
|
typedef typename Base::CoeffReturnType CoeffReturnType;
|
||||||
|
|
||||||
/** \copydoc DenseBase::rows() */
|
/** \copydoc DenseBase::rows() */
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_rows.value(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_rows.value(); }
|
||||||
/** \copydoc DenseBase::cols() */
|
/** \copydoc DenseBase::cols() */
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_cols.value(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_cols.value(); }
|
||||||
|
|
||||||
/** Returns a pointer to the first coefficient of the matrix or vector.
|
/** Returns a pointer to the first coefficient of the matrix or vector.
|
||||||
*
|
*
|
||||||
|
@ -258,8 +258,8 @@ class Matrix : public PlainObjectBase<Matrix<Scalar_, Rows_, Cols_, Options_, Ma
|
|||||||
/** \brief Moves the matrix into the other one.
|
/** \brief Moves the matrix into the other one.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Matrix& operator=(Matrix&& other)
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Matrix& operator=(Matrix&& other) noexcept(
|
||||||
EIGEN_NOEXCEPT_IF(std::is_nothrow_move_assignable<Scalar>::value) {
|
std::is_nothrow_move_assignable<Scalar>::value) {
|
||||||
Base::operator=(std::move(other));
|
Base::operator=(std::move(other));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
@ -393,8 +393,8 @@ class Matrix : public PlainObjectBase<Matrix<Scalar_, Rows_, Cols_, Options_, Ma
|
|||||||
template <typename OtherDerived>
|
template <typename OtherDerived>
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Matrix(const EigenBase<OtherDerived>& other) : Base(other.derived()) {}
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Matrix(const EigenBase<OtherDerived>& other) : Base(other.derived()) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return 1; }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return 1; }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return this->innerSize(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return this->innerSize(); }
|
||||||
|
|
||||||
/////////// Geometry module ///////////
|
/////////// Geometry module ///////////
|
||||||
|
|
||||||
|
@ -45,8 +45,8 @@ class NestByValue : public internal::dense_xpr_base<NestByValue<ExpressionType>
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit inline NestByValue(const ExpressionType& matrix) : m_expression(matrix) {}
|
EIGEN_DEVICE_FUNC explicit inline NestByValue(const ExpressionType& matrix) : m_expression(matrix) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_expression.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_expression.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_expression.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_expression.cols(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC operator const ExpressionType&() const { return m_expression; }
|
EIGEN_DEVICE_FUNC operator const ExpressionType&() const { return m_expression; }
|
||||||
|
|
||||||
|
@ -162,8 +162,8 @@ class PlainObjectBase : public internal::dense_xpr_base<Derived>::type {
|
|||||||
EIGEN_DEVICE_FUNC Base& base() { return *static_cast<Base*>(this); }
|
EIGEN_DEVICE_FUNC Base& base() { return *static_cast<Base*>(this); }
|
||||||
EIGEN_DEVICE_FUNC const Base& base() const { return *static_cast<const Base*>(this); }
|
EIGEN_DEVICE_FUNC const Base& base() const { return *static_cast<const Base*>(this); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const EIGEN_NOEXCEPT { return m_storage.rows(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const noexcept { return m_storage.rows(); }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const EIGEN_NOEXCEPT { return m_storage.cols(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const noexcept { return m_storage.cols(); }
|
||||||
|
|
||||||
/** This is an overloaded version of DenseCoeffsBase<Derived,ReadOnlyAccessors>::coeff(Index,Index) const
|
/** This is an overloaded version of DenseCoeffsBase<Derived,ReadOnlyAccessors>::coeff(Index,Index) const
|
||||||
* provided to by-pass the creation of an evaluator of the expression, thus saving compilation efforts.
|
* provided to by-pass the creation of an evaluator of the expression, thus saving compilation efforts.
|
||||||
@ -450,7 +450,7 @@ class PlainObjectBase : public internal::dense_xpr_base<Derived>::type {
|
|||||||
/** \brief Move constructor */
|
/** \brief Move constructor */
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr PlainObjectBase(PlainObjectBase&&) = default;
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr PlainObjectBase(PlainObjectBase&&) = default;
|
||||||
/** \brief Move assignment operator */
|
/** \brief Move assignment operator */
|
||||||
EIGEN_DEVICE_FUNC constexpr PlainObjectBase& operator=(PlainObjectBase&& other) EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr PlainObjectBase& operator=(PlainObjectBase&& other) noexcept {
|
||||||
m_storage = std::move(other.m_storage);
|
m_storage = std::move(other.m_storage);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
@ -224,8 +224,8 @@ class Product
|
|||||||
"if you wanted a coeff-wise or a dot product use the respective explicit functions");
|
"if you wanted a coeff-wise or a dot product use the respective explicit functions");
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const EIGEN_NOEXCEPT { return m_lhs.rows(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const noexcept { return m_lhs.rows(); }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const EIGEN_NOEXCEPT { return m_rhs.cols(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const noexcept { return m_rhs.cols(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const LhsNestedCleaned& lhs() const { return m_lhs; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const LhsNestedCleaned& lhs() const { return m_lhs; }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const RhsNestedCleaned& rhs() const { return m_rhs; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const RhsNestedCleaned& rhs() const { return m_rhs; }
|
||||||
|
@ -58,8 +58,8 @@ class ReturnByValue : public internal::dense_xpr_base<ReturnByValue<Derived> >::
|
|||||||
EIGEN_DEVICE_FUNC inline void evalTo(Dest& dst) const {
|
EIGEN_DEVICE_FUNC inline void evalTo(Dest& dst) const {
|
||||||
static_cast<const Derived*>(this)->evalTo(dst);
|
static_cast<const Derived*>(this)->evalTo(dst);
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return static_cast<const Derived*>(this)->rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return static_cast<const Derived*>(this)->rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return static_cast<const Derived*>(this)->cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return static_cast<const Derived*>(this)->cols(); }
|
||||||
|
|
||||||
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
||||||
#define Unusable \
|
#define Unusable \
|
||||||
|
@ -87,8 +87,8 @@ class Reverse : public internal::dense_xpr_base<Reverse<MatrixType, Direction> >
|
|||||||
|
|
||||||
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Reverse)
|
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Reverse)
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC inline Index innerStride() const { return -m_matrix.innerStride(); }
|
EIGEN_DEVICE_FUNC inline Index innerStride() const { return -m_matrix.innerStride(); }
|
||||||
|
|
||||||
|
@ -63,8 +63,8 @@ class Select : public internal::dense_xpr_base<Select<ConditionMatrixType, ThenM
|
|||||||
eigen_assert(m_condition.cols() == m_then.cols() && m_condition.cols() == m_else.cols());
|
eigen_assert(m_condition.cols() == m_then.cols() && m_condition.cols() == m_else.cols());
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_condition.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_condition.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_condition.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_condition.cols(); }
|
||||||
|
|
||||||
inline EIGEN_DEVICE_FUNC const Scalar coeff(Index i, Index j) const {
|
inline EIGEN_DEVICE_FUNC const Scalar coeff(Index i, Index j) const {
|
||||||
if (m_condition.coeff(i, j))
|
if (m_condition.coeff(i, j))
|
||||||
|
@ -73,10 +73,10 @@ class SelfAdjointView : public TriangularBase<SelfAdjointView<MatrixType_, UpLo>
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit inline SelfAdjointView(MatrixType& matrix) : m_matrix(matrix) {}
|
EIGEN_DEVICE_FUNC explicit inline SelfAdjointView(MatrixType& matrix) : m_matrix(matrix) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return m_matrix.outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return m_matrix.outerStride(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return m_matrix.innerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return m_matrix.innerStride(); }
|
||||||
|
|
||||||
/** \sa MatrixBase::coeff()
|
/** \sa MatrixBase::coeff()
|
||||||
* \warning the coordinates must fit into the referenced triangular part
|
* \warning the coordinates must fit into the referenced triangular part
|
||||||
|
@ -66,8 +66,8 @@ class Solve : public SolveImpl<Decomposition, RhsType, typename internal::traits
|
|||||||
|
|
||||||
Solve(const Decomposition &dec, const RhsType &rhs) : m_dec(dec), m_rhs(rhs) {}
|
Solve(const Decomposition &dec, const RhsType &rhs) : m_dec(dec), m_rhs(rhs) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_dec.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_dec.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_rhs.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_rhs.cols(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC const Decomposition &dec() const { return m_dec; }
|
EIGEN_DEVICE_FUNC const Decomposition &dec() const { return m_dec; }
|
||||||
EIGEN_DEVICE_FUNC const RhsType &rhs() const { return m_rhs; }
|
EIGEN_DEVICE_FUNC const RhsType &rhs() const { return m_rhs; }
|
||||||
|
@ -216,8 +216,8 @@ struct triangular_solve_retval : public ReturnByValue<triangular_solve_retval<Si
|
|||||||
|
|
||||||
triangular_solve_retval(const TriangularType& tri, const Rhs& rhs) : m_triangularMatrix(tri), m_rhs(rhs) {}
|
triangular_solve_retval(const TriangularType& tri, const Rhs& rhs) : m_triangularMatrix(tri), m_rhs(rhs) {}
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_rhs.rows(); }
|
constexpr Index rows() const noexcept { return m_rhs.rows(); }
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_rhs.cols(); }
|
constexpr Index cols() const noexcept { return m_rhs.cols(); }
|
||||||
|
|
||||||
template <typename Dest>
|
template <typename Dest>
|
||||||
inline void evalTo(Dest& dst) const {
|
inline void evalTo(Dest& dst) const {
|
||||||
|
@ -36,11 +36,11 @@ class indexed_based_stl_iterator_base {
|
|||||||
typedef Index difference_type;
|
typedef Index difference_type;
|
||||||
typedef std::random_access_iterator_tag iterator_category;
|
typedef std::random_access_iterator_tag iterator_category;
|
||||||
|
|
||||||
indexed_based_stl_iterator_base() EIGEN_NO_THROW : mp_xpr(0), m_index(0) {}
|
indexed_based_stl_iterator_base() noexcept : mp_xpr(0), m_index(0) {}
|
||||||
indexed_based_stl_iterator_base(XprType& xpr, Index index) EIGEN_NO_THROW : mp_xpr(&xpr), m_index(index) {}
|
indexed_based_stl_iterator_base(XprType& xpr, Index index) noexcept : mp_xpr(&xpr), m_index(index) {}
|
||||||
|
|
||||||
indexed_based_stl_iterator_base(const non_const_iterator& other) EIGEN_NO_THROW : mp_xpr(other.mp_xpr),
|
indexed_based_stl_iterator_base(const non_const_iterator& other) noexcept
|
||||||
m_index(other.m_index) {}
|
: mp_xpr(other.mp_xpr), m_index(other.m_index) {}
|
||||||
|
|
||||||
indexed_based_stl_iterator_base& operator=(const non_const_iterator& other) {
|
indexed_based_stl_iterator_base& operator=(const non_const_iterator& other) {
|
||||||
mp_xpr = other.mp_xpr;
|
mp_xpr = other.mp_xpr;
|
||||||
@ -335,15 +335,14 @@ class pointer_based_stl_iterator {
|
|||||||
typedef std::conditional_t<bool(is_lvalue), value_type*, const value_type*> pointer;
|
typedef std::conditional_t<bool(is_lvalue), value_type*, const value_type*> pointer;
|
||||||
typedef std::conditional_t<bool(is_lvalue), value_type&, const value_type&> reference;
|
typedef std::conditional_t<bool(is_lvalue), value_type&, const value_type&> reference;
|
||||||
|
|
||||||
pointer_based_stl_iterator() EIGEN_NO_THROW : m_ptr(0) {}
|
pointer_based_stl_iterator() noexcept : m_ptr(0) {}
|
||||||
pointer_based_stl_iterator(XprType& xpr, Index index) EIGEN_NO_THROW : m_incr(xpr.innerStride()) {
|
pointer_based_stl_iterator(XprType& xpr, Index index) noexcept : m_incr(xpr.innerStride()) {
|
||||||
m_ptr = xpr.data() + index * m_incr.value();
|
m_ptr = xpr.data() + index * m_incr.value();
|
||||||
}
|
}
|
||||||
|
|
||||||
pointer_based_stl_iterator(const non_const_iterator& other) EIGEN_NO_THROW : m_ptr(other.m_ptr),
|
pointer_based_stl_iterator(const non_const_iterator& other) noexcept : m_ptr(other.m_ptr), m_incr(other.m_incr) {}
|
||||||
m_incr(other.m_incr) {}
|
|
||||||
|
|
||||||
pointer_based_stl_iterator& operator=(const non_const_iterator& other) EIGEN_NO_THROW {
|
pointer_based_stl_iterator& operator=(const non_const_iterator& other) noexcept {
|
||||||
m_ptr = other.m_ptr;
|
m_ptr = other.m_ptr;
|
||||||
m_incr.setValue(other.m_incr);
|
m_incr.setValue(other.m_incr);
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -65,8 +65,8 @@ class Transpose : public TransposeImpl<MatrixType, typename internal::traits<Mat
|
|||||||
|
|
||||||
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Transpose)
|
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(Transpose)
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index rows() const noexcept { return m_matrix.cols(); }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr Index cols() const noexcept { return m_matrix.rows(); }
|
||||||
|
|
||||||
/** \returns the nested expression */
|
/** \returns the nested expression */
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const internal::remove_all_t<MatrixTypeNested>& nestedExpression() const {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const internal::remove_all_t<MatrixTypeNested>& nestedExpression() const {
|
||||||
|
@ -293,9 +293,9 @@ class Transpose<TranspositionsBase<TranspositionsDerived> > {
|
|||||||
public:
|
public:
|
||||||
explicit Transpose(const TranspositionType& t) : m_transpositions(t) {}
|
explicit Transpose(const TranspositionType& t) : m_transpositions(t) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index size() const EIGEN_NOEXCEPT { return m_transpositions.size(); }
|
EIGEN_DEVICE_FUNC constexpr Index size() const noexcept { return m_transpositions.size(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_transpositions.size(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_transpositions.size(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_transpositions.size(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_transpositions.size(); }
|
||||||
|
|
||||||
/** \returns the \a matrix with the inverse transpositions applied to the columns.
|
/** \returns the \a matrix with the inverse transpositions applied to the columns.
|
||||||
*/
|
*/
|
||||||
|
@ -58,10 +58,10 @@ class TriangularBase : public EigenBase<Derived> {
|
|||||||
eigen_assert(!((int(Mode) & int(UnitDiag)) && (int(Mode) & int(ZeroDiag))));
|
eigen_assert(!((int(Mode) & int(UnitDiag)) && (int(Mode) & int(ZeroDiag))));
|
||||||
}
|
}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return derived().rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return derived().rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return derived().cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return derived().cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index outerStride() const EIGEN_NOEXCEPT { return derived().outerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index outerStride() const noexcept { return derived().outerStride(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index innerStride() const EIGEN_NOEXCEPT { return derived().innerStride(); }
|
EIGEN_DEVICE_FUNC constexpr Index innerStride() const noexcept { return derived().innerStride(); }
|
||||||
|
|
||||||
// dummy resize function
|
// dummy resize function
|
||||||
EIGEN_DEVICE_FUNC void resize(Index rows, Index cols) {
|
EIGEN_DEVICE_FUNC void resize(Index rows, Index cols) {
|
||||||
@ -194,9 +194,9 @@ class TriangularView
|
|||||||
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(TriangularView)
|
EIGEN_INHERIT_ASSIGNMENT_OPERATORS(TriangularView)
|
||||||
|
|
||||||
/** \copydoc EigenBase::rows() */
|
/** \copydoc EigenBase::rows() */
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
/** \copydoc EigenBase::cols() */
|
/** \copydoc EigenBase::cols() */
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
/** \returns a const reference to the nested expression */
|
/** \returns a const reference to the nested expression */
|
||||||
EIGEN_DEVICE_FUNC const NestedExpression& nestedExpression() const { return m_matrix; }
|
EIGEN_DEVICE_FUNC const NestedExpression& nestedExpression() const { return m_matrix; }
|
||||||
|
@ -64,12 +64,8 @@ class PartialReduxExpr : public internal::dense_xpr_base<PartialReduxExpr<Matrix
|
|||||||
EIGEN_DEVICE_FUNC explicit PartialReduxExpr(const MatrixType& mat, const MemberOp& func = MemberOp())
|
EIGEN_DEVICE_FUNC explicit PartialReduxExpr(const MatrixType& mat, const MemberOp& func = MemberOp())
|
||||||
: m_matrix(mat), m_functor(func) {}
|
: m_matrix(mat), m_functor(func) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return (Direction == Vertical ? 1 : m_matrix.rows()); }
|
||||||
return (Direction == Vertical ? 1 : m_matrix.rows());
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return (Direction == Horizontal ? 1 : m_matrix.cols()); }
|
||||||
}
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT {
|
|
||||||
return (Direction == Horizontal ? 1 : m_matrix.cols());
|
|
||||||
}
|
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC typename MatrixType::Nested nestedExpression() const { return m_matrix; }
|
EIGEN_DEVICE_FUNC typename MatrixType::Nested nestedExpression() const { return m_matrix; }
|
||||||
|
|
||||||
|
@ -294,9 +294,9 @@ class visitor_evaluator {
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit visitor_evaluator(const XprType& xpr) : m_evaluator(xpr), m_xpr(xpr) {}
|
EIGEN_DEVICE_FUNC explicit visitor_evaluator(const XprType& xpr) : m_evaluator(xpr), m_xpr(xpr) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_xpr.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_xpr.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_xpr.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_xpr.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index size() const EIGEN_NOEXCEPT { return m_xpr.size(); }
|
EIGEN_DEVICE_FUNC constexpr Index size() const noexcept { return m_xpr.size(); }
|
||||||
// outer-inner access
|
// outer-inner access
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE CoeffReturnType coeff(Index row, Index col) const {
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE CoeffReturnType coeff(Index row, Index col) const {
|
||||||
return m_evaluator.coeff(row, col);
|
return m_evaluator.coeff(row, col);
|
||||||
|
@ -235,7 +235,7 @@ constexpr EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
|
|||||||
* Tie arguments together into a tuple.
|
* Tie arguments together into a tuple.
|
||||||
*/
|
*/
|
||||||
template <typename... Args, typename ReturnType = TupleImpl<sizeof...(Args), Args&...>>
|
template <typename... Args, typename ReturnType = TupleImpl<sizeof...(Args), Args&...>>
|
||||||
constexpr EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ReturnType tie(Args&... args) EIGEN_NOEXCEPT {
|
constexpr EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE ReturnType tie(Args&... args) noexcept {
|
||||||
return ReturnType{args...};
|
return ReturnType{args...};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1277,11 +1277,6 @@ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE constexpr void ignore_unused_variable(cons
|
|||||||
#define EIGEN_CATCH(X) else
|
#define EIGEN_CATCH(X) else
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define EIGEN_NOEXCEPT noexcept
|
|
||||||
#define EIGEN_NOEXCEPT_IF(x) noexcept(x)
|
|
||||||
#define EIGEN_NO_THROW noexcept(true)
|
|
||||||
#define EIGEN_EXCEPTION_SPEC(X) noexcept(false)
|
|
||||||
|
|
||||||
// The all function is used to enable a variadic version of eigen_assert which can take a parameter pack as its input.
|
// The all function is used to enable a variadic version of eigen_assert which can take a parameter pack as its input.
|
||||||
namespace Eigen {
|
namespace Eigen {
|
||||||
namespace internal {
|
namespace internal {
|
||||||
|
@ -833,46 +833,44 @@ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void* eigen_aligned_alloca_helper(void* pt
|
|||||||
|
|
||||||
// HIP does not support new/delete on device.
|
// HIP does not support new/delete on device.
|
||||||
#if EIGEN_MAX_ALIGN_BYTES != 0 && !defined(EIGEN_HIP_DEVICE_COMPILE)
|
#if EIGEN_MAX_ALIGN_BYTES != 0 && !defined(EIGEN_HIP_DEVICE_COMPILE)
|
||||||
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign) \
|
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign) \
|
||||||
EIGEN_DEVICE_FUNC void* operator new(std::size_t size, const std::nothrow_t&) EIGEN_NO_THROW { \
|
EIGEN_DEVICE_FUNC void* operator new(std::size_t size, const std::nothrow_t&) noexcept { \
|
||||||
EIGEN_TRY { return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); } \
|
EIGEN_TRY { return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); } \
|
||||||
EIGEN_CATCH(...) { return 0; } \
|
EIGEN_CATCH(...) { return 0; } \
|
||||||
}
|
}
|
||||||
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign) \
|
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign) \
|
||||||
EIGEN_DEVICE_FUNC void* operator new(std::size_t size) { \
|
EIGEN_DEVICE_FUNC void* operator new(std::size_t size) { \
|
||||||
return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); \
|
return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); \
|
||||||
} \
|
} \
|
||||||
EIGEN_DEVICE_FUNC void* operator new[](std::size_t size) { \
|
EIGEN_DEVICE_FUNC void* operator new[](std::size_t size) { \
|
||||||
return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); \
|
return Eigen::internal::conditional_aligned_malloc<NeedsToAlign>(size); \
|
||||||
} \
|
} \
|
||||||
EIGEN_DEVICE_FUNC void operator delete(void* ptr) EIGEN_NO_THROW { \
|
EIGEN_DEVICE_FUNC void operator delete(void* ptr) noexcept { \
|
||||||
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
||||||
} \
|
} \
|
||||||
EIGEN_DEVICE_FUNC void operator delete[](void* ptr) EIGEN_NO_THROW { \
|
EIGEN_DEVICE_FUNC void operator delete[](void* ptr) noexcept { \
|
||||||
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
||||||
} \
|
} \
|
||||||
EIGEN_DEVICE_FUNC void operator delete(void* ptr, std::size_t /* sz */) EIGEN_NO_THROW { \
|
EIGEN_DEVICE_FUNC void operator delete(void* ptr, std::size_t /* sz */) noexcept { \
|
||||||
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
||||||
} \
|
} \
|
||||||
EIGEN_DEVICE_FUNC void operator delete[](void* ptr, std::size_t /* sz */) EIGEN_NO_THROW { \
|
EIGEN_DEVICE_FUNC void operator delete[](void* ptr, std::size_t /* sz */) noexcept { \
|
||||||
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
||||||
} \
|
} \
|
||||||
/* in-place new and delete. since (at least afaik) there is no actual */ \
|
/* in-place new and delete. since (at least afaik) there is no actual */ \
|
||||||
/* memory allocated we can safely let the default implementation handle */ \
|
/* memory allocated we can safely let the default implementation handle */ \
|
||||||
/* this particular case. */ \
|
/* this particular case. */ \
|
||||||
EIGEN_DEVICE_FUNC static void* operator new(std::size_t size, void* ptr) { return ::operator new(size, ptr); } \
|
EIGEN_DEVICE_FUNC static void* operator new(std::size_t size, void* ptr) { return ::operator new(size, ptr); } \
|
||||||
EIGEN_DEVICE_FUNC static void* operator new[](std::size_t size, void* ptr) { return ::operator new[](size, ptr); } \
|
EIGEN_DEVICE_FUNC static void* operator new[](std::size_t size, void* ptr) { return ::operator new[](size, ptr); } \
|
||||||
EIGEN_DEVICE_FUNC void operator delete(void* memory, void* ptr) EIGEN_NO_THROW { \
|
EIGEN_DEVICE_FUNC void operator delete(void* memory, void* ptr) noexcept { return ::operator delete(memory, ptr); } \
|
||||||
return ::operator delete(memory, ptr); \
|
EIGEN_DEVICE_FUNC void operator delete[](void* memory, void* ptr) noexcept { \
|
||||||
} \
|
return ::operator delete[](memory, ptr); \
|
||||||
EIGEN_DEVICE_FUNC void operator delete[](void* memory, void* ptr) EIGEN_NO_THROW { \
|
} \
|
||||||
return ::operator delete[](memory, ptr); \
|
/* nothrow-new (returns zero instead of std::bad_alloc) */ \
|
||||||
} \
|
EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign) \
|
||||||
/* nothrow-new (returns zero instead of std::bad_alloc) */ \
|
EIGEN_DEVICE_FUNC void operator delete(void* ptr, const std::nothrow_t&) noexcept { \
|
||||||
EIGEN_MAKE_ALIGNED_OPERATOR_NEW_NOTHROW(NeedsToAlign) \
|
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
||||||
EIGEN_DEVICE_FUNC void operator delete(void* ptr, const std::nothrow_t&) EIGEN_NO_THROW { \
|
} \
|
||||||
Eigen::internal::conditional_aligned_free<NeedsToAlign>(ptr); \
|
|
||||||
} \
|
|
||||||
typedef void eigen_aligned_operator_new_marker_type;
|
typedef void eigen_aligned_operator_new_marker_type;
|
||||||
#else
|
#else
|
||||||
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign)
|
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign)
|
||||||
|
@ -171,7 +171,7 @@ class variable_if_dynamic<T, Dynamic> {
|
|||||||
T m_value;
|
T m_value;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE explicit variable_if_dynamic(T value = 0) EIGEN_NO_THROW : m_value(value) {}
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE explicit variable_if_dynamic(T value = 0) noexcept : m_value(value) {}
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T value() const { return m_value; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T value() const { return m_value; }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE operator T() const { return m_value; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE operator T() const { return m_value; }
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void setValue(T value) { m_value = value; }
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void setValue(T value) { m_value = value; }
|
||||||
|
@ -515,8 +515,8 @@ struct TridiagonalizationMatrixTReturnType : public ReturnByValue<Tridiagonaliza
|
|||||||
result.template diagonal<-1>() = m_matrix.template diagonal<-1>();
|
result.template diagonal<-1>() = m_matrix.template diagonal<-1>();
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_matrix.rows(); }
|
constexpr Index rows() const noexcept { return m_matrix.rows(); }
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typename MatrixType::Nested m_matrix;
|
typename MatrixType::Nested m_matrix;
|
||||||
|
@ -69,10 +69,10 @@ class Homogeneous : public MatrixBase<Homogeneous<MatrixType, Direction_> >, int
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC explicit inline Homogeneous(const MatrixType& matrix) : m_matrix(matrix) {}
|
EIGEN_DEVICE_FUNC explicit inline Homogeneous(const MatrixType& matrix) : m_matrix(matrix) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept {
|
||||||
return m_matrix.rows() + (int(Direction) == Vertical ? 1 : 0);
|
return m_matrix.rows() + (int(Direction) == Vertical ? 1 : 0);
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept {
|
||||||
return m_matrix.cols() + (int(Direction) == Horizontal ? 1 : 0);
|
return m_matrix.cols() + (int(Direction) == Horizontal ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -244,8 +244,8 @@ struct homogeneous_left_product_impl<Homogeneous<MatrixType, Vertical>, Lhs>
|
|||||||
EIGEN_DEVICE_FUNC homogeneous_left_product_impl(const Lhs& lhs, const MatrixType& rhs)
|
EIGEN_DEVICE_FUNC homogeneous_left_product_impl(const Lhs& lhs, const MatrixType& rhs)
|
||||||
: m_lhs(take_matrix_for_product<Lhs>::run(lhs)), m_rhs(rhs) {}
|
: m_lhs(take_matrix_for_product<Lhs>::run(lhs)), m_rhs(rhs) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_lhs.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_lhs.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_rhs.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_rhs.cols(); }
|
||||||
|
|
||||||
template <typename Dest>
|
template <typename Dest>
|
||||||
EIGEN_DEVICE_FUNC void evalTo(Dest& dst) const {
|
EIGEN_DEVICE_FUNC void evalTo(Dest& dst) const {
|
||||||
@ -275,8 +275,8 @@ struct homogeneous_right_product_impl<Homogeneous<MatrixType, Horizontal>, Rhs>
|
|||||||
typedef remove_all_t<typename Rhs::Nested> RhsNested;
|
typedef remove_all_t<typename Rhs::Nested> RhsNested;
|
||||||
EIGEN_DEVICE_FUNC homogeneous_right_product_impl(const MatrixType& lhs, const Rhs& rhs) : m_lhs(lhs), m_rhs(rhs) {}
|
EIGEN_DEVICE_FUNC homogeneous_right_product_impl(const MatrixType& lhs, const Rhs& rhs) : m_lhs(lhs), m_rhs(rhs) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_lhs.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_lhs.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_rhs.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_rhs.cols(); }
|
||||||
|
|
||||||
template <typename Dest>
|
template <typename Dest>
|
||||||
EIGEN_DEVICE_FUNC void evalTo(Dest& dst) const {
|
EIGEN_DEVICE_FUNC void evalTo(Dest& dst) const {
|
||||||
|
@ -346,13 +346,11 @@ class Quaternion : public QuaternionBase<Quaternion<Scalar_, Options_> > {
|
|||||||
|
|
||||||
// We define a copy constructor, which means we don't get an implicit move constructor or assignment operator.
|
// We define a copy constructor, which means we don't get an implicit move constructor or assignment operator.
|
||||||
/** Default move constructor */
|
/** Default move constructor */
|
||||||
EIGEN_DEVICE_FUNC inline Quaternion(Quaternion&& other)
|
EIGEN_DEVICE_FUNC inline Quaternion(Quaternion&& other) noexcept(std::is_nothrow_move_constructible<Scalar>::value)
|
||||||
EIGEN_NOEXCEPT_IF(std::is_nothrow_move_constructible<Scalar>::value)
|
|
||||||
: m_coeffs(std::move(other.coeffs())) {}
|
: m_coeffs(std::move(other.coeffs())) {}
|
||||||
|
|
||||||
/** Default move assignment operator */
|
/** Default move assignment operator */
|
||||||
EIGEN_DEVICE_FUNC Quaternion& operator=(Quaternion&& other)
|
EIGEN_DEVICE_FUNC Quaternion& operator=(Quaternion&& other) noexcept(std::is_nothrow_move_assignable<Scalar>::value) {
|
||||||
EIGEN_NOEXCEPT_IF(std::is_nothrow_move_assignable<Scalar>::value) {
|
|
||||||
m_coeffs = std::move(other.coeffs());
|
m_coeffs = std::move(other.coeffs());
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
@ -353,10 +353,10 @@ class Transform {
|
|||||||
inline QTransform toQTransform(void) const;
|
inline QTransform toQTransform(void) const;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept {
|
||||||
return int(Mode) == int(Projective) ? m_matrix.cols() : (m_matrix.cols() - 1);
|
return int(Mode) == int(Projective) ? m_matrix.cols() : (m_matrix.cols() - 1);
|
||||||
}
|
}
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_matrix.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_matrix.cols(); }
|
||||||
|
|
||||||
/** shortcut for m_matrix(row,col);
|
/** shortcut for m_matrix(row,col);
|
||||||
* \sa MatrixBase::operator(Index,Index) const */
|
* \sa MatrixBase::operator(Index,Index) const */
|
||||||
|
@ -183,7 +183,7 @@ class HouseholderSequence : public EigenBase<HouseholderSequence<VectorsType, Co
|
|||||||
* \returns Number of rows
|
* \returns Number of rows
|
||||||
* \details This equals the dimension of the space that the transformation acts on.
|
* \details This equals the dimension of the space that the transformation acts on.
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT {
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept {
|
||||||
return Side == OnTheLeft ? m_vectors.rows() : m_vectors.cols();
|
return Side == OnTheLeft ? m_vectors.rows() : m_vectors.cols();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -191,7 +191,7 @@ class HouseholderSequence : public EigenBase<HouseholderSequence<VectorsType, Co
|
|||||||
* \returns Number of columns
|
* \returns Number of columns
|
||||||
* \details This equals the dimension of the space that the transformation acts on.
|
* \details This equals the dimension of the space that the transformation acts on.
|
||||||
*/
|
*/
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return rows(); }
|
||||||
|
|
||||||
/** \brief Essential part of a Householder vector.
|
/** \brief Essential part of a Householder vector.
|
||||||
* \param[in] k Index of Householder reflection
|
* \param[in] k Index of Householder reflection
|
||||||
|
@ -51,8 +51,8 @@ class DiagonalPreconditioner {
|
|||||||
compute(mat);
|
compute(mat);
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_invdiag.size(); }
|
constexpr Index rows() const noexcept { return m_invdiag.size(); }
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_invdiag.size(); }
|
constexpr Index cols() const noexcept { return m_invdiag.size(); }
|
||||||
|
|
||||||
template <typename MatType>
|
template <typename MatType>
|
||||||
DiagonalPreconditioner& analyzePattern(const MatType&) {
|
DiagonalPreconditioner& analyzePattern(const MatType&) {
|
||||||
|
@ -84,10 +84,10 @@ class IncompleteCholesky : public SparseSolverBase<IncompleteCholesky<Scalar, Up
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** \returns number of rows of the factored matrix */
|
/** \returns number of rows of the factored matrix */
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_L.rows(); }
|
constexpr Index rows() const noexcept { return m_L.rows(); }
|
||||||
|
|
||||||
/** \returns number of columns of the factored matrix */
|
/** \returns number of columns of the factored matrix */
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_L.cols(); }
|
constexpr Index cols() const noexcept { return m_L.cols(); }
|
||||||
|
|
||||||
/** \brief Reports whether previous computation was successful.
|
/** \brief Reports whether previous computation was successful.
|
||||||
*
|
*
|
||||||
|
@ -135,9 +135,9 @@ class IncompleteLUT : public SparseSolverBase<IncompleteLUT<Scalar_, StorageInde
|
|||||||
/** \brief Extraction Method for U-Factor */
|
/** \brief Extraction Method for U-Factor */
|
||||||
const FactorType matrixU() const;
|
const FactorType matrixU() const;
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_lu.rows(); }
|
constexpr Index rows() const noexcept { return m_lu.rows(); }
|
||||||
|
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_lu.cols(); }
|
constexpr Index cols() const noexcept { return m_lu.cols(); }
|
||||||
|
|
||||||
/** \brief Reports whether previous computation was successful.
|
/** \brief Reports whether previous computation was successful.
|
||||||
*
|
*
|
||||||
|
@ -218,10 +218,10 @@ class IterativeSolverBase : public SparseSolverBase<Derived> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** \internal */
|
/** \internal */
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return matrix().rows(); }
|
constexpr Index rows() const noexcept { return matrix().rows(); }
|
||||||
|
|
||||||
/** \internal */
|
/** \internal */
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return matrix().cols(); }
|
constexpr Index cols() const noexcept { return matrix().cols(); }
|
||||||
|
|
||||||
/** \returns the tolerance threshold used by the stopping criteria.
|
/** \returns the tolerance threshold used by the stopping criteria.
|
||||||
* \sa setTolerance()
|
* \sa setTolerance()
|
||||||
|
@ -50,8 +50,8 @@ class SolveWithGuess : public internal::generic_xpr_base<SolveWithGuess<Decompos
|
|||||||
SolveWithGuess(const Decomposition &dec, const RhsType &rhs, const GuessType &guess)
|
SolveWithGuess(const Decomposition &dec, const RhsType &rhs, const GuessType &guess)
|
||||||
: m_dec(dec), m_rhs(rhs), m_guess(guess) {}
|
: m_dec(dec), m_rhs(rhs), m_guess(guess) {}
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_dec.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_dec.cols(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_rhs.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_rhs.cols(); }
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC const Decomposition &dec() const { return m_dec; }
|
EIGEN_DEVICE_FUNC const Decomposition &dec() const { return m_dec; }
|
||||||
EIGEN_DEVICE_FUNC const RhsType &rhs() const { return m_rhs; }
|
EIGEN_DEVICE_FUNC const RhsType &rhs() const { return m_rhs; }
|
||||||
|
@ -100,8 +100,8 @@ class KLU : public SparseSolverBase<KLU<MatrixType_> > {
|
|||||||
if (m_numeric) klu_free_numeric(&m_numeric, &m_common);
|
if (m_numeric) klu_free_numeric(&m_numeric, &m_common);
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return mp_matrix.rows(); }
|
constexpr Index rows() const noexcept { return mp_matrix.rows(); }
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return mp_matrix.cols(); }
|
constexpr Index cols() const noexcept { return mp_matrix.cols(); }
|
||||||
|
|
||||||
/** \brief Reports whether previous computation was successful.
|
/** \brief Reports whether previous computation was successful.
|
||||||
*
|
*
|
||||||
|
@ -391,8 +391,8 @@ class FullPivLU : public SolverBase<FullPivLU<MatrixType_, PermutationIndex_> >
|
|||||||
|
|
||||||
MatrixType reconstructedMatrix() const;
|
MatrixType reconstructedMatrix() const;
|
||||||
|
|
||||||
EIGEN_DEVICE_FUNC constexpr Index rows() const EIGEN_NOEXCEPT { return m_lu.rows(); }
|
EIGEN_DEVICE_FUNC constexpr Index rows() const noexcept { return m_lu.rows(); }
|
||||||
EIGEN_DEVICE_FUNC constexpr Index cols() const EIGEN_NOEXCEPT { return m_lu.cols(); }
|
EIGEN_DEVICE_FUNC constexpr Index cols() const noexcept { return m_lu.cols(); }
|
||||||
|
|
||||||
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
||||||
template <typename RhsType, typename DstType>
|
template <typename RhsType, typename DstType>
|
||||||
|
@ -210,8 +210,8 @@ class PartialPivLU : public SolverBase<PartialPivLU<MatrixType_, PermutationInde
|
|||||||
|
|
||||||
MatrixType reconstructedMatrix() const;
|
MatrixType reconstructedMatrix() const;
|
||||||
|
|
||||||
constexpr Index rows() const EIGEN_NOEXCEPT { return m_lu.rows(); }
|
constexpr Index rows() const noexcept { return m_lu.rows(); }
|
||||||
constexpr Index cols() const EIGEN_NOEXCEPT { return m_lu.cols(); }
|
constexpr Index cols() const noexcept { return m_lu.cols(); }
|
||||||
|
|
||||||
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
#ifndef EIGEN_PARSED_BY_DOXYGEN
|
||||||
template <typename RhsType, typename DstType>
|
template <typename RhsType, typename DstType>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user