我试图实现Matrix.class来学习一些Java。
现在,我在使用高斯消除后返回矩阵的方法上遇到了一些困难,该方法稍后将用于查找矩阵的逆。
到目前为止,这是我想出的:
public Matrix gaussianElimination() {
Matrix inv = this.clone();
int i = 0;
int j = 0;
while (i<inv.getHeight() && j<inv.getWidth()) {
int pivot = i;
for (int k=i+1; k<inv.getHeight(); k++) {
if (Math.abs(inv.getArray()[k][j]) > Math.abs(inv.getArray()[pivot][j])) {
pivot = k;
}
}
if (inv.getArray()[pivot][j] != 0) {
inv = inv.swapRow(i, pivot);
double div = inv.getArray()[i][j];
for (double value : inv.getArray()[i]) {
value = value/div;
}
for (int u=i+1; u < inv.getHeight(); u++) {
double mult = inv.getArray()[u][j];
for (int l=0; l<inv.getWidth(); l++) {
inv.getArray()[u][l] = mult * inv.getArray()[i][l];
}
}
}
j++;
i++;
}
return inv;
}
getArray()函数返回矩阵的double [] [],而getHeight()和getWidth()分别返回inv.length和inv [0] .length。
我遵循了这个wikipedia页面的伪代码来实现该算法。
该方法返回一个矩阵,其中第一个枢轴元素的线在顶部,但不能正确计算下面的行。
例如:
一种
0.2635522849474877 0.10001114673002853 0.442971040143471
0.2986277338922876 0.7517642579959294 0.09150190333830721
0.8913610667753092 0.8898546572478708 0.25592546060133237
Inv
0.8913610667753092 0.8898546572478708 0.25592546060133237
0.26618513545092265 0.26573527978742995 0.07642644034471581
0.062426597261833985 0.06232109565941264 0.017923775508624545
由于找不到解决方案,我将非常感谢您的帮助。我可能在某个地方混合了一个指针,或者实现了错误的算法。
最佳答案
我看到两个问题。
在这些行中:
for (double value : inv.getArray()[i]) {
value = value/div;
}
您没有修改存储在矩阵中的值;您只是在修改
value
的值,然后将其丢弃。您想要类似的东西:for (int idx=0; idx<inv.getWidth(); idx++) {
inv.getArray()[i,idx] = inv.getArray()[i,idx] / div;
}
另外,在这一行:
inv.getArray()[u][l] = mult * inv.getArray()[i][l];
您应该将
=
更改为-=
。该算法说“从行u减去A [u,j] *第i行”。您只需用产品替换u行中的值。