Registered Member
|
Hello
I'm confused by the behavior of this code snippet, a block operation matrix product:
The compiler error is "YOU_ARE_TRYING_TO_USE_AN_INDEX_BASED_ACCESSOR_ON_AN_EXPRESSION_THAT_DOES_NOT_SUPPORT_THAT" and it's coming from MapBase. This is using gcc 4.7. Why is the temporary "column" variable necessary for the code to compile? Thanks! Alan |
Moderator
|
That's indeed a bug in Eigen. The reason it has not been detected so far is that your use case is rather unusual because it is not recommended at all (for performance reasons) to use general MatrixXd to represent vectors. "row" should be a RowVectorXd. So what happens is the following:
Eigen knows at compile time that "D.col(1)" is a column vector, so when you perform the multiplication with "row.leftCols(3)", Eigen also determines at compile time that "row.leftCols(3)" is actually a row vector. Therefore, "row.leftCols(3)" gets read through 1D indexes and the implementation of "row.leftCols(3)" complains because it still see itself as a general 2D sub-matrix. Doing row.col(0).head(3) will also do the trick. Let's see if this can be easily fixed... |
Moderator
|
Partial fix:
https://bitbucket.org/eigen/eigen/commits/ed3a129e7e2b/ https://bitbucket.org/eigen/eigen/commits/792917d7f245/ The following still won't compile: Eigen::MatrixXd prod = (D.col(1))*(row.block(0,0,1,3)); but fixing this implies transforming this static assertion into a runtime one while this actually reveal a bad use of the API. |
Registered Member
|
Thanks for the explanation and the tip, I'll switch to a row vector.
|
Registered users: Bing [Bot], claydoh, Google [Bot], rblackwell, Yahoo [Bot]