低亮度图片增强方法:基于相机相应模型的低亮度图片增强算法

这篇博客介绍一篇基于相机相应模型的低亮度图片增强算法:

  • A New Low-Light Image Enhancement Algorithm using Camera Response Model (CRM)

这篇文章指出,对于相机拍摄到的图片而言,其像素值并非是正比于物体反射的亮度值。对于从相机感光元件感受到的亮度值到图像实际像素值之间的非线性变换函数,称之为相机响应函数(camera response function, CRF)。

这篇文章:

  • 首先通过分析不同曝光度的图片之间的关系得到一个相机响应模型
  • 然后利用图片亮度分量估计方法得到图像的曝光比图(exposure ratio)
  • 最后使用相机相应模型和曝光比图来对低亮度图片进行增强。

相机响应模型

将相机响应模型定义为:

\mathbf{P}=f(\mathbf{E})

其中 \mathbf{E}是图片的辐照度,\mathbf{P}是图片的像素值。

f应当满足:
\mathcal{F} :=\{f | f(0)=0, f(1)=1, x>y \Leftrightarrow f(x)>f(y)\}

文章使用亮度变换函数(brightness transform function, BTF)来估计f。BTF是一个对于相同场景但是曝光度不同的两幅图之间的映射函数:

\mathbf{P}_{1}=g\left(\mathbf{P}_{0}, k\right)
其中\mathbf{P}_{1}\mathbf{P}_{0}是同一场景下不同曝光程度的图像,k为曝光比。

则CRM可以由下式计算得到:
g(f(\mathbf{E}), k)=f(k \mathbf{E})

  • 估计BTF


通过比较相同从场景下不同曝光程度的两幅图的直方图,可以用以下的函数来描述BTF:

\mathbf{P}_{1}=g\left(\mathbf{P}_{0}, k\right)=\beta \mathbf{P}_{0}^{\gamma}
其中\beta\gamma是由相机参数和曝光比决定的参数。

  • 估计CRM

    f(k E)=\beta f(E)^{\gamma}
    可解得:
    f(E)=\left\{\begin{array}{ll}{e^{b\left(1-E^{a}\right)},} & {\text { if } \gamma \neq 1} \\ {E^{c},} & {\text { if } \gamma=1}\end{array}\right.
    \gamma \neq 1时:
    a=\log _{k} \gamma, \quad b=\frac{\ln \beta}{1-\gamma}
    \gamma=1时:
    c=\log _{k} \beta
    在大多数情况,仅考虑当\gamma \neq 1的情形。

文章中有比较该CRM模型相比于其他模型的优势,这里不做详述。

  • 参数求解
    由上式:
    \beta=e^{b\left(1-k^{a}\right)}, \quad \gamma=k^{a}
    对于给定的相机,其CRM是固定的,参数ab也是固定的。对于给定的输入图片\mathbf{P}_{0}和任意的的曝光比k_{x},我们可以得到相应的图片\mathbf{P}_{*}:
    g\left(\mathbf{P}_{0}, k_{*}\right)=\mathbf{P}_{*}=\beta_{*} \mathbf{P}_{0}^{\gamma_{*}}=e^{b\left(1-k_{*}^{a}\right)} \mathbf{P}_{0}^{\left(k_{*}^{a}\right)}

图像的亮度增强

基于Retinex理论:
\mathbf{E}=\mathbf{R} \circ \mathbf{T}
其中,\mathbf{R}\mathbf{T}分别对应图片的反射图和亮度图。

这里,考虑\mathbf{R}作为理想亮度下的图像。

当考虑到相机相应模型时,有:

\mathbf{P}=f(\mathbf{E}), \quad \mathbf{P}^{\prime}=f(\mathbf{R})

其中\mathbf{P}是实际该分解的图像,\mathbf{P}^{\prime}是实际理想亮度下的图像。

则:
\mathbf{P}^{\prime}=f(\mathbf{R}) = f(\mathbf{E} \circ(\mathbf{1} \oslash \mathbf{T})) = g(f(\mathbf{E}), \mathbf{1} \oslash \mathbf{T})=g(\mathbf{P}, \mathbf{1} \oslash \mathbf{T})

则可以发现\mathbf{T}\mathbf{K}之间的关系:
\mathbf{K}=1 \oslash \mathbf{T}

  • 图像亮度分量的估计
    这篇文章借鉴了Lime: Low-light image enhancement
    via illumination map estimation文章中求取亮度图的方法:
    初始亮度图:
    \mathbf{L}(x)=\max _{c \in\{R, G, B\}} \mathbf{P}_{c}(x)
    作者设计了新的权重函数:
    \mathbf{W}_{d}(x)=\frac{1}{\left|\sum_{y \in \omega(x)} \nabla_{d} \mathbf{L}(y)\right|+\epsilon}, \quad d \in\{h, v\}
    目标函数可写为:
    \min _{\mathbf{T}} \sum_{x}\left((\mathbf{T}(x)-\mathbf{L}(x))^{2}+\lambda \sum_{d \in\{h, v\}} \frac{\mathbf{W}_{d}(x)\left(\nabla_{d} \mathbf{T}(x)\right)^{2}}{\left|\nabla_{d} \mathbf{L}(x)\right|+\epsilon}\right)
    具体求解过程不做详解,可参见原文和LIME的文章。

则可得到曝光比图:
\mathbf{K}(x)=\frac{1}{\max (\mathbf{T}(x), \epsilon)}

最后,基于相机相应模型的低亮度增强算法可由下式计算得到:
\mathbf{P}_{c}^{\prime}(x)=e^{b\left(1-\mathbf{K}(x)^{a}\right)} \mathbf{P}_{c}(x)^{\left(\mathbf{K}(x)^{a}\right)}

文章中设置(a=-0.3293, b=1.1258)

算法实现

https://github.com/baidut/OpenCE

增强效果

低亮度图片
增强后的效果图

参考文献

  1. https://ieeexplore.ieee.org/document/8265567
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容