This is a Java Program to Implement Gaussian Elimination Algorithm. Gaussian elimination (also known as row reduction) is an algorithm for solving systems of linear equations.
Here is the source code of the Java Program to Implement Gaussian Elimination Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/** ** Java Program to Implement Gaussian Elimination Algorithm **/ import java.util.Scanner; /** Class GaussianElimination **/ public class GaussianElimination { public void solve(double[][] A, double[] B) { int N = B.length; for (int k = 0; k < N; k++) { /** find pivot row **/ int max = k; for (int i = k + 1; i < N; i++) if (Math.abs(A[i][k]) > Math.abs(A[max][k])) max = i; /** swap row in A matrix **/ double[] temp = A[k]; A[k] = A[max]; A[max] = temp; /** swap corresponding values in constants matrix **/ double t = B[k]; B[k] = B[max]; B[max] = t; /** pivot within A and B **/ for (int i = k + 1; i < N; i++) { double factor = A[i][k] / A[k][k]; B[i] -= factor * B[k]; for (int j = k; j < N; j++) A[i][j] -= factor * A[k][j]; } } /** Print row echelon form **/ printRowEchelonForm(A, B); /** back substitution **/ double[] solution = new double[N]; for (int i = N - 1; i >= 0; i--) { double sum = 0.0; for (int j = i + 1; j < N; j++) sum += A[i][j] * solution[j]; solution[i] = (B[i] - sum) / A[i][i]; } /** Print solution **/ printSolution(solution); } /** function to print in row echleon form **/ public void printRowEchelonForm(double[][] A, double[] B) { int N = B.length; System.out.println("\nRow Echelon form : "); for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) System.out.printf("%.3f ", A[i][j]); System.out.printf("| %.3f\n", B[i]); } System.out.println(); } /** function to print solution **/ public void printSolution(double[] sol) { int N = sol.length; System.out.println("\nSolution : "); for (int i = 0; i < N; i++) System.out.printf("%.3f ", sol[i]); System.out.println(); } /** Main function **/ public static void main (String[] args) { Scanner scan = new Scanner(System.in); System.out.println("Gaussian Elimination Algorithm Test\n"); /** Make an object of GaussianElimination class **/ GaussianElimination ge = new GaussianElimination(); System.out.println("\nEnter number of variables"); int N = scan.nextInt(); double[] B = new double[N]; double[][] A = new double[N][N]; System.out.println("\nEnter "+ N +" equations coefficients "); for (int i = 0; i < N; i++) for (int j = 0; j < N; j++) A[i][j] = scan.nextDouble(); System.out.println("\nEnter "+ N +" solutions"); for (int i = 0; i < N; i++) B[i] = scan.nextDouble(); ge.solve(A,B); } }
Output:
Gaussian Elimination Algorithm Test Enter number of variables 3 Enter 3 equations coefficients 2 1 -1 -3 -1 2 -2 1 2 Enter 3 solutions 8 -11 -3 Row Echelon form : -3.000 -1.000 2.000 | -11.000 0.000 1.667 0.667 | 4.333 0.000 0.000 0.200 | -0.200 Solution : 2.000 3.000 -1.000
Related posts:
Java Program to Implement Uniform-Cost Search
Spring WebClient and OAuth2 Support
Limiting Query Results with JPA and Spring Data JPA
Mapping Nested Values with Jackson
Sorting Query Results with Spring Data
Java Program to Implement JobStateReasons API
Java Program to Perform Search in a BST
Giới thiệu Swagger – Công cụ document cho RESTfull APIs
A Quick Guide to Spring Cloud Consul
Convert Character Array to String in Java
Java Program to Create a Random Linear Extension for a DAG
Java Program to Implement Segment Tree
Java Program to Implement Euclid GCD Algorithm
Getting Started with Stream Processing with Spring Cloud Data Flow
Spring Boot - Rest Template
Spring Boot Change Context Path
Hashing a Password in Java
Java Program to implement Associate Array
Guide to the Fork/Join Framework in Java
Partition a List in Java
Java Perform to a 2D FFT Inplace Given a Complex 2D Array
Java Program to Check whether Directed Graph is Connected using BFS
Anonymous Classes in Java
Java Program to Implement Dijkstra’s Algorithm using Set
Java Program to Find the Shortest Path from Source Vertex to All Other Vertices in Linear Time
Display Auto-Configuration Report in Spring Boot
Spring 5 WebClient
Hướng dẫn sử dụng String Format trong Java
Spring Boot Configuration with Jasypt
Converting String to Stream of chars
Java – Byte Array to Reader
Guide to Spring Cloud Kubernetes