Expression of a fixed-size or dynamic-size sub-vector.
VectorType | the type of the object in which we are taking a sub-vector |
Size | size of the sub-vector we are taking at compile time (optional) |
This class represents an expression of either a fixed-size or dynamic-size sub-vector. It is the return type of DenseBase::segment(Index,Index) and DenseBase::segment<int>(Index) and most of the time this is the only way it is used.
However, if you want to directly manipulate sub-vector expressions, for instance if you want to write a function returning such an expression, you will need to use this class.
Here is an example illustrating the dynamic case:
#include <Eigen/Core> #include <iostream> using namespace Eigen; using namespace std; template<typename Derived> Eigen::VectorBlock<Derived> segmentFromRange(MatrixBase<Derived>& v, int start, int end) { return Eigen::VectorBlock<Derived>(v.derived(), start, end-start); } template<typename Derived> const Eigen::VectorBlock<const Derived> segmentFromRange(const MatrixBase<Derived>& v, int start, int end) { return Eigen::VectorBlock<const Derived>(v.derived(), start, end-start); } int main(int, char**) { Matrix<int,1,6> v; v << 1,2,3,4,5,6; cout << segmentFromRange(2*v, 2, 4) << endl; // calls the const version segmentFromRange(v, 1, 3) *= 5; // calls the non-const version cout << "Now the vector v is:" << endl << v << endl; return 0; }
Output:
6 8 Now the vector v is: 1 10 15 4 5 6
Here is an example illustrating the fixed-size case:
#include <Eigen/Core> #include <iostream> using namespace Eigen; using namespace std; template<typename Derived> Eigen::VectorBlock<Derived, 2> firstTwo(MatrixBase<Derived>& v) { return Eigen::VectorBlock<Derived, 2>(v.derived(), 0); } template<typename Derived> const Eigen::VectorBlock<const Derived, 2> firstTwo(const MatrixBase<Derived>& v) { return Eigen::VectorBlock<const Derived, 2>(v.derived(), 0); } int main(int, char**) { Matrix<int,1,6> v; v << 1,2,3,4,5,6; cout << firstTwo(4*v) << endl; // calls the const version firstTwo(v) *= 2; // calls the non-const version cout << "Now the vector v is:" << endl << v << endl; return 0; }
Output:
4 8 Now the vector v is: 2 4 3 4 5 6
VectorBlock (VectorType &vector, Index start) | |
VectorBlock (VectorType &vector, Index start, Index size) | |
| inline |
Dynamic-size constructor
| inline |
Fixed-size constructor
© Eigen.
Licensed under the MPL2 License.
https://eigen.tuxfamily.org/dox/classEigen_1_1VectorBlock.html