Passing objects by value is almost always a very bad idea in C++, as this means useless copies, and one should pass them by reference instead.
With Eigen, this is even more important: passing fixed-size vectorizable Eigen objects by value is not only inefficient, it can be illegal or make your program crash! And the reason is that these Eigen objects have alignment modifiers that aren't respected when they are passed by value.
For example, a function like this, where v
is passed by value:
needs to be rewritten as follows, passing v
by const reference:
Likewise if you have a class having an Eigen object as member:
This function also needs to be rewritten like this:
Note that on the other hand, there is no problem with functions that return objects by value.