【ISP】基于暗通道先验改进的红外图像透雾

一、基于暗通道先验改进的灰度图像增强

短波中波红外图像对比度低层次感差,分辨率小导致视觉模糊,本文将暗通道先验应用于红外图像增强,改善红外图像低对比度问题。重点应用在室外观测实景

二、可见光RGB图像的暗通道先验透雾

可见光图像暗通道透雾算法是由何凯明提出,他把无雾图像划分为较小的图像区域,发现每个区域内都存在一些颜色通道非常低的值,几乎接近于 0,因此把趋于 0 的颜色通道称之为暗通道。暗通道先验基于可见光RGB图像的统计规律:无雾图像中,局部区域至少一个通道像素值极低(趋近0)

暗通道算法不适合含有天空、镜面反射物体的场景

2.1 可见光暗通道计算

在RGB通道选择一个数值最小的通道作为暗通道数据

I dark ( x ) = min ⁡ c ∈ { r , g , b } ( min ⁡ y ∈ Ω ( x ) I c ( y ) ) I^{\text{dark}}(x)=\min_{c\in\{r,g,b\}}\left(\min_{y\in\Omega(x)}I^c(y)\right) Idark(x)=c∈{r,g,b}min(y∈Ω(x)minIc(y))

其中 J C J^C JC是不同色彩通道, Ω ( x ) \Omega(x) Ω(x)是以当前像素x为中心的窗口(3×3滑窗),y是滑窗内的邻域像素

2.2 透射率计算

t ( x ) = 1 − ω ∗ I d a r k ( y ) A t(x)=1−\omega *\frac{I^{dark}(y)}{A} t(x)=1−ω∗AIdark(y)

ω \omega ω为去雾强度,通常常取 0.95

2.3 透雾图像恢复

J ( x ) = I ( x ) − A m a x ( t ( x ) , t 0 ) + A J(x)=\frac{I(x)−A}{max(t(x),t0)}+A J(x)=max(t(x),t0)I(x)−A+A

t0​为透射率下限,避免除零

三、红外灰度图像的暗通道先验透雾

3.1 灰度图像DCP

红外图像为单通道数据,将局部最小滤波替代三通道最小,提取暗通道图。

I dark ( x ) = min ⁡ y ∈ Ω ( x ) I ( y ) I^{\text{dark}}(x)=\min_{y\in\Omega(x)}I(y) Idark(x)=y∈Ω(x)minI(y)

Ω ( x ) \Omega(x) Ω(x):以x为中心的窗口(选择15×15滑窗)

3.2 透射率计算

t ( x ) = 1 − ω I d a r k ( y ) A t(x)=1−\omega \frac{I^{dark}(y)}{A} t(x)=1−ωAIdark(y)

ω \omega ω为透雾强度,通常常取0.8-0.9

用原图I做引导,对透射率做引导滤波处理,消除块效应、保留边缘

3.3 大气光A估计

取暗通道前0.1% 最亮像素的均值

3.4 透雾图像恢复

J ( x ) = I ( x ) − A m a x ( t ( x ) , t 0 ) + A J(x)=\frac{I(x)−A}{max(t(x),t0)}+A J(x)=max(t(x),t0)I(x)−A+A

t0​为透射率下限,避免除零,取0.1

四、仿真结果

对网上找到的红外图像(左图)进行仿真,仿真结果(右图)具有透雾效果,对比度提升很多,还有一些artifit需要进一步处理

仿真代码链接如下,感兴趣的可以跑跑

测试代码链接


我的个人博客主页,欢迎访问

我的CSDN主页,欢迎访问

我的GitHub主页,欢迎访问

我的知乎主页,欢迎访问

相关推荐
小爷毛毛_卓寿杰1 小时前
我把一个 3B 模型塞进了 Xinference,然后它干掉了 DeepSeek V3.2
人工智能·开源·github
秦先生在广东1 小时前
Agent 闭环才是真正的护城河:Anthropic “300 个 Agent“ 背后被忽视的秘密
人工智能
Bigfish_coding1 小时前
前端转agent-【python】- 14 记忆系统优化:摘要与遗忘
人工智能
Bigfish_coding1 小时前
前端转agent-【python】-13 Ollama Python流式输出教程:stream=True 与 async 实践
人工智能
字节跳动数据库3 小时前
文章分享——相似函数处理方法
人工智能·后端·程序员
Bigfish_coding3 小时前
前端转agent-【python】-12 LangChain 入门实战:RAG + LCEL 链式调用
人工智能
程序员cxuan4 小时前
读懂 Claude Code 架构分析系列,第一篇,开始!
人工智能·后端·架构
饼干哥哥4 小时前
扣子3.0测评:我让 Codex 和 Claude Code 住同一个桌面,结果它们打架了!
人工智能·开源·代码规范
Token炼金师5 小时前
IP-Adapter:解耦交叉注意力如何让扩散模型看见图像
人工智能
Bigfish_coding5 小时前
前端转agent-【python】-11 LangGraph 高级特性:时间旅行与人工介入
人工智能