Convolutional Neural Networks(1): Architecture
Concolutional Neural Networks(CNN)同样使用三层结构,但结构上同Feedforward Neural Network有很大不同,其结构如下图:

Input layer: 对单张图片来说,输入数据是3D的(Width*Length*Depth),见下方的立体图。但如果我们使用mini-batch去训练神经网络的话,则input变为了4D数据(Width*Length*Depth*Batch_size)。

Feature-extraction layers:Convolution layer(+Relu)和Pooling layer成对出现,进行高阶映射和特征提取。如下图所示,对于单张图片(3D data)来说,使用Filter(也叫Kernel,可以看成是一个Sliding Window,一般尺寸比数据要小)去扫描该图片并做卷积。通常情况下,从input volumn到Convolutional Layer,数据的Width和Length有了少许的减少,而the 3rd Dimension Depth,则被扩张了,因为有多个Kernels。在中间的过程中,可以看到经过Filter以后,depth变成了6,证明有6个Filter,将原先Depth=3扩展到了6。而后通过pooling layer,Width和Length又被进一步压缩,在这里一般使用Average,或者Maximum去压缩。

Classification layer:在最终输出层之前,会有一个Fully-connected layer,形式和Feedfoward Neural Network的Hidden layer是一样的,与前一Pooling layer的Neurons做全连接,与输出层的Output nodes也做全连接,一层或多层根据需要。
Output layer:用Softmax输出概率或根据需要输出其他形式。如果使用了Mini batch,则输出是2D的(Probabilities*Batch_size)。
实际工作流程,可以用下例来说明:
a. Input是32*32的(depth=1)
b.在Layer1中有6个kernel,Convolution之后有6个28*28的Activation Map,经过Pooling(Subsample)四选一之后,变成了6*14*14.
c.Layer2中有16个kernel,Convolution之后有16个10*10的Activation Map,经过Pooling(Subsample)四选一之后,变成了16*5*5.
d.C5是含有120个neurons的全连接层,F6是输出层

Convolutional Neural Networks(1): Architecture的更多相关文章
- A Beginner's Guide To Understanding Convolutional Neural Networks(转)
		A Beginner's Guide To Understanding Convolutional Neural Networks Introduction Convolutional neural ... 
- (转)A Beginner's Guide To Understanding Convolutional Neural Networks
		Adit Deshpande CS Undergrad at UCLA ('19) Blog About A Beginner's Guide To Understanding Convolution ... 
- 论文笔记之:Learning Multi-Domain Convolutional Neural Networks for Visual Tracking
		Learning Multi-Domain Convolutional Neural Networks for Visual Tracking CVPR 2016 本文提出了一种新的CNN 框架来处理 ... 
- 卷积神经网络Convolutional Neural Networks
		Convolutional Neural Networks NOTE: This tutorial is intended for advanced users of TensorFlow and a ... 
- 深度卷积神经网络用于图像缩放Image Scaling using Deep Convolutional Neural Networks
		This past summer I interned at Flipboard in Palo Alto, California. I worked on machine learning base ... 
- [转] Understanding Convolutional Neural Networks for NLP
		http://www.wildml.com/2015/11/understanding-convolutional-neural-networks-for-nlp/ 讲CNN以及其在NLP的应用,非常 ... 
- (zhuan) Building Convolutional Neural Networks with Tensorflow
		Ahmet Taspinar Home About Contact Building Convolutional Neural Networks with Tensorflow Posted on a ... 
- [转]An Intuitive Explanation of Convolutional Neural Networks
		An Intuitive Explanation of Convolutional Neural Networks https://ujjwalkarn.me/2016/08/11/intuitive ... 
- Understanding Convolutional Neural Networks for NLP
		When we hear about Convolutional Neural Network (CNNs), we typically think of Computer Vision. CNNs ... 
随机推荐
- 【CF321E】+【bzoj5311】贞鱼
			决策单调性 + WQS二分 我们首先列出转移式: \(f[i]=Min(f[j]+Sum[j+1 , i])\) 首先我们考虑如果让一段区间的小鱼在一起的代价怎么预处理,我们可以对于一个上三角矩阵求个 ... 
- JavaScript基础6——全选示例
			<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ... 
- frontend-dev面试
			1.笔试题 vuex 存储的数据为null或者undefined是为啥? 1.伸缩布局 flex规则 2.横向布局的实现方法有多少? 3.说一说 flex:1; 的含义 / 说一说flex:1 1 3 ... 
- vue实现PC端调用摄像头拍照人脸录入、移动端调用手机前置摄像头人脸录入、及图片旋转矫正、压缩上传base64格式/文件格式
			进入正题 1. PC端调用摄像头拍照上传base64格式到后台,这个没什么花里胡哨的骚操作,直接看代码 (canvas + video) <template> <div> &l ... 
- CentOS下性能监测工具 dstat
			原文链接:http://www.bkjia.com/Linuxjc/935113.html 参考链接:https://linux.cn/article-3215-1.html,http://lhfli ... 
- 2018-8-10-使用-Resharper-特性
			title author date CreateTime categories 使用 Resharper 特性 lindexi 2018-08-10 19:16:51 +0800 2018-4-25 ... 
- c++ sizeof的实现
			c++中的sizeof,可以通过以下宏定义实现. #include <stdio.h> #define sizeof_T(T) ((size_t)((T*)0+1)) ///求类型的大小 ... 
- APKMirror - 直接下载google play里的应用
			APKMirror - Free APK Downloads - Download Free Android APKs #APKPLZ https://www.apkmirror.com/ 
- Linux wc -l 统计行数问题
			统计文件行数 通过wc -l 来实现. [root@xguang_02 xguang]# wc -l tt.dat 798 tt.dat 而通过nl\ cat -n 查看时发现为79 ... 
- 王垠-40行代码 -cps.ss
			;; A simple CPS transformer which does proper tail-call and does not ;; duplicate contexts for if-ex ... 
