- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 jama 包来查找 lsa 。我被告知要减少维度,因此在这种情况下我将其减少到 3,并重建了矩阵。但生成的矩阵与我提供给系统的矩阵非常不同
这是代码
a = new Matrix(termdoc); // get the matrix here
a = a.transpose() ; // since the matrix is in the form of doc * terms i transpose it
SingularValueDecomposition sv =new SingularValueDecomposition(a) ;
u = sv.getU();
v = sv.getV();
s = sv.getS();
uarray = u.getArray();
sarray = s.getArray();
varray = v.getArray();
sarray_mod = new double[3][3]; //reducing dimension
uarray_mod = new double[uarray.length][3];
varray_mod = new double[3][varray.length];
move(sarray,3,3,sarray_mod); // my method to move the contents
move(uarray,uarray.length,3,uarray_mod);
move(varray,3,varray.length,varray_mod);
e = new Matrix(uarray_mod);
f = new Matrix(sarray_mod);
g = new Matrix(varray_mod);
Matrix temp =e.times(f);
result = temp.times(g);
result = result.transpose();
results = result.getArray() ;
System.out.println(" The array after svd : \n");
print(results);// my method to print the array
private static void move(double[][] sarray2, int r, int c,
double[][] sarrayMod) {
// TODO Auto-generated method stub
for(int i=0;i<r;i++)
for(int t=0;t<c;t++)
sarrayMod[i][t]=sarray2[i][t];
}
仅包含 3 个文件的示例输出,其中两个文件相似
0.25 0 0 0 0 0 0 0 0.25 0 0.25 0.25 0
0 0.083 0.083 0.083 0.083 0.083 0.083 0.083 0 0.083 0.083 0.167 0.083
0.25 0 0 0 0 0 0 0 0.25 0 0.25 0.25 0
svd 之后的数组:
0.225 0.029 0.029 0.029 0.029 0.029 0.029 0.029 0.225 0.029 0.253 0.282 0.029
-0.121 0.077 0.077 0.077 0.077 0.077 0.077 0.077 -0.121 0.077 -0.044 0.033 0.077
0.245 0.012 0.012 0.012 0.012 0.012 0.012 0.012 0.245 0.012 0.257 0.269 0.012
最佳答案
查看示例 Here
在示例中,我们从 U,S 和 V 中获取前 2 列。然后我们将它们相乘。它不会给你相同的矩阵,但会提高相似度的性能。
如果你看过这个例子,你会发现用户和人类之间的相似度在 -ve 中。但在我们执行 SVD 后,相似度增加到接近 1 的 +ve 值。
我认为你的移动方式是正确的。只需浏览一次示例即可。
关于java - 在java中使用Jama进行LSA的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9060168/
我正在与 Jama Matrix 一起工作.我将它用于 LSI。它工作正常。但是,当我传递一个像 8000x8000 这样的大矩阵时,它会杀死我的整个系统。我只是调用 SVD,然后减小矩阵大小并相加。
当我使用 matrix.eig() 时,我得到了一个错误的特征向量(也通过运行多次来确定)。矩阵是: 1.2290 1.2168 2.8760 2.6370 2.2949 2.6402 1.2168
我正在使用 Jama API 解决线性代数问题。但它给我一个错误:java.lang.RuntimeException: Matrix is singular. 我想当矩阵是奇异矩阵时,有多种可能的解
我不熟悉将 Jama 用于矩阵。我的问题是,当我使用 det() 方法(与 LUDecomposition 类相关)时,它给出了 “Matrix must be square”。好的,我的矩阵是三角形
我有以下矩阵,它是对称且实数的(它是汉密尔顿运算符):(Matlab 友好) [63.000000, -1.732051, 0.000000, 0.000000, 0.000000, 0.000000
我正在尝试编写一段代码,允许我创建 2x2 矩阵,然后使用 JAMA 库 ( http://math.nist.gov/javanumerics/jama/ ) 来计算我刚刚创建的矩阵的特征值和特征向
首先,抱歉我的英语不好,但我需要你的帮助。 我用 java swing 开发了一个模拟程序,其中使用了大量矩阵计算。我的程序刚刚完成,但我需要加快我的表现。所以我使用了java Visual vm p
我正在使用 JAMA 进行图像处理中的一些矩阵运算。 在这里,我将矩阵与其转置相乘。肯定是有可能的。 但我收到以下错误: Exception in thread "main" java.lang.Il
我正在尝试在 Linux 的代码中使用 Jama 包。在我的主类中,我尝试使用 Matrix 类。 这是我的主要类(class): import Jama.*; class Main { pu
我有这个数组 double a[][] = {{1,1,1}, {0,1,1} , { 1,0,0} ,{0,1,0},{1,0,0},{1,0,1},{1,1,1},{1,1,1},
我想使用jama库将矩阵写入java文件。但是,只生成一个空文件。我正在使用下面的代码。可能出了什么问题? PrintWriter writer = null; try { w
我想使用 Jama 库将 2 矩阵相乘,但它返回: A col: 4 row: 4 B col: 1 row: 4 Exception in thread "AWT-EventQueue-0" jav
谁能告诉我 JAMA MATRIX 包 setMatrix 的工作原理吗?请不要建议我查看文档。我多次搜索文档,但没有得到任何其工作原理的示例。我有代码想要使用 JAMA MATRIX 包设置具有所需
我是 Java 编程的新手。我正在做一个科学模拟,其中必须求解一个线性方程组。 我在 Eclipse 中工作。我下载了 jama jar 文件并添加到 JRE 系统库中。问题是当我通过传递一个二维双数
这可能是一个有点愚蠢的问题,我也可能误解了解决这个问题的最佳方法,但我本质上想做的是: 我想将以下矩阵相乘以获得结果 -0.8。但是,理想情况下,我希望使用 JAMA 函数来执行此操作。到目前为止,我
我使用 JAMA.matrix 包..我如何打印矩阵的列 最佳答案 最简单的方法可能是 transpose矩阵,然后打印每一行。以API中的部分示例为例: double[][] vals = {{1.
关注 Jama矩阵在我的代码中定义: P: 3*3 Matrix I: 3*3 identity Matrix K: 3*2 Matrix H: 2*3 Matrix Q: 3*3 Matrix 以下
我正在尝试使用 Jama 求解 4x4 线性方程组(4 个变量,4 个方程)。我已经尝试过以下代码,但它不起作用。如果有人可以使用 Jama 或任何其他方法帮助我,我将不胜感激。 import Jam
我正在开发一个小型 Java 应用程序,用于对矩阵执行计算。这就是我现在计算方阵的行列式和逆矩阵的方法。但我想使用 Jama 类来计算特征值和特征向量,但我不知道如何使用它,有人可以帮我吗?谢谢。 i
我有一个使用 JAMA 的程序而需要测试的是一个矩阵是否可以倒置。我知道我可以尝试它并捕获异常,但这似乎是个坏主意(将 catch block 作为“正常”代码路径的一部分似乎是一种不好的形式)。 首
我是一名优秀的程序员,十分优秀!