读《Multi-level Wavelet-CNN for Image Restoration》
Multi-level Wavelet-CNN for Image Restoration:MWCNN
- 摘要
- 一. 介绍
- 二.相关工作
- 三.方法
摘要
存在的问题:
- 在低级视觉任务中,对于感受野尺寸与效率之间的平衡是一个关键的问题;
- 普通卷积网络通常以牺牲计算成本去扩大感受野;
解决办法:
- 使用膨胀卷积代理普通卷积方式,以此扩大感受野;此方式缺点:其使用棋盘模式对输入图像进行稀疏采样,导致处理结果会存在网格效应;
本文提出的方法MWCNN:
- 在改进的U-Net架构之上,引入小波变换去减少压缩子网络中的特征尺寸;
- 使用一个单独的卷积层去减少特征的通道数目;
- 在扩大子网络中使用小波逆变换重构高分辨率特征;
效果:
- 可应用于许多图像恢复任务,比如去噪、单一图像超分辨任务等;
- 可将MWCNN视为膨胀滤波和子采样的泛化形式;
原文链接:《Multi-level Wavelet-CNN for Image Restoration》
一. 介绍
图像恢复:
- 目的是从质量退化的图像y中恢复出干净图像x;
- 传统方法有基于先验建模和鉴别学习的,近些年卷积神经网络(CNNs)广泛应用于许多具有代表性的图像恢复任务,并展现出了优越的性能;
为什么CNN在图像恢复领域比较受欢迎?
- 基于CNN的方法在一些图像恢复任务上的表现比传统方法好,且有很大的超越;
- 研究表明可将现有的基于CNN的去噪器插入基于模型的优化方法,以此解决更复杂的图像恢复任务;
基于CNN进行研究:
-
感受野越大,对于图像的空间上下文则考虑的越多,因此更大的感受野有助于提升网络性能;
-
由于输入图像和输出图像通常需保持一样的尺寸,所以一个经典方案是使用移除池化层的全卷积网络(FCN);
-
FCN可通过加深网络或者使用尺寸更大的卷积核,以此扩大模型感受野,但显而易见的是这种方式会带来更大的计算成本消耗;
-
使用膨胀卷积代理普通卷积方式,以此扩大感受野;此方式缺点:其使用棋盘模式对输入图像进行稀疏采样,导致处理结果会存在网格效应;
-
通常随着感受野的扩大,网络模型的性能也会随之提升,但可看出这种推论也可能存在特殊情况(FSRCNN)。所以在进行感受野增大时,需要考虑如何避免增加计算成本以及性能提升的潜在牺牲。
Multi-level Wavelet-CNN for Image Restoration:MWCNN
- 目的:扩大感受野,对网络性能和效率之间做一个更好的平衡;
- 采用改进的U-Net,U-Net中包含一个压缩子网络、一个扩大子网络:MWCNN采用小波变化替换压缩子网络中的池化操作;
- DWT可逆,故可保证在下采样过程中保留所有信息;DWT可捕捉特征的所有频率信息和位置信息,故有助于保存细节纹理信息;
- 在扩大子网络中使用小波逆变换对低分辨率特征进行上采样, 重构高分辨率特征;
- 为了丰富特征表示以及减少计算成本,在连接同层压缩-扩大子网络的特征图时,使用元素级加法;
- 可将MWCNN视为膨胀滤波和子采样的泛化形式,MWCNN在扩大感受野方面更有效;
本文贡献:
- 提出MWCNN用于扩大感受野,对网络性能和网络效率做了更好的均衡;
- 由于DWT良好的空间-频域定位能力,该网络可以保存更好的纹理细节信息;
- MWCNN在许多图像恢复任务上展现出良好的性能;
二.相关工作
- 之前的研究比如WaveResNet、DWSR表明将DWT应用于CNN有利于CNN学习;
- 之前的工作通常只考虑一级小波变换,而忽略了子带之间的依赖影响;
- 本文提出的MWCNN考虑了多级小波变换,再扩大感受野的同时保证无信息损失;MWCNN可以将DWT嵌入到任何具有池化的CNN中,更有效地对空间上下文和子带之间的依赖进行建模。
三.方法
WPT VS MWCNN:
-
MWCNN受多级小波变换(WPT)的启发,引入CNN搭建;
-
WPT采用二级小波变换,MWCNN在WPT基础上引入CNN块;
-
在每级小波变换后引入CNN块,将其分解的子带作为CNN块的输入,进而将CNN块的输出作为下一级小波变换的输入;
MWCNN可视为WPT的通用模式,当CNN块变为一致性映射时,MWCNN则退化为WPT了; 骨干网络采用改进的U-Net:分解阶段使用DWT进行下采样,实现池化的功能; 重构阶段使用IWT+卷积实现重构操作;
网络结构:
- CNN块为无池化的4层FCN;
- 每次完整的卷积过程包括:卷积核为3*3的卷积层、BatchNormalization层以及ReLU层;
- 需要注意的是,扩张子网络中最后一个卷积块的最后一个卷积过程只有卷积操作,丢弃了BatchNormalization层以及ReLU层;
- 整个网络共涉及24个网络层,图中可看到最终MWCNN借助三级小波变换/逆变换实现下采样、上采样操作;
- MWCNN默认采用哈尔小波进行小波变换/逆变换;
MWCNN对U-Net做的改进:
- U-Net中的下采样、上采样操作分别被DWT和IWT代替;
- MWCNN中除了第一个卷积块对特征图通道进行了增加,其他的卷积块都是减少特征图通道,以此学习压缩表示;
- 采用元素级加法连接同层的压缩子网与扩张子网的特征图;
损失函数:
其中xi为真实干净图像(标签),yi为退化图像(网络输入),F(yi,θ)为网络输出,θ为网络参数。
这里我不知道他右下角这个F表示F范数还是啥意思?
DWT为啥可以实现下采样,实现池化:
以2维哈尔小波为例,有四个滤波核分别为:
以fLL为例,类似卷积操作,对应位置求和,一个大小为4*4的特征即可变为2*2,实现下采样,IWT反向操作,实现上采样,将低分辨率图像重构为高分辨率图像。
DWT为啥可以近似膨胀滤波,扩大感受野:
原文中这么描述二者的关系,我举个例子:
3*3卷积核在膨胀率为2的膨胀卷积中,可看做一个5*5的卷积核,所以在进行隔点采样,如果原始特征大小为5*5,则膨胀卷积结果为1*1;
而使用DWT先对5*5特征进行滤波会得到3*3特征,再对其进行3*3卷积即可得到1*1结果;
上图中的公式可按照下图的例子进行理解,区别在于作者对于特征图的下标从1开始计算,我这里是从0开始,x1为对x进行fLL滤波后的结果,其中一个像素点对应原图中的4领域像素。
相关文章:

读《Multi-level Wavelet-CNN for Image Restoration》
Multi-level Wavelet-CNN for Image Restoration:MWCNN摘要一. 介绍二.相关工作三.方法摘要 存在的问题: 在低级视觉任务中,对于感受野尺寸与效率之间的平衡是一个关键的问题;普通卷积网络通常以牺牲计算成本去扩大感受野&#…...

【Linux】安装DHCP服务器
1、先检测网络是否通 get dhcp.txt rpm -qa //查看软件包 rpm -qa |grep dhcp //确定是否安装 yum install dhcp //进行安装 安装完成后 查询 rpm -ql dhcp 进行配置 cd /etc/dhcp 查看是否有遗留dhcpd.conf.rpmsave 删除该文件 cp /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sampl…...

功能测试转型测试开发年薪27W,又一名功能测试摆脱点点点,进了大厂
咱们直接开门见山,没错我的粉丝向我投来了喜报,从功能测试转型测试开发,进入大厂,摆脱最初级的点点点功能测试,拿到高薪,遗憾的是,这名粉丝因为个人原因没有经过指导就去面试了,否则…...

数据结构之哈希表
常见的三种哈希结构 数组set(集合)map(映射) set(集合) 集合底层实现是否有序数值是否可以重复能否更改数值查询效率增删效率std::set红黑树有序否否O(log n)O(log n)std::multiset红黑树有序是否O(log n)O(log n)std::unordere…...
linux信号理解
linux信号:用户、系统或进程发送给目标进程的信息,以通知目标进程中某个状态的改变或是异常。 信号产生原因:软中断或者硬中断。可细分为如下几种原因: ①系统终端Terminal中输入特殊的字符来产生一个信号,比如按下&am…...

HC小区管理系统window系统安装教程
实操视频 HC小区管理系统局域网window物理机部署教程_哔哩哔哩_bilibili 一、下载安装包 百度网盘: 链接:https://pan.baidu.com/s/1XAjxtpeBjHIQUZs4M7TsRg 提取码:hchc 或者 123盘 hc-window.zip官方版下载丨最新版下载丨绿色版下…...

自动化测试工具软测界的不二之选,还不快速来了解
目录 引言: 前言: 一.龙测AI-TestOps云平台使用教程 1.如何登录龙测AI-TestOps云平台 登录方法① 登录方法② 2.龙测AI-TestOps云平台界面布局 3.龙测AI-TestOps云平台菜单功能 ①创建项目 ②应用管理 ③设备管理 ④订单 二.总结 引言&#…...

centos系统/dev/mapper/centos-root目录被占满的解决方式
最近在做虚拟机部署docker微服务时,发现磁盘内存占满,无法进行操作。open /var/lib/dpkg/info/libc6:amd64.templates: no space left on device接下来就写下我在备份虚拟机上如何解决根目录被占满的问题:1、查看虚拟机磁盘使用情况df -h可以…...

【C++】STL容器、算法的简单认识
几种模板首先认识一下函数模板、类模板、栈模板。函数模板函数模板就是一个模型,而模板函数是函数模板经过类型实例化的函数。如下template<class T>是一个简单的函数模板:template<class T> T Max(T a, T b) {return a > b ? a : b; } …...
把python开发的web服务,打包成docker镜像的方法
要将Python开发的服务打成Docker镜像,可以按照以下步骤操作:1. 创建一个Dockerfile文件,该文件描述了如何构建Docker镜像。例如,以下是一个简单的Dockerfile文件,用于构建一个基于Python的Web应用程序: FRO…...

【Linux】多线程
进程和线程进程:一个正在运行的程序。状态:就绪,运行,阻塞;线程是进程中的一个执行路径,一个进程中至少有一个主线程(main函数);有多条执行路径为多线程。创建一个线程用…...

Qt 设置窗口背景图片的几种方法实例
1.在paintEvent事件中绘制图片 void Widget::paintEvent(QPaintEvent * ev) {QPainter painter(this);painter.drawPixmap(rect(),QPixmap(":/bg.jpg"),QRect()); } drawPixmap在Widget的整个矩形区域绘制背景图片,第三个参数为要绘制的图片区域&#x…...

springcloud微服务架构搭建过程
项目地址:源代码 仅作为学习用例使用,是我开发过程中的总结、实际的一部分使用方式 开发环境: jdk11 springboot2.7.6 springcloud2021.0.5 alibabacloud 2021.0.4.0 redis6.0 mysql8.0 一、项目搭建 wdz-api:存放远程服务调用相关…...

LeetCode:215. 数组中的第K个最大元素
🍎道阻且长,行则将至。🍓 🌻算法,不如说它是一种思考方式🍀算法专栏: 👉🏻123 一、🌱215. 数组中的第K个最大元素 题目描述:给定整数数组nums和整…...

vue面试题(day06)
文章目录前言请谈谈WXML与标准的html的异同?请谈谈WXSS和CSS的异同?请谈谈微信小程序主要目录和文件的作用?请谈谈小程序的双向绑定和vue的异同?简单描述下微信小程序的相关文件类型?微信小程序有哪些传值(传递数据)方…...
22 k8s常用命令
一、k8s网络 service网络 pod网络 节点网络 》 svc、pod网络都是虚拟机网络,真实网络是节点网络 二、内核升级 因为coentos系统3.10存在一些bug,docker、kubernetes不稳定,建议升级到4.4版本以上 三、集群资源分类 名称空间级别࿱…...

基于ESP32做低功耗墨水屏时钟
基于ESP32做低功耗墨水屏时钟电子墨水屏概述ESP32实验低功耗电子时钟功能描述接线开发实验结果电子墨水屏 概述 电子墨水是一种革新信息显示的新方法和技术。和传统纸差异是电子墨水在通电时改变颜色,并且可以显示变化的图象,像计算器或手机那样的显示。…...
常见路由器开源系统(固件)简介
前段时间在折腾如何通过 SD-WAN 组网方式打通办公室和家里的异地局域网。需要用到路由器的静态路由表功能,但是遍历整个家用路由器市场几乎没有支持这个功能的路由器(只有华硕 RT-AX57 有这个功能,但是成本超出了我的预算)。所有就…...
HCIE-Cloud Computing LAB备考第二步:逐题攻破--第二题:FusionAccess-搭建FA实验环境之安装基础组件和初始化ITA组件
HCIE-Cloud Computing LAB备考第二步:逐题攻破–第二题:FusionAccess-思维导图+题目=建立逻辑 专业术语 名词描述备注FusionAccess华为推出的桌面云产品,是一种虚拟桌面应用,它主要通过在硬件上部署FusionAccess配套的软件基础上,虚拟化出相互隔离的桌面,用户通过瘦客户端…...

Android APP检查设备是否为平板
正文 Android APP判断设备是否为平板的三种方法: 通过屏幕尺寸判断。一般来说,平板电脑的屏幕尺寸比手机大很多,可以根据屏幕的长宽比和尺寸等信息来区分设备类型。通过屏幕像素密度判断。一般来说,平板电脑的屏幕像素密度比手机…...

基于FPGA的PID算法学习———实现PID比例控制算法
基于FPGA的PID算法学习 前言一、PID算法分析二、PID仿真分析1. PID代码2.PI代码3.P代码4.顶层5.测试文件6.仿真波形 总结 前言 学习内容:参考网站: PID算法控制 PID即:Proportional(比例)、Integral(积分&…...

高频面试之3Zookeeper
高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个?3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制(过半机制࿰…...
oracle与MySQL数据库之间数据同步的技术要点
Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异,它们的数据同步要求既要保持数据的准确性和一致性,又要处理好性能问题。以下是一些主要的技术要点: 数据结构差异 数据类型差异ÿ…...

【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...

GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...
django blank 与 null的区别
1.blank blank控制表单验证时是否允许字段为空 2.null null控制数据库层面是否为空 但是,要注意以下几点: Django的表单验证与null无关:null参数控制的是数据库层面字段是否可以为NULL,而blank参数控制的是Django表单验证时字…...
深度剖析 DeepSeek 开源模型部署与应用:策略、权衡与未来走向
在人工智能技术呈指数级发展的当下,大模型已然成为推动各行业变革的核心驱动力。DeepSeek 开源模型以其卓越的性能和灵活的开源特性,吸引了众多企业与开发者的目光。如何高效且合理地部署与运用 DeepSeek 模型,成为释放其巨大潜力的关键所在&…...
ubuntu22.04 安装docker 和docker-compose
首先你要确保没有docker环境或者使用命令删掉docker sudo apt-get remove docker docker-engine docker.io containerd runc安装docker 更新软件环境 sudo apt update sudo apt upgrade下载docker依赖和GPG 密钥 # 依赖 apt-get install ca-certificates curl gnupg lsb-rel…...
高防服务器价格高原因分析
高防服务器的价格较高,主要是由于其特殊的防御机制、硬件配置、运营维护等多方面的综合成本。以下从技术、资源和服务三个维度详细解析高防服务器昂贵的原因: 一、硬件与技术投入 大带宽需求 DDoS攻击通过占用大量带宽资源瘫痪目标服务器,因此…...