夜深人静时分,宿舍就我自己,只有蚊子陪伴着我,我慢慢码下这段文字............

  感觉知识结构不完善:上学期看论文,发现类间离散度矩阵和类内离散度矩阵,然后百度,找不到,现在学模式识别,见了,发现是数学公司,不过老师不讲........

一.问题来源

  今天有个意想不到的收货,下午讲课的时候遇到一个人主动加我,来自南京信息工程大学的某X(处于隐私保护,未经李某X同意,笔者不敢公开其信息),下面是他的话:很久没去博客园了。。。。现在只有matlab版本的一些hash算法;我现在主要就是在研究基于hash的图像检索,如果你有需要的话,可以给你一些资料。

  我们俩交流了很多.......从实验室,到研究课题,到LOL,笔者深深为他渊博的学识和不俗的谈吐所打动,恩恩,遇到志同道合的人挺不容易的........最重要的是感谢他的开源精神,给我了很多我急需的资料和代码。在此,也感谢博客园提供的这个平台,让我们在这茫茫人海中有了相知相识的机会,哈哈,这其实就是局部敏感哈希的思想——在茫茫人海中发现相似的你啊,爱你们.............

  该篇博客来自于某X分享的代码,我产生了写此篇博文的灵感。

二.问题解析

  实现矩阵间任意行之间的欧式距离。通俗地说如下:两个点的距离知道吧,矩阵是类似的原理,求X1和X2矩阵的距离,假设得到的结果矩阵为C,那么C的下标ij表示的是X1中的第i行和X2中的第j行的距离。

2.1 方法1

if nargin == 2
P1 = double(P1);
P2 = double(P2); X1=repmat(sum(P1.^2,2),[1 size(P2,1)]);%sum(x,2):横向相加,得到列向量;sum(x),默认为竖向相加。
X2=repmat(sum(P2.^2,2),[1 size(P1,1)]);
R=P1*P2';
D=real(sqrt(X1+X2'-2*R));
else
P1 = double(P1); % each vector is one row
X1=repmat(sum(P1.^2,2),[1 size(P1,1)]);
R=P1*P1';
D=X1+X1'-2*R;
D = real(sqrt(D));
end

  加入p1:100*256,p2:5900*256,那么x1:100*5900,x25900*100,R:5900*100。

  repmat表示复制和平铺,sum(P1.^2,2)就是每个元素先平方,然后每行求和,就变成一个列向量;求矩阵X1和X2的距离:类似于(A-B)^2 = A^2+B^2-2AB然后开根号;matlab里面调用repmat(a,m,n)命令:三个参数的含义:a:要被复制的矩阵或者向量,m复制成多少行,n复制成多少列。就是把a复制成m行,n列。[1 size(P2,1)]:这个就是将sum(P1.^2,2)得到的列向量复制一行,size(p2,1)列。

  不计算距离如何知道样本是不是紧邻呀,这个就是欧式距离度量紧邻与否。紧邻与否可以通过语意度量,也可以通过距离度量,欧式距就是其中一种。

2.2 方法2

  写到上面,我想起了王老师写的k-means(链接),那时候第一次接触repmat函数。

%repmat 即 Replicate Matrix ,复制和平铺矩阵,是 MATLAB 里面的一个函数。
%B = repmat(A,m,n)将矩阵 A 复制 m×n 块,即把 A 作为 B 的元素,B 由 m×n 个 A 平铺而成。B 的维数是 [size(A,1)*m, size(A,2)*n] 。
%点乘方a.^b,矩阵a中每个元素按b中对应元素乘方或者b是常数
%sum(x,2)表示矩阵x的横向相加,求每行的和,结果是列向量。 而缺省的sum(x)就是竖向相加,求每列的和,结果是行向量。
dist = sum((repmat(x(i,:),k,1)-nc).^2,2);

2.3 方法3

  直接饮用小伙伴们的问题。

  比如说,A阵是20*10,B阵是30*10的,A阵的20个行向量和B阵中的30个行向量计算欧式距,得到20*30的欧式距离矩阵C这个应该怎么写?
  我每次写出来的C阵每行都是相同的 简直郁闷死了,请教大牛~

clear all
%你可以定义自己的A,B矩阵,下面的矩阵仅作为例子
A=zeros(20,10);
B=ones(30,10);
%Dist距离矩阵
Dist=zeros(20,30);
for i=1:20
for j=1:30
Dist(i,j)=norm(A(i,:)-B(j,:));
end
end

2.4 方法4

Dist = sqrt(A.^2*ones(size(B'))+ones(size(A))*(B').^2-2*A*B')

  这个和方法1,异曲同工。而且,据传,此方法较快。

2.5 方法五

for i = 1:size(X,1)
Distance(i,:) = diag((repmat(X(i,:),n,1)-X)*(repmat(X(i,:),n,1)-X)');
end

三.结束语

  看了这么久的LSH,苦于没有合适的代码,很痛苦,给国内的某些大牛写信,从来没收到过回信,给国外的大牛写信基本当天就会回信..........这算是国内外学者的精神风貌不同吧........正式这个原因,我慢慢想着摒弃开源,恩恩,感谢某X,让我有了继续开源的精神动力,人生路上就是需要这类人的陪伴.....从长远来源,笔者认为开源更有意义,也更能体现自己的价值.......每次我说我不懂,别人说我谦虚,其实我是真的不懂.....知道个大概,对面其实是一种误导.......不过有时候也挺佩服自己能坚持下来...........笔者的目标是——互联网行业布道者,欢迎志同道合的人和我联系............晚安~~~

  参考文献:IloveMatlab社区,百度知道,某X语录。

Matlab计算矩阵间距离的更多相关文章

  1. matlab计算矩阵每列非0元素个数

    在统计分析中,有时候需要计算矩阵每列非0元素的个数,可以用以下方法: 先用find找到每列不为0的元素index,然后用count计数. 假设有矩阵A[M,N], 结果存在countZeros cou ...

  2. Matlab计算矩阵和函数梯度

    一.差分与微分 我自己的理解. 二.求解 2.1 矩阵 这就是matlab的计算结果.太小的话放大些: c = 4 5 9 7 2 1 5 2 6 >> [x,y]=gradient(c) ...

  3. Matlab Tricks(十八)—— 矩阵间元素距离的计算

    两个矩阵间元素(向量)距离的度量,首先想到的是遍历,循环的方式,显然 matlab 下的编程并不推荐,matlab 下矩阵向量化编程效率尤高. 先考虑两个向量距离的计算: ∥x−y∥2=∥x∥2+∥y ...

  4. HDOJ2001计算两点间的距离

    计算两点间的距离 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  5. 计算两点间的距离,hdu-2001

    计算两点间的距离 Problem Description 输入两点坐标(X1,Y1),(X2,Y2),计算并输出两点间的距离.   Input 输入数据有多组,每组占一行,由4个实数组成,分别表示x1 ...

  6. TSQL 根据经纬度计算两点间的距离;返回米(m)

    -- ============================================= -- Author:Forrest -- Create date: 2013-07-16 -- Des ...

  7. php根据地球上任意两点的经纬度计算两点间的距离 原理

    地球是一个近乎标准的椭球体,它的赤道半径为6378.140千米,极半径为6356.755千米,平均半径6371.004千米.如果我们假设地球是一个完美的球体,那么它的半径就是地球的平均半径,记为R.如 ...

  8. hdu2001 计算两点间的距离【C++】

    计算两点间的距离 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  9. MATLAB求马氏距离(Mahalanobis distance)

    MATLAB求马氏距离(Mahalanobis distance) 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1.马氏距离计算公式 d2(xi,  ...

随机推荐

  1. ASP.NET MVC Partial页输出JS

    很多情况Partial是需要引用到JS的,通常做法是吧JS在引用Partial的页面中加入JS文件或者JS代码. 前阵子网上看到一段代码可以在Partial页面中添加JS,输出道引用页面. publi ...

  2. 转 Android 4.0后,自定义Title报错 You cannot combine custom titles with other title feature

      自定义Titlebar时为了避免冲突 需要修改:AndroidManifest.xml android:theme="@style/mystyle" styles.xml文件中 ...

  3. JavaScript之模拟评星打分

    <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312&qu ...

  4. 牢记!SQL Server数据库开发的二十一条注意点

    如果你正在负责一个基于SQL Server的项目,或者你刚刚接触SQL  Server,你都有可能要面临一些数据库性能的问题,这篇文章会为你提供一些有用的指导(其中大多数也可以用于其它的DBMS). ...

  5. linux中FTP自动备份VPS脚本

    服务器多了,网站也越来越多,总觉得不整个备份心里放不下心,并且有好几次rm的操作失误,造成难以挽回的损失.并且大多数的VPS提供商是不提供自动备份功能或者此功能收费价格略高.所以自己还是有必要把这个工 ...

  6. stl中的map数据类型

    1.1 STL map 1.1.1 背景 关联容器使用键(key)来存储访问读取元素,而顺序容器则通过元素在容器中的位置存储和访问元素. 常见的顺序容器有:vector.list.deque.stac ...

  7. 40个容易上瘾的HTML5网页游戏,总有一款适合你

    我记得姐姐家的孩子在刚刚才学会走路,说话还不能完整的时候就已经能自己用小手点出小游戏的网站来一个人自娱自乐.我一直在想这一代跟着计算机一起茁壮成长的孩子会不会也和美国那一代人一样,出现9岁的黑客和计算 ...

  8. 代码优化—From <effective C++>

    1.尽可能的延后变量定义式的出现时间 不止应该延后变量的定义,直到非得使用该变量的前一刻为止,甚至应该尝试延后这份定义直到能够给它初值实参为止. 如果这样不仅能够避免构造和析构非必要对象,还可以避免无 ...

  9. Linux SCSI回调IO的分析

    本文转载自:http://blog.csdn.net/xushiyan/article/details/6941640,如需参考,请访问原始链接地址. 没找到如何转载的入口,只好全文copy了. -- ...

  10. [转]主键冲突的话就更新否则插入 (ON DUPLICATE KEY UPDATE )

    mysql "ON DUPLICATE KEY UPDATE" 语法如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQ ...