亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ludecomposition.java

?? 美國標準化組織和馬里蘭大學共同開發.實現java matrix包. JAMA由六個java類組成:Matrix, CholeskyDecomposition , LUDecomposition QR
?? JAVA
字號:
package Jama;

   /** LU Decomposition.
   <P>
   For an m-by-n matrix A with m >= n, the LU decomposition is an m-by-n
   unit lower triangular matrix L, an n-by-n upper triangular matrix U,
   and a permutation vector piv of length m so that A(piv,:) = L*U.
   If m < n, then L is m-by-m and U is m-by-n.
   <P>
   The LU decompostion with pivoting always exists, even if the matrix is
   singular, so the constructor will never fail.  The primary use of the
   LU decomposition is in the solution of square systems of simultaneous
   linear equations.  This will fail if isNonsingular() returns false.
   */

public class LUDecomposition implements java.io.Serializable {

/* ------------------------
   Class variables
 * ------------------------ */

   /** Array for internal storage of decomposition.
   @serial internal array storage.
   */
   private double[][] LU;

   /** Row and column dimensions, and pivot sign.
   @serial column dimension.
   @serial row dimension.
   @serial pivot sign.
   */
   private int m, n, pivsign; 

   /** Internal storage of pivot vector.
   @serial pivot vector.
   */
   private int[] piv;

/* ------------------------
   Constructor
 * ------------------------ */

   /** LU Decomposition
   @param  A   Rectangular matrix
   @return     Structure to access L, U and piv.
   */

   public LUDecomposition (Matrix A) {

   // Use a "left-looking", dot-product, Crout/Doolittle algorithm.

      LU = A.getArrayCopy();
      m = A.getRowDimension();
      n = A.getColumnDimension();
      piv = new int[m];
      for (int i = 0; i < m; i++) {
         piv[i] = i;
      }
      pivsign = 1;
      double[] LUrowi;
      double[] LUcolj = new double[m];

      // Outer loop.

      for (int j = 0; j < n; j++) {

         // Make a copy of the j-th column to localize references.

         for (int i = 0; i < m; i++) {
            LUcolj[i] = LU[i][j];
         }

         // Apply previous transformations.

         for (int i = 0; i < m; i++) {
            LUrowi = LU[i];

            // Most of the time is spent in the following dot product.

            int kmax = Math.min(i,j);
            double s = 0.0;
            for (int k = 0; k < kmax; k++) {
               s += LUrowi[k]*LUcolj[k];
            }

            LUrowi[j] = LUcolj[i] -= s;
         }
   
         // Find pivot and exchange if necessary.

         int p = j;
         for (int i = j+1; i < m; i++) {
            if (Math.abs(LUcolj[i]) > Math.abs(LUcolj[p])) {
               p = i;
            }
         }
         if (p != j) {
            for (int k = 0; k < n; k++) {
               double t = LU[p][k]; LU[p][k] = LU[j][k]; LU[j][k] = t;
            }
            int k = piv[p]; piv[p] = piv[j]; piv[j] = k;
            pivsign = -pivsign;
         }

         // Compute multipliers.
         
         if (j < m & LU[j][j] != 0.0) {
            for (int i = j+1; i < m; i++) {
               LU[i][j] /= LU[j][j];
            }
         }
      }
   }

/* ------------------------
   Temporary, experimental code.
   ------------------------ *\

   \** LU Decomposition, computed by Gaussian elimination.
   <P>
   This constructor computes L and U with the "daxpy"-based elimination
   algorithm used in LINPACK and MATLAB.  In Java, we suspect the dot-product,
   Crout algorithm will be faster.  We have temporarily included this
   constructor until timing experiments confirm this suspicion.
   <P>
   @param  A             Rectangular matrix
   @param  linpackflag   Use Gaussian elimination.  Actual value ignored.
   @return               Structure to access L, U and piv.
   *\

   public LUDecomposition (Matrix A, int linpackflag) {
      // Initialize.
      LU = A.getArrayCopy();
      m = A.getRowDimension();
      n = A.getColumnDimension();
      piv = new int[m];
      for (int i = 0; i < m; i++) {
         piv[i] = i;
      }
      pivsign = 1;
      // Main loop.
      for (int k = 0; k < n; k++) {
         // Find pivot.
         int p = k;
         for (int i = k+1; i < m; i++) {
            if (Math.abs(LU[i][k]) > Math.abs(LU[p][k])) {
               p = i;
            }
         }
         // Exchange if necessary.
         if (p != k) {
            for (int j = 0; j < n; j++) {
               double t = LU[p][j]; LU[p][j] = LU[k][j]; LU[k][j] = t;
            }
            int t = piv[p]; piv[p] = piv[k]; piv[k] = t;
            pivsign = -pivsign;
         }
         // Compute multipliers and eliminate k-th column.
         if (LU[k][k] != 0.0) {
            for (int i = k+1; i < m; i++) {
               LU[i][k] /= LU[k][k];
               for (int j = k+1; j < n; j++) {
                  LU[i][j] -= LU[i][k]*LU[k][j];
               }
            }
         }
      }
   }

\* ------------------------
   End of temporary code.
 * ------------------------ */

/* ------------------------
   Public Methods
 * ------------------------ */

   /** Is the matrix nonsingular?
   @return     true if U, and hence A, is nonsingular.
   */

   public boolean isNonsingular () {
      for (int j = 0; j < n; j++) {
         if (LU[j][j] == 0)
            return false;
      }
      return true;
   }

   /** Return lower triangular factor
   @return     L
   */

   public Matrix getL () {
      Matrix X = new Matrix(m,n);
      double[][] L = X.getArray();
      for (int i = 0; i < m; i++) {
         for (int j = 0; j < n; j++) {
            if (i > j) {
               L[i][j] = LU[i][j];
            } else if (i == j) {
               L[i][j] = 1.0;
            } else {
               L[i][j] = 0.0;
            }
         }
      }
      return X;
   }

   /** Return upper triangular factor
   @return     U
   */

   public Matrix getU () {
      Matrix X = new Matrix(n,n);
      double[][] U = X.getArray();
      for (int i = 0; i < n; i++) {
         for (int j = 0; j < n; j++) {
            if (i <= j) {
               U[i][j] = LU[i][j];
            } else {
               U[i][j] = 0.0;
            }
         }
      }
      return X;
   }

   /** Return pivot permutation vector
   @return     piv
   */

   public int[] getPivot () {
      int[] p = new int[m];
      for (int i = 0; i < m; i++) {
         p[i] = piv[i];
      }
      return p;
   }

   /** Return pivot permutation vector as a one-dimensional double array
   @return     (double) piv
   */

   public double[] getDoublePivot () {
      double[] vals = new double[m];
      for (int i = 0; i < m; i++) {
         vals[i] = (double) piv[i];
      }
      return vals;
   }

   /** Determinant
   @return     det(A)
   @exception  IllegalArgumentException  Matrix must be square
   */

   public double det () {
      if (m != n) {
         throw new IllegalArgumentException("Matrix must be square.");
      }
      double d = (double) pivsign;
      for (int j = 0; j < n; j++) {
         d *= LU[j][j];
      }
      return d;
   }

   /** Solve A*X = B
   @param  B   A Matrix with as many rows as A and any number of columns.
   @return     X so that L*U*X = B(piv,:)
   @exception  IllegalArgumentException Matrix row dimensions must agree.
   @exception  RuntimeException  Matrix is singular.
   */

   public Matrix solve (Matrix B) {
      if (B.getRowDimension() != m) {
         throw new IllegalArgumentException("Matrix row dimensions must agree.");
      }
      if (!this.isNonsingular()) {
         throw new RuntimeException("Matrix is singular.");
      }

      // Copy right hand side with pivoting
      int nx = B.getColumnDimension();
      Matrix Xmat = B.getMatrix(piv,0,nx-1);
      double[][] X = Xmat.getArray();

      // Solve L*Y = B(piv,:)
      for (int k = 0; k < n; k++) {
         for (int i = k+1; i < n; i++) {
            for (int j = 0; j < nx; j++) {
               X[i][j] -= X[k][j]*LU[i][k];
            }
         }
      }
      // Solve U*X = Y;
      for (int k = n-1; k >= 0; k--) {
         for (int j = 0; j < nx; j++) {
            X[k][j] /= LU[k][k];
         }
         for (int i = 0; i < k; i++) {
            for (int j = 0; j < nx; j++) {
               X[i][j] -= X[k][j]*LU[i][k];
            }
         }
      }
      return Xmat;
   }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品欧美日韩精品| 久久精品一区八戒影视| 亚洲国产一区二区在线播放| 99久久精品国产一区二区三区| 国产日产亚洲精品系列| 国产一区二区免费视频| 精品国产制服丝袜高跟| 九色|91porny| 精品三级av在线| 精品亚洲欧美一区| 精品久久久久久久人人人人传媒| 另类专区欧美蜜桃臀第一页| 日韩一区二区三区电影| 男人的j进女人的j一区| 91精品国产综合久久香蕉的特点| 视频在线观看91| 欧美一区二区在线看| 日韩va欧美va亚洲va久久| 91麻豆精品国产91久久久更新时间 | 91在线观看污| 国产精品麻豆欧美日韩ww| 成人app软件下载大全免费| 国产精品乱码一区二区三区软件 | 久久久久久亚洲综合影院红桃| 激情综合色综合久久综合| 久久色视频免费观看| 国产成人欧美日韩在线电影| 国产精品全国免费观看高清| 99久久久精品免费观看国产蜜| 亚洲日本乱码在线观看| 色国产精品一区在线观看| 亚洲国产aⅴ天堂久久| 欧美人与z0zoxxxx视频| 美女网站色91| 国产天堂亚洲国产碰碰| av一区二区三区| 亚洲自拍偷拍麻豆| 91精品国产品国语在线不卡| 九九九精品视频| 国产精品少妇自拍| 色婷婷一区二区三区四区| 亚洲福利国产精品| 久久激五月天综合精品| 国产视频一区在线播放| 93久久精品日日躁夜夜躁欧美| 一二三四社区欧美黄| 6080国产精品一区二区| 国产毛片精品国产一区二区三区| 国产精品不卡在线| 欧美手机在线视频| 久久av中文字幕片| 国产精品久久国产精麻豆99网站| 欧美性受xxxx黑人xyx性爽| 蜜臀av性久久久久蜜臀aⅴ| 欧美激情综合在线| 欧美午夜精品一区二区三区| 久久99国产精品麻豆| 中文字幕一区二区在线观看| 欧美日韩高清在线播放| 国产精品资源在线| 一区二区三区免费在线观看| 欧美成人精品福利| 91香蕉视频污在线| 免费在线一区观看| 亚洲欧美综合色| 日韩一区二区精品在线观看| 成人午夜电影网站| 日韩精品三区四区| 国产精品视频在线看| 欧美乱妇20p| 国产黄人亚洲片| 亚洲午夜在线视频| 久久久.com| 欧美日韩国产另类不卡| 成人一区二区三区中文字幕| 亚洲国产aⅴ成人精品无吗| 国产网红主播福利一区二区| 欧美精三区欧美精三区| 国产·精品毛片| 日韩高清在线观看| 国产精品久久久久久久久免费丝袜 | 久久久久久久久99精品| 欧美色精品天天在线观看视频| 国产精品中文字幕欧美| 亚洲bt欧美bt精品777| 国产精品免费视频网站| 欧美电影免费观看高清完整版在线 | 91麻豆精品国产自产在线 | 日韩精品一区二区三区老鸭窝| 色综合色综合色综合| 激情深爱一区二区| 亚洲一区在线看| 国产精品久久久久一区| 日韩亚洲欧美一区| 色婷婷综合久久久中文字幕| 国产乱国产乱300精品| 天堂精品中文字幕在线| 日韩理论片网站| 久久精品人人做人人爽97| 欧美精品v国产精品v日韩精品| 91色视频在线| 国产盗摄一区二区| 精品久久久久av影院| 欧美日韩国产首页在线观看| 91免费国产视频网站| 国产激情一区二区三区四区| 免费观看在线色综合| 亚洲福利视频三区| 亚洲精品国产第一综合99久久 | 国产亚洲va综合人人澡精品 | 亚洲精品在线一区二区| 欧美性淫爽ww久久久久无| 99久久久国产精品免费蜜臀| 国产精品一区二区视频| 久久成人久久爱| 男男视频亚洲欧美| 日韩在线一区二区| 午夜日韩在线观看| 亚洲一区成人在线| 亚洲综合视频网| 一区二区三区成人| 亚洲另类在线一区| 亚洲女与黑人做爰| 亚洲视频在线一区| 日韩美女精品在线| 亚洲男人的天堂在线aⅴ视频| www.av精品| 99riav一区二区三区| aa级大片欧美| 97精品久久久午夜一区二区三区| 99视频在线精品| av在线播放不卡| 91免费观看在线| 91豆麻精品91久久久久久| 色菇凉天天综合网| 欧洲另类一二三四区| 欧美网站大全在线观看| 欧美图片一区二区三区| 欧美日韩免费一区二区三区视频| 欧美伊人久久大香线蕉综合69| 欧美性色欧美a在线播放| 欧美性猛交xxxxxxxx| 欧美老肥妇做.爰bbww| 91超碰这里只有精品国产| 欧美一区二区福利视频| 欧美电影免费观看完整版| 久久网这里都是精品| 国产女人18毛片水真多成人如厕 | 欧美日韩一二三区| 3d动漫精品啪啪一区二区竹菊| 91麻豆精品国产91久久久久| 久久99最新地址| 国产精品伊人色| a亚洲天堂av| 91久久精品午夜一区二区| 欧美三级电影网站| 日韩欧美在线不卡| 久久久不卡网国产精品二区| 国产精品久久福利| 亚洲午夜视频在线观看| 日韩av不卡在线观看| 久久不见久久见免费视频7| 国产成人免费视频网站高清观看视频| 成人av电影免费观看| 91国偷自产一区二区三区成为亚洲经典 | 成人免费毛片aaaaa**| 91小视频在线免费看| 欧美日韩精品三区| 精品国内二区三区| 国产精品免费久久| 亚洲国产精品一区二区www在线| 美女视频黄久久| 成人午夜精品在线| 欧美午夜精品理论片a级按摩| 久久精品国产一区二区三| 国产高清亚洲一区| 91久久精品一区二区| 欧美不卡视频一区| 最新欧美精品一区二区三区| 丝袜亚洲另类欧美综合| 国产精品99久久久久久似苏梦涵| 色综合久久中文综合久久97| 日韩视频一区在线观看| 国产精品剧情在线亚洲| 日韩国产在线观看一区| 国产成人免费在线| 欧美日韩免费在线视频| 国产三级一区二区| 亚洲成av人片在线| 国产福利一区在线| 欧美三级电影一区| 国产欧美一区二区在线| 亚洲超丰满肉感bbw| 国产1区2区3区精品美女| 欧美日韩高清一区二区不卡| 国产欧美日韩精品一区| 日日摸夜夜添夜夜添精品视频| 成人精品国产一区二区4080| 欧美一区二区不卡视频| 自拍偷自拍亚洲精品播放|