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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ludecomposition.java

?? Java 編寫的多種數(shù)據(jù)挖掘算法 包括聚類、分類、預(yù)處理等
?? JAVA
字號(hào):
/*
 * This software is a cooperative product of The MathWorks and the National
 * Institute of Standards and Technology (NIST) which has been released to the
 * public domain. Neither The MathWorks nor NIST assumes any responsibility
 * whatsoever for its use by other parties, and makes no guarantees, expressed
 * or implied, about its quality, reliability, or any other characteristic.
 */

/*
 * LUDecomposition.java
 * Copyright (C) 1999 The Mathworks and NIST
 *
 */

package weka.core.matrix;

import java.io.Serializable;

/** 
 * LU Decomposition.
 * <P>
 * For an m-by-n matrix A with m &gt;= 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 &lt; 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.
 * <p/>
 * Adapted from the <a href="http://math.nist.gov/javanumerics/jama/" target="_blank">JAMA</a> package.
 *
 * @author The Mathworks and NIST 
 * @author Fracpete (fracpete at waikato dot ac dot nz)
 * @version $Revision: 1.1 $
 */

public class LUDecomposition 
  implements Serializable {

  /** 
   * 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;

  /** 
   * 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];
        }
      }
    }
  }

  /** 
   * 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;
  }
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
gogo大胆日本视频一区| 欧美日韩一卡二卡三卡 | 91精品国产麻豆| 狠狠色丁香婷综合久久| 亚洲欧美激情插 | 日本高清不卡aⅴ免费网站| 奇米综合一区二区三区精品视频| 国产精品高潮呻吟| 欧美成人欧美edvon| 欧美丝袜第三区| www.欧美日韩国产在线| 精品无人码麻豆乱码1区2区 | 欧美日韩一区中文字幕| av在线不卡观看免费观看| 免费在线看成人av| 亚洲午夜私人影院| 国产精品乱人伦| 国产亚洲精品aa午夜观看| 欧美一区二区播放| 欧美三级视频在线观看| 99久久er热在这里只有精品15| 久久91精品国产91久久小草 | 欧美日韩视频一区二区| av在线综合网| 国产精品123| 麻豆91小视频| 理论电影国产精品| 首页国产欧美日韩丝袜| 亚洲午夜精品17c| 亚洲免费观看高清完整版在线观看 | 蜜臀精品久久久久久蜜臀| 亚洲第一成人在线| 亚洲一区二区在线免费观看视频| 中文字幕一区二区三区在线不卡| 国产亚洲成年网址在线观看| 欧美成人性战久久| 欧美刺激午夜性久久久久久久| 欧美人狂配大交3d怪物一区 | 欧美另类videos死尸| 色婷婷国产精品久久包臀 | 日韩视频免费直播| 日韩欧美一区在线观看| 7777精品伊人久久久大香线蕉| 欧美午夜精品一区二区三区| 在线视频一区二区免费| 欧洲国内综合视频| 欧美视频一区二区三区| 欧美年轻男男videosbes| 欧美日韩国产美| 欧美高清激情brazzers| 制服.丝袜.亚洲.另类.中文| 欧美美女一区二区在线观看| 欧美日韩国产高清一区二区三区 | 成人禁用看黄a在线| gogo大胆日本视频一区| 色偷偷久久人人79超碰人人澡| 91碰在线视频| 欧美日韩精品欧美日韩精品一综合 | 国产精品一区二区在线观看不卡| 国产自产视频一区二区三区| 国产精品1区2区| 91麻豆文化传媒在线观看| 欧美在线视频不卡| 欧美一二区视频| 国产午夜亚洲精品理论片色戒| 国产精品青草综合久久久久99| 亚洲天堂免费在线观看视频| 亚洲国产美国国产综合一区二区| 视频一区二区中文字幕| 国产真实乱偷精品视频免| 成人精品一区二区三区中文字幕| 日本久久电影网| 欧美一二三区在线观看| 国产精品午夜在线观看| 夜夜夜精品看看| 蜜臂av日日欢夜夜爽一区| 成人性视频免费网站| 91精品福利视频| 日韩免费成人网| 国产精品久久久久久久久免费丝袜| 一区二区三区日韩| 久久精品国产网站| www.日本不卡| 91精品国产免费| 国产精品福利一区| 日韩成人免费电影| 成人高清免费在线播放| 精品视频在线免费| 日本一区二区免费在线观看视频| 一区二区三区四区不卡视频| 激情综合亚洲精品| 欧美午夜精品免费| 久久伊人蜜桃av一区二区| 亚洲精品精品亚洲| 国内精品国产成人| 欧美三电影在线| 欧美国产欧美综合| 久久国产精品99久久人人澡| 色哟哟精品一区| 久久久一区二区三区| 午夜不卡av在线| 99久久精品国产观看| 精品毛片乱码1区2区3区| 亚洲一区二区在线视频| 大桥未久av一区二区三区中文| 欧美精品高清视频| 国产一区二区三区四| 欧美日韩一区高清| 日韩一区日韩二区| 国产一区二区三区| 欧美一级免费大片| 亚洲成av人影院| 91色|porny| 国产精品美日韩| 国产精品一区2区| 日韩欧美一区在线| 日本系列欧美系列| 欧美午夜精品免费| 伊人开心综合网| 91美女精品福利| 亚洲色图另类专区| 懂色av一区二区三区免费看| 精品国产凹凸成av人网站| 丝袜美腿亚洲综合| 欧美色综合天天久久综合精品| 亚洲少妇30p| av激情综合网| 日韩美女视频19| av一区二区三区四区| 国产精品毛片大码女人| 国产不卡高清在线观看视频| 精品国产一区二区三区四区四 | 日韩女优电影在线观看| 日韩中文字幕1| 538在线一区二区精品国产| 图片区小说区区亚洲影院| 色婷婷av一区二区三区gif | 欧美老人xxxx18| 亚洲一区二区三区四区在线| 色诱视频网站一区| 亚洲欧美福利一区二区| 在线一区二区三区做爰视频网站| 一区二区中文视频| 91首页免费视频| 亚洲精选免费视频| 中文字幕五月欧美| 成人永久免费视频| 国产精品久久久久久户外露出| 国产91在线看| 亚洲欧美偷拍卡通变态| 91免费国产在线| 一区二区三区不卡视频在线观看| 日本乱码高清不卡字幕| 亚洲国产欧美日韩另类综合| 8v天堂国产在线一区二区| 日本视频中文字幕一区二区三区| 91精品国产黑色紧身裤美女| 美女久久久精品| 国产人伦精品一区二区| 91网页版在线| 亚洲成av人片一区二区| 欧美一级爆毛片| 国产精品夜夜嗨| 国产精品国产三级国产专播品爱网| 色综合一区二区三区| 亚洲国产精品嫩草影院| 欧美一区二区三区性视频| 精品一区二区三区免费播放| 久久久久九九视频| 色综合天天综合在线视频| 亚洲综合色噜噜狠狠| 91精品国产乱码| 国产91精品露脸国语对白| 亚洲乱码国产乱码精品精可以看| 欧洲av在线精品| 精品亚洲国内自在自线福利| 国产精品理论片| 欧美日本在线播放| 国产麻豆欧美日韩一区| 亚洲美女电影在线| 日韩网站在线看片你懂的| 国产iv一区二区三区| 一区二区三区四区视频精品免费| 91精品国产综合久久久久久 | 成人动漫一区二区| 香蕉加勒比综合久久| 精品理论电影在线| 91麻豆国产福利精品| 日韩av中文字幕一区二区三区| 国产亚洲1区2区3区| 欧美亚洲综合一区| 欧美日韩国产另类一区| 国产老肥熟一区二区三区| 亚洲精品福利视频网站| 欧美精品一区二区三区四区| 93久久精品日日躁夜夜躁欧美| 久久99日本精品| 亚洲午夜日本在线观看| 中文字幕欧美日韩一区| 日韩亚洲电影在线|