深度学习_经典网络_VGGNet

2023-10-11 23:58

本文主要是介绍深度学习_经典网络_VGGNet,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.模型介绍

VGGNet是由牛津大学视觉几何小组(Visual Geometry Group,VGG)提出的一种深度卷积网络结构,他们以7.32%的错误率赢得了2014年ILSVRC分类任务的亚军(冠军由GoogleNet以6.65%的错误率夺得)和25.32%的错误率夺得定位任务(Localization)的第一名,网络名称VGGNet取自该小组名缩写。
VGGNet是首批把图像分类的错误率降到10%以内的模型,同时该网络采用的3*3卷积核的思想是后来许多模型的基础。该模型对深度学习的发展有很大的推动作用,也很值得我们去深入学习。
VGG论文地址

二.模型结构

图1.VGG16模型结构

原论文中的VGGNet包含了6个版本的演进,分别是VGG11、VGG11-LRN、VGG13、VGG16-1、VGG16-3和VGG19,不同的后缀值表示不同的网络层数。
其中VGG11-LRN表示在第一层中采用了LRN的VGG11,VGG16-1表示后三组卷积块中最后一层卷积采用卷积核尺寸为1 * 1,而VGG16-3表示卷积核尺寸为3 * 3。
我们介绍的VGG16为VGG16-3。图1中的VGG16体现了VGGNet的核心思路,使用3 * 3的卷积组合代替大尺寸的卷积:2个3 * 3卷积即可与5 * 5卷积拥有相同的感受野。
下面我们列出VGG16网络参数配置:

网络层;输入尺寸;核尺寸输出尺寸;参数个数
卷积层C11;224 * 224 * 3;3 * 3 * 64/1224 * 224 * 64;(3 * 3 * 3+1)*64
卷积层C12;224 * 224 * 64;3 * 3 * 64/1224 * 224 * 64;(3 * 3 * 64+1)*64
下采样层Smax1;224 * 224 * 64;2 * 2/2112 * 112 * 128;(0)
卷积层C21;112 * 112 * 64;3 * 3 * 128112 * 112 * 128;(3 * 3 * 64+1)*128
卷积层C22;112 * 112 * 128;3 * 3 * 128/1112 * 112 * 128;(3 * 3 * 128+1)*128
下采样层Smax2;112 * 112 * 128;2 * 2/256 * 56 * 128;(0)
卷积层C31;56 * 56 * 128;3 * 3 * 256/156 * 56 * 256;(3 * 3 * 128+1)*256
卷积层C32;56 * 56 * 256;3 * 3 * 256/156 * 56 * 256;(3 * 3 * 256+1)*256
卷积层C33;56 * 56 * 256 ;3 * 3 * 256/156 * 56 * 256;(3 * 3 * 256+1)*256
下采样层Smax3;56 * 56 * 256;2 * 2/228 * 28 * 256;(0)
卷积层C41;28 * 28 * 256;3 * 3 * 512/128 * 28 * 512;(3 * 3 * 256+1)*512
卷积层C42;28 * 28 * 512;3 * 3 * 512/128 * 28 * 512;(3 * 3 * 512+1)*512
卷积层C43;28 * 28 * 512;3 * 3 * 512/128 * 28 * 512;(3 * 3 * 512+1)*512
下采样层Smax4;28 * 28 * 512;2 * 2/214 * 14 * 512;(0)
卷积层C51;14 * 14 * 512;3 * 3 * 512/114 * 14 * 512;(3 * 3 * 512+1)*512
卷积层C52;14 * 14 * 512;3 * 3 * 512/114 * 14 * 512;(3 * 3 * 512+1)*512
卷积层C53;14 * 14 * 512;3 * 3 * 512/114 * 14 * 512;(3 * 3 * 512+1)*512
下采样层Smax5;14 * 14 * 512;2 * 2/27 * 7 * 512;(0)
全连接层FC1;7 * 7 * 512;7 * 7 *40961 * 4096;(7 * 7 * 512+1)*4096
全连接层FC2;1 * 4096;4096 * 40961 * 4096;(4096+1)*4096
全连接层FC3;1 * 4096;4096 * 10001 * 1000;(4096+1)*1000

三.模型特点

  1. 整个网络都使用了同样大小的卷积核尺寸3 * 3和最大池化尺寸2 * 2.
  2. 1*1卷积的意义在于线性变换,而输入通道数和输出通道数不变,没有发生降维。
  3. 两个3 * 3的卷积串联相当于1个5 * 5的卷积层,感受野大小为5 * 5。同样的,3个3 * 3的卷积层串联的效果则相当于1个7 * 7的卷积层。这样的连接方式使得网络的参数量更少,而且多层的激活函数(前者可以使用三次ReLU激活函数,而后者只有一次)令网络对特征的学习能力更强。
  4. VGGNet在训练时有一个小技巧,先训练浅层的简单网络VGG11,再复用VGG11的权重来初始化VGG13,如此反复训练并初始化VGG19,能够使训练时收敛的速度更快。
  5. 在训练的过程中使用多尺度的变换对原始数据做数据增强,使得模型不易过拟合。

这篇关于深度学习_经典网络_VGGNet的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

五大特性引领创新! 深度操作系统 deepin 25 Preview预览版发布

《五大特性引领创新!深度操作系统deepin25Preview预览版发布》今日,深度操作系统正式推出deepin25Preview版本,该版本集成了五大核心特性:磐石系统、全新DDE、Tr... 深度操作系统今日发布了 deepin 25 Preview,新版本囊括五大特性:磐石系统、全新 DDE、Tree

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

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

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

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

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor