Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: Eigen_test Odometry_test AttitudeEstimation_usingTicker MPU9250_Quaternion_Binary_Serial ... more
Flags
[Core module]
  These are the possible bits which can be OR'ed to constitute the flags of a matrix or expression. More...
| Variables | |
| const unsigned int | RowMajorBit = 0x1 | 
| for a matrix, this means that the storage order is row-major. | |
| const unsigned int | EvalBeforeNestingBit = 0x2 | 
| means the expression should be evaluated by the calling expression | |
| const unsigned int | EvalBeforeAssigningBit = 0x4 | 
| means the expression should be evaluated before any assignment | |
| const unsigned int | PacketAccessBit = 0x8 | 
| Short version: means the expression might be vectorized. | |
| const unsigned int | ActualPacketAccessBit = PacketAccessBit | 
| If vectorization is enabled (EIGEN_VECTORIZE is defined) this constant is set to the value PacketAccessBit. | |
| const unsigned int | LinearAccessBit = 0x10 | 
| Short version: means the expression can be seen as 1D vector. | |
| const unsigned int | LvalueBit = 0x20 | 
| Means the expression has a coeffRef() method, i.e. | |
| const unsigned int | DirectAccessBit = 0x40 | 
| Means that the underlying array of coefficients can be directly accessed as a plain strided array. | |
| const unsigned int | AlignedBit = 0x80 | 
| means the first coefficient packet is guaranteed to be aligned | |
Detailed Description
These are the possible bits which can be OR'ed to constitute the flags of a matrix or expression.
It is important to note that these flags are a purely compile-time notion. They are a compile-time property of an expression type, implemented as enum's. They are not stored in memory at runtime, and they do not incur any runtime overhead.
- See also:
- MatrixBase::Flags
Variable Documentation
| const unsigned int ActualPacketAccessBit = PacketAccessBit | 
If vectorization is enabled (EIGEN_VECTORIZE is defined) this constant is set to the value PacketAccessBit.
If vectorization is not enabled (EIGEN_VECTORIZE is not defined) this constant is set to the value 0.
Definition at line 92 of file Constants.h.
| const unsigned int AlignedBit = 0x80 | 
means the first coefficient packet is guaranteed to be aligned
Definition at line 147 of file Constants.h.
| const unsigned int DirectAccessBit = 0x40 | 
Means that the underlying array of coefficients can be directly accessed as a plain strided array.
The memory layout of the array of coefficients must be exactly the natural one suggested by rows(), cols(), outerStride(), innerStride(), and the RowMajorBit. This rules out expressions such as Diagonal, whose coefficients, though referencable, do not have such a regular memory layout.
See the comment on LvalueBit for an explanation of how LvalueBit and DirectAccessBit are mutually orthogonal.
Definition at line 142 of file Constants.h.
| const unsigned int EvalBeforeAssigningBit = 0x4 | 
means the expression should be evaluated before any assignment
Definition at line 63 of file Constants.h.
| const unsigned int EvalBeforeNestingBit = 0x2 | 
means the expression should be evaluated by the calling expression
Definition at line 58 of file Constants.h.
| const unsigned int LinearAccessBit = 0x10 | 
Short version: means the expression can be seen as 1D vector.
Long version: means that one can access the coefficients of this expression by coeff(int), and coeffRef(int) in the case of a lvalue expression. These index-based access methods are guaranteed to not have to do any runtime computation of a (row, col)-pair from the index, so that it is guaranteed that whenever it is available, index-based access is at least as fast as (row,col)-based access. Expressions for which that isn't possible don't have the LinearAccessBit.
If both PacketAccessBit and LinearAccessBit are set, then the packets of this expression can be accessed by packet(int), and writePacket(int) in the case of a lvalue expression.
Typically, all vector expressions have the LinearAccessBit, but there is one exception: Product expressions don't have it, because it would be troublesome for vectorization, even when the Product is a vector expression. Thus, vector Product expressions allow index-based coefficient access but not index-based packet access, so they don't have the LinearAccessBit.
Definition at line 117 of file Constants.h.
| const unsigned int LvalueBit = 0x20 | 
Means the expression has a coeffRef() method, i.e.
is writable as its individual coefficients are directly addressable. This rules out read-only expressions.
Note that DirectAccessBit and LvalueBit are mutually orthogonal, as there are examples of expression having one but note the other:
- writable expressions that don't have a very simple memory layout as a strided array, have LvalueBit but not DirectAccessBit
- Map-to-const expressions, for example Map<const Matrix>, have DirectAccessBit but not LvalueBit
Expressions having LvalueBit also have their coeff() method returning a const reference instead of returning a new value.
Definition at line 131 of file Constants.h.
| const unsigned int PacketAccessBit = 0x8 | 
Short version: means the expression might be vectorized.
Long version: means that the coefficients can be handled by packets and start at a memory location whose alignment meets the requirements of the present CPU architecture for optimized packet access. In the fixed-size case, there is the additional condition that it be possible to access all the coefficients by packets (this implies the requirement that the size be a multiple of 16 bytes, and that any nontrivial strides don't break the alignment). In the dynamic-size case, there is no such condition on the total size and strides, so it might not be possible to access all coeffs by packets.
- Note:
- This bit can be set regardless of whether vectorization is actually enabled. To check for actual vectorizability, see ActualPacketAccessBit.
Definition at line 81 of file Constants.h.
| const unsigned int RowMajorBit = 0x1 | 
for a matrix, this means that the storage order is row-major.
If this bit is not set, the storage order is column-major. For an expression, this determines the storage order of the matrix created by evaluation of that expression.
- See also:
- TopicStorageOrders
Definition at line 53 of file Constants.h.
Generated on Tue Jul 12 2022 17:47:02 by
 1.7.2
 1.7.2