Matrix3d m = Matrix3i::zero(); m.part().setOnes(); cout << "Here is the matrix m:" << endl << m << endl; cout << "And let us now compute m*m.adjoint() in a very optimized way" << endl << "taking advantage of the symmetry." << endl; Matrix3d n; n.part() = (m*m.adjoint()).lazy(); cout << "The result is:" << endl << n << endl;