《数字图像处理与机器视觉》案例一(库尔勒香梨果梗提取和测量)

  • 一、引言

       果梗是判断水果新鲜程度的重要标志,对水果的贮藏和保鲜也具有重要的参考价值。库尔勒香梨分级标准中对果梗有明确要求,要求果梗完整,但由于库尔勒香梨果梗颜色与果实接近,用传统的简单阈值分割方法难以提取。因此,下面基于数学形态学开发一个能实现其果梗提取和测量的程序。

  • 二、程序代码

clear all;

close all;

clc;

I=imread('.\FragrantPear.tif');

I_R=I(:,:,1);

I_G=I(:,:,2);

I_B=I(:,:,3);

I_GB=I_G-I_B;

figure,imshow(I_GB),title('G-B图像');

figure,imhist(I_GB),title('G-B灰度直方图');

%I_GB_bw=im2bw(I_GB,graythresh(I_GB));  %分割阈值的选择

I_GB_bw=im2bw(I_GB,2/255);  %分割阈值的选择

figure,imshow(I_GB_bw);

SE=strel('disk',1);%确定结构元素形式和尺寸

obj=imopen(I_GB_bw,SE);%数学形态学开运算,消除小目标并平滑边界

obj=imfill(obj,'holes');

figure,imshow(obj),title('库尔勒香梨二值图像');

obj2=uint8(obj).*I;

figure,imshow(obj2),title('库尔勒香梨彩色图像');

[L,num]=bwlabel(obj);

stats=regionprops(L,'Area','Perimeter');

A=[stats.Area];      %获取库尔勒香梨的面积

P=[stats.Perimeter]; %获取库尔勒香梨的周长

FP=bwmorph(obj,'remove');

figure,imshow(FP);%获取库尔勒香梨的边缘图像

imtool(obj)

SE2=strel('disk',10);  %选取合适的结构元素

M=imopen(obj,SE2);

figure,imshow(M);

Stem=logical(obj-M);%图像减法获取果梗图像像

figure,imshow(Stem);

Stem2=bwareaopen(Stem,100);%去除噪声

figure,imshow(Stem2);

%测量果梗的长和宽

% 计算区域属性

props = regionprops(Stem2, 'Area','BoundingBox','MajorAxisLength','MinorAxisLength');% doc regionprops

 % 提取最小外矩形的长轴和短轴

MajorLength=props.MajorAxisLength;%估计果梗长度

MinorLength=props.MinorAxisLength;%估计果梗直径

% 提取最小面积的矩形

minAreaRect = props(1).BoundingBox;

% 绘制最小外矩形

rectangle('Position', minAreaRect, 'EdgeColor', 'r'),title('绘制最小外接矩形');%绘制最小外接矩形

%%https://www.mathworks.com/help/images/ref/regionprops_zh_CN.html

figure,

subplot(2,2,1),imshow(I),title('原始图像');

subplot(2,2,2),imshow(obj),title('二值图像');

subplot(2,2,3),imshow(FP),title('库尔勒香梨边缘图像');

subplot(2,2,4),imshow(Stem2),title('库尔勒香梨果梗二值图像');

三、程序部分运行结果

四、总结

    本次果梗提取和测量,充分利用MATLAB中内置函数imopen、imtool和imhist各自特点对彩色图像进行分析,确定了最优分割方案,获得了较好分割效果,对其它水果果梗检测也具有一定参考价值。

五、原始图像

如果觉得本案例对大家今后的编程有帮助,请点赞和收藏。如有改进意见可以与我联系,谢谢!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/736120.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue79-路由组件独有的2个新的生命周期钩子

一、需求 news.vue路由组件被缓存了(因为想要保留里面的输入框的数据!),导致,路由页面切走,组件也不会被销毁,所以,beforeDestroy()函数就不会被执行,所以,定…

【数据挖掘】机器学习中相似性度量方法-闵可夫斯基距离

写在前面: 首先感谢兄弟们的订阅,让我有创作的动力,在创作过程我会尽最大能力,保证作品的质量,如果有问题,可以私信我,让我们携手共进,共创辉煌。 路虽远,行则将至&#…

Typora最新安装教程2024

Typora是一款广受好评的跨平台Markdown编辑软件,支持Windows、MacOS和Linux操作系统。它的设计旨在提供一个无干扰、高效且直观的写作环境。户快速管理和查找文档,支持直接在软件内浏览和操作文件结构。 Typora以其简洁而强大的功能集合,成为…

html做一个画热图的软件

完整示例 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>热图生成器</title><script src"https://cdn.plot.ly/plotly-latest.min.js"></script><style>body …

基于SpringBoot+大数据城市景观画像可视化设计和实现

&#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者&#xff0c;博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌&#x1f497; &#x1f31f;文末获取源码数据库&#x1f31f; 感兴趣的可以先收藏起来&#xff0c;…

Kafka~基础原理与架构了解

Kafka是什么 Kafka我们了解一直认为是一个消息队列&#xff0c;但是其设计初&#xff0c;是一个&#xff1a;分布式流式处理平台。流平台具有三个关键功能&#xff1a; 消息队列&#xff1a;发布和订阅消息流&#xff0c;这个功能类似于消息队列&#xff0c;这也是 Kafka 也被…

数组的操作

数组的操作也可以大概分为增删查改。 Arrays.toString**&#xff1a;**把数组内的内容输出。 获取长度 获得数组的元素数量。 格式&#xff1a; 数组名.length注意&#xff0c;请不要写成 ** 数组名.length&#xff08;&#xff09;** 存数据 如果使用了动态初始化或者我们…

C++11 标准库头文件模拟实现

系列文章目录 文章目录 系列文章目录前言● 智能指针模板● Vector1. 简单版本2. X 总结 前言 暂不考虑支持多线程 常用STL的简单实现&#xff0c;主要内容百行左右完成&#xff0c;意在理解STL的原理 ● 智能指针模板 SharedPtr #include <assert.h> #include <ato…

c#使用自带库对字符串进行AES加密、解密

文章目录 1 代码1.1 定义Aes加密类块1.2 在主函数中调用 2 获取Key和IV2.1 基本方法2.2 自定义Key2.3 技术方面的原理 参考文章&#xff1a; C#软件加密实例&#xff1f; 。 参考官文&#xff1a; Aes 类。 在使用C#的自带的System.Security.Cryptography.Aes模块进行加密和解…

图的学习.

目录 一、图的基本概念 1.1图的种类 1.2顶点的度、入度和出度 1.3边的权和网 1.4路径、路径长度和回路 二、图的存储结构 2.1邻接矩阵法 2.2邻接表法 2.3十字链表 2.4邻接多重表 三、图的遍历 3.1广度优先搜索 3.2深度优先搜索 四、图的应用 4.1最小生成树 4.1.…

密码没有未来

无密码认证的好处 引领无密码未来之路万能钥匙 英国通过具体法律打击可预测密码 强密码是抵御网络威胁的第一道防线 如何破解价值百万美元的加密钱包密码 复制此链接到微信打开阅读全部以发布文章 新 GPU 在不到一小时内打开了网络上 59% 的密码。 现代计算机的能力不断增…

AGV机器人的调度开发分析(1)- 内核中的路线规划

准备开始写一个系列&#xff0c;介绍下AGV机器人的调度的开发和应用。 按照openTCS的核心内容&#xff0c;国内多家广泛应用于AGV的调度。那么架构图如下&#xff1a; Kernel中有一个是Routing&#xff0c;这是路由规划模块&#xff0c;需要实现的细节功能包括如下&#xff1a…

cesium 包络线

cesium 包络线 以下为源码直接复制可用 1、实现思路 通过turf.js中union方法来计算包络线官方地址:https://turfjs.fenxianglu.cn/ 闪烁线请查看cesium轨迹线(闪烁轨迹线) 2、示例代码 <!DOCTYPE html> <html lang="en"&g

Pwn刷题记录(不停更新)

1、CTFshow-pwn04&#xff08;基础canary&#xff09; ​ 好久没碰过pwn了&#xff0c;今天临时做一道吧&#xff0c;毕竟刚联合了WSL和VSCode&#xff0c;想着试着做一道题看看&#xff0c;结果随手一点&#xff0c;就是一个很少接触的&#xff0c;拿来刷刷&#xff1a; ​ …

计算机组成原理 —— 存储系统(DRAM和SRAM,ROM)

计算机组成原理 —— 存储系统&#xff08;DRAM和SRAM&#xff09; DRAM和SRAMDRAM的刷新DRAM地址复用ROM&#xff08;Read-Only Memory&#xff08;只读存储器&#xff09;&#xff09; 我们今天来看DRAM和SRAM&#xff1a; DRAM和SRAM DRAM&#xff08;动态随机存取存储器&…

springboot 酒庄内部管理系统(源码+sql+论文)

绪论 1.1 系统研究目的意义 随着信息技术的不断发展&#xff0c;我们现在已经步入了信息化的时代了&#xff0c;而信息时代的代表便是网络技术的日渐成熟&#xff0c;而现在网络已经和我们的生活紧密的联系起来了&#xff0c;我们不敢想象没有网络我们的生活会像怎么样&#…

六、资产安全—数据管理(CISSP)

目录 1.学习目标 2.数据管理最佳参考实践 3.数据质量维度:DAMA 4.数据生命周期控制 5.数据净化方式 6.生命周期安全控制 7.EOL、EOS、EOSL 1.学习目标 2.数据管理最佳参考实践 数据策略: 角色与责任: 数据所有权:

数据分析必备:一步步教你如何用matplotlib做数据可视化(10)

1、Matplotlib 二维箭头图 箭头图将速度矢量显示为箭头&#xff0c;其中分量(u&#xff0c;v)位于点(x&#xff0c;y)。 quiver(x,y,u,v)上述命令将矢量绘制为在x和y中每个对应元素对中指定的坐标处的箭头。 参数 下表列出了quiver()函数的参数 - x - 1D或2D阵列&#xff0c;…

C语言中的进制转换

基础概念 进制又称数制&#xff0c;是指用一组固定的符号和统一的规则来表示数值的方法&#xff0c;在C语言中&#xff0c;可以使用不同的前缀来表示不同的进制&#xff1a; 二进制&#xff1a;以0b或0B为前缀&#xff08;部分编译器可能不支持&#xff09;八进制&#xff1a…

Go日常分享 - error类型是指针类型吗?

背景 这个问题的产生来源于小泉在开发rpc接口时返回error遇到的问题&#xff0c;开发时想在defer里对err进行最终的统一处理赋值&#xff0c;发现外层接收一直都未生效。问题可以简化为成下面的小demo。 func returnError() error {var err errordefer func() {//err errors…