Now, I think i understand the concept. But when i put it all into code it doesnt work...
First i try to turn the matrix into a Upper Triangle matrix, but for some reason after column 2 it stops working..
The array im inputing is:
[1.00 ] [5.00] [4.00] [4.00] [1.00]
[5.00] [7.00] [7.00] [4.00] [8.00]
[7.00] [4.00] [8.00] [4.00] [7.00]
[10.00] [12.00] [8.00] [4.00] [3.00]
[10.00] [12.00] [13.00] [4.00] [3.00]
double** inverseMatrix(double **matA, int dimension)
{
double** matInverse=malloc(dimension*sizeof(double*));
double **holder = matA;
for(int i = 0; i < dimension; i++){
matInverse[i] = malloc(dimension*sizeof(matInverse[0]));
}
for(int i = 0; i < dimension; i++){
for(int j = 0; j < dimension; j++){
matInverse[i][j] = 0.0;
}
matInverse[i][i] = 1.0;
}
for(int i = 0; i < dimension; i++){
double pivot = holder[i][i];
for(int j = 0; j < dimension; j++){
holder[i][j] = (holder[i][j]/pivot);
matInverse[i][j] = (matInverse[i][j]/pivot);
}
for(int row = i+1; row < dimension; row++){
int number = holder[row][i];
for(int col = 0; col < dimension; col++){
holder[row][col] = holder[row][col] - (holder[i][col] * number);
matInverse[row][col] = matInverse[row][col] - (matInverse[i][col] * number);
}
}
}
While the function is incomplete and we can't tell if there are other problems at the caller site, an error is detectable in the posted snippet:
Here
number
should be adouble
.