This is a java program to LU Decomposition of a given matrix. LU decomposition is the process of reducing single matrix into 2 matrices such that, upon multiplication we get the original matrix, having property that one of them is lower trinagular matrix and other one is upper trinagular matrix.
Here is the source code of the Java Program to Perform LU Decomposition of any Matrix. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a sample program to calulate the LU decomposition of the given matrix
import java.util.Scanner;
public class LUDecomposition
{
public static void main(String args[])
{
System.out.println("Enter the dimension of the matrix:");
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
double [][]mat = new double[n][n];
for(int i=0; i<n; i++)
for(int j=0; j<n; j++)
mat[i][j] = sc.nextDouble();
if(n==2)
{
double [][]l = new double[n][n];
l[0][0] = l[1][1] = 1;
l[0][1] = 0;
double [][]u = new double[n][n];
u[1][0] = 0;
u[0][0] = mat[0][0];
u[0][1] = mat[0][1];
l[1][0] = mat[1][0]/mat[0][0];
u[1][1] = mat[1][1] - (l[1][0]*u[0][1]); //mat[2][2]-(mat[2][1]*mat[1][2]/mat[1][1]);
System.out.println("The L Component is:");
for(int i=0; i<n; i++)
{
for(int j=0; j<n; j++)
System.out.print(" "+l[i][j]);
System.out.println();
}
System.out.println("The U Component is:");
for(int i=0; i<n; i++)
{
for(int j=0; j<n; j++)
System.out.print(" "+u[i][j]);
System.out.println();
}
}
if(n==3)
{
double [][]l = new double[n][n];
l[0][0] = l[1][1] = l[2][2] = 1;
l[0][1] = l[0][2] = l[1][2] = 0;
double [][]u = new double[n][n];
u[1][0] = u[2][0] = u[2][1] = 0;
u[0][0] = mat[0][0];
u[0][1] = mat[0][1];
u[0][2] = mat[0][2];
l[1][0] = mat[1][0]/mat[0][0];
u[1][1] = mat[1][1] - (l[1][0]*u[0][1]); //mat[2][2]-(mat[2][1]*mat[1][2]/mat[1][1]);
u[1][2] = mat[1][2] - (l[1][0]*u[0][2]);
l[2][0] = mat[2][0]/u[0][0];
l[2][1] = (mat[2][1] - l[2][1]*u[0][1])/u[1][1];
u[2][2] = mat[2][2] - (l[2][0]*u[0][2]) - (l[2][1]*u[1][2]);
System.out.println("The L Component is:");
for(int i=0; i<n; i++)
{
for(int j=0; j<n; j++)
System.out.print(" "+l[i][j]);
System.out.println();
}
System.out.println("The U Component is:");
for(int i=0; i<n; i++)
{
for(int j=0; j<n; j++)
System.out.print(" "+u[i][j]);
System.out.println();
}
}
sc.close();
}
}
Output:
$ javac LUDecomposition.java $ java LUDecomposition.java Enter the dimension of the matrix: 3 2 3 1 4 5 1 1 1 1 The L Component is: 1.0 0.0 0.0 2.0 1.0 0.0 0.5 -1.0 1.0 The U Component is: 2.0 3.0 1.0 0.0 -1.0 -1.0 0.0 0.0 -0.5
Related posts:
An Intro to Spring Cloud Security
Guide to Apache Commons CircularFifoQueue
Java Program to Delete a Particular Node in a Tree Without Using Recursion
Java Program to Apply DFS to Perform the Topological Sorting of a Directed Acyclic Graph
Java Program to Compute the Area of a Triangle Using Determinants
A Guide to EnumMap
Jackson Unmarshalling JSON with Unknown Properties
Java Program to Find the Connected Components of an UnDirected Graph
Array to String Conversions
Logout in an OAuth Secured Application
Introduction to Using Thymeleaf in Spring
Converting Between a List and a Set in Java
Removing Elements from Java Collections
Java Program to Repeatedly Search the Same Text (such as Bible by building a Data Structure)
Constructor Injection in Spring with Lombok
Hướng dẫn Java Design Pattern – Object Pool
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
A Guide to the Java ExecutorService
Jackson Date
String Processing with Apache Commons Lang 3
Java Program to Implement Efficient O(log n) Fibonacci generator
Toán tử instanceof trong java
Java Program to Find Shortest Path Between All Vertices Using Floyd-Warshall’s Algorithm
Guide to Character Encoding
Hướng dẫn sử dụng Printing Service trong Java
Chuyển đổi từ HashMap sang ArrayList
Java InputStream to Byte Array and ByteBuffer
Returning Custom Status Codes from Spring Controllers
Tránh lỗi NullPointerException trong Java như thế nào?
Java Program to Compute DFT Coefficients Directly
Java Program to Implement Interpolation Search Algorithm
Custom Exception trong Java