- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个问题。我正在尝试计算向量之间的成对距离。先解释一下问题:我有两组向量X
和 Y
. X
有三个向量 x1
, x2
和 x3
. Y
有三个向量 y1
, y2
和 y3
.注意 X
中的向量和 Y
长度为 m
和 n
分别。让数据集表示为这张图片:
我正在尝试计算这样的相似度矩阵:
.现在解释了不同颜色编码的部分 - 所有那些标有 0
的单元格不需要计算。我故意把它写成 100
(它可以是任何值)。必须计算灰色单元格。相似性得分计算为 L2
(xi-xj)
的规范+ L2
(yi-yj)
的规范.
这意味着条目是
M((x_i,y_j), (x_k,y_l)) := norm(x_i-x_k,2) + norm(y_j-y_l,2)
我已经写了一个基本的代码来做到这一点:
clc;clear all;close all;
%% randomly generate data
m=3; n1=4; n2=6;
train_a_mean = rand(m,n1);
train_b_mean = rand(m,n2);
p = size(train_a_mean,1)*size(train_b_mean,1);
score_mean_ab = zeros(p,p);
%% This is to store the index variables
%% This is required for futu
idx1 = score_mean_ab;
idx2 = idx1; idx3 = idx1; idx4 = idx1;
a=1; b=1;
for i=1:size(score_mean_ab,1)
c = 1; d = 1;
for j=1:size(score_mean_ab,2)
if (a==c)
score_mean_ab(i,j) = 100;
else
%% computing distances between the different modalities and
%% summing them up
score_mean_ab(i,j) = norm(train_a_mean(a,:)-train_a_mean(c,:),2) ...
+ norm(train_b_mean(b,:)-train_b_mean(d,:),2);
end
%% saving the indices
idx1(i,j)=a; idx2(i,j)=b; idx3(i,j)=c; idx4(i,j)=d;
%% updating the values of c and d
if mod(d,size(train_a_mean,1))==0
c = c + 1;
d = 1;
else
d = d+1;
end
end
%% updating the values of a and b
if mod(b,size(train_a_mean,1))==0
a = a + 1;
b = 1;
else
b = b+1;
end
end
对于矩阵的干样本运行:我得到这些结果 -
score_mean_ab =
100.0000 100.0000 100.0000 0.6700 1.6548 1.5725 0.8154 1.8002 1.7179
100.0000 100.0000 100.0000 1.6548 0.6700 1.5000 1.8002 0.8154 1.6454
100.0000 100.0000 100.0000 1.5725 1.5000 0.6700 1.7179 1.6454 0.8154
0.6700 1.6548 1.5725 100.0000 100.0000 100.0000 1.3174 2.3022 2.2200
1.6548 0.6700 1.5000 100.0000 100.0000 100.0000 2.3022 1.3174 2.1475
1.5725 1.5000 0.6700 100.0000 100.0000 100.0000 2.2200 2.1475 1.3174
0.8154 1.8002 1.7179 1.3174 2.3022 2.2200 100.0000 100.0000 100.0000
1.8002 0.8154 1.6454 2.3022 1.3174 2.1475 100.0000 100.0000 100.0000
1.7179 1.6454 0.8154 2.2200 2.1475 1.3174 100.0000 100.0000 100.0000
但是我的代码很慢。我进行了很少的样本运行并得到了这些结果:
m=3; n1=3; n2=3;
Elapsed time is 0.000363 seconds.
m=10; n1=3; n2=3;
Elapsed time is 0.042015 seconds.
m=10; n1=1800; n2=1800;
Elapsed time is 0.230046 seconds.
m=20; n1=1800; n2=1800;
Elapsed time is 4.309134 seconds.
m=30; n1=1800; n2=1800;
Elapsed time is 23.058106 seconds.
我的问题:
m~100
和 n1~2000
和 n2~2000
.我自己的代码在这一点上崩溃了。有什么优化的方法可以做到这一点吗?注意:向量实际上是行向量的形式,n1
的值和 n2
可能不相等。
最佳答案
这是一种方法。这将计算所有条目。
m = 3; %// number of (row) vectors in X and in Y
n1 = 3; %// length of vectors in X
n2 = 3; %// length of vectors in Y
X = rand(m, n1); %// random data: X
Y = rand(m, n2); %// random data: Y
[ii, jj] = ndgrid(1:m);
U = reshape(sqrt(sum((X(ii,:)-X(jj,:)).^2, 2)), m, m);
V = reshape(sqrt(sum((Y(ii,:)-Y(jj,:)).^2, 2)), m, m);
result = U(ceil(1/m:1/m:m), ceil(1/m:1/m:m)) + repmat(V, m, m);
或者您可以使用 bsxfun
而不是 ndgrid
:
U = sqrt(sum(bsxfun(@minus, permute(X, [1 3 2]), permute(X, [3 1 2])).^2, 3));
V = sqrt(sum(bsxfun(@minus, permute(Y, [1 3 2]), permute(Y, [3 1 2])).^2, 3));
result = U(ceil(1/m:1/m:m), ceil(1/m:1/m:m)) + repmat(V, m, m);
关于matlab - 跨两种模式的交叉成对距离测量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28719829/
在 Matlab 中,您可以选择创建新的“示例”脚本文件以及脚本、函数、类等。创建它们时,它们会获得一个脚本图标。 它们与其他标准脚本文件的处理方式有何不同? 是否有关于这些示例脚本类型的预期用途的文
我正在运行一个不是我自己编写的大 m 文件,它依赖于某些子函数。我想知道是否在所有嵌套函数的任何地方都使用了特定函数(在我的例子中是函数 eig.m(计算特征值))。有没有快速的方法来做到这一点? 亲
Matlab中有一个函数叫 copulafit .我怎样才能看到这个函数背后的代码?许多 Python 的 numpy 和 scipy 函数在 Github 上很容易开源,但由于某种原因我在 Gith
我定义了一个抽象基类measurementHandler < handle它定义了所有继承类的接口(interface)。这个类的两个子类是a < measurementHandler和 b < me
假设有一个矩阵 A = 1 3 2 4 4 2 5 8 6 1 4 9 例如,我有一个 Vector 包含该矩阵每一列的“类”
我有一个在后台运行的 Matlab 脚本。随着计算的进行,它会不断弹出进度栏窗口。这很烦人。 问题是我没有自己写 Matlab 脚本,这是一段很长很复杂的代码,我不想搞砸。那么如何在不修改 Matla
有没有办法从一个 matlab 程序中检测计算机上正在运行多少个 matlab 进程? 我想要恰好有 n 个 matlab 进程在运行。如果我的数量太少,我想创建它们,如果数量太多,我想杀死一些。您当
我正在测试我们在 Matlab 中开发的一个独立应用程序,当时我注意到它的内存使用量(根据 Windows 任务管理器)达到了 16gb 以上的数倍峰值。我决定在编译版本后面的脚本上使用 profil
我面临着一个相当棘手的问题。在 Matlab 中,命令 S = char(1044) 将俄语字母 д 放入变量 S。但是 disp(S) 返回空白符号,尽管内容实际上是正确的: >> S = char
我在这行 MATLAB 代码中遇到内存不足错误: result = (A(1:xmax,1:ymax,1:zmax) .* B(2:xmax+1,2:ymax+1,2:zmax+1) +
我正在寻找一种在 MATLAB 中比较有限顺序数据与非确定性顺序的方法。基本上,我想要的是一个数组,但不对包含的元素强加顺序。如果我有对象 a = [x y z]; 和 b = [x z y]; 我希
我有一个由 1 和 0 组成的二维矩阵。 mat = [0 0 0 0 1 1 1 0 0 1 1 1 1 1 0 0 1 0 0 0 1 0 1 1 0 0 1]; 我需
我可以在 Matlab 中用一组 x,y 点绘制回归线。但是,如果我有一组点(如下图),假设我有四组点,我想为它们绘制四条回归线……我该怎么做?所有的点都保存在 x,y 中。没有办法将它们分开并将它们
我正在尝试使用以下代码在 MATLAB 中绘制圆锥体。但是,当 MATLAB 生成绘图时,曲面中有一个间隙,如下图所示。谁能建议关闭它的方法? clearvars; close all; clc; [
我有一个 map称为 res_Map,包含一组不同大小的数组。我想找到用于存储 res_Map 的总内存。 正如您在下面看到的,看起来 res_Map 几乎不占用内存,而 res_Map 中的各个元素
有没有办法在 MATLAB 中组合 2 个向量,这样: mat = zeros(length(C),length(S)); for j=1:length(C) mat(j,:)=C(j)*S;
已结束。此问题不符合 Stack Overflow guidelines 。它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答它。 关闭 5 年前
我正在尝试将MatLab中的t copula适配到我的数据,并且我的功能是: u = ksdensity(range_1, range_1,'function','cdf'); v = ksdens
大家好,我目前正在尝试使用论文“多尺度形态学图像简化”中的 SMMT 运算符 Dorini .由于没有订阅无法访问该页面,因此我将相关详细信息发布在这里: 请注意,我将相关文章的部分内容作为图片发布。
我在MATLAB中编写代码,需要使用一个名为modwt的函数,该函数同时存在于两个我同时使用的工具箱(Wavelet和WMTSA)中。问题在于,一个版本仅返回一个输出,而另一个版本则返回三个输出。我应
我是一名优秀的程序员,十分优秀!