文章目录

  • 1 使用场景
  • 2 原理
  • 3 实现步骤
  • 4 实现
  • 5 效果

1 使用场景

当一张图片出现过亮或者过暗的时候导致图像对比度较差,可以使用Gamma校正来处理

2 原理


如上图所示,为函数 f(I)=Iγf(I) = I^γf(I)=Iγ的曲线表示:
当γ<1γ<1γ<1时,为图中上方的虚线曲线,图中γ=1/2.2γ=1/2.2γ=1/2.2
当γ=1γ=1γ=1时,为图中间的直线,也就是f(I)=If(I)=If(I)=I
当γ>1γ>1γ>1时, 为图中下方的曲线实线,图中γ=2.2γ=2.2γ=2.2

当γ!=1γ!=1γ!=1时,会将对I进行非线性的变换,对0,1两端的变换最小,对中间的变换最大。如果把图像0-255像素值,归一化到0-1, 带入进来,通过该变换,则可达到一定的效果:
1)当γ<1γ<1γ<1时,图像中最亮(1)或者最暗(0)的像素保持不变,整体亮度会发生提升,像素值中间的部分效果最明显,用来处理比较暗的图片非常好
2)当γ>1γ>1γ>1时,图像中最亮(1)或者最暗(0)的像素保持不变,整体亮度会发生降低,像素值中间的部分效果最明显,用来处理比较亮的图片非常好

最后x255即可

3 实现步骤

假设图像中有一个像素,值是 200 ,那么对这个像素进行校正必须执行如下步骤:

1. 归一化 :将像素值转换为 0 ~ 1 之间的实数。 算法如下 : ( i + 0. 5)/256 这里包含 1 个除法和 1 个加法操作。对于像素 A 而言 , 其对应的归一化值为 0. 783203 。

2. 预补偿 :根据公式 , 求出像素归一化后的 数据以 1 /gamma 为指数的对应值。这一步包含一个 求指数运算。若 gamma 值为 2. 2 , 则 1 /gamma 为 0. 454545 , 对归一化后的 A 值进行预补偿的结果就 是 0. 783203 ^0. 454545 = 0. 894872 。

3. 反归一化 :将经过预补偿的实数值反变换为 0 ~ 255 之间的整数值。具体算法为 : f*256 - 0. 5 此步骤包含一个乘法和一个减法运算。续前 例 , 将 A 的预补偿结果 0. 894872 代入上式 , 得到 A 预补偿后对应的像素值为 228 , 这个 228 就是最后送 入显示器的数据。

如上所述如果直接按公式编程的话,假设图像的分辨率为 800*600 ,对它进行 gamma 校正,需要执行 48 万个浮点数乘法、除法和指数运算。效率太低,根本达不到实时的效果。

针对上述情况,提出了一种快速算法,如果能够确知图像的像素取值范围 , 例如 , 0 ~ 255 之间的整数 , 则图像中任何一个像素值只能 是 0 到 255 这 256 个整数中的某一个 ; 在 gamma 值 已知的情况下 ,0 ~ 255 之间的任一整数 , 经过“归一 化、预补偿、反归一化”操作后 , 所对应的结果是唯一的 , 并且也落在 0 ~ 255 这个范围内。

如前例 , 已知 gamma 值为 2. 2 , 像素 A 的原始值是 200 , 就可求得 经 gamma 校正后 A 对应的预补偿值为 228 。基于上述原理 , 我们只需为 0 ~ 255 之间的每个整数执行一次预补偿操作 , 将其对应的预补偿值存入一个预先建立的 gamma 校正查找表 (LUT:Look Up Table) , 就可以使用该表对任何像素值在 0 ~ 255 之 间的图像进行 gamma 校正。

4 实现

#include <iostream>
#include <opencv2/opencv.hpp>using namespace cv;
Mat gammaTransform(Mat &srcImage, float kFactor)
{unsigned char LUT[256];for (int i = 0; i < 256; i++){float f = (i + 0.5f) / 255;f = (float)(pow(f, kFactor));LUT[i] = saturate_cast<uchar>(f*255.0f - 0.5f);}Mat resultImage = srcImage.clone();if (srcImage.channels() == 1){MatIterator_<uchar> iterator = resultImage.begin<uchar>();MatIterator_<uchar> iteratorEnd = resultImage.end<uchar>();for (; iterator != iteratorEnd; iterator++){*iterator = LUT[(*iterator)];}}else{MatIterator_<Vec3b> iterator = resultImage.begin<Vec3b>();MatIterator_<Vec3b> iteratorEnd = resultImage.end<Vec3b>();for (; iterator != iteratorEnd; iterator++){(*iterator)[0] = LUT[((*iterator)[0])];//b(*iterator)[1] = LUT[((*iterator)[1])];//g(*iterator)[2] = LUT[((*iterator)[2])];//r}}return resultImage;
}

5 效果

老胡拉来尝试一把:

γ=1/2.2γ=1/2.2γ=1/2.2 的提亮效果

图像处理算法之Gamma校正相关推荐

  1. gama校正算法matlab,Gamma校正及其FPGA实现(一)

    最近在做一个千兆以太网传输的项目,里面用到了Gama校正算法,本来想使用Altera 的IP核Gamma Corrector,但Quartus16.0把Gamma Corrector的IP核集成到了Q ...

  2. 古老的基于亮度平均值的自动Gamma校正算法。

    本篇博文来自博主Imageshop,更多内容可以移步至Imageshop查看. 转载自:https://www.cnblogs.com/Imageshop/p/13380028.html 侵删 在gi ...

  3. 【图像处理】——图像的灰度化处理(Python实现三种方法——最大值法、平均值法、加权均值法、gamma校正)

    目录 一.什么是图像的灰度化? 二.灰度化的几种方法(最大值法.平均值法.加权均值法.gamma校正) 1.直接调用函数:cv2.cvtColor() 图像颜色空间转换 2.最大值法 (1)概念 (2 ...

  4. 【图像处理】gamma校正通俗解释及python实现(替代matlab imadjust)

    Motivation 之前把matlab代码转python的时候转过这个函数.最近自己动手发现还会用到,遂贴上来方便有需要的朋友们自取. Gamma校正(gamma correction) 一句话解释 ...

  5. 图像处理之Gamma校正

    基于查找表的快速Gamma校正 在图像预处理中经常通过Gamma校正实现像素修正,常见的Gamma校正是按照公式 对每个像素进行校正,这样做对一张图片还好,当你有大量图片需要做相同处理的时 候计算量就 ...

  6. 在OpenCV环境下对图像做Gamma校正

    什么是Gamma校正? Gamma校正是对输入图像灰度值进行的非线性操作,使输出图像灰度值与输入图像灰度值呈指数关系. 上面中的指数γ即为Gamma. 经过Gamma校正后的输入和输出图像灰度值关系如 ...

  7. gamma校正到底是个什么玩意儿

    一. 在哪见过.听说过Gamma? * 还用说,Adobe Gamma * 常听说MAC的默认Gamma是1.8,PC的是2.2 * 我的显卡驱动程序里有Gamma调节 * 我下载了一个软件,也可以调 ...

  8. 一种基于分段线性插值的Gamma校正硬件实现

    一种基于分段线性插值的Gamma校正硬件实现 以下gamma校正内容摘自<视频信号预处理IP的硬件实现和软件验证>电子科技大学 徐琦 GAMMA 曲线校正(Gamma Correction ...

  9. 【CV春季划】170分钟学习OpenCV与经典图像处理算法基础

    本次给大家带来的是有三AI-CV春季划组OpenCV与经典图像处理算法的直播回放,如果你还不知道有三AI-CV春季划是什么,可以看下面的视频和图文. 点击边框调出视频工具条 [CV春季划]言有三手把手 ...

最新文章

  1. 优先深度搜索判断曲线相交_程序员必知的十大基础实用算法之-DFS(深度优先搜索)...
  2. html5模拟keyup事件
  3. 大数据时代的创新者们
  4. Redhat 打开防火墙某个端口
  5. 科大星云诗社动态20210315
  6. java 主题爬虫_主题爬虫 - 长颈鹿Giraffe - 博客园
  7. HDLBits答案(19)_Verilog有限状态机(6)
  8. Linux学习笔记7
  9. python从入门到放弃pdf下载-Python从入门到放弃(一): Python下载及打开世界之窗...
  10. 测试ai模糊软件,“马赛克视频”AI还原软件被疯传!测试效果出乎意料!
  11. 解决Edge不兼容onpropertychange的方法
  12. 模拟人生4极乐净土mod_如何在《模拟人生4》中下载Mod
  13. 安装已经下载好的whl文件
  14. 一款表达谱数据分析的神器--CCLE--转载
  15. CSS水平居中与垂直居中
  16. 致終將失去的手机形态
  17. springboot定义全局异常处理类GlobalExceptionHandler
  18. php 失去焦点,对象失去焦点时自己动提交数据的实现代码
  19. JVM内存分析工具JProfiler的简单使用
  20. ubuntu16.04 自定义fctix输入法

热门文章

  1. RHCE7 试题 linux 公社,全面分析RHCE7(红帽认证工程师)考试题目之 ----Samba文件共享篇...
  2. FL Studio中的音源分类
  3. 【学习笔记】【计算机网络【总】】物理层;链路层;网络层;传输层;应用层;详解
  4. RabbitMQ安装 win
  5. 春节7日高赞视频的背后,是怎样的节日流量收割秘籍?
  6. VC++6.0显示cannot compile the file***:no compile tool is associated with ....或者cannot execute program
  7. 2022-2028全球与中国液流电池储能系统市场现状及未来发展趋势
  8. 3Dmax人物建模入门教程教学- 头部制作
  9. java连oracle代码,连oracle
  10. 如何成为自学成才的PYTHON后端开发人员?