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

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

?? singularvaluedecomposition.java

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

   /** Singular Value Decomposition.
   <P>
   For an m-by-n matrix A with m >= n, the singular value decomposition is
   an m-by-n orthogonal matrix U, an n-by-n diagonal matrix S, and
   an n-by-n orthogonal matrix V so that A = U*S*V'.
   <P>
   The singular values, sigma[k] = S[k][k], are ordered so that
   sigma[0] >= sigma[1] >= ... >= sigma[n-1].
   <P>
   The singular value decompostion always exists, so the constructor will
   never fail.  The matrix condition number and the effective numerical
   rank can be computed from this decomposition.
   */

public class SingularValueDecomposition implements java.io.Serializable {

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

   /** Arrays for internal storage of U and V.
   @serial internal storage of U.
   @serial internal storage of V.
   */
   private double[][] U, V;

   /** Array for internal storage of singular values.
   @serial internal storage of singular values.
   */
   private double[] s;

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

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

   /** Construct the singular value decomposition
   @param A    Rectangular matrix
   @return     Structure to access U, S and V.
   */

   public SingularValueDecomposition (Matrix Arg) {

      // Derived from LINPACK code.
      // Initialize.
      double[][] A = Arg.getArrayCopy();
      m = Arg.getRowDimension();
      n = Arg.getColumnDimension();

      /* Apparently the failing cases are only a proper subset of (m<n), 
	 so let's not throw error.  Correct fix to come later?
      if (m<n) {
	  throw new IllegalArgumentException("Jama SVD only works for m >= n"); }
      */
      int nu = Math.min(m,n);
      s = new double [Math.min(m+1,n)];
      U = new double [m][nu];
      V = new double [n][n];
      double[] e = new double [n];
      double[] work = new double [m];
      boolean wantu = true;
      boolean wantv = true;

      // Reduce A to bidiagonal form, storing the diagonal elements
      // in s and the super-diagonal elements in e.

      int nct = Math.min(m-1,n);
      int nrt = Math.max(0,Math.min(n-2,m));
      for (int k = 0; k < Math.max(nct,nrt); k++) {
         if (k < nct) {

            // Compute the transformation for the k-th column and
            // place the k-th diagonal in s[k].
            // Compute 2-norm of k-th column without under/overflow.
            s[k] = 0;
            for (int i = k; i < m; i++) {
               s[k] = Maths.hypot(s[k],A[i][k]);
            }
            if (s[k] != 0.0) {
               if (A[k][k] < 0.0) {
                  s[k] = -s[k];
               }
               for (int i = k; i < m; i++) {
                  A[i][k] /= s[k];
               }
               A[k][k] += 1.0;
            }
            s[k] = -s[k];
         }
         for (int j = k+1; j < n; j++) {
            if ((k < nct) & (s[k] != 0.0))  {

            // Apply the transformation.

               double t = 0;
               for (int i = k; i < m; i++) {
                  t += A[i][k]*A[i][j];
               }
               t = -t/A[k][k];
               for (int i = k; i < m; i++) {
                  A[i][j] += t*A[i][k];
               }
            }

            // Place the k-th row of A into e for the
            // subsequent calculation of the row transformation.

            e[j] = A[k][j];
         }
         if (wantu & (k < nct)) {

            // Place the transformation in U for subsequent back
            // multiplication.

            for (int i = k; i < m; i++) {
               U[i][k] = A[i][k];
            }
         }
         if (k < nrt) {

            // Compute the k-th row transformation and place the
            // k-th super-diagonal in e[k].
            // Compute 2-norm without under/overflow.
            e[k] = 0;
            for (int i = k+1; i < n; i++) {
               e[k] = Maths.hypot(e[k],e[i]);
            }
            if (e[k] != 0.0) {
               if (e[k+1] < 0.0) {
                  e[k] = -e[k];
               }
               for (int i = k+1; i < n; i++) {
                  e[i] /= e[k];
               }
               e[k+1] += 1.0;
            }
            e[k] = -e[k];
            if ((k+1 < m) & (e[k] != 0.0)) {

            // Apply the transformation.

               for (int i = k+1; i < m; i++) {
                  work[i] = 0.0;
               }
               for (int j = k+1; j < n; j++) {
                  for (int i = k+1; i < m; i++) {
                     work[i] += e[j]*A[i][j];
                  }
               }
               for (int j = k+1; j < n; j++) {
                  double t = -e[j]/e[k+1];
                  for (int i = k+1; i < m; i++) {
                     A[i][j] += t*work[i];
                  }
               }
            }
            if (wantv) {

            // Place the transformation in V for subsequent
            // back multiplication.

               for (int i = k+1; i < n; i++) {
                  V[i][k] = e[i];
               }
            }
         }
      }

      // Set up the final bidiagonal matrix or order p.

      int p = Math.min(n,m+1);
      if (nct < n) {
         s[nct] = A[nct][nct];
      }
      if (m < p) {
         s[p-1] = 0.0;
      }
      if (nrt+1 < p) {
         e[nrt] = A[nrt][p-1];
      }
      e[p-1] = 0.0;

      // If required, generate U.

      if (wantu) {
         for (int j = nct; j < nu; j++) {
            for (int i = 0; i < m; i++) {
               U[i][j] = 0.0;
            }
            U[j][j] = 1.0;
         }
         for (int k = nct-1; k >= 0; k--) {
            if (s[k] != 0.0) {
               for (int j = k+1; j < nu; j++) {
                  double t = 0;
                  for (int i = k; i < m; i++) {
                     t += U[i][k]*U[i][j];
                  }
                  t = -t/U[k][k];
                  for (int i = k; i < m; i++) {
                     U[i][j] += t*U[i][k];
                  }
               }
               for (int i = k; i < m; i++ ) {
                  U[i][k] = -U[i][k];
               }
               U[k][k] = 1.0 + U[k][k];
               for (int i = 0; i < k-1; i++) {
                  U[i][k] = 0.0;
               }
            } else {
               for (int i = 0; i < m; i++) {
                  U[i][k] = 0.0;
               }
               U[k][k] = 1.0;
            }
         }
      }

      // If required, generate V.

      if (wantv) {
         for (int k = n-1; k >= 0; k--) {
            if ((k < nrt) & (e[k] != 0.0)) {
               for (int j = k+1; j < nu; j++) {
                  double t = 0;
                  for (int i = k+1; i < n; i++) {
                     t += V[i][k]*V[i][j];
                  }
                  t = -t/V[k+1][k];
                  for (int i = k+1; i < n; i++) {
                     V[i][j] += t*V[i][k];
                  }
               }
            }
            for (int i = 0; i < n; i++) {
               V[i][k] = 0.0;
            }
            V[k][k] = 1.0;
         }
      }

      // Main iteration loop for the singular values.

      int pp = p-1;
      int iter = 0;
      double eps = Math.pow(2.0,-52.0);
      double tiny = Math.pow(2.0,-966.0);
      while (p > 0) {
         int k,kase;

         // Here is where a test for too many iterations would go.

         // This section of the program inspects for
         // negligible elements in the s and e arrays.  On
         // completion the variables kase and k are set as follows.

         // kase = 1     if s(p) and e[k-1] are negligible and k<p
         // kase = 2     if s(k) is negligible and k<p
         // kase = 3     if e[k-1] is negligible, k<p, and
         //              s(k), ..., s(p) are not negligible (qr step).
         // kase = 4     if e(p-1) is negligible (convergence).

         for (k = p-2; k >= -1; k--) {
            if (k == -1) {
               break;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产 欧美在线| 欧美日韩一区二区三区在线看 | 精品国产一区二区三区久久影院| 精品国产制服丝袜高跟| 国产精品久久久99| 麻豆国产91在线播放| 91一区一区三区| 久久嫩草精品久久久精品| 一区二区三区久久| 国产精品中文字幕一区二区三区| 91精品91久久久中77777| 26uuu久久综合| 日本不卡123| 在线精品视频一区二区| 亚洲自拍偷拍网站| 国产99久久久久久免费看农村| 欧美理论电影在线| 亚洲精品免费看| 风间由美中文字幕在线看视频国产欧美| 欧美人妖巨大在线| 一区二区在线观看视频在线观看| 久久精品国产网站| 欧美一级免费大片| 香蕉加勒比综合久久| 91视频.com| 最新不卡av在线| 成人一区二区视频| 国产三级一区二区| 国产精品91一区二区| 精品欧美久久久| 欧美aa在线视频| 日韩精品专区在线影院重磅| 午夜影视日本亚洲欧洲精品| 日本韩国欧美三级| 亚洲激情男女视频| 欧美在线你懂得| 亚洲一区二区三区国产| 91免费在线看| 尤物在线观看一区| 在线免费观看日本一区| 一区二区免费在线| 欧美色视频一区| 日韩中文字幕区一区有砖一区 | 91美女片黄在线观看| 午夜一区二区三区在线观看| 99久久精品国产一区二区三区 | 九九九久久久精品| 精品久久久久一区| 国产一区二三区好的| 国产午夜一区二区三区| 高清视频一区二区| 亚洲少妇屁股交4| 日本精品视频一区二区| 亚洲国产婷婷综合在线精品| 欧美美女直播网站| 久久99国产乱子伦精品免费| 久久久久久久久久久99999| 国产成人午夜片在线观看高清观看| 久久久亚洲精华液精华液精华液| 国产成人av一区二区三区在线 | 国产在线一区观看| 国产精品不卡在线观看| 91色婷婷久久久久合中文| 一个色综合av| 日韩一级视频免费观看在线| 国产在线精品一区二区| 国产精品女人毛片| 欧美日韩欧美一区二区| 激情综合网天天干| 亚洲欧美偷拍另类a∨色屁股| 欧美日韩在线观看一区二区| 秋霞电影网一区二区| 欧美精彩视频一区二区三区| 色噜噜狠狠一区二区三区果冻| 972aa.com艺术欧美| 亚洲va国产天堂va久久en| 久久男人中文字幕资源站| 99久久精品国产观看| 日韩精品亚洲一区| 中文字幕中文乱码欧美一区二区| 欧美在线观看一区二区| 国产美女视频91| 亚洲国产成人av网| 国产婷婷精品av在线| 欧美挠脚心视频网站| 成人国产精品免费网站| 日韩黄色片在线观看| 国产精品欧美一区喷水| 91精品国产91久久久久久一区二区| 国产jizzjizz一区二区| 美女一区二区三区| 一区二区在线观看视频| 国产欧美日韩另类一区| 日韩一级二级三级精品视频| 99久久综合国产精品| 国产伦精品一区二区三区免费| 亚洲成人一区在线| 中文字幕一区二区三区蜜月 | 日本韩国欧美一区二区三区| 加勒比av一区二区| 日韩黄色小视频| 亚洲综合在线观看视频| 日本一区二区三区电影| 欧美tickling挠脚心丨vk| 欧美日韩中文字幕一区二区| 99久久国产综合精品麻豆| 精品一区二区三区的国产在线播放| 亚洲综合激情网| 亚洲激情自拍偷拍| 亚洲三级在线免费| 国产精品久久久久婷婷二区次| www日韩大片| 欧美不卡在线视频| 日韩欧美国产不卡| 欧美一级国产精品| 制服丝袜亚洲色图| 69堂精品视频| 欧美一区二区三区爱爱| 8x8x8国产精品| 7777女厕盗摄久久久| 欧美肥妇free| 91精品国产综合久久福利| 欧美日韩在线播| 欧美精品一二三区| 7777精品伊人久久久大香线蕉的| 欧美日韩一区久久| 91精品国产乱| 精品欧美一区二区三区精品久久| 日韩欧美三级在线| 久久女同性恋中文字幕| 国产午夜精品美女毛片视频| 国产三级精品三级| 国产精品美日韩| 亚洲精品中文字幕乱码三区| 一区二区三区在线免费播放| 一区二区三区**美女毛片| 亚洲国产日日夜夜| 蜜臀av性久久久久蜜臀av麻豆| 久久精品免费看| 国产成人av电影在线观看| av高清久久久| 欧美在线播放高清精品| 日韩一区二区在线看| 久久人人爽人人爽| ●精品国产综合乱码久久久久| 亚洲欧美韩国综合色| 天堂影院一区二区| 国产麻豆视频一区二区| jizz一区二区| 制服丝袜中文字幕亚洲| 国产校园另类小说区| 一区二区三区四区国产精品| 日本aⅴ精品一区二区三区| 国产麻豆成人精品| 在线一区二区三区做爰视频网站| 制服视频三区第一页精品| 久久久精品综合| 夜夜精品视频一区二区| 久久99精品国产.久久久久| 99精品国产热久久91蜜凸| 欧美高清dvd| 国产精品国产三级国产普通话三级 | 亚洲图片有声小说| 国产精品系列在线播放| 91久久精品一区二区三| 精品国产91亚洲一区二区三区婷婷 | 欧美精品一区二区三区高清aⅴ| 国产精品黄色在线观看| 轻轻草成人在线| 91啦中文在线观看| 欧美精品一区二区三区在线播放 | 成人精品国产一区二区4080| 欧美日韩在线亚洲一区蜜芽| 国产拍揄自揄精品视频麻豆| 亚洲国产sm捆绑调教视频| 国产剧情av麻豆香蕉精品| 欧美亚洲一区二区在线| 欧美国产欧美亚州国产日韩mv天天看完整| 亚洲二区在线观看| aa级大片欧美| 久久品道一品道久久精品| 午夜精品久久久久| 色先锋aa成人| 欧美激情在线一区二区三区| 日本不卡视频在线观看| 色欧美日韩亚洲| 国产精品久久久久婷婷二区次| 精品在线免费视频| 欧美久久久久免费| 亚洲午夜电影网| 色中色一区二区| 亚洲欧洲日韩综合一区二区| 国模冰冰炮一区二区| 欧美一区二区黄| 日日噜噜夜夜狠狠视频欧美人| 99综合影院在线| 一区在线播放视频| 成人不卡免费av| 国产精品久久久久久久久免费樱桃| 国产一区欧美日韩|