[英]Matrix inverse from PLU decomposition
我试图从 plu 分解计算逆矩阵,但我得到的结果是错误的。 使用调试器,我找不到可以责备的单个步骤,所以这里是反转函数的代码:
template<class T>
Matrix<T> Matrix<T>::inv() const {
std::tuple<Matrix<T>, Matrix<T>, Matrix<T>> PLU(this->decomp_PLU());
Matrix<T> P(std::get<0>(PLU));
Matrix<T> L(std::get<1>(PLU));
Matrix<T> U(std::get<2>(PLU));
if (!this->lines() == this->cols()) { throw std::logic_error("Matrix must be square"); }
unsigned N = this->lines();
Matrix<T> Y(N, N);
for (unsigned i = 0; i < N; i++) {
Matrix<T> B(Matrix<T>::gen_col(P.transp().data[i])); // B is the ith column vector of P
Y[i] = Matrix<T>::solve_climb(L, B).transp().data[0]; // Compute LY=P for each column vector
Matrix<T> conf(L.dot(Matrix<T>::gen_col(Y[i])));
if (!conf.allclose(B, 1e-9, 1e-9)) {
throw std::logic_error("WHYY");
}
}
Y = Y.transp();
Matrix<T> X(N, N);
for (unsigned i = 0; i < N; i++) {
Matrix<T> B(Matrix<T>::gen_col(Y.transp().data[i])); // B is the ith column vector of Y
X[i] = Matrix<T>::solve_descent(U, B).transp().data[0]; // Compute UX=Y for each column vector
Matrix<T> conf(U.dot(Matrix<T>::gen_col(X[i])));
if (!conf.allclose(B, 1e-9, 1e-9)) {
throw std::logic_error("WHYY");
}
}
X = X.transp();
return X;
}
函数Matrix<T>::gen_col
从其输入生成一个列向量, solve_climb
/ solve_descent
分别计算求解 AX=B 的列向量,其中 A 是三角矩阵(根据情况不同或优于)
仅供参考,当尝试检查每个向量的计算是否正确时,代码会抛出逻辑错误“WHYY”。
代码可能出错的任何线索?
谢谢
编辑:完整代码在这里 (matrix_def.h)和这里 (matrix.h)
由于 L 是三角形劣势,您应该使用solve_descent
,而不是solve_climb
。 U(三角上级)也是如此,您需要使用solve_climb
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.