高斯-约旦法 求矩阵的逆(急)
我在网上找了一个高斯-约旦法求矩阵的逆,结果不对,请问他的原理是什么?一些程序错在什么地方?
void inverse(double n[4][4],double m[4][4]){
int is[4]={0,0,0,0};
int js[4]={0,0,0,0};
double fDet = 1.0;
double f =1.0;
for(int x=0;x<4;x++)
for(int y=0;y<4;y++)
m[x][y]=n[x][y];
for (int k = 0; k < 4; k ++){
double fMax = 0.0;
//戞堦庡尦
for (int i = k; i < 4; i ++){
for (int j = k; j < 4; j ++){
double f = abs(m[i][j]);
if (f > fMax){
fMax = f;
is[k] = i;//嵟戝擵強嵼揑峴
js[k] = j;//嵟戝擵強嵼揑楍
}
}
}
cout<<endl<<"is["<<k<<"]="<<is[k];
cout<<endl<<"js["<<k<<"]="<<js[k]<<endl;
if (is[k] != k){//晄嵼峴
f = -f;
//峴??
swap(m[k][0],m[is[k]][0]);
swap(m[k][1],m[is[k]][1]);
swap(m[k][2],m[is[k]][2]);
swap(m[k][3],m[is[k]][3]);
}
if (js[k] != k){ //晄嵼?楍
f = -f;
//楍??
swap(m[0][k], m[0][js[k]]);
swap(m[1][k], m[1][js[k]]);
swap(m[2][k], m[2][js[k]]);
swap(m[3][k], m[3][js[k]]);
}
fDet *= m[k][k];
m[k][k] = 1.0/m[k][k];
for (int j= 0;j<4;j++){
if (j!= k)
m[k][j] *= m[k][k];
}
for (i = 0; i < 4; i ++)
if (i != k)
for (int j = 0; j < 4; j ++)
if (j != k)
m[i][j] = m[i][j] - m[i][k] * m[k][j];
for (i = 0; i < 4; i ++){
if (i != k)
m[i][k] *= -m[k][k];
}
}
for (k = 3; k >= 0; k --){
if (js[k] != k){
swap(m[k][0], m[js[k]][0]);
swap(m[k][1], m[js[k]][1]);
swap(m[k][2], m[js[k]][2]);
swap(m[k][3], m[js[k]][3]);
}
if (is[k] != k){
swap(m[0][k], m[0][is[k]]);
swap(m[1][k], m[1][is[k]]);
swap(m[2][k], m[2][is[k]]);
swap(m[3][k], m[3][is[k]]);
}
}
}