javascript - 使用 Jama 计算特征值/特征向量?

标签 javascript java jakarta-ee jama

我正在开发一个小型 Java 应用程序,用于对矩阵执行计算。这就是我现在计算方阵的行列式和逆矩阵的方法。但我想使用 Jama 类来计算特征值和特征向量,但我不知道如何使用它,有人可以帮我吗?谢谢。

import java.util.Scanner;
import Jama.*;

public class matrix {
   public static void main(String[] args) {
      double[][] matrix;
      double det;
      int n;

      Scanner scanner = new Scanner(System.in);

      System.out.println("Dimension of the matrix: ");
      n = scanner.nextInt();

      matrix = new int[n][n];

      // insert values
      for (int i = 0; i < n; i++) {
         for (int j = 0; j < n; j++) {

            System.out.printf("Values: " + i + " - " + j);
            System.out.printf("\n");
            matrix[i][j] = scanner.nextDouble();

         }
      }

      // calculate determinant
      det = dete(matrix, n);
   }

   private static dete(double ai[][], int i) {
      double l = 0;
      if (i == 1)
         l = ai[0][0];
      else if (i == 2) {
         l = ai[0][0] * ai[1][1] - ai[0][1] * ai[1][0];
      } else {
         double ai1[][] = new double[i - 1][i - 1];
         for (int k = 0; k < i; k++) {
            for (int i1 = 1; i1 < i; i1++) {
               int j = 0;
               for (int j1 = 0; j1 < i; j1++)
                  if (j1 != k) {
                     ai1[i1 - 1][j] = ai[i1][j1];
                     j++;
                  }

            }

            if (k % 2 == 0)
               l += ai[0][k] * dete(ai1, i - 1);
            else
               l -= ai[0][k] * dete(ai1, i - 1);
         }

      }
      return l;
   }
}

最佳答案

你只需要这样做 -

Matrix mat = oldMatrix.eig();

不要忘记包含 Jama.Matrix.EigenvalueDecomposition。

您可以看看here

关于javascript - 使用 Jama 计算特征值/特征向量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10675769/

相关文章:

javascript - 奇怪的 AJAX 错误

javascript - 下拉菜单 popper.js

java - Solr - 如何在 solrconfig.xml 中使用 <lib> 标记的 "dir"属性

java - 使用 JPA EntityManager 批量插入

java - 我可以锁定 DB2 的行以供读取吗?

javascript - 使用 lodash 对包含文档的数组进行排序

javascript - 选择具有多个参数的行(ajax 和 PHP)

java - struts.serve.static=true 和 struts,serve.static.browserCache=false 不起作用

java - 通过snmp获取设备名称和型号

java - 在java中创建动态函数调用