我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Matlab空心散点检测的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Matlab空心散点检测的示例分析

这篇文章主要介绍Matlab空心散点检测的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

问题描述

有一张这样的图片,如何提取里面的红色圈圈坐标,并且连接这些坐标形成两个封闭的环路?

Matlab空心散点检测的示例分析

过程展示

图像导入

oriPic=imread('test1.png');subplot(2,2,1)imshow(oriPic)

依据RGB值图像二值化

原理就是图中颜色种类比较少,只有红黑白,而红色和白色都是R通道数值较大,因此我们可以利用这一点进行图像分割

% 删除红色外的部分并构造二值图grayPic=rgb2gray(oriPic);grayPic(oriPic(:,:,1)<250)=255;grayPic(grayPic<250)=0;%subplot(2,2,2)figureimshow(grayPic)

Matlab空心散点检测的示例分析

图像腐蚀

对于白色来说是腐蚀,对于黑色来说是膨胀,这一步是为了让那些有缺口的小圆圈将缺口补起来

% 图像膨胀,使未连接边缘连接SE=[0 1 0;1 1 1;0 1 0];bwPic=imerode(grayPic,SE);figureimshow(bwPic)

Matlab空心散点检测的示例分析

图像边缘清理

就是把和边缘连接的不被黑色包围的区域变成黑色:

% 边缘清理:保留圆圈联通区域bwPic=imclearborder(bwPic);%subplot(2,2,3)figureimshow(bwPic)

Matlab空心散点检测的示例分析

联通区域查找与坐标均值计算

现在每一个白点都是一个坐标区域,我们检测所有联通区域并计算各个区域的重心即可:

% 获取每一个联通区域[LPic,labelNum]=bwlabel(bwPic);% 计算每一个联通区域 坐标均值pointSet=zeros(labelNum,2);for i=1:labelNum    [X,Y]=find(LPic==i);    Xmean=mean(X);    Ymean=mean(Y);    pointSet(i,:)=[Xmean,Ymean];end% 画个图展示一下%subplot(2,2,4)figureimshow(bwPic)hold onscatter(pointSet(:,2),pointSet(:,1),'r','LineWidth',1)

可以看出定位结果还是非常准确的:

Matlab空心散点检测的示例分析

圈查找

就以一个点开始不断找最近的点呗,没啥好说的:

n=1;while ~isempty(pointSet)    circleSetInd=1;    for j=1:length(pointSet)        disSet=sqrt(sum((pointSet-pointSet(circleSetInd(end),:)).^2,2));        [~,ind]=sort(disSet);        ind=ind(1:5);        [~,~,t_ind]=intersect(circleSetInd,ind);        ind(t_ind)=[];        if ~isempty(ind)            circleSetInd=[circleSetInd;ind(1)];        else            circleSet{n}=pointSet(circleSetInd,:);            pointSet(circleSetInd,:)=[];            n=n+1;            break        end    endendfigureimshow(oriPic)hold onfor i=1:n-1plot(circleSet{i}(:,2),circleSet{i}(:,1),'LineWidth',2)end

这效果就很美滋滋:

Matlab空心散点检测的示例分析

完整代码

function redPntoriPic=imread('test1.png');%subplot(2,2,1)figureimshow(oriPic)% 删除红色外的部分并构造二值图grayPic=rgb2gray(oriPic);grayPic(oriPic(:,:,1)<250)=255;grayPic(grayPic<250)=0;%subplot(2,2,2)figureimshow(grayPic)% 图像膨胀,使未连接边缘连接SE=[0 1 0;1 1 1;0 1 0];bwPic=imerode(grayPic,SE);figureimshow(bwPic)% 边缘清理:保留圆圈联通区域bwPic=imclearborder(bwPic);%subplot(2,2,3)figureimshow(bwPic)% 获取每一个联通区域[LPic,labelNum]=bwlabel(bwPic);% 计算每一个联通区域 坐标均值pointSet=zeros(labelNum,2);for i=1:labelNum    [X,Y]=find(LPic==i);    Xmean=mean(X);    Ymean=mean(Y);    pointSet(i,:)=[Xmean,Ymean];end%subplot(2,2,4)figureimshow(bwPic)hold onscatter(pointSet(:,2),pointSet(:,1),'r','LineWidth',1)n=1;while ~isempty(pointSet)    circleSetInd=1;    for j=1:length(pointSet)        disSet=sqrt(sum((pointSet-pointSet(circleSetInd(end),:)).^2,2));        [~,ind]=sort(disSet);        ind=ind(1:5);        [~,~,t_ind]=intersect(circleSetInd,ind);        ind(t_ind)=[];        if ~isempty(ind)            circleSetInd=[circleSetInd;ind(1)];        else            circleSet{n}=pointSet(circleSetInd,:);            pointSet(circleSetInd,:)=[];            n=n+1;            break        end    endendfigureimshow(oriPic)hold onfor i=1:n-1plot(circleSet{i}(:,2),circleSet{i}(:,1),'LineWidth',2)endend

其它形状空心散点检测

来波正方形试试:

Matlab空心散点检测的示例分析

Matlab空心散点检测的示例分析

Matlab空心散点检测的示例分析

Matlab空心散点检测的示例分析

Matlab空心散点检测的示例分析

Matlab空心散点检测的示例分析

可以看出效果还是很棒的,当然大家可以根据实际情况自行更改图像腐蚀模板形状,如果散点是其它颜色请自行更改第一步的图像分割条件。

后注:

若是因为点较为密集而导致圈形路径内部白色区域没被清除,可能会将内部区域也算作散点造成错误,解决方法是计算每个联通区域面积并剔除远远大于区域面积中位数的联通区域:

问题出现原因的图片描述:

Matlab空心散点检测的示例分析

Matlab空心散点检测的示例分析

如图所示种间那一大片区域也被算作散点

Matlab空心散点检测的示例分析

更改后代码如下:

function redPntoriPic=imread('test2.png');figureimshow(oriPic)% 删除红色外的部分并构造二值图grayPic=rgb2gray(oriPic);grayPic(oriPic(:,:,1)<250)=255;grayPic(grayPic<250)=0;figureimshow(grayPic)% 图像膨胀,使未连接边缘连接SE=[0 1 0;1 1 1;0 1 0];bwPic=imerode(grayPic,SE);figureimshow(bwPic)% 边缘清理:保留圆圈联通区域bwPic=imclearborder(bwPic);figureimshow(bwPic)% 获取每一个联通区域[LPic,labelNum]=bwlabel(bwPic);% 筛掉超大区域pointSizeSet=zeros(1,labelNum);for i=1:labelNum    pointSizeSet(i)=sum(sum(LPic==i));end[~,ind]=find(pointSizeSet>10*median(pointSizeSet));% 计算每一个联通区域 坐标均值pointSet=zeros(labelNum,2);for i=1:labelNum    [X,Y]=find(LPic==i);    Xmean=mean(X);    Ymean=mean(Y);    pointSet(i,:)=[Xmean,Ymean];endpointSet(ind,:)=[];figureimshow(bwPic)hold onscatter(pointSet(:,2),pointSet(:,1),'r','LineWidth',1)n=1;while ~isempty(pointSet)    circleSetInd=1;    for j=1:length(pointSet)        disSet=sqrt(sum((pointSet-pointSet(circleSetInd(end),:)).^2,2));        [~,ind]=sort(disSet);        ind=ind(1:min(5,length(ind)));        [~,~,t_ind]=intersect(circleSetInd,ind);        ind(t_ind)=[];        if ~isempty(ind)            circleSetInd=[circleSetInd;ind(1)];        else            circleSet{n}=pointSet(circleSetInd,:);            pointSet(circleSetInd,:)=[];            n=n+1;            break        end    endendfigureimshow(oriPic)hold onfor i=1:n-1plot(circleSet{i}(:,2),circleSet{i}(:,1),'LineWidth',2)endend

注:

2016版本及以前可能这句:

disSet=sqrt(sum((pointSet-pointSet(circleSetInd(end),:)).^2,2));

会出现数组大小不匹配问题,可以将其改为:

tempMat=repmat(pointSet(circleSetInd(end),:),[size(pointSet,1),1]);disSet=sqrt(sum((pointSet-tempMat).^2,2));

以上是“Matlab空心散点检测的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Matlab空心散点检测的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Matlab空心散点检测的示例分析

这篇文章主要介绍Matlab空心散点检测的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!问题描述有一张这样的图片,如何提取里面的红色圈圈坐标,并且连接这些坐标形成两个封闭的环路?过程展示图像导入oriPic=
2023-06-29

python中Harris角点检测的示例分析

这篇文章主要介绍了python中Harris角点检测的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、基本思想选择在图像上任意方向的固定窗口进行滑动,如果灰度变化较
2023-06-15

OCR活体检测的示例分析

这篇文章主要介绍了OCR活体检测的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。活体检测技术是防止系统攻击的主要手段,其价值在于在于判断操作用户身份,抵御照片,视频,
2023-06-02

Angular中变更检测的示例分析

这篇文章主要介绍Angular中变更检测的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!核心概念-视图ViewAngular的文档中通篇都提到了一个Angular应用是一个组件树。但是Angular底层其实使
2023-06-14

Matlab图像处理的公路裂缝案例检测分析

本篇内容主要讲解“Matlab图像处理的公路裂缝案例检测分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Matlab图像处理的公路裂缝案例检测分析”吧!一、简介1 案例背景随着国家对公路建设的
2023-06-29

微信域名拦截检测的示例分析

微信域名拦截检测的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。平时在微信跑产品经常被屏蔽拦截停止访问怎么办?我们都知道 微信对外部链接管理非常严格,所以自家域名网
2023-06-05

PHP核心特性命名空间的示例分析

小编给大家分享一下PHP核心特性命名空间的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!提出PHP 在 5.3 后提出了命名空间用来解决组件之间的命名冲突问题,主要参考了文件系统的设计:同一个目录下不允许有相同的文
2023-06-15

VB.NET网络应用之连通检测的示例分析

小编给大家分享一下VB.NET网络应用之连通检测的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!VB.NET网络应用连通检测许多应用程序常常需要在程序中直
2023-06-17

Python数据异常值检测和处理的示例分析

这篇文章主要介绍Python数据异常值检测和处理的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1 什么是异常值?在机器学习中,异常检测和处理是一个比较小的分支,或者说,是机器学习的一个副产物,因为在一般的预
2023-06-29

Linux下c++程序内存泄漏检测代码的示例分析

这期内容当中小编将会给大家带来有关如何解决Linux下c++程序内存泄漏检测代码,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Linux下对于程序内存泄漏检测的方法很多,最常用的的莫过于使用valgrin
2023-06-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录