opencv 一种不均匀光照的补偿方法
来源:互联网 发布:c语言实现文件复制传输 编辑:程序博客网 时间:2024/04/29 23:40
如果一张图片中,光照不均匀,使用全局阈值时,就无法达到想要的阈值化效果。因此,不均匀光照的补偿算法研究,具有一定的意义。
当然,不均匀光照的补偿方法有很多,本文只是记录其中一种,具体效果如何,实际价值如何,还有待验证。希望看到此博文的读者,对不均匀光照有深入研究的,可以一起交流。
其主要思路为:
1、求取源图I的平均灰度,并记录rows和cols;
2、按照一定大小,分为N*M个方块,求出每块的平均值,得到子块的亮度矩阵D;
3、用矩阵D的每个元素减去源图的平均灰度,得到子块的亮度差值矩阵E;
4、用双立方差值法,将矩阵E差值成与源图一样大小的亮度分布矩阵R;
5、得到矫正后的图像result=I-R;
好了,下面是opencv实现的代码部分。其中blockSize建议取值32,当然其他值也可以试下效果
void unevenLightCompensate(Mat &image, int blockSize){if (image.channels() == 3) cvtColor(image, image, 7);double average = mean(image)[0];int rows_new = ceil(double(image.rows) / double(blockSize));int cols_new = ceil(double(image.cols) / double(blockSize));Mat blockImage;blockImage = Mat::zeros(rows_new, cols_new, CV_32FC1);for (int i = 0; i < rows_new; i++){for (int j = 0; j < cols_new; j++){int rowmin = i*blockSize;int rowmax = (i + 1)*blockSize;if (rowmax > image.rows) rowmax = image.rows;int colmin = j*blockSize;int colmax = (j + 1)*blockSize;if (colmax > image.cols) colmax = image.cols;Mat imageROI = image(Range(rowmin, rowmax), Range(colmin, colmax));double temaver = mean(imageROI)[0];blockImage.at<float>(i, j) = temaver;}}blockImage = blockImage - average;Mat blockImage2;resize(blockImage, blockImage2, image.size(), (0, 0), (0, 0), INTER_CUBIC);Mat image2;image.convertTo(image2, CV_32FC1);Mat dst = image2 - blockImage2;dst.convertTo(image, CV_8UC1);}效果图展示如下:
0 0
- opencv 一种不均匀光照的补偿方法
- 不均匀光照的二值化方法(去阴影、去曝光)
- opencv之光照补偿和去除光照
- 《光照不均匀图像的灰度波动局部阈值分割》opencv编码实现
- 不均匀光照文本图像的二值化
- 不均匀光照文本图像的二值化
- 不均匀光照文本图像的二值化
- 不均匀光照二值化算法 sauvola
- 光照补偿问题解决办法
- 图像预处理-光照补偿
- 同态滤波用于光照不均匀校正
- 一种VS2010配置OPENCV的方法
- 一种简单的OpenCV配置方法
- opencv 一种图像加密的方法
- PMAC 误差补偿的方法及步骤
- 光照不均匀图像分割技巧1——分块阈值
- 去光照不均匀matlab 算法和代码放出
- VisualStudio2010配置OpenCV的一种一劳永逸的方法
- H5 微信开发 小bug
- Eclipse alt+/代码提示不好用的解决方法
- 解决jsp页面取出的数据乱码
- androoid framework学习之 - InCallUI中CallButton界面更新介绍(audioButton等)
- 使用idea创建springboot项目并打成war包发布到weblogic上
- opencv 一种不均匀光照的补偿方法
- C语言 system函数
- python爬取历史天气数据
- rac 环境下增加控制文件
- butterknife 8.4.0
- zookeeper实现分布式锁
- android权限(permission)大全
- Android 异步加载图片,使用LruCache和SD卡或手机缓存,效果非常的流畅
- 智和网管平台SugarNMS能源行业综合网管解决方案