aboutsummaryrefslogtreecommitdiffhomepage
path: root/Eigen/src/Core/util/XprHelper.h
diff options
context:
space:
mode:
authorGravatar Gael Guennebaud <g.gael@free.fr>2010-03-02 15:31:39 +0100
committerGravatar Gael Guennebaud <g.gael@free.fr>2010-03-02 15:31:39 +0100
commit2f3d685e0c687ae1121428dab6bc0ec868b14fe3 (patch)
treeb1a2470ff34d18c567987cdef31af042095b5c92 /Eigen/src/Core/util/XprHelper.h
parent0ed5edd24dc72404dd9f2a998d7a6b742d29ec9d (diff)
a matrix (or array) does not always have the LinearAccessBit!
=> fixes in outerStride and matrix flags
Diffstat (limited to 'Eigen/src/Core/util/XprHelper.h')
-rw-r--r--Eigen/src/Core/util/XprHelper.h9
1 files changed, 7 insertions, 2 deletions
diff --git a/Eigen/src/Core/util/XprHelper.h b/Eigen/src/Core/util/XprHelper.h
index a09475e20..fc4c01468 100644
--- a/Eigen/src/Core/util/XprHelper.h
+++ b/Eigen/src/Core/util/XprHelper.h
@@ -90,14 +90,19 @@ class ei_compute_matrix_flags
inner_max_size = MaxCols==1 ? MaxRows
: MaxRows==1 ? MaxCols
: row_major_bit ? MaxCols : MaxRows,
+ inner_size = Cols==1 ? Rows
+ : Rows==1 ? Cols
+ : row_major_bit ? Cols : Rows,
is_big = inner_max_size == Dynamic,
+ is_matrix = Cols!=1 && Rows!=1,
is_packet_size_multiple = MaxRows==Dynamic || MaxCols==Dynamic || ((MaxCols*MaxRows) % ei_packet_traits<Scalar>::size) == 0,
aligned_bit = (((Options&DontAlign)==0) && (is_big || is_packet_size_multiple)) ? AlignedBit : 0,
- packet_access_bit = ei_packet_traits<Scalar>::size > 1 && aligned_bit ? PacketAccessBit : 0
+ packet_access_bit = ei_packet_traits<Scalar>::size > 1 && aligned_bit ? PacketAccessBit : 0,
+ linear_access_bit = (inner_max_size!=Dynamic && inner_size!=inner_max_size && is_matrix) ? 0 : LinearAccessBit
};
public:
- enum { ret = LinearAccessBit | DirectAccessBit | NestByRefBit | packet_access_bit | row_major_bit | aligned_bit };
+ enum { ret = DirectAccessBit | NestByRefBit | packet_access_bit | row_major_bit | aligned_bit | linear_access_bit };
};
template<int _Rows, int _Cols> struct ei_size_at_compile_time