forked from indy256/codelibrary
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGauss.java
48 lines (45 loc) · 1.62 KB
/
Gauss.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package linearalgebra;
import java.util.stream.IntStream;
public class Gauss {
public static double[] gauss(double[][] A, double[] B) {
int n = A.length;
double[][] a = IntStream.range(0, n).mapToObj(i -> A[i].clone()).toArray(double[][] ::new); // make a copy
double[] b = B.clone();
for (int row = 0; row < n; row++) {
int best = row;
for (int i = row + 1; i < n; i++)
if (Math.abs(a[best][row]) < Math.abs(a[i][row]))
best = i;
double[] tt = a[row];
a[row] = a[best];
a[best] = tt;
double t = b[row];
b[row] = b[best];
b[best] = t;
for (int i = row + 1; i < n; i++) a[row][i] /= a[row][row];
b[row] /= a[row][row];
// a[row][row] = 1;
for (int i = 0; i < n; i++) {
double z = a[i][row];
if (i != row && z != 0) {
// row + 1 instead of row is an optimization
for (int j = row + 1; j < n; j++) a[i][j] -= a[row][j] * z;
b[i] -= b[row] * z;
}
}
}
return b;
}
// Usage example
public static void main(String[] args) {
double[][] a = {{4, 2, -1}, {2, 4, 3}, {-1, 3, 5}};
double[] b = {1, 0, 0};
double[] x = gauss(a, b);
for (int i = 0; i < a.length; i++) {
double y = 0;
for (int j = 0; j < a[i].length; j++) y += a[i][j] * x[j];
if (Math.abs(b[i] - y) > 1e-9)
throw new RuntimeException();
}
}
}