亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
综合电影一区二区三区| 蜜桃精品视频在线| 日韩一区二区三区三四区视频在线观看| 91一区一区三区| 成人黄色网址在线观看| 国产精品亚洲一区二区三区在线| 麻豆成人在线观看| 丁香一区二区三区| 91丝袜美腿高跟国产极品老师 | 亚洲一线二线三线久久久| 亚洲日本免费电影| 视频一区视频二区在线观看| 最新国产精品久久精品| 亚洲精品视频一区二区| 亚洲精品综合在线| 首页亚洲欧美制服丝腿| 激情久久五月天| 韩国成人在线视频| 99久久精品国产网站| 欧美日本韩国一区| 精品国产区一区| 亚洲欧美电影院| 亚洲天堂成人在线观看| 天天色综合天天| 不卡一区二区在线| 色婷婷av一区二区三区大白胸| 7777精品伊人久久久大香线蕉 | 亚洲色大成网站www久久九九| 亚洲国产wwwccc36天堂| 看电视剧不卡顿的网站| 99国产精品国产精品久久| 欧美性videosxxxxx| 国产欧美一区二区精品婷婷| 18欧美乱大交hd1984| 精品一区二区在线观看| 欧美性色黄大片| 久久久久久黄色| 免费在线观看一区二区三区| 色综合视频一区二区三区高清| 欧美午夜宅男影院| 国产日韩亚洲欧美综合| 久久国产福利国产秒拍| 欧美亚洲高清一区| 欧美精彩视频一区二区三区| 蜜芽一区二区三区| 日本韩国一区二区| 中文子幕无线码一区tr| 国产精品自拍网站| 一本大道av一区二区在线播放 | 久久精品视频免费观看| 日韩av成人高清| 欧美日韩在线一区二区| 亚洲综合色婷婷| 成人深夜在线观看| 精品少妇一区二区三区视频免付费 | av日韩在线网站| 精品福利视频一区二区三区| 日韩一区欧美小说| 国产精品中文字幕欧美| 91色九色蝌蚪| 欧美xxxxxxxxx| 亚洲欧美日韩一区| 在线精品视频免费观看| 中文字幕巨乱亚洲| 激情丁香综合五月| 欧美综合亚洲图片综合区| 日韩三级视频在线看| 亚洲人被黑人高潮完整版| 91在线免费看| 亚洲乱码国产乱码精品精小说| 色又黄又爽网站www久久| 久久久精品黄色| 在线观看日韩国产| 日欧美一区二区| ...中文天堂在线一区| 日韩一区二区免费在线电影| 成人国产精品免费观看动漫| 婷婷中文字幕一区三区| 中文字幕欧美日韩一区| 在线电影院国产精品| 成人动漫一区二区| 国产激情视频一区二区三区欧美 | 日本久久精品电影| 国产欧美日韩视频在线观看| 99久久er热在这里只有精品15| 亚洲免费电影在线| 欧美高清视频在线高清观看mv色露露十八 | 亚洲va欧美va国产va天堂影院| 欧美不卡一区二区三区| 欧美视频一区二区三区四区| 国产成人在线视频免费播放| 免费观看91视频大全| 亚洲免费观看在线视频| 亚洲国产精品av| 国产亚洲女人久久久久毛片| 日韩午夜精品视频| 欧美夫妻性生活| 久久草av在线| 中文字幕永久在线不卡| 国产欧美精品日韩区二区麻豆天美| 欧美一级国产精品| 日韩午夜在线影院| 日韩三级高清在线| 欧美哺乳videos| 久久男人中文字幕资源站| 精品粉嫩超白一线天av| 久久综合中文字幕| 欧美精品一区二区三区很污很色的| 精品视频在线免费看| 欧美欧美欧美欧美首页| 成人h动漫精品一区二区| 色欲综合视频天天天| 91精品办公室少妇高潮对白| 欧美日韩一区在线| 91精品国产综合久久精品麻豆 | 美国av一区二区| 韩国精品主播一区二区在线观看| 国产精品18久久久久久vr| 国产成人在线免费观看| 99久久婷婷国产综合精品| 丁香六月综合激情| 色久综合一二码| 精品国产91亚洲一区二区三区婷婷 | 欧美三级视频在线| 日韩美一区二区三区| 日本一区二区三区在线观看| 亚洲精品亚洲人成人网| 六月丁香综合在线视频| 成人av免费观看| 日韩一区二区三区观看| 成人欧美一区二区三区白人| 性做久久久久久久免费看| 国产大片一区二区| 欧美老肥妇做.爰bbww视频| 国产蜜臀97一区二区三区| 舔着乳尖日韩一区| 在线日韩一区二区| 国产视频一区二区在线| 麻豆精品精品国产自在97香蕉 | 午夜精品爽啪视频| 99re在线精品| 欧美国产精品一区二区三区| 午夜电影网亚洲视频| 91在线视频播放| 国产视频一区在线观看| 激情文学综合插| 精品少妇一区二区三区日产乱码 | 91精品国产欧美一区二区| 欧美日韩五月天| 亚洲免费观看高清完整| 懂色av一区二区三区蜜臀| 日韩欧美国产小视频| 亚洲精品高清在线观看| 国产99久久久国产精品潘金网站| 日韩限制级电影在线观看| 亚洲欧美另类小说| 99久久婷婷国产精品综合| 日韩精品一区二区三区三区免费 | 粉嫩av一区二区三区粉嫩| 日韩免费高清视频| 国产乱子轮精品视频| 久久久久久免费网| 国产精品乡下勾搭老头1| 精品少妇一区二区三区视频免付费| 男人的j进女人的j一区| 精品久久久久香蕉网| 粉嫩av一区二区三区粉嫩| 国产精品视频线看| 日本精品一区二区三区高清 | 久久综合色8888| 国产精品一品二品| 国产精品毛片久久久久久久| 99精品在线免费| 日韩成人午夜电影| 久久精品视频在线看| 99精品视频一区| 日本欧美大码aⅴ在线播放| 日韩精品一区二区三区视频播放| 国产一区二区电影| 亚洲丰满少妇videoshd| 精品国产成人在线影院| 91老司机福利 在线| 美国十次了思思久久精品导航| 国产精品久久久久久久久免费相片| 欧美在线小视频| 国产激情一区二区三区桃花岛亚洲| 亚洲欧美激情小说另类| 2017欧美狠狠色| 色嗨嗨av一区二区三区| 九九精品视频在线看| 亚洲免费观看高清完整版在线 | 国产精品一区专区| 亚洲午夜在线视频| 国产精品成人一区二区艾草 | 欧美一二三四在线| 欧美在线播放高清精品| 国产高清一区日本| 久久av资源网| 久久国产欧美日韩精品| 五月天丁香久久|