基于Lab空间的色彩分割.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于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));%选择每一小块颜色的样本区域 end subplot(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:nColors color_markers(count,1)= mean2(a(sample_regions(:,:,count)));%a均值 color_markers(count,2)= mean2(b(sample_regions(:,:,count)));%b均值 end disp(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

文档评论(0)

153****9595 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档