- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个大而密集的矩阵 A,我的目标是使用迭代方法找到线性系统 Ax=b 的解(在 MATLAB 中是使用其内置 GMRES 的计划)。对于超过 10,000 行,这对我的计算机来说太多了,无法在内存中存储,但我知道 A 中的条目是由两个已知的长度为 N 的 vector x 和 y 构造的,并且条目满足:A(i,j) = .5*(x[i]-x[j])^2+([y[i]-y[j])^2 * log(x[i]-x[j] )^2+([y[i]-y[j]^2).
MATLAB 的 GMRES 命令接受一个可以计算矩阵 vector 乘积 A*x 的函数调用作为输入,这使我能够处理比我可以存储在内存中的更大的矩阵。为了编写 matrix-vecotr 乘积函数,我首先在 matlab 中逐行尝试并使用一些矢量化,但我避免生成整个数组 A(因为它太大)。不幸的是,这在我申请 GMRES 时相当缓慢。我的计划是为 MATLAB 编写一个 mex 文件,它是用 C 编写的,理想情况下应该比 matlab 代码快得多。我是 C 的新手,所以这很糟糕,我天真的尝试用 C 编写代码比我在 Matlab 中部分矢量化的尝试慢。
#include <math.h>
#include "mex.h"
void Aproduct(double *x, double *ctrs_x, double *ctrs_y, double *b, mwSize n)
{
mwSize i;
mwSize j;
double val;
for (i=0; i<n; i++) {
for (j=0; j<i; j++) {
val = pow(ctrs_x[i]-ctrs_x[j],2)+pow(ctrs_y[i]-ctrs_y[j],2);
b[i] = b[i] + .5* val * log(val) * x[j];
}
for (j=i+1; j<n; j++) {
val = pow(ctrs_x[i]-ctrs_x[j],2)+pow(ctrs_y[i]-ctrs_y[j],2);
b[i] = b[i] + .5* val * log(val) * x[j];
}
}
}
以上是 matlab mex 文件代码的计算部分(如果我理解正确的话,它是稍微修改过的 C)。请注意,我跳过了 i=j 的情况,因为在这种情况下变量 val 将是 0*log(0),对我来说它应该被解释为 0,所以我直接跳过它。
有没有更有效或更快速的写法?当我在 matlab 中通过 mex 文件调用这个 C 函数时,它非常慢,甚至比我使用的 matlab 方法还慢。这让我感到惊讶,因为我怀疑 C 代码应该比 matlab 快得多。
我正在与之比较的部分矢量化的替代 matlab 方法是
function Ax = Aprod(x,ctrs)
n = length(x);
Ax = zeros(n,1);
for j=1:(n-3)
v = .5*((ctrs(j,1)-ctrs(:,1)).^2+(ctrs(j,2)-ctrs(:,2)).^2).*log((ctrs(j,1)-ctrs(:,1)).^2+(ctrs(j,2)-ctrs(:,2)).^2);
v(j)=0;
Ax(j) = dot(v,x(1:n-3);
end
(n-3是因为实际上多了3个组件,但是是分开处理的,所以去掉了那段代码)。这是部分向量化的,只需要一个 for 循环,所以它更快是有道理的。但是,我希望我可以使用 C+mex 文件走得更快。
如有任何建议或帮助,我们将不胜感激!谢谢!
编辑:我应该更清楚。我愿意接受任何可以帮助我使用 GMRES 反转我感兴趣的矩阵的更快方法,这需要一种更快的方法来执行矩阵 vector 乘积,而无需将数组显式加载到内存中。谢谢!
最佳答案
如果你有Parallel Computing Toolbox和 MATLAB Distributed Computing Server ,您可以直接使用反斜杠求解大型密集线性系统。 (如果您没有可用的集群,您可能想使用 Amazon EC2 machines )。像这样:http://www.mathworks.co.uk/help/distcomp/examples/benchmarking-a-b.html
关于c++ - 在 GMRES 中使用 C 或 C++ 中大型矩阵的矩阵 vector 乘积的更快方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19719879/
我希望我的问题有一个非常简单的解决方案。我只是找不到它: 假设您有两个向量(一个是列向量,一个是行向量)A、B: A = [1,2,3] B = [4;5;6] 如果我们按如下方式将它们相乘,我们会得
我有一个 Tuple 的列表: "dog", 25 "cat", 5 "cat", 7 "rat", 4 "dog", 10 我需要的 Linq 查询规则必须满足以下条件:我需要按字符串值对元组进行分
给定 2 个不同的 NDarray,A 和 B,形状相同但尺寸任意,我如何获得 NDarray C,其中 C 是 A 和 B(含)范围内所有整数的乘积。 我的意思是A是起始数组,B是结束数组,我想要数
假设我需要为某些输入构建一个真值表,它要求我提供逻辑和、算术和和逻辑乘积。它们之间有什么区别? 最佳答案 逻辑和 - 一种计算机加法,当一个或两个输入变量为 1 时,结果为 1;当输入变量均为 0 时
我正在尝试执行一个简单的矩阵乘法 vector 乘法,但出于某种原因,我在几次乘法的结果中得到了错误的符号。我不知道为什么会这样,任何指针将不胜感激。 这是我的全部代码,即矩阵 * vector 函数
我在上一个主题中找到了一些关于 cuda 矩阵 vector 积的代码: Matrix-vector multiplication in CUDA: benchmarking & performanc
我遇到的第一个问题是显示三个数字中的最小和最大。出现两个单独的警报 - 第一个警报说第二大数字是最大的(因为它还没有考虑第三个数字),第二个警报正确地指出三个中最大的数字是最大的.不确定为什么会这样—
我有两个矩阵 a = np.matrix([[1,2], [3,4]]) b = np.matrix([[5,6], [7,8]]) 我想得到元素乘积,[[1*5,2*6], [3*7,4*8]],等
我有一个数组和一个 vector : ArrayXd m1(3, 1337); ArrayXd v1(1, 1337); ArrayXd result(3, 1337); 现在我想将 m1 的每一行与
我有两个 3D 矩阵: a = np.random.normal(size=[3,2,5]) b = np.random.normal(size=[5,2,3]) 我想要每个切片分别沿 2 轴和 0
我正在创建一个 C++ 软件,我需要一个包装器,它基于 Eigen 库,实现类似于官方网页中解释的运算符* https://eigen.tuxfamily.org/dox/group__Matrixf
我正在尝试将张量 (m, n, o) 分解为矩阵 A(m, r)、B (n, r) 和 C (k, r)。这被称为 PARAFAC 分解。 Tensorly已经做了这种分解。 一个重要的步骤是将 A、
我目前正面临这个问题。我有两个矩阵 MatrixXf答: 0.5 0.5 0.5 0.50.694496 0.548501 0.680067 0.7171110
我有以下 df: df = pd.DataFrame({'A': ['foo', 'bar', 'dex', 'tru'], 'B': ['abc', 'def'
假设我们有 2 个 2X2 numpy 数组: X=np.array([[0,1],[1,0]]) 和 I=np.array([[1,0],[0,1]]) 考虑一下克罗内克产品 XX=X^X 我让符号
我想弄清楚这是 Eigen 中的错误还是我做错了什么。我只想要两个复数 vector [1,i] 和 [1,-i] 的点积。答案是 1*1 + i*(-i) = 2。但是 Eigen 给出的答案是零。
我的 C 代码有问题。我所做的就是这样: #include int main() { float zahlen[2]; for (int i = 0; i < 2; i++) {
为了找到数字的因数,我正在使用函数 void primeFactors(int n) # include # include # include # include using namespa
我是一名优秀的程序员,十分优秀!