namespace Eigen { /** \eigenManualPage TutorialReshapeSlicing Reshape and Slicing %Eigen does not expose convenient methods to take slices or to reshape a matrix yet. Nonetheless, such features can easily be emulated using the Map class. \eigenAutoToc \section TutorialReshape Reshape A reshape operation consists in modifying the sizes of a matrix while keeping the same coefficients. Instead of modifying the input matrix itself, which is not possible for compile-time sizes, the approach consist in creating a different \em view on the storage using class Map. Here is a typical example creating a 1D linear view of a matrix: <table class="example"> <tr><th>Example:</th><th>Output:</th></tr> <tr><td> \include Tutorial_ReshapeMat2Vec.cpp </td> <td> \verbinclude Tutorial_ReshapeMat2Vec.out </td></tr></table> Remark how the storage order of the input matrix modifies the order of the coefficients in the linear view. Here is another example reshaping a 2x6 matrix to a 6x2 one: <table class="example"> <tr><th>Example:</th><th>Output:</th></tr> <tr><td> \include Tutorial_ReshapeMat2Mat.cpp </td> <td> \verbinclude Tutorial_ReshapeMat2Mat.out </td></tr></table> \section TutorialSlicing Slicing Slicing consists in taking a set of rows, columns, or elements, uniformly spaced within a matrix. Again, the class Map allows to easily mimic this feature. For instance, one can skip every P elements in a vector: <table class="example"> <tr><th>Example:</th><th>Output:</th></tr> <tr><td> \include Tutorial_SlicingVec.cpp </td> <td> \verbinclude Tutorial_SlicingVec.out </td></tr></table> One can olso take one column over three using an adequate outer-stride or inner-stride depending on the actual storage order: <table class="example"> <tr><th>Example:</th><th>Output:</th></tr> <tr><td> \include Tutorial_SlicingCol.cpp </td> <td> \verbinclude Tutorial_SlicingCol.out </td></tr></table> */ }