基于Matlab图像处理求植物叶片面积
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
图像处理实验报告
实验名称
基于Matlab 图像处理求植物叶片面积 实验目的
1.用matlab 测试叶片面积与网格测面积对比,研究可用性。
2.学习用matlab 对图像进行背景去除、对比度处理、图像型学处理及中值滤波处理等。
3.学习用matlab 计算像素点的比例,利用已知参照物面积计算出要求的叶子面子。 实验原理
实验通过手动网格法测叶子面积与matlab 处理计算叶子面积对比,研究matlab 测试叶子面积的可用性。
matlab 测面积所选择的图片是把植物叶片放置在旁边画有已知面积的小方格作为参照物的白纸上用手机拍取图像。如此即将叶片信息转化为计算机可识别的图像信息。由于数字图像都是由一个个像素点组成。可以根据像素点比例和参照物面积求出植物叶片面积。叶片面积计算公式如下:
参照物像素数
叶片像素数
参照物面积叶片面积⨯
=
实验内容步骤
1、网格测面积
由于用excel 做30mm*30mm 网格及10mm*10mm 小方格打印出来实际面积变为29mm*28mm 网格及9mm*9mm 小方格(如下两图)故参照物面积为81mm 2,网格法测出叶子所占空格490,共有900网格,故叶子面积为442mm 2计算如下:
442
2829900
490
=⨯⨯=⨯=
网格面积网格总个数叶子轮廓所占网格个数网格法测叶子面积
2、matlab测面积
(1)通过手机拍照如下保存为leaf..jpg和一张白色背景图background.jpg,通过matlab读取图像。如图1
(2)图像灰度处理
由于手机拍摄的是彩色即rgb格式,为了进行下一步处理,需要先将图像转换为灰度图像。灰度变换是图像增强的一种手段,是图形动态范围加大,对比度扩展,图形更清晰,特征更明显。用rgb2gray函数。处理后如图2
图1 图2
(3)用差分法进行图像分割
图像差分法用imsubtract函数将一幅输入图像的像素值从另外一幅输入图像相应的像素值中减去,再将相应的像素值之差作为输出图像的对应的像素值。处理图像后可使用imclearborder命令消除图像中的边缘对象。如图3 (4)调节对比度
调节对比度imadjust函数可以使原来模糊不清甚至无法辨别的原始图像处理成清晰的富含大量有用信息的可使用图像,有效的去除图像中的噪音、增强图像中的边缘或其他需要的区域,从而更加容易对图像中需要的目标进行检测和测量。处理后如图4
图3 图4
(5)边缘检测
通过edge函数对图像分别用sobel、robert、prewitt和canny算子方法比较在
本实验叶片中canny效果最好。分析如图5
图5
(6)图像型学处理
通过strel和imdilate函数对图像进行膨胀操作,填补边缘缝隙后通过imfill 函数对空隙填充,再用菱形结构对图像进行平滑处理。
(7)中值滤波处理
中值滤波在衰减噪声同时不会使图像边界模糊,去噪效果依赖2个要素:领域的空间范围和中值计算中涉及的像素数。具体函数medfilt2。
(8)标记及面积计算
这个步骤是确定图像中的目标对象并标记。调用bwlabe函数寻找连通成份而且用唯一的数字将他们分类标记。通过ismember函数去除不符合区域,在图片中显示像素数,图6所示。
图6
实验结果与分析
最终得到图片中两个像素数带入原理中公式,求得叶片面积为438.12mm 2:
12.4388111467
62024
=⨯=叶片面积
通过两种测试方法得到的结果误差为442-438.12=3.88mm 2可知,matlab 测试数据相对准确具有可用性,而且matlab 通过几行代码测试可以减少人工费时费力,解决了实际问题。
代码附下