VGG 参数分析 转
上面放了一个keras用vgg16训练测试的例子,我也试过用vgg16训练然后测试自己的例子,效果一般,这里我们来分析一下vgg16的网络结果
keras代码如下
- def VGG_16(weights_path=None):
- model = Sequential()
- model.add(ZeroPadding2D((1,1),input_shape=(3,224,224)))#卷积输入层,指定了输入图像的大小
- model.add(Convolution2D(64, 3, 3, activation='relu'))#64个3x3的卷积核,生成64*224*224的图像,激活函数为relu
- model.add(ZeroPadding2D((1,1)))#补0,保证图像卷积后图像大小不变,其实用<span style="font-family:Consolas, 'Andale Mono WT', 'Andale Mono', 'Lucida Console', 'Lucida Sans Typewriter', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Liberation Mono', 'Nimbus Mono L', Monaco, 'Courier New', Courier, monospace;color:#333333;"><span style="font-size:10.8px;">padding = 'valid'参数就可以了</span></span>
- model.add(Convolution2D(64, 3, 3, activation='relu'))#再来一次卷积 生成64*224*224
- model.add(MaxPooling2D((2,2), strides=(2,2)))#pooling操作,相当于变成64*112*112
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(128, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(128, 3, 3, activation='relu'))
- model.add(MaxPooling2D((2,2), strides=(2,2)))#128*56*56
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(256, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(256, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(256, 3, 3, activation='relu'))
- model.add(MaxPooling2D((2,2), strides=(2,2)))#256*28*28
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(512, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(512, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(512, 3, 3, activation='relu'))
- model.add(MaxPooling2D((2,2), strides=(2,2)))#512*14*14
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(512, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(512, 3, 3, activation='relu'))
- model.add(ZeroPadding2D((1,1)))
- model.add(Convolution2D(512, 3, 3, activation='relu'))
- model.add(MaxPooling2D((2,2), strides=(2,2))) #到这里已经变成了512*7*7
- model.add(Flatten())#压平上述向量,变成一维25088
- model.add(Dense(4096, activation='relu'))#全连接层有4096个神经核,参数个数就是4096*25088
- model.add(Dropout(0.5))#0.5的概率抛弃一些连接
- model.add(Dense(4096, activation='relu'))#再来一个全连接
- model.add(Dropout(0.5))
- model.add(Dense(1000, activation='softmax'))
- if weights_path:
- model.load_weights(weights_path)
- return model
下面是详细的参数个数
- INPUT: [224x224x3] memory: 224*224*3=150K weights: 0
- CONV3-64: [224x224x64] memory: 224*224*64=3.2M weights: (3*3*3)*64 = 1,728 3*3 代表卷积大小 *3 代表输入时3个通道 *64代表输出64个
- CONV3-64: [224x224x64] memory: 224*224*64=3.2M weights: (3*3*64)*64 = 36,864 同理3*3是卷积大小 *64代表输入64通道 *64代表输出是64通道
- POOL2: [112x112x64] memory: 112*112*64=800K weights: 0
- CONV3-128: [112x112x128] memory: 112*112*128=1.6M weights: (3*3*64)*128 = 73,728
- CONV3-128: [112x112x128] memory: 112*112*128=1.6M weights: (3*3*128)*128 = 147,456
- POOL2: [56x56x128] memory: 56*56*128=400K weights: 0
- CONV3-256: [56x56x256] memory: 56*56*256=800K weights: (3*3*128)*256 = 294,912
- CONV3-256: [56x56x256] memory: 56*56*256=800K weights: (3*3*256)*256 = 589,824
- CONV3-256: [56x56x256] memory: 56*56*256=800K weights: (3*3*256)*256 = 589,824
- POOL2: [28x28x256] memory: 28*28*256=200K weights: 0
- CONV3-512: [28x28x512] memory: 28*28*512=400K weights: (3*3*256)*512 = 1,179,648
- CONV3-512: [28x28x512] memory: 28*28*512=400K weights: (3*3*512)*512 = 2,359,296
- CONV3-512: [28x28x512] memory: 28*28*512=400K weights: (3*3*512)*512 = 2,359,296
- POOL2: [14x14x512] memory: 14*14*512=100K weights: 0
- CONV3-512: [14x14x512] memory: 14*14*512=100K weights: (3*3*512)*512 = 2,359,296
- CONV3-512: [14x14x512] memory: 14*14*512=100K weights: (3*3*512)*512 = 2,359,296
- CONV3-512: [14x14x512] memory: 14*14*512=100K weights: (3*3*512)*512 = 2,359,296
- POOL2: [7x7x512] memory: 7*7*512=25K weights: 0
- FC: [1x1x4096] memory: 4096 weights: 7*7*512*4096 = 102,760,448
- FC: [1x1x4096] memory: 4096 weights: 4096*4096 = 16,777,216
- FC: [1x1x1000] memory: 1000 weights: 4096*1000 = 4,096,000
- TOTAL memory: 24M * 4 bytes ~= 93MB / image (only forward! ~*2 for bwd)
- TOTAL params: 138M parameters
VGG 参数分析 转的更多相关文章
- AI:IPPR的数学表示-CNN结构/参数分析
前言:CNN迎接多类的挑战 特定类型的传统PR方法特征提取的方法是固定的,模式函数的形式是固定的,在理论上产生了特定的"局限性" 的,分类准确度可以使用PAC学习理论的方法计算出来 ...
- http_load安装与测试参数分析 - 追求自由自在的编程 - ITeye技术网站
http_load安装与测试参数分析 - 追求自由自在的编程 - ITeye技术网站 http_load -p 50 -s 120 urls
- cocos2dx tolua传递参数分析
cocos2dx tolua传递参数分析: tolua_Cocos2d_CCNode_addChild00 == void CCNode::addChild(CCNode *child) tolua_ ...
- jQuery学习笔记之jQuery.fn.init()的参数分析
这篇文章主要介绍了jQuery.fn.init()的参数分析,需要的朋友可以参考下 从return new jQuery.fn.init( selector, context, rootjQuer ...
- JavaScript事件监听以及addEventListener参数分析
事件监听 在Javascript中事件的监听是用来对某些操作做出反应的方法.例如监听一个按钮的pressdown, 或者获取鼠标左键按下时候鼠标的位置.这些都需要使用监听来完成.监听的函数很简单:ad ...
- Jmeter5.1——聚合报告参数分析
Jmeter5.1——聚合报告参数分析 Label: 每个JMeter的element的Name值.例如HTTP Request的Name. Samples:发出请求的数量.如果线程组中配置的是线程数 ...
- BMDP为常规的统计分析提供了大量的完备的函数系统,如:方差分析(ANOVA)、回归分析(Regression)、非参数分析(Nonparametric Analysis)、时间序列(Times Series)等等。此外,BMDP特别擅于进行出色的生存分析(Survival Analysis )。许多年来,一大批世界范围内顶级的统计学家都曾今参与过BMDP的开发工作。这不仅使得BMDP的权威性得到
BMDP是Bio Medical Data Processing的缩写,是世界级的统计工具软件,至今已经有40多年的历史.目前在国际上与SAS.SPSS被并称为三大统计软件包.BMDP是一个大 ...
- Impala队列内存参数分析
同步发布在csdn上 问题 对Impala队列内存的几个参数分析了下,欢迎指正 队列资源池的几个内存配置 Maximum Query Memory Limit 某个队列资源池,一个查询在一个Impal ...
- external-attacher源码分析(1)-main方法与启动参数分析
更多 ceph-csi 其他源码分析,请查看下面这篇博文:kubernetes ceph-csi分析目录导航 摘要 ceph-csi分析-external-attacher源码分析.external- ...
随机推荐
- BZOJ1070[SCOI2007]修车——最小费用最大流
题目描述 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序,使得顾客平均等待 ...
- BZOJ5251 八省联考2018劈配(网络流)
劈配,匹配,网络流.那么考虑怎么跑网络流. 先看第一问.首先套路的建出超源超汇.不用想也知道导师向汇连容量为战队人数上限的边.特别地,给出局也建一个点,向汇连容量inf的边(似乎没有必要).对于一个新 ...
- 洛谷P4035 [JSOI2008]球形空间产生器(高斯消元)
洛谷题目传送门 球啊球 @xzz_233 qaq 高斯消元模板题,关键在于将已知条件转化为方程组. 可以发现题目要求的未知量有\(n\)个,题目却给了我们\(n+1\)个点的坐标,这其中必有玄机. 由 ...
- HGOI 20180224 题解
/* The Most Important Things: ljc chat with fyh on QQTa说期末考Ta数学74分感觉不好但是我觉得fyh是地表最强的鸭~~(of course en ...
- [luogu2590][bzoj1036][ZJOI2008]树的统计
题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成 一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u ...
- luogu4360 锯木厂选址 (斜率优化dp)
设: sw[i]为1..i的w之和 sd[i]为1到i的距离 cost[i]为把第一个锯木厂建在i带来的花费 all[i,j]为把i..j所有木头运到j所需要的花费 所以$all[i,j]=cost[ ...
- The 2018 ACM-ICPC China JiangSu Provincial Programming Contest快速幂取模及求逆元
题目来源 The 2018 ACM-ICPC China JiangSu Provincial Programming Contest 35.4% 1000ms 65536K Persona5 Per ...
- A1059. Prime Factors
Given any positive integer N, you are supposed to find all of its prime factors, and write them in t ...
- Persits.Jpeg CMYK-to-RGB
这几天发现有几个用户上传的图片显示一个“红叉叉”,用迅雷下载一看,原来图片的“模式”是CMYK,这样的模式是不能在IE中正常显示的. 我想起能不能用程序自动转换呢? 在网上看到利用Persits.Jp ...
- Codeforces Round #419 (Div. 2)(B)差分数组
传送门:Problem B https://www.cnblogs.com/violet-acmer/p/9721160.html 题意: Karen有n个关于煮咖啡的食谱,每个食谱都有个煮咖啡的最适 ...