From 8b4945a5a2468f1eb82028af959389d98dc0b74c Mon Sep 17 00:00:00 2001 From: Benoit Jacob Date: Sat, 19 Jul 2008 00:25:41 +0000 Subject: [PATCH] add some static asserts, use them, fix gcc 4.3 warning in Product.h. --- Eigen/src/Core/CwiseNullaryOp.h | 2 ++ Eigen/src/Core/Matrix.h | 23 ++++++++++------------- Eigen/src/Core/Product.h | 4 ++-- Eigen/src/Core/util/StaticAssert.h | 18 +++++++++++++++--- 4 files changed, 29 insertions(+), 18 deletions(-) diff --git a/Eigen/src/Core/CwiseNullaryOp.h b/Eigen/src/Core/CwiseNullaryOp.h index 9b15d4240..167993e02 100644 --- a/Eigen/src/Core/CwiseNullaryOp.h +++ b/Eigen/src/Core/CwiseNullaryOp.h @@ -225,6 +225,7 @@ template const typename MatrixBase::ConstantReturnType MatrixBase::constant(const Scalar& value) { + EIGEN_STATIC_ASSERT_FIXED_SIZE(Derived) return NullaryExpr(RowsAtCompileTime, ColsAtCompileTime, ei_scalar_constant_op(value)); } @@ -472,6 +473,7 @@ template inline const CwiseNullaryOp::Scalar>, Derived> MatrixBase::identity() { + EIGEN_STATIC_ASSERT_FIXED_SIZE(Derived) return NullaryExpr(RowsAtCompileTime, ColsAtCompileTime, ei_scalar_identity_op()); } diff --git a/Eigen/src/Core/Matrix.h b/Eigen/src/Core/Matrix.h index 569d7207c..92988b725 100644 --- a/Eigen/src/Core/Matrix.h +++ b/Eigen/src/Core/Matrix.h @@ -235,7 +235,10 @@ class Matrix : public MatrixBase 0); - ei_assert((RowsAtCompileTime == 1 - && (ColsAtCompileTime == Dynamic || ColsAtCompileTime == dim)) - || (ColsAtCompileTime == 1 - && (RowsAtCompileTime == Dynamic || RowsAtCompileTime == dim))); + ei_assert(SizeAtCompileTime == Dynamic || SizeAtCompileTime == dim); } /** This constructor has two very different behaviors, depending on the type of *this. @@ -287,24 +288,21 @@ class Matrix : public MatrixBase::size==1) - ||(DestDerived::Flags&ActualPacketAccessBit) && (!(DestDerived::Flags & RowMajorBit)) }; + ||((DestDerived::Flags&ActualPacketAccessBit) && (!(DestDerived::Flags & RowMajorBit))) }; Scalar* __restrict__ _res; if (EvalToRes) _res = &res.coeffRef(0); @@ -572,7 +572,7 @@ struct ei_cache_friendly_product_selector::size==1) - ||(DestDerived::Flags & ActualPacketAccessBit) && (DestDerived::Flags & RowMajorBit) }; + ||((DestDerived::Flags & ActualPacketAccessBit) && (DestDerived::Flags & RowMajorBit)) }; Scalar* __restrict__ _res; if (EvalToRes) _res = &res.coeffRef(0); diff --git a/Eigen/src/Core/util/StaticAssert.h b/Eigen/src/Core/util/StaticAssert.h index 9fcf55d84..6979e4ac1 100644 --- a/Eigen/src/Core/util/StaticAssert.h +++ b/Eigen/src/Core/util/StaticAssert.h @@ -58,7 +58,9 @@ you_tried_calling_a_vector_method_on_a_matrix, you_mixed_vectors_of_different_sizes, you_mixed_matrices_of_different_sizes, + this_method_is_only_for_vectors_of_a_specific_size, you_did_a_programming_error, + you_called_a_fixed_size_method_on_a_dynamic_size_matrix_or_vector, unaligned_load_and_store_operations_unimplemented_on_AltiVec }; }; @@ -75,12 +77,22 @@ #endif // EIGEN_NO_STATIC_ASSERT -// static assertion failling if the type \a TYPE is not a vector type +// static assertion failing if the type \a TYPE is not a vector type #define EIGEN_STATIC_ASSERT_VECTOR_ONLY(TYPE) \ EIGEN_STATIC_ASSERT(TYPE::IsVectorAtCompileTime, \ you_tried_calling_a_vector_method_on_a_matrix) -// static assertion failling if the two vector expression types are not compatible (same fixed-size or dynamic size) +// static assertion failing if the type \a TYPE is not fixed-size +#define EIGEN_STATIC_ASSERT_FIXED_SIZE(TYPE) \ + EIGEN_STATIC_ASSERT(TYPE::SizeAtCompileTime!=Eigen::Dynamic, \ + you_called_a_fixed_size_method_on_a_dynamic_size_matrix_or_vector) + +// static assertion failing if the type \a TYPE is not a vector type of the given size +#define EIGEN_STATIC_ASSERT_VECTOR_SPECIFIC_SIZE(TYPE, SIZE) \ + EIGEN_STATIC_ASSERT(TYPE::IsVectorAtCompileTime && TYPE::SizeAtCompileTime==SIZE, \ + this_method_is_only_for_vectors_of_a_specific_size) + +// static assertion failing if the two vector expression types are not compatible (same fixed-size or dynamic size) #define EIGEN_STATIC_ASSERT_SAME_VECTOR_SIZE(TYPE0,TYPE1) \ EIGEN_STATIC_ASSERT( \ (int(TYPE0::SizeAtCompileTime)==Eigen::Dynamic \ @@ -88,7 +100,7 @@ || int(TYPE0::SizeAtCompileTime)==int(TYPE1::SizeAtCompileTime)),\ you_mixed_vectors_of_different_sizes) -// static assertion failling if the two matrix expression types are not compatible (same fixed-size or dynamic size) +// static assertion failing if the two matrix expression types are not compatible (same fixed-size or dynamic size) #define EIGEN_STATIC_ASSERT_SAME_MATRIX_SIZE(TYPE0,TYPE1) \ EIGEN_STATIC_ASSERT( \ ((int(TYPE0::RowsAtCompileTime)==Eigen::Dynamic \