如何在不改变列顺序的情况下使用特征库计算输入矩阵的下三角?
例如矩阵:
A=[1 2 3;4 5 6 ;7 8 9]
我希望结果是:
1 0 0
4 0 0
7 0 0
你的文字和你的例子不匹配。我将通过三种可能的方式来理解您的问题。首先,我们将设置矩阵:
Matrix3d mat;
mat << 1, 2, 3, 4, 5, 6, 7, 8, 9;
如果你想要实际的下三角矩阵,你会使用:
std::cout << Matrix3d(mat.triangularView<Lower>()) << "\n\n";
或类似的。结果是:
1 0 0
4 5 0
7 8 9
请注意您的示例中缺少的 5,8,9。如果您只想要最左边的列,您可以使用:
std::cout << mat.col(0) << "\n\n";
这使
1
4
7
如果(如示例的第二部分所示)您想要mat * [1, 0, 0]
,那么您可以进行矩阵乘法(不推荐)或仅构造结果:
Matrix3d z = Matrix3d::Zero();
z.col(0) = mat.col(0);
std::cout << z << "\n\n";
这给出了与您的示例相同的结果:
1 0 0
4 0 0
7 0 0