- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我最近安装了 Armadillo 并尝试了稀疏矩阵的特征值问题。不幸的是,分解失败是因为参数“N”(下面的代码)太大了。 1000. 我想知道这里发生了什么。矩阵不是很复杂——它有对角线结构。
更新
Mathematica 也有这个矩阵的问题。它告诉我 Arnoldi 算法不收敛。也许我需要在 arnoldi arpack 例程中手动指定一些参数以确保收敛?
这是我的代码:
#include <armadillo>
int main ()
{
double N = 1000.0;
// create matrix
int kmin = 0;
int kmax = static_cast<int>( std::floor( N/2.0 ) );
int dim = (kmax - kmin) + 1;
// locations and values in sparse matrices
arma::umat hc_locations (2, 3*dim-2);
arma::vec hc_values (3*dim-2);
// diagonal part
for (int k=0; k<dim; k++)
{
hc_locations (0,k) = k;
hc_locations (1,k) = k;
hc_values (k) = 2.0/N*static_cast<double>(kmin + k)*( 2.0*( N-2.0*static_cast<double>(k + kmin) ) - 1.0 );
}
// upper and lower diagonal
for (int k=0; k<dim-1; k++)
{
hc_locations (0,k+dim) = k;
hc_locations (1,k+dim) = k+1;
hc_values (k+dim) = 2.0/N*std::sqrt( ( static_cast<double>(k+1+kmin) ) *
( static_cast<double>(k+1+kmin) ) *
( N - static_cast<double>(2*(k+1+kmin)) + 1.0 ) *
( N - static_cast<double>(2*(k+1+kmin)) + 2.0 ) );
hc_locations (0, k+2*dim-1) = k+1;
hc_locations (1, k+2*dim-1) = k;
hc_values (k+2*dim-1) = 2.0/N*std::sqrt ( ( static_cast<double>(k+1+kmin) ) *
( static_cast<double>(k+1+kmin) ) *
( N - static_cast<double>(2*(k+kmin)) ) *
( N - static_cast<double>(2*(k+kmin)) - 1.0 ) );
}
arma::sp_mat Ham(hc_locations, hc_values);
// eigenvalue problem
arma::vec eigval;
arma::mat eigvec;
arma::eigs_sym( eigval, eigvec, Ham, 3, "sa");
最佳答案
对于大小为 2000 左右的小矩阵,通常更容易找到所有特征值和特征向量,因为这些方法不易受近奇异矩阵的影响。
我替换了你的代码
arma::eigs_sym( eigval, eigvec, Ham, 3, "sa");
与
arma::mat fullMat = arma::mat(Ham);
arma::eig_sym( eigval, eigvec, fullMat);
在我 2015 年后期的 Macbook Pro 上,编译后的程序只需不到一秒钟的时间即可求解。
关于c++ - 对于太大的矩阵, Armadillo eigs_sym() 的特征值分解失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36842712/
我对 CBMutableCharacteristic 的特征值可以有多长感到困惑。如果我有一个归档对象数组,我可以将特征值设置为这个归档数组吗?或者我最好为数组中的每个归档对象设置一个单独的特征? 最
我在 Python Sympy 中使用来计算带有变量的矩阵 A 的特征值(例如)。有谁知道如何计算这样的矩阵的特征值?命令 A.eigenvals() 不起作用。例如下面的代码: x = symbol
我正在计算协方差矩阵的特征值,它是实数且对称的半正定矩阵。因此,特征值和特征向量都应该是实数,然而numpy.linalg.eig()返回具有(几乎)零虚部的复数值。 协方差矩阵太大,这里贴不出来,但
我正在尝试对图像使用光谱聚类。我首先计算亲和性矩阵,然后尝试获取特征向量。但是,在 7056x7056 矩阵上,eig() 调用花费的时间太长。关于如何改进这个的任何建议?也许我应该使用不同形式的亲和
我目前正在使用 Dart/Flutter BLE 插件来更好地了解 BLE 设备。 插件: https://pub.dartlang.org/packages/flutter_blue 当我连接到我的
我在使用 Eigen 库时遇到错误,我想做的就是从 Eigen::VectorXf 中减去一个标量。所以,我的代码如下: #define VECTOR_TYPE Eigen::VectorXf #de
假设我有一个对称矩阵 M,它不是正(半)定的,我想计算它的 k 顶(绝对值)特征值(和相应的特征向量)。现在,可以使用截断的 SVD 来做到这一点,它将返回所述特征值的绝对值,然后必须检查符号并找到相
我有一个关于 split 节点的问题。我有 4 个特征,想要预测这个人是否会玩,可能会玩,也可能不会玩。根据信息增益,我将“天气”作为第一个要分割的特征,其中“多雨”、“炎热”和“潮湿”作为分支。下雨
我有一个 ~3000x3000 类似协方差的矩阵,我在该矩阵上计算特征值-特征向量分解(它是一个 OpenCV 矩阵,我使用 cv::eigen() 来完成工作)。 但是,我实际上只需要前 30 个特
我想计算 K*es,其中 K 是一个 Eigen 矩阵(维度 pxp)和 es 是一个 px1 随机二进制 vector ,值为 1。 例如,如果 p=5 和 t=2 一个可能的 es 是 [1,0,
我正在尝试使用 CoreBluetooth 框架从设备读取所有可用服务及其特征值。 - (void)centralManager:(CBCentralManager *)central didDisc
我已经在 Internet 上多次看到这个主题,但从未见过一个完整、全面的解决方案,它可以适用于当前库版本的 sklearn 的所有用例。有人可以尝试使用以下示例解释如何实现吗? In this ex
我的输入 数据框(缩短)如下所示: >>> import numpy as np >>> import pandas as pd >>> df_in = pd.DataFrame([[1, 2, 'a
我想读取低功耗蓝牙(智能)的特征值。我不想使用 gatttool 或 btgatt-client。 d-bus 也没有帮助。我想在 Python 中执行此操作。我在以下内容中找不到任何示例: http
我是一名优秀的程序员,十分优秀!