【轻量级网络系列三】MobileNetV2: Inverted Residuals and Linear Bottlenecks论文总结

本文主要是介绍【轻量级网络系列三】MobileNetV2: Inverted Residuals and Linear Bottlenecks论文总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

摘要

本文将介绍一种新型的适合移动端的网络MobileNetV2,在最近众多的tasks和benchmarks上都取得了最好的表现。它是建立在一种倒转的残差结构上面的,其中的短路连接建立在thin bottleneck layers之间。中间的扩展层使用lightweight depthwise convolutions 来对特征进行过滤来提升网络非线性能力。特别的是,我们发现去除狭窄层的非线性能力对于表现特征的能力是重要的。最后,我们的方法允许对于输入输出域去耦,这对于后面的研究分析提供了一个很轻便的网络。

一、介绍

近些年,神经网络使得许多方向的机器智能产生了革命性的变换,达到了超越人类的识别准确率。但是这些提高识别准确率的背后,这些网络需要大量的计算能力而无法在嵌入式设备和手机等移动设备上部署。

本篇文章介绍了一种新型的网络是为手机和受限制的环境量身定制的,此网络在达到同样的准确率下,大大的降低了网络的运算操作以及内存需要。主要贡献在于,提出一个the inverted residual with linear bottleneck(倒转线性残差块),这使得输入低维度的特征,可以先让其扩张成高维度的,然后使用轻量的depthwise convolution进行卷积。特征随后被使用一个a linear convolution
送回低纬度的表征里。

本模型可以适用于几乎所有的经典网络结构中,也在许多评价数据集上取得了很好的表现。它减少了在嵌入式设备上对于主存的访问,转而支持对于cache内存的访问,这样提高了访问速度。

二、相关工作 

介绍了下神经网络发展过程中的一些经典网络,介绍了ShuffleNet这种开始改变卷积内部的连接。作者也提到最近有一些使用强化学习来进行网络结构搜索的部分,来设计这种轻量级网络,但是本文是想从直观上的改变神经网络运算以及设计更简单得网络。然后提了下自己之前的工作MobileNetV1。

三、前期准备,讨论以及直觉

3.1 Depthwise Separable Convolutions

Depthwise Separable Convolutions是构建运算高效卷积神经网络的重要部分,很多工作都用了。其大概的思想就是把之前的一个卷积模块给替换成两个有着放缩因子的分离层。两个层也就是分组的卷积和1*1卷积,我在这篇文章中有写过。分组卷积是为了降低该部分操作的运算量,然后通过1*1卷积来弥补通道的不足。MobileNetV2是使用3*3的depthwise separable convolutions,所以减少的运算量在8-9倍。

3.2 Linear Bottlenecks

 

作者提出了在特征的通道低纬度的时候,ReLU激活函数会带来数据坍塌,而在高维度的时候就保留了其中大部分信息。为此,作者提出使用在低维度的时候不用ReLU,转而在其中加入线性变换。但是在这部分代码中,作者后面是将这个ReLU替换成ReLU,将大于6得输出不在增长,可以看一下pytorch给的图,比较清楚。

3.3 Inverted residuals

可以看到其的结构与普通残差块的结构差距,只是在于普通残差两头粗中间瘦(即通道数在残差块内缩小),而Inverted residuals是在块内对于通道数进行增加。作者说为什么把残差应用在其中,灵感来自于,为了让梯度不衰减。而且这样的设计可以更加高效使用内存。

3.4 信息流解释 

对于我们结构中,一个很有兴趣的属性,它提供了一种在构建块上自然的输入输出域分离和一个层,是一个非线性函数用来将输入转换为输出。前者可以被看作为网络每层的容量,后者可以看作网络的表现力。这在传统的常规和分离的卷积神经网络中是相矛盾的,当表现力和容量都纠缠在一起的时候,是输出层深度的函数。

特别的是,在我们的情况里,当内部深度为0时,底层的卷积为身份函数由于短路连接的存在。当ratio小于1的话,是常规的残差块,但我们展现出了当ratio大于1的时候,才是被最好利用的时候。

这个解释让我们允许我们可以它的容量中去单独研究网络的表现力,我们相信对于分离方面进一步的探索会给更好理解网络性质带来保证。

模型结构

Bottleneck residual block由1*1卷积先提高通道数,在通过3*3卷积,之后通过1*1卷积降低通道维数。使用ReLU6替代ReLU的原因是,为了在不降低准确率的情况下减少计算量。

这篇关于【轻量级网络系列三】MobileNetV2: Inverted Residuals and Linear Bottlenecks论文总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

Kubernetes常用命令大全近期总结

《Kubernetes常用命令大全近期总结》Kubernetes是用于大规模部署和管理这些容器的开源软件-在希腊语中,这个词还有“舵手”或“飞行员”的意思,使用Kubernetes(有时被称为“... 目录前言Kubernetes 的工作原理为什么要使用 Kubernetes?Kubernetes常用命令总

Python中实现进度条的多种方法总结

《Python中实现进度条的多种方法总结》在Python编程中,进度条是一个非常有用的功能,它能让用户直观地了解任务的进度,提升用户体验,本文将介绍几种在Python中实现进度条的常用方法,并通过代码... 目录一、简单的打印方式二、使用tqdm库三、使用alive-progress库四、使用progres

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.