- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于L*a*b空间的色彩分割
实验原理
数字图像处理技术是一个跨学科的领域。随着计算机科学技术的不断发展,图像处理和分析逐渐形成了自己的科学体系,新的处理方法层出不穷,尽管其发展历史不长,但却引起各 方面人士的广泛关注。首先,视觉是人类最重要的感知手段,图像又是视觉的基础,因此,数字图像成为心理学、生理学、计算机科学等诸多领域内的学者们研究视 觉感知的有效工具。其次,图像处理在军事、遥感、气象等大型应用中有不断增长的需求。
所谓图像分割是指根据灰度、彩色、空间纹理、几何形状等特征把图像划分成若干个互不相交的区域,使得这些特征在同一区域内,表现出一致性或相似性,而在不同区域间表现出明显的不同。简单的讲,就是在一幅图像中,把目标从背景中分离出来,以便于进一步处理。图像分割是图像处理与计算机视觉领域低层次视觉中最为基础和重要的领域之一,它是对图像进行视觉分析和模式识别的基本前提。同时它也是一个经典难题,到目前为止既不存在一种通用的图像分割方法,也不存在一种判断是否分割成功的客观标准。
L*a*b空间中L:亮度层,a:颜色在红绿轴的分量,b:颜色在蓝黄轴的分量。
基于L*a*b空间的色彩分割的基本步骤如下:
1. 读取图像并选择合适的样本区域;为每种颜色的样本选择一个很小的样本区域,然后计算每个样本区域中这种颜色的平均值。
fabric = imread(fabric.png);%读取图像figure; subplot(121); imshow(fabric), %显示title(fabric);load regioncoordinates;%下载颜色区域坐标到工作空间nColors = 6;sample_regions = false([size(fabric,1) size(fabric,2) nColors]);for count = 1:nColors sample_regions(:,:,count) = roipoly(fabric,... region_coordinates(:,1,count), ... region_coordinates(:,2,count));%选择每一小块颜色的样本区域endsubplot(122),imshow(sample_regions(:,:,2));%显示红色区域的样本title(sample region for red);
2. 转换色彩空间;利用彩色空间转换函数把图像从RGB色彩空间转换到L*a*b色彩空间。
cform = makecform(srgb2lab);%rgb空间转换成L*a*b*空间结构lab_fabric = applycform(fabric,cform);%rgb空间转换成L*a*b*空间a = lab_fabric(:,:,2); b = lab_fabric(:,:,3);color_markers = repmat(0, [nColors, 2]);%初始化颜色均值for count = 1:nColorscolor_markers(count,1)= mean2(a(sample_regions(:,:,count)));%a均值color_markers(count,2)= mean2(b(sample_regions(:,:,count)));%b均值enddisp(sprintf([%0.3f,%0.3f],color_markers(2,1),... color_markers(2,2)));%显示红色分量样本的均值color_labels = 0:nColors-1;a = double(a); b = double(b);distance = repmat(0,[size(a), nColors]);%初始化距离矩阵for count = 1:nColors distance(:,:,count) = ( (a - color_markers(count,1)).^2 + ... (b - color_markers(count,2)).^2 ).^0.5;%计算到各种颜色的距离end
3. 根据样本区域的颜色对图像进行分割;通过计算每个像素点和六种颜色平均值的欧氏距离,这六种距离中最小的距离既为该像素点的颜色,这种方法称为最近邻近法,例如:如果像素点距离红色平均值的欧氏距离最小,那么该像素点就为红色。
[value, label] = min(distance,[],3);%求出最小距离的颜色label = color_labels(label);clear value distance;rgb
您可能关注的文档
最近下载
- 山东职业学院档案管理.pdf VIP
- 冀教版小学数学四年级下册【全册】课时练+单元测试卷(含答案).pdf VIP
- DB11T 214-2016 居住区绿地设计规范.pdf VIP
- 国家开放大学电大本科《C语言程序设计》期末试题标准题库及答案(试卷号:1253).pdf VIP
- 天津专用2025届高考化学一轮复习考点规范练37生命中的基础有机化合物有机合成含解析.docx VIP
- 爆破工程技术人员取证培训初级D设计题真题参考答案.pdf VIP
- 利安隆(珠海)新材料有限公司年产5.15万吨高分子材料抗老化助剂混配、造粒项目环评报告表.pdf VIP
- 医生三基三严知识题库(附答案).docx VIP
- 2025年【N1叉车司机】考试及N1叉车司机考试题库(含答案).docx
- 未成年人防性侵安全教育.pptx VIP
文档评论(0)