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

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

?? singularvaluedecomposition.java

?? java程序包
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package com.biolab.node.nexTest.Jama;

   /** 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一区二区三区免费野_久草精品视频
亚洲人成网站精品片在线观看| 亚洲免费观看高清完整版在线| www.爱久久.com| 天天综合色天天| 国产精品久久三| 欧美一级夜夜爽| 99精品偷自拍| 韩国三级电影一区二区| 综合自拍亚洲综合图不卡区| 日韩欧美国产综合在线一区二区三区| 成人午夜av电影| 久久99精品久久久| 婷婷成人综合网| 18成人在线视频| 国产亚洲一区二区三区| 8x8x8国产精品| 日本精品视频一区二区三区| 国产黑丝在线一区二区三区| 日韩中文字幕区一区有砖一区 | 欧美熟乱第一页| 成年人网站91| 国产乱码精品一品二品| 日韩成人伦理电影在线观看| 亚洲天堂福利av| 中国av一区二区三区| 日韩欧美黄色影院| 欧美日韩一卡二卡| 色悠久久久久综合欧美99| 国产盗摄女厕一区二区三区| 蜜臀av性久久久久蜜臀aⅴ | 亚洲最色的网站| 国产精品免费aⅴ片在线观看| ...xxx性欧美| 久久久亚洲午夜电影| 精品精品国产高清a毛片牛牛| 91精品国产综合久久久久久久久久 | 一区二区三区四区中文字幕| 国产日韩av一区| 久久天堂av综合合色蜜桃网| 日韩欧美色电影| 日韩一区二区三区视频在线| 欧美日韩国产一级片| 欧美色视频在线观看| 欧美视频一区二| 欧美四级电影网| 69av一区二区三区| 欧美一区二区三区免费视频 | 91首页免费视频| 色综合久久中文综合久久97| 色久综合一二码| 日本韩国视频一区二区| 欧美日韩在线三级| 6080国产精品一区二区| 欧美一区永久视频免费观看| 日韩欧美一区二区三区在线| 久久香蕉国产线看观看99| 国产亚洲精品久| 中文字幕视频一区二区三区久| 亚洲摸摸操操av| 亚洲高清免费观看高清完整版在线观看| 亚洲成人午夜影院| 免费观看成人av| 国产91在线观看| 91久久一区二区| 欧美日韩免费一区二区三区 | 日韩欧美一区二区久久婷婷| 欧美精品一区二区蜜臀亚洲| 国产婷婷色一区二区三区 | 午夜日韩在线电影| 日韩电影在线免费观看| 国内外成人在线视频| 成人一区在线观看| 色老综合老女人久久久| 91精品国产综合久久精品| 26uuu亚洲| 亚洲少妇30p| 日韩av网站免费在线| 国产精品系列在线播放| 日本道在线观看一区二区| 欧美一区二区在线免费观看| 国产午夜精品理论片a级大结局 | 亚洲欧美激情小说另类| 日日夜夜精品视频免费 | 欧美日韩国产首页在线观看| 欧美成人精精品一区二区频| 中文久久乱码一区二区| 亚洲成人在线免费| 国产不卡在线播放| 欧美无砖砖区免费| 国产亚洲污的网站| 丝袜亚洲另类欧美综合| 成人一区二区三区中文字幕| 欧美福利视频一区| 中文字幕在线观看一区二区| 日本亚洲一区二区| 91在线观看成人| 欧美大片一区二区| 一区二区三区四区亚洲| 国产精品 欧美精品| 欧美精品色一区二区三区| 中文字幕免费不卡| 久久超级碰视频| 欧美日韩国产一二三| 亚洲日本va午夜在线电影| 国内外精品视频| 91精品国产综合久久香蕉的特点 | 懂色av一区二区三区蜜臀| 欧美精品日韩精品| 亚洲少妇30p| 国产成人免费视频网站 | 天天综合色天天综合| 97精品超碰一区二区三区| 精品国产污污免费网站入口| 亚洲成av人影院| 91老师片黄在线观看| 久久精品欧美日韩| 99国产精品久久久久久久久久| 欧美精品一区二区三区一线天视频| 亚洲高清不卡在线| 欧洲视频一区二区| 亚洲欧洲精品一区二区三区不卡 | 欧美午夜精品一区二区三区| 国产精品天美传媒| 国产成人精品影视| 久久久久久久久免费| 久久不见久久见中文字幕免费| 91精品综合久久久久久| 午夜一区二区三区视频| 91成人免费在线视频| 亚洲欧美一区二区三区国产精品| 懂色中文一区二区在线播放| 久久久久99精品国产片| 国产盗摄视频一区二区三区| 久久久久久久久久美女| 国产麻豆精品在线| 久久日韩精品一区二区五区| 激情综合网激情| 26uuu久久综合| 国产真实精品久久二三区| 欧美一二三区在线观看| 日本三级韩国三级欧美三级| 在线播放91灌醉迷j高跟美女 | 成人免费视频一区| 日本一二三四高清不卡| 成人美女在线视频| 亚洲欧美在线高清| 色综合天天综合色综合av| 亚洲四区在线观看| 一本一道波多野结衣一区二区| 亚洲日本一区二区三区| 99精品欧美一区二区三区小说| 亚洲欧洲色图综合| 欧美日韩一区视频| 偷拍一区二区三区四区| 日韩欧美激情四射| 国产成人自拍网| 一区精品在线播放| 欧美日韩aaa| 经典一区二区三区| 国产精品色在线| 色激情天天射综合网| 偷偷要91色婷婷| 国产日韩av一区| 欧美在线高清视频| 久草在线在线精品观看| 国产精品三级久久久久三级| 日本黄色一区二区| 久久精品国产精品青草| 久久蜜桃香蕉精品一区二区三区| 99久久99久久精品国产片果冻| 午夜精品视频一区| 久久精品在线免费观看| 色94色欧美sute亚洲13| 天天亚洲美女在线视频| 久久久久久影视| 91蜜桃视频在线| 精品久久人人做人人爽| 99re在线精品| 天天综合色天天综合色h| 久久久精品黄色| 色噜噜狠狠成人网p站| 日韩成人dvd| 日韩一区二区影院| 99久久国产综合精品色伊 | 国产精品综合一区二区三区| 久久精品亚洲精品国产欧美kt∨| 成人免费视频免费观看| 亚洲图片欧美视频| 精品美女一区二区| 欧美色视频一区| 国产69精品久久777的优势| 亚洲欧美激情插| 欧美精品久久天天躁| 9久草视频在线视频精品| 日韩码欧中文字| 欧美一二三区在线| 91视频免费观看| 国产精品综合视频| 午夜av一区二区三区| 国产视频一区二区在线观看|