基于MATLAB的米粒识别.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数字图像采集与处理大作业 题 目:基于MATLAB的米粒识别技术 实验目的及意义 针对目前大米人工计数方法存在的不足,提出了一种基于MATLAB图像识别和处理技术的大米计数方法,该方法减轻了操作者劳动强度,弥补了人视觉的不足之处,提高了效率和准确率,为今后进一步研究奠定了必要的理论与实践基础,对完善“精细农业”具有重要意义。 此程序消除简单图片中亮度不一致的背景,并使用阈值将修改后的图像转换为二值图像,使用成员标记返回图像中对象个数以及统计特性。 实验原理 这里以米粒图片(rice.jpg)为例,把图片中的背景颜色亮度调整到相同,二值化后清楚的显示出白黑的位置,较准确的计算出图像中研究对象的个数并标记,最后进行系统统计,通过直方图显示出统计结果。 1、使用阈值将修改后的图像转换为二值图像:图像的二值化处理就是将图像上的点的灰度值为0或255,也就是将整个图像呈现出明显的黑白效果。即将256个亮度等级的灰度图像通过适当的 HYPERLINK /item/%E9%98%88%E5%80%BC \t _blank 阈值选取而获得仍然可以反映图像整体和局部特征的二值化图像。在数字图像处理中,二值图像占有非常重要的地位,特别是在实用的图像处理中,以二值图像处理实现而构成的系统是很多的,要进行二值图像的处理与分析,首先要把灰度图像二值化,得到二值化图像,这样子有利于在对图像做进一步处理时,图像的集合性质只与 HYPERLINK /item/%E5%83%8F%E7%B4%A0 \t _blank 像素值为0或255的点的位置有关,不再涉及像素的多级值,使处理变得简单,而且数据的处理和压缩量小。为了得到理想的二值图像,一般采用封闭、连通的边界定义不交叠的区域。所有灰度大于或等于阈值的像素被判定为属于特定物体,其灰度值为255表示,否则这些像素点被排除在物体区域以外,灰度值为0,表示背景或者例外的物体区域。 在MATLAB中将图像转换为二值图像,主要运用im2bw函数,涉及到一个灰度门槛的数值。对于灰度图像bw=im2bw(I,level); level默认是0.5,level一般使用graythresh函数来计算。 2、使用成员标记返回图像中对象的个数以及统计特性:bwlabel函数表示了二值图像中的所有相关成分并返回在图像中找到的对象个数,最后绘制一个直方图反应米粒分布情况。 实验内容 实验一:首先对简单的图像进行处理 1、读取和显示图像 clear;close all%清空Matlab工作平台所有变量 I=imread(‘rice.jpg’); %读取图像,将图片放在工程目录bin文件夹内 figure,imshow(I) %显示图像 2、估计图像背景 图像中心位置背景亮度强于其他部分亮度,用imopen函数和一个半径为15的圆盘结构元素对输入的图像I进行形态学开操作,去掉那些不完全包括在圆盘中的对象,从而实现对背景亮度的估计。 background=imopen(I,strel(‘disk’,25)); %创建一个半径为25的圆盘结构元素 imshow(background) figure,surf(double(background(1:8:end,1:8:end))),zilm([0,255]); set(gca,’ydir’,’reverse’); 显示了背景图(上)和背景表面图(下) 3、从原始图像中减去背景图像 原始图像I减去背景图像得到背景较为一致的图像。 I2=imsubstract(I,background); figure,imshow(I2) 4、调节图像的对比度:图像较暗,可用imadjust函数命令来调节图像的对比度。 I3=imadjust(I2,stretchlim(I2),[0 1]); figure,imshow(I3); 5、使用阈值操作将图像转换为二进制(二值)图像(bw) level=graythresh(I3);%图像灰度处理 bw=im2bw(I3,level);%图像二值化处理 figure,imshow(bw)%显示处理后的图片 6、检查图像中对象个数 Bwlabel函数表示了二值图像中的所有相关成分并返回在图像中找到的对象的个数。 [labeled,numObjects]=bwlabel(bw,4); numObjects 图像中的米粒对象个数是: numObjects = 5 实验二:对较复杂问题进行计数 1、前几部步骤与实验一相同,但创建一个半径为17的圆盘结构元素 clear;close all I=imread(rice.png); figure,imshow(I) background=imopen(I,strel(di

文档评论(0)

kbook + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档