Advertisement
Guest User

ADAAD

a guest
Dec 10th, 2019
88
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 4.02 KB | None | 0 0
  1. import Jama.Matrix;
  2.  
  3. import java.util.ArrayList;
  4.  
  5. public class Main {
  6.  
  7.     public static void main(String[] args) {
  8.         double[][] mA = {{1, 3, 4,7}, {-4,11, 3, 1}, {10, 3, 1,11},{2,1,17,4}};
  9.        Matrix matrix = new Matrix(mA);
  10.         //Matrix matrix=Matrix.random(7,7);
  11.         Matrix m=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  12.         Matrix p=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  13.         ArrayList<Matrix> permutacje=new ArrayList<>();
  14.         matrix.print(5,2);
  15.         double norm=matrix.normF(),norm1;
  16.         for(int i=0;i<matrix.getColumnDimension()-1;i++)
  17.         {
  18.             System.out.println("Macierz permutacji: ");
  19.             permutacja(matrix,i).print(5,2);
  20.             p=permutacja(matrix,i);
  21.             permutacje.add(permutacja(matrix,i));
  22.             matrix=permutacja(matrix,i).times(matrix);
  23.             System.out.println("Macierz po zmianie: ");
  24.             matrix.print(5,2);
  25.             m=m.times(eliminacja(matrix,i).inverse());
  26.             System.out.println("L: chwil");
  27.             Matrix chw=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  28.             for(int j=permutacje.size()-1;j>0;j--)
  29.             {
  30.                 chw=permutacje.get(j).times(chw);
  31.             }
  32.             m.print(5,2);
  33.             chw.print(5,2);
  34.             chw=chw.times(m);
  35.             chw.print(5,2);
  36.  
  37.             System.out.println("Macierz eliminacji "+i);
  38.             eliminacja(matrix,i).print(5,2);
  39.             matrix=eliminacja(matrix,i).times(matrix);
  40.  
  41.             System.out.println("Macierz po eliminacji "+i);
  42.             matrix.print(5,2);
  43.  
  44.         }
  45.         System.out.println("Sprawdzenie");
  46.  
  47.         System.out.println("L:");
  48.         Matrix chw=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  49.         m.print(5,2);
  50.         for(int j=permutacje.size()-1;j>0;j--)
  51.         {
  52.             chw=permutacje.get(j).times(chw);
  53.         }
  54.  
  55.         System.out.println("U:");
  56.         matrix.print(5,2);
  57.         System.out.println("Pc:");
  58.         p=Matrix.identity(matrix.getColumnDimension(),matrix.getRowDimension());
  59.         for(int j=permutacje.size()-1;j>-1;j--)
  60.         {
  61.             p=permutacje.get(j).times(p);
  62.         }
  63.         p.print(5,2);
  64.         matrix=m.times(matrix);
  65.         System.out.println("L*U");
  66.         matrix=chw.times(matrix);
  67.         matrix.print(5,2);
  68.         System.out.println("Pc*A");
  69.         chw=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  70.         for(int j=permutacje.size()-1;j>-1;j--)
  71.         {
  72.             chw=permutacje.get(j).times(chw);
  73.         }
  74.         matrix=chw.times(matrix);
  75.         matrix.print(5,2);
  76.  
  77.  
  78.  
  79.  
  80.  
  81.  
  82.     }
  83.     static Matrix eliminacja(Matrix matrix, int column)
  84.     {
  85.         Matrix elim=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  86.         for(int i=0;i<matrix.getRowDimension();i++)
  87.         {
  88.             if(i>column)
  89.             {
  90.                 if(matrix.get(column,column)!=0) {
  91.                     elim.set(i, column, matrix.get(i, column) / matrix.get(column, column) * (-1));
  92.                 }
  93.                 else{
  94.                     return null;
  95.                 }
  96.             }
  97.         }
  98.         return elim;
  99.     }
  100.     static int findmax(Matrix matrix, int column)
  101.     {
  102.         double maxval=0, val;
  103.         int max=0;
  104.         for(int i=column; i<matrix.getRowDimension();i++)
  105.         {
  106.             val=matrix.get(i,column);
  107.             if(val<0)
  108.                 val=-val;
  109.             if(val>maxval)
  110.             {
  111.                 maxval=val;
  112.                 max=i;
  113.             }
  114.         }
  115.         return max;
  116.     }
  117.  
  118.     static Matrix permutacja(Matrix matrix, int column)
  119.     {
  120.         int max=findmax(matrix,column);
  121.  
  122.         Matrix m=Matrix.identity(matrix.getRowDimension(),matrix.getRowDimension());
  123.         m.set(column,column,0);
  124.         m.set(max,column,1);
  125.  
  126.         m.set(max,max,0);
  127.         m.set(column,max,1);
  128.  
  129.  
  130.         return m;
  131.     }
  132. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement