欧氏距离的MATLAB实现
问题描述
实现任意给定两个相同维度的向量之间的欧氏距离计算函数dist_E(x,y)。
测试代码:x=[1,3,0,2]; y=[2,3,2,0]; dist=dist_E(x,y);
代码实现
实现程序如下图所示:
% 方法1
function dist = dist_E(x,y)
dist = [];
if(length(x)~=length(y))
disp('length of input vectors must agree') % disp函数会直接将内容输出在Matlab命令窗口中
else
z =(x-y).*(x-y);
dist = sqrt(sum(z));
end
end
% 方法2:公式法
function dist = dist_E(x,y)
[m,n] = size(x);
dist = 0;
for i=1:max(m,n)
dist = dist+(x(i)-y(i))^2;
end
dist = sqrt(dist);
end
% 方法3:采用pdist函数
function dist = dist_E(x,y)
dist = [x;y];
dist = pdist(dist); % 计算各行向量之间的欧式距离
end
命令行窗口输入如下代码:
x=[1,3,0,2];
y=[2,3,2,0];
dist=dist_E(x,y)
代码执行结果:
今天的文章【数据挖掘】MATLAB实现欧氏距离计算分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/27141.html