• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

JavaScript编程通过Matlab质心算法定位学习

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

Matlab作为封闭的商业软件,受美国政府左右,无视商业道德,故不建议使用。如果喜欢Matlab语法,可移步开源的octave,其语法与matlab完全相同。

Matlab质心算法

所谓质心,就是当密度作为像素点灰度值时的重心,例如其质心的x坐标为

最直观的方法就是下面的这种方式了。

%%通过质心算法找到img的质心位置
function [x,y] = oCenter(img)
img = double(img);
[m,n] = size(img);
x = 0;y = 0;sum=0;
for i = 1:m
    for j = 1:n
        y = y + img(i,j)*i;
        x = x + img(i,j)*j;
        sum = sum+img(i,j);
    end
end
x = x/sum;
y = y/sum;

这么写足够简单粗暴,却也太丑了,毕竟在Matlab中,矩阵才是最基本的操作单元。
而且在累加求和的过程中,也的确反复使用了相同的数组。对于第i行而言,每一列分别与1,2,3...相乘并求和,也就是第i行向量与向量[1:n]的点积。于是先不管整张图片,第i行向量的质心也就可以比较简单地写出来了。

x = img(i,:)*(1:n)'/sum(img(i,:));

基于此,我们还得到了一个意外收获,即可以很方便地把每一行的质心用一行表达式写出来

x = img*(1:n)'./sum(img,2);%每一行的质心
y = (1:m)*img./sum(img);%每一列的质心

强迫症表示看上去很舒服。
相应地,图片整体的质心可写为

sumImg = sum(img(:));
x = sum(img)*(1:n)'/sumImg;
y = (1:m)*sum(img,2)/sumImg;

以上就是JavaScript编程通过Matlab质心算法定位学习的详细内容,更多关于JavaScript定位Matlab质心算法的资料请关注极客世界其它相关文章!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
浅谈VUE uni-app 生命周期发布时间:2022-02-05
下一篇:
微信小程序骨架屏的实现示例发布时间:2022-02-05
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap