矩阵的计算等级
Compute rank of Matrix
本文关键字:计算 更新时间:2023-10-16
我需要计算 4096x4096 稀疏矩阵的秩,我使用 C/C++ 代码。我找到了一些库(如犰狳)可以做到这一点,但它们太慢了(几乎 5 分钟)。
我也尝试了两个开源版本的Matlab(Freemat和Octave),但是当我尝试使用脚本进行测试时,它们都崩溃了。
5 分钟并不多,但我必须从一百万个矩阵中获得排名,这样越快越好。
有人知道用于排名计算的快速库吗?
特征库支持稀疏矩阵,请尝试一下。
计算代
数秩是 O(n^3),其中 n 是矩阵大小,所以它本质上很慢。你需要例如。执行枢轴,如果您的矩阵条件不佳,这将很慢且不准确(对于 n = 4096,典型的矩阵条件非常差)。
现在,排名是多少?它是图像的维度。当 n 很大时很难计算,并且会被输入的任何小数值不准确性所破坏。对于 n = 4096,除非你碰巧有特别好的条件矩阵,否则这将阻止你用枢轴算法做任何有用的事情。
事实上,最好的方法是固定一个截止 epsilon,计算奇异值 s_1> ...> s_n 并将最低整数 r 作为秩,使得 sum(s_i^2, i> r)
因此,您需要一个稀疏的 SVD 例程,例如。 从那里。
这可能不是更快,但至少是正确的。
您可以要求减少速度所需的奇异值。这是一个棘手的问题,由于没有关于背景和如何获得这些矩阵的信息,我们无能为力。
尝试以下代码(文档在这里)。这是一个使用特征库计算矩阵 A 秩的示例:
MatrixXd A(2,2);
A << 1 , 0, 1, 0;
FullPivLU<MatrixXd> luA(A);
int rank = luA.rank();
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 递归函数计算序列中的平方和(并输出过程)
- (C++)分析树以计算返回错误值的简单算术表达式
- 我的字符计数代码计算错误.为什么
- 在计算中使用二的幂有多有利可图
- 如何计算文件中的"columns"数?
- 计算排序向量的向量中唯一值的计数
- 如何使用 std::累积在 C++ 中计算总和立方体
- 使用Qt C++计算类似Git的SHA1哈希
- OpenCV C++.快速计算混淆矩阵
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- C++如何计算用户输入的数字中的偶数位数
- 如何计算数据类型的范围,例如int
- 类似枚举的计算常量
- 计算每个节点的树高,帮助我解释这个代码解决方案
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 计算缩放多边形的比例,得到给定的多边形面积
- 在C++中如何在没有pow的情况下进行基础计算
- 计算平均值,不包括上次得分
- 如何计算多映射中重复对的数量