对“DOF: A Demand-oriented Framework for ImageDenoising“的理解

2023-10-07 20:20

本文主要是介绍对“DOF: A Demand-oriented Framework for ImageDenoising“的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

译:"DOF:面向需求的图像去噪框架"

-- IEEE Transactions on Industrial Informatics -- 2021


目录

一、引言

二、方法

A、需求为导向的框架

B、基于DOF的网络

三、实验


一、引言

        大多数图像去噪算法的重点是最大化图像去噪质量,在降低参数数量和计算复杂度方面仍有相当大的空间。当面对不同的任务时,对参数个数、计算复杂度和去噪质量的要求是不同的。为了克服这一问题,本文作者提出了一种灵活的需求导向框架(DOF),通过在训练阶段选择适当的超参数,生成一个可以优先考虑参数数量计算复杂度去噪质量的可控模型。

        本文方法的结构包括一个尺度编码器,一个分流模块和一个尺度解码器

二、方法

        作者提出一个以需求为导向的框架,以实现以下三个目标:

(1)、需求导向:根据应用场景,基于DOF的去噪可以平衡上述三个性能指标。

(2)、普遍性:该框架可应用于其他基于CNN的去噪模型,通过该框架,重构模型可以减少参数数量,提高计算效率。

(3)、鲁棒性:当将所提框架应用于其他模型以降低计算复杂度和参数数量时,基于所提框架重建的去噪模型在去噪质量上应达到与原始模型相似的性能。

A、需求为导向的框架

        图像退化模型可以表示为:

其中x是干净图像,y表示噪声观测,v是加性噪声。

DOF模型通过下式估计噪声映射:

此外,为了提高计算效率和减少参数数量,DOF在尺度解码器的帮助下,将整个噪声图的估计转化为几个较小的噪声图的估计。因此,使用尺度编码器和分流模块估计每个子噪声图。

(1)、尺度编码器:第一步,尺度编码器利用步长为1的卷积层提取特征,发现有用信息和冗余信息;第二步,利用步长为2的卷积层对特征进行尺度缩减,借助训练过程减少空间冗余信息。这样,该方法以较低的计算复杂度达到了去噪的效果。如表一所示,这种方案的效果较好。

        为了使网络更可控,作者引入一个比例因子S=2^{\frac{j}{2}}来控制浅层特征的空间大小,j表示尺度编码器中的卷积层数。给定一幅尺寸为W x H,尺度因子为S的观测图像y,尺度编码器丢弃空间冗余信息,提取浅层特征:

(2)、分流模块:结构如图1 (b)所示。

它由几个简单的网络分支组成,其编号由超参数G配置。每个分支以提取的一部分浅层特征作为输入,通过几层卷积进一步提取深层特征。一般来说,网络分支可以采用不同的结构,每个分支的结构可以是任何现有去噪模型的低复杂度版本。给定大小为\frac{H}{S}\times \frac{W}{S}的浅层特征f, 分流模块首先将其划分为给定的组(f_1,f_2,...,f_G)。然后将这些浅层特征分别反馈给G个网络分支。这个过程表示为:

在每个网络分支中,引入一个容量比R来控制所发现信息的数据量。让每个分支发现的信息跨所有分支流动。如图2所示,

每个网络分支将发现的信息划分为G组。然后,它保留一组原始信息,让其他信息在每个分支之间流动。请注意,信息流操作强调信息的共享。经过信息流动操作后,重组后的信息可以表示为:

然后,每个分支网络的下一个特征提取器将重组后的信息作为输入,更新深度特征I。通过信息流动操作,一个网络分支的信息将与其他网络分支共享。因此,每个网络分支都可以利用来自不同网络分支的所有信息,尽管一个网络分支的输入只占整个信息的一小部分。最后,分流模块利用深度特征估计子噪声映射:

其中等式左边就是网络的输出,表示子噪声图。

注意这种信息流动操作不需要额外的可学习参数和浮点运算。

(3)、尺度解码器:尺度解码器的目标是生成与输入噪声图像大小相同的最终噪声图,使用大小为子噪声图来重建大小为H × W的噪声图。如图1(a)所示,尺度解码器将子噪声图的像素重新排列到噪声映射的空间维度上。给定子噪声图,通过下式重构最终的噪声图\widehat{v}

这里的E表示解码器。

注意这里所提出的尺度解码器不需要任何可学习参数。尺度解码器通过将误差反向传播到每个子噪声映射,使噪声映射的预测具有可学习性。

B、基于DOF的网络

        DOF有三个重要的超参数:比例因子S分支数量G容量比R。作者根据这三个参数的选择制定了不同的网络,分别有:parameter-oriented DONet (DONet-P),computation-oriented DONet (DONet-C), quality-oriented DONet (DONet-Q), 和 balanced DONet (DONet-B)。顾名思义,每个网络的需求是不一样的。然后优化目标如下:

三、实验

        下面是部分实验结果:

这篇关于对“DOF: A Demand-oriented Framework for ImageDenoising“的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/160204

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

如何通俗理解注意力机制?

1、注意力机制(Attention Mechanism)是机器学习和深度学习中一种模拟人类注意力的方法,用于提高模型在处理大量信息时的效率和效果。通俗地理解,它就像是在一堆信息中找到最重要的部分,把注意力集中在这些关键点上,从而更好地完成任务。以下是几个简单的比喻来帮助理解注意力机制: 2、寻找重点:想象一下,你在阅读一篇文章的时候,有些段落特别重要,你会特别注意这些段落,反复阅读,而对其他部分

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO

分布式系统的个人理解小结

分布式系统:分的微小服务,以小而独立的业务为单位,形成子系统。 然后分布式系统中需要有统一的调用,形成大的聚合服务。 同时,微服务群,需要有交流(通讯,注册中心,同步,异步),有管理(监控,调度)。 对外服务,需要有控制的对外开发,安全网关。

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

理解java虚拟机内存收集

学习《深入理解Java虚拟机》时个人的理解笔记 1、为什么要去了解垃圾收集和内存回收技术? 当需要排查各种内存溢出、内存泄漏问题时,当垃圾收集成为系统达到更高并发量的瓶颈时,我们就必须对这些“自动化”的技术实施必要的监控和调节。 2、“哲学三问”内存收集 what?when?how? 那些内存需要回收?什么时候回收?如何回收? 这是一个整体的问题,确定了什么状态的内存可以