RGB图像归一化
2015-07-18 22:44
330 查看
通过对图像的RGB色彩空间进行归一化处理,在某些情况下是去除光照和阴影影响的一种简单和有效的方法。
假设RGB代表原图像某点的像素值,rgb表示归一化之后的值,则
r = R / (R+G+B);g = G / (R+G+B);b = B / (R+G+B);
实现归一化RGB的方法如下:
// 对输入的原始RGB图像获取对应的归一化图像
IplImage* NormalizeImage(IplImage *img)
{
1、创建归一化的图像;
IplImage* imgavg = cvCreateImage(cvGetSize(img), 8, 3);
2、获取图像高度和宽度信息,设置epslon的目的是防止除0的操作产生;
int width = img->width;int height = img->height;int redValue, greenValue, blueValue;double sum, epslon = 0.000001;
3、计算归一化的结果,并替换掉原像素值;
for (int y = 0; y < height; y++) {for (int x = 0; x < width; x++) {
CvScalar src = cvGet2D(img, y, x);redValue = src.val[0];greenValue = src.val[1];blueValue = src.val[2];// 加上epslon,为了防止除以0的情况发生 sum = redValue + greenValue + blueValue + epslon;CvScalar des = cvScalar(redValue / sum * 255, greenValue
/ sum * 255, blueValue / sum * 255, src.val[4]);cvSet2D(imgavg, y, x, des);
}}
4、返回归一化后的图像;
return imgavg;
}
注意:归一化之后的图像仅使用两个字节便可以表示一个像素值,
r = R/(R+G+B)
g = G/(R+G+B)
b = B/(R+G+B)
b可以表示为:b = 1-R’-G’
物理上,这种变换方式从图像上移除了光照的信息。
假设RGB代表原图像某点的像素值,rgb表示归一化之后的值,则
r = R / (R+G+B);g = G / (R+G+B);b = B / (R+G+B);
实现归一化RGB的方法如下:
// 对输入的原始RGB图像获取对应的归一化图像
IplImage* NormalizeImage(IplImage *img)
{
1、创建归一化的图像;
IplImage* imgavg = cvCreateImage(cvGetSize(img), 8, 3);
2、获取图像高度和宽度信息,设置epslon的目的是防止除0的操作产生;
int width = img->width;int height = img->height;int redValue, greenValue, blueValue;double sum, epslon = 0.000001;
3、计算归一化的结果,并替换掉原像素值;
for (int y = 0; y < height; y++) {for (int x = 0; x < width; x++) {
CvScalar src = cvGet2D(img, y, x);redValue = src.val[0];greenValue = src.val[1];blueValue = src.val[2];// 加上epslon,为了防止除以0的情况发生 sum = redValue + greenValue + blueValue + epslon;CvScalar des = cvScalar(redValue / sum * 255, greenValue
/ sum * 255, blueValue / sum * 255, src.val[4]);cvSet2D(imgavg, y, x, des);
}}
4、返回归一化后的图像;
return imgavg;
}
注意:归一化之后的图像仅使用两个字节便可以表示一个像素值,
r = R/(R+G+B)
g = G/(R+G+B)
b = B/(R+G+B)
b可以表示为:b = 1-R’-G’
物理上,这种变换方式从图像上移除了光照的信息。
相关文章推荐
- .Net知识点(基础加强)
- 【linux下编程】MakeFile
- 所闻所获2:使用块回调来实现代理的功能
- 集合特点
- iOS 阶段学习第25天笔记(iOS沙盒机制介绍)
- 反射
- brophp写商品管理模块
- Karatsuba Multiplication
- phper談談最近重構代碼的感受(2)
- Android问题集锦之二十八:You need to use a Theme.AppCompat theme (or descendant) with this activity.
- JAVA爬虫WebCollector
- [LeetCode]Intersection of Two Linked Lists
- finally代码块中的代码什么时候执行
- UEFI简单的应用程序模块MyHelloWorld:C源文件/INF工程文件源码/简析[6]
- ACM--Entrophy(优先队列建树+哈希)
- Java数据结构-线性表之单链表LinkedList
- 参数类型对java用继承实现多态时的影响
- hdu 5285 wyh2000 and pupil
- 浅谈跨域请求
- 颜色的原理,三基色原理以及HLS(色相、亮度、饱和度)原理