Unsupervised Single Image Dehazing Using DarkChannel Prior Loss(使用暗通道先验损失的无监督单图像去雾)

本文主要是介绍Unsupervised Single Image Dehazing Using DarkChannel Prior Loss(使用暗通道先验损失的无监督单图像去雾),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述:

        由于收集匹配的清晰和模糊图像的固有限制,基于先验和基于学习的方法诉诸于综合数据的训练; 由室内图像和相应的深度信息构建。在处理室外场景时,这可能会导致域转移。我们提出了一种通过最小化众所周知的暗通道先验 (DCP) 能量函数的完全无监督的训练方法。我们不使用合成数据向网络提供,而是仅使用真实世界的户外图像,并通过直接最小化DCP来调整网络的参数。尽管我们的 “深度DCP” 技术可以被视为DCP的快速逼近器,但它实际上可以显着改善其结果。这表明通过网络和学习过程获得了额外的正则化。实验表明,我们的方法与大规模监督方法相当。

提出方法:

无监督只使用真实世界的模糊图像以无监督的方式训练它们。 我们通过最小化无监督损失函数来优化网络的权重,本质上是暗通道先验 (DCP)的能量函数。 我们的网络可以看作是 DCP 的快速前馈逼近器

        我们的网络基于上下文聚合网络 (CAN) 架构 ,从头开始进行端到端训练,不依赖于原始模糊图像之外的任何外部数据。 它提供预测的透射图作为输出,从中可以轻松地重建去雾图像。

        一些方法使用更准确的室内深度信息来创建标记输入 。 然而,这种做法引导越来越多的研究努力优化室内性能,而除雾的主要需求实际上是在户外。 

本文的贡献:

  • 它在室外单幅图像去雾方面提供了最先进的结果,优于基于先验和完全监督的 CNN 方法
  • 与经典 DCP 相比,它在室外 PSNR 中实现了令人印象深刻的 ∼ 6.5dB 提升,验证了有效的正则化。
  • 它成功地处理了 DCP 通常失败的天空。
  • 它是第一个在单张图像去雾中执行无监督训练的,减少了对合成数据的需求。
  • 它不需要像 DCP 那样对每个图像进行显式优化,而是在训练期间学习底层变换,在测试期间需要快速前向传递。
  •  它提供了一种通用的能量函数无监督训练方法,可以应用于任何成功的能量函数

 网络架构

        系统架构。我们的全卷积网络接收真实世界的模糊图像。除了输入和输出层,我们的网络是级联的扩张残差块(扩张写在每个块之上),逐渐增加感受野。网络的预测传输和输入图像被馈送到无监督的 DCP 损失。

         因此,网络被构建为 6 个扩展残差块的级联; 每个由两个常规卷积组成,然后是一个空洞卷积。 从一个块到下一个块,膨胀因子增加了 2 的幂。 所有卷积层(除了输出)的滤波器大小和宽度为 3 × 3 × 32。所有常规卷积之后是批归一化  和 ReLU 非线性,所有空洞卷积之后是批范数。 最后一层是对传输图 1×1×1 的输出维度的线性变换。 为了改善梯度流并将更精细的细节传播到输出,我们在每个块的输入和输出之间加入了额外的 Resnet 样式 跳过残差连接。 跳过连接是将输入简单地添加到每个块的输出。 

        网络完成训练后,可以通过前向传递操作获得新的朦胧图像的传输图t θ(x)。这用于通过 大气散射模型中的雾霾形成模型恢复场景辐射:

        其中,不鼓励除以接近零的数字的 t0 设置为 t0 = 0.1,如 [3] 中所建议的那样。 为了恢复丢失的空气光分量 A,我们遵循 DCP 中建议的方法:我们首先在模糊图像的暗通道中选择 0.1% 最亮的像素。 然后,我们从这些位置中挑选出朦胧图像中最亮的像素 。这就是最终选择的大气光 A。 

 Soft Matting

        大气散射模型中的雾霾模型和《A closed form solution to natural image matting》中的image matting组成模型很相似,其中αi是像素前景不透明读

 其输出图像是一个前景图像F与背景图像B的凸线性组合,受控于α[0,1]。用t‘(x)替换α

 式(6)的第一项有利于成功抠图,第二项代表暗通道的保真度。确定二者之间的关系程度,可以取10-4。是类拉普拉斯矩阵,

损失函数的实现

         将(6)式中的第一项可以通过拉普拉斯矩阵分解,通过(8)中给出的权重,改写成更为Tensor-friendly(友好张量)的格式,

        我们对生成的传输图 t 中 N 个像素周围的所有重叠补丁以及给定 3 × 3 补丁中像素对 i、j 的所有可能组合求和。组合的最大数量为(32)·(32)=81。我们可以矢量化这个术语      

可以将这项连同保真项一起向量化:

 W 是权重的矢量化版本,TI, TJ是输出传输图的重复

可以基于式(10)的损失函数来训练网络参数预测的传输图。这一问题就转化为基于只包含雾霾图像的训练集

m是图像的数量。损失模块的输入输出图如图 :

我们的损失模块,它接收网络的预测tθ和模糊图像I,并输出DCP能量损耗的值(损失值)

实验结果:

 

这篇关于Unsupervised Single Image Dehazing Using DarkChannel Prior Loss(使用暗通道先验损失的无监督单图像去雾)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/w18226357716/article/details/124734808
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/651373

相关文章

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字