Retinex 算法

目录

1、Retinex 理论及数学模型

2、Retinex 算法发展历程

2.1 基于迭代的 Retinex 算法

2.1.1 Frankle-McCann Retinex 算法

2.1.2 McCann99 Retinex 算法

2.2 基于中心环绕的 Retinex 算法 

2.2.1 SSR算法(单尺度)

2.2.2 MSR算法(多尺度)

2.2.3 MSRCR算法

2.3 Retinex算法的频域处理


1、Retinex 理论及数学模型

Retinex 理论指出,入射光决定了一副图像中的所有像素点的动态范围的大小,而物体自身所固有不变的反射系数决定了图像的内在固有属性。也就是说,我们所看到的图像是照射光根据物体的反射系数所反射的光线形成的,如图所示。很显然,如果把一幅图像看作是由照射光和反射光组成的话,Retinex 图像增强的基本思想就是去除照射光的影响,保留物体自身的反射属性。

 

核心:从S图像中估测L分量,并去除L分量,得到原始反射分量R

retina(视网膜) + cortex(皮层) —— Retinex

提出者:埃德温·赫伯特·兰德 —— Polaroid(宝丽来)

Retinex百度百科RETINEX_百度百科

2、Retinex 算法发展历程

2.1 基于迭代的 Retinex 算法

2.1.1 Frankle-McCann Retinex 算法

基本原理:
Frankle-McCann 算法采用了一种新的基于螺旋结构的迭代分段线性比较路径,螺旋结构路径像素点间的比较是一个由远到近的比较过程,在进行完一次比较之后,下一次的做比较的两个像素点间的间距缩短为上一次比较间距的一半,并且比较路径的方向同时也按顺时针方向发生转变,就这样逐次比较直至像素点间距为 1 为止。

Frankle-McCann Retinex 算法步骤 :
(1)数据的前期转换
        把原图像的像素值由整数域转到对数域,减少后续算法的运算量
        对于彩色图像要先分解为R.G.B三幅灰度图再转换
        因为RGB图像的像素值是
(0,255),在做对数运算时为避免负值的出现,可以将原图像像素值整体加 1,即s (x, y) = log(1+S (x, y))
(2)初始化一个与原图像 S(x,y)同样大小的常数为 t 的矩阵
        m*n的图像,则矩阵包含m*n个t,保证每个像素点都进行一次迭代。
        t是原图像亮度的均值,

(3)求解 S = 2P的值,P=fix[log2 min(m, n)-1]
        S是目标点与两个比较点之间的最大距离
(4)计算路径上的像素点
假设 rn (x,y)是上一次迭代的结果,将此次迭代差值累加保存到相应的 rn (x,y)位置中,最终得到此次的迭代结果,然后再对两者做一个平均,最后得到输出结果。l是目标点在此路径上的亮度

     

(5)令S=-S/2
        每下一步的两个比较点与目标点的间距缩短为上一步的一半,同时方向按顺时针改变,即S=-S/2
(6)重复3.4.5三个步骤直到|S|<1
(7)迭代n次,也就是重复3.4.5.6四个步骤n次
        每次迭代选取不同的初始比较点
(8)线性拉伸,彩色图像还需要三个通道的合成,然后输出显示
经过像素间的比较校正 n 次迭代之后,输出结果是以初始化值 t中心,集中分布在 t 附近的一系列的浮点数。也就是说原图像的数据经过迭代后起到了压缩的效果,因此需要对迭代结果做线性拉伸处理,提高图像对比度。通常采用的 8 bit 图像的动态范围值是 0 255,拉伸公式:

 其中maxmin分别是迭代结果的最大和最小值,R(x,y)是最终的增强结果。

2.1.2 McCann99 Retinex 算法

 

基本原理:
提出了一种金字塔比较模型,由金字塔顶端到底端分辨率由低到高,依次逐层迭代。这种采用分辨率由低到高的迭代方法可以有效减少算法的运算量,节约算法的执行时间。

算法步骤:
1) 将原图像变换到对数域S;
2) 初始化(计算图像金字塔层数;初始化常数图像矩阵R作为进行迭代运算的初始值);
3) 从顶层开始,到最后一层进行8邻域比较运算,运算规则与MccCann Retinex算法相同;
4) 第n层运算结束后对第n层的运算结果进行插值,变成原来的两倍,与n+1层大小相同;
5) 当最底层计算完毕得到的即最终增强后的图像。

局限性:
读取图像的尺寸必须符合2的整数次幂,即图像长宽可表示为(col*2^n)*(row*2^n)
Col必须大于row ,并且属于集合{1,2,3,4,5}

改进算法:

适用于各种尺寸的图像,保持扩展后的图像与原图的一致性,尽量避免扩展像素点对原图的干扰,采取只对图像边界扩展的方法。

基于迭代的 Retinex 算法总结:

迭代次数对算法的影响:
算法的执行时间随着迭代次数 n 取值变大而增加
n 取 5 到 8 之间能同时兼顾图像质量和计算速度

优点:
颜色恒常性、动态范围压缩大(像素点丰富)、色彩逼真度高(图像高保真)

缺点:
增强后的图像存在“光晕”现象,即在图像色彩交界处渐变
光晕缺陷同样也存在于其他 Retinex算法之中

2.2 基于中心环绕的 Retinex 算法 

基于路径比较的 Retinex 算法和 McCann 算法,像素点之间亮暗关系的比较路径实质上都是一维的,一维路径的比较方法不论在效率上还是在准确性上都有较大的缺陷。为了更加准确地估计出图像的照射分量,1986 年Land 在分析一维路径缺陷的基础上对算法做了改进,用二维区域内像素比较来取代一维路径比较,提出了基于二维路径比较的 Retinex 算法,经过后续发展之后就是我们现在所熟知的基于中心环绕的 Retinex 算法。

2.2.1 SSR算法(单尺度)

基本理论:
在计算图像中目标像素点的灰度值时,是通过以目标点为中心的区域内的像素值的加权得到的,权重的比例大小则是由环绕函数(高斯函数)来确定。

σ 越小,高斯模型会变得越尖锐,目标像素点受到周围像素影响的范围就越小;
σ 越大,则高斯模型会变得越平缓,目标像素点受到周围像素影响的范围就越大。
SSR算法σ 一般取80-100

SSR算法步骤:


2.2.2 MSR算法(多尺度)

基本理论:
采用几个不同大小的尺度参数对R.G.B三个分量分别单独做滤波后再线性加权归一化就得到了MSR算法。

MSR算法步骤:


同样在这里,对于灰度图像来说,直接对灰度值做上述步骤处理即可;对于彩色图像来说,可以将图像分解为 R、G、B 三副灰度图分别进行以上步骤处理,然后再合成彩色图像。

2.2.3 MSRCR算法

MSRCR 算法在 MSR 算法的基础上增加了一个色彩恢复的步骤
利用彩色图像的各个色彩通道间的比例关系,较好地解决了颜色恒常性的问题

2.3 Retinex算法的频域处理

SSR、MSR、MSRCR 算法都需要用高斯核对图像进行卷积计算,所有算法都要进行下式的计算

在时域中卷积,特别是对于大尺度 σ 时,需要进行的计算量过大,耗时过长。

卷积定理:时域中卷积相当于频域中乘积

假设一个序列的长度为 m,那么此序列做卷积运算是的运算复杂度是 O(m*m);如果将序列做快速傅里叶变换转换到频域再做乘积运算则运算复杂度降低为O(m*logm)。也就是说将计算搬移到频域,卷积计算变成乘法计算,计算量将会大大下降。式 3-13 可以简化为 

在做图像增强之前,首先需要对原图像和高斯核做二维离散傅里叶变换

  • 32
    点赞
  • 262
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: Retinex是一种图像处理算法,用于调整图像的亮度和对比度,以便更好地还原图像的细节和颜色。Matlab是一种用于科学和工程计算的编程语言和环境。因此,Retinex Matlab就是使用Matlab编程语言和环境来实现Retinex算法。 Retinex算法是基于人眼的颜色感知原理和图像感知机制来设计的。它通过模拟人眼对光照条件的自适应调整,提高图像的亮度平衡和对比度,使图像更加鲜明和清晰。这一算法主要包括两个步骤:反射建模和增益调整。 在Matlab中实现Retinex算法可以通过以下步骤进行: 1. 读取图像:使用Matlab内置的图像处理函数读取待处理的图像。 2. 反射建模:使用Retinex算法的原理,对图像进行反射分解,得到反射图像。 3. 增益调整:根据反射图像的亮度分布,对图像进行增益调整,使其与原始图像更加一致。 4. 合成图像:将调整后的反射图像与原始图像的低频分量合成,得到最终的Retinex处理后的图像。 5. 显示和保存图像:使用Matlab的图像处理函数进行图像的显示和保存。 通过使用Matlab编程语言和环境实现Retinex算法,可以方便地对图像进行处理,并且可以根据需要进行参数调整和算法优化,以获得更好的图像处理效果。同时,Matlab还提供了丰富的图像处理函数和工具箱,可以进一步完善和扩展Retinex算法的应用。 ### 回答2: Retinex是一种图像增强算法,用于改善图像的亮度、对比度和饱和度。通过模拟人类视觉的色彩感知机制,Retinex算法可以校正图像中的光照变化,使得图像看起来更加真实和清晰。 Matlab是一种常用的计算机编程语言和环境,可用于图像处理和分析。在Matlab中,有许多函数和工具箱可以用于实现Retinex算法。 Retinex算法的主要思想是分解图像的亮度和色彩两个分量,并根据亮度分量的比率调整色彩分量,以消除光照变化。在Matlab中,可以使用图像处理工具箱中的一些函数来实现这一思想,例如imadjust函数可以用于对图像进行亮度调整,histeq函数可以用于直方图均衡化,adapthisteq函数可以用于自适应直方图均衡化。 此外,还可以使用Matlab中的滤波函数来实现Retinex算法,例如高斯滤波函数可以用于图像平滑,中值滤波函数可以用于去除图像中的噪声。通过滤波处理,可以减小图像中的光照变化,从而提高图像的质量。 总的来说,Retinex算法可以通过Matlab来实现,利用Matlab的图像处理函数和滤波函数,可以对图像进行增强,提高图像的质量和视觉效果。 ### 回答3: Retinex算法是一种用于图像增强和颜色恢复的算法。它的目标是通过模拟人眼感知机制来调整图像的亮度和颜色平衡,使图像更加清晰和自然。 在Matlab中,可以使用Retinex算法来处理图像。首先,需要将图像转换为灰度图像,然后计算图像的对数域表示。接下来,对图像进行滤波操作,将低频部分进行平滑处理。然后,将原始图像与滤波后的图像相除,得到一个比例因子。最后,通过将比例因子应用于原始图像,即可得到经过Retinex算法增强的图像。 在Matlab中,可以使用imread函数读取图像,然后使用rgb2gray函数将图像转换为灰度图像。接下来,使用log函数计算图像的对数域表示。然后,可以使用imfilter函数对图像进行滤波操作,例如使用高斯滤波器进行平滑处理。之后,可以使用./运算符将原始图像与滤波后的图像相除,得到比例因子。最后,可以使用im2uint8函数将图像数据类型转换为uint8,并使用imshow函数显示经过Retinex算法处理后的图像。 总之,通过在Matlab中使用Retinex算法,可以对图像进行增强和颜色恢复,使图像的亮度和颜色平衡更加自然和清晰。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值