引入HSI彩色模型与RGB转HSI?

发布时间:2020-09-16 23:18:05 作者:Joe科技
来源:网络 阅读:7970

1.为什么要引入HSI彩色模型?

        简单的来说,RGB模型可以很好的适应颜色的事实,但是并不能很好的适应人解释的颜色。当人观察一个彩色物体时候,我们用色调(Hue),饱和度(Saturation )和强度(Intensity)来描述。

        色 调:是指一种纯色的颜色属性,(色调与波长有关,是人对不同颜色的感受);

        饱和度:是指纯色被白光稀释的程度的度量,(饱和度越大越鲜艳);

        亮 度:是一个主观因子,实际上是不可度量的,(亮度和图像灰度是颜色的明亮程度)。

总体来说,RGB模型更适合图像颜色生成,而HSI模型适合图像描述。

2.从RGB转化到HSI

RGB模式的分量是一个正方体上的单元定义的,而HSI模型是定义在如下的一个颜色三角形中。

对于一副三原色RGB 彩×××像,每个RGB像素可用如下公式求HSI分量:


引入HSI彩色模型与RGB转HSI?

HSI色彩空间模型:

引入HSI彩色模型与RGB转HSI?

3、补充:HSV色彩空间常用

引入HSI彩色模型与RGB转HSI?引入HSI彩色模型与RGB转HSI?

代码1-1-1:HSV通道分离


//转换成HSV (这里貌似转成HSV了)
cv::Mat img_h, img_s, img_v, imghsv;
std::vector<cv::Mat> hsv_vec;
cv::cvtColor(srcImage,imghsv, CV_BGR2HSV);
cv::imshow("hsv",imghsv);
cv::waitKey(0);


//分割HSV通道
cv::split(imghsv,hsv_vec);
img_h=hsv_vec[0];
img_s=hsv_vec[1];
img_v=hsv_vec[2];


//转换通道数据类型
img_h.convertTo(img_h,CV_32F);
img_s.convertTo(img_s,CV_32F);
img_v.convertTo(img_v,CV_32F);


//计算每个通道的最大值
double max_h,max_s,max_v;
cv::minMaxIdx(img_h,0,&max_h);
cv::minMaxIdx(img_s,0,&max_s);
cv::minMaxIdx(img_v,0,&max_v);


//各个通道归一化
img_h /=max_h;
img_s /=max_s;
img_v /=max_v;


总结:通过公式分别计算出H、S、I分量以得到图像。对上述图像(汽车车牌识别)分析可得,相比原始的RGB图像,HSI图像对颜色信息的利用率更高,更适合于目标分析目标分割等场景。

推荐阅读:
  1. ARGB转RGB,RGB、ARGB转10进制数方法
  2. tensorflow模型如何转ncnn

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

图像处理 opencv rgb

上一篇:ManageEngine-ADAudit-Plus-6-x6

下一篇:Go语言利用time.After实现超时控制的方法详解

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》