机器学习之深度学习

本文基于台大机器学习技法系列课程进行的笔记总结。

一、主要内容


topic 1  深度神经网络结构

从类神经网络结构中我们已经发现了神经网络中的每一层实际上都是对前一层进行的特征转换,也就是特征抽取。一般的隐藏层(hidden layer)较少的类神经网络结构我们称之为shallow,而当隐藏层数比较多的类神经网络结构我们称之为deep。如下图所示:


从两者的对比中可以明显发现,随着类神经网络结构的层数逐渐变多,由shallow转向deep,训练的效率会下降,结构变得复杂,那么对应的能力(powerful)呢?实际上shallow的类神经网络已经很强的powerful了,那么多增加layer的目的到底是什么呢?是如何的更加富有意义(meaningful)呢?且往下看:


图中所示的一个非常常见的问题:识别手写体数字的模式识别问题。最原始的特征就是我们的原始数字化的图像(raw features:pixels),从pixels出发,通过第一层的转换我们可以得到一些稍微复杂一点点的features:笔画特征,然后我们再由这些笔画特征开始输入到下一层中,就可以得到更加抽象的认识特征(将像素组合成笔画,然后再由笔画的组成去构成对数字的认识,进而识别数字)。上图中可以看出,数字1可以由第一层的左边三个笔画构成,而数字5可以由第一层右边四个笔画构成,从第一层到第二层,链接权重红色表示抑制,蓝色表示激励,其实就是模仿人类神经元的工作机制(最简单的模仿:激励和抑制)。那么这个手写体数字的模式识别问题就可以通过这一层一层的类神经网络结构得到解决。但是问题是,类神经网络的结构如何确定,模型复杂度如何评估(会不会overfitting呢),以及优化的方式和计算复杂度的评估呢?且看下图总结:


对于第一个问题,如何确定类神经网络的结构,可以通过domain knowledge来解决,比如在图像处理中应用的卷积神经网络,就是利用了像素在空间上的关系。

对于第二个问题,我们知道一个非常经典的关系,overfitting与模型复杂度、数据量、噪声的关系:模型复杂度越大,数据量越小,噪声越大,就越容易发生overfitting,反之亦然。所以,如果我们训练时候的数据量足够大,就完全可以消弭由于模型复杂度带来的overfitting的风险。所以,对于模型复杂度,要保证足够大的数据量。当然,另外一种我们最熟悉的用来抑制模型复杂度的工具就是regularization,通过对噪声的容忍(noise-tolerant)对象不同可以有两种regularization的方式:对网络节点退化可以容忍的dropout以及对输入数据退化可以容忍的denoising,都表现在对噪声的抑制。所以,第二个问题可以通过在数据量上的保证和对噪声的抑制来解决。

对于第三个问题,deep learning的layer越多,权重也就越多,在进行优化的时候就更加容易出现局部最优,因为变量多了,想象一下,似乎连绵起伏的山一样,局部最优的情况也就更加容易发生。那么如果克服发生局部最优的优化问题呢?可以通过一个叫做pre-training的方法,慎重的对权重进行初始化,使得权重一开始就出现在全局最优的那个“山峰”上,然后通过梯度下降或者随机梯度的方式往下滚,直到全局最优。所以,这个pre-training就可以克服局部最优的问题,后面也将是我们讲解的一个重点。

对于第四个问题,计算的复杂度是与deep learning的结构复杂度正相关的,但是不用担心,一个强有力的硬件支持或者架构支持已经被用来进行深度神经网络的训练和计算,那就是GPU或FPGA这种可以进行大量的硬件上的并行计算的处理器。所以第四个问题只要通过选择专用的硬件平台就可以解决。

那么四个问题都加以了分析和解决,我们下面的重点在于pre-training的机制,如何获得较好的网络初始值呢?

上图就是典型的深度神经网络的训练过程,先通过pre-training进行网络参数的初始设置,然后再通过第二步利用误差回传机制对网络参数进行调优(fine-tune)。

那么这个pre-training的具体是如何进行的呢?实际上就是如上图所示,每次只进行两层之间的参数训练,确定之后再往其紧接着的上面两层参数进行训练,就这样逐层的训练。那么训练的机制呢?就是今天的第二个topic,autoencoder,自动编码器。

topic 2  自动编码器

那么我们看,自动编码器是如何实现的。在这之前,先说明一个概念:information preserving,就是信息保持,我们在层与层之间的进行的特征转换实际上就是一个编码的过程,那么一个好的编码就是能够做到information preserving。所以一个好的特征转换就是转换后的特征能够最大限度地保留原始信息,而不至于使得信息变得面目全非。转换后的特征是raw features的一个好的representation。且看下图:

我们还以原来的手写体数字的识别为例,将原始特征(raw features,pixels)转换为笔画特征是一个好的特征转换吗?能够保持原始信息吗?那么如何衡量这个信息是不是丢失了呢?自然而然就想到了,我把数字1的转化成了笔画,那么这些笔画能不能重新组合表示为数字1呢?根据上面的介绍,我们可以做到从1到笔画,然后还可以从笔画再到1的过程。这就是很好的信息保持(information preserving)。那么根据这种由输入通过一层hidden layer,然后再转变为输入的机制去评估信息保持的效果,去衡量特征转化的品质。那么就得到以下的一个训练机制,且看下图:

这就是我们要将的pre-training的机制。由输入经编码权重得到原始数据的特征转换,然后再由特征转换经解码权重得到原始数据的机制。整个映射实际上就是一个identity function,因为输出=输入嘛!

那么实际上我们设计的这个训练过程能够应用到监督学习和非监督学习。对于监督学习,我们可以用来学习数据的informative representation,hidden layer的输出就是。对于非监督学习,我们可以用来进行密度估计(density estimation):当g(x)≈x时的x处的密度更大;还可以用来进行outlier检测:那些g(x)与x相差远的x就可以作为outlier。那些g(x)≈x的隐藏层输出,能够作为x的典型表示(typical representation)。

因此,一个基本的autoencoder的完整流程就有了,且看下图:

因为上面解释的就比较多了,下面就不再对这个流程进行详细说明。一个需要点出的就是使得编码权重Wij与解码权重Wji相等可以用来作为一种形式的regularization。而整个训练一层一层的进行实际上就是一个只有两层的类神经网络,进行误差回传和梯度下降计算的复杂度都不会很大。

有了pre-training,于是乎我们的deep learning的过程就变成了下图:

上面讲完了通过pre-training得到较好的初始权重,以便于整个deep learning能够在开始训练的时候就站在一个非常好的位置,即在一定程度上避免由于模型结构复杂度导致的overfitting发生的风险。由此引出的autoencoder。

那么前面讲为了克服overfitting的风险,还可以从另一个角度:noise的角度出发。下面我们就进行denoising autoencoder的相关内容。

topic 3  去噪自动编码器

在类神经网络中其实已经介绍过一些用于regularization的方法,比如通过限制模型输出的精度、权重的消减或者提前终止训练等,那么下面介绍的是一种比较另类的regularization的方法。

上面说了,基于消除噪声的方式,一般直接的想法或者常用的是data cleaning/pruning,那么我们这里介绍的也不是这种常规的方法,而是一种反向思维的方式:如果我直接往输入数据中加入人工的噪声呢?会发生什么样的情况。这就是我们下面要探讨的去噪自动编码器。

这种往input中添加噪声的思维是以robustness健壮性出发的,试想如果我加完噪声后的数据作为输入,经过编码和解码后,如果输出依然等于加入噪声前的数据,这样的类神经网络结构是不是非常的稳健,也就说抗干扰能力很强。基于此想法,我们就得到denoising autoencoder的方法,且看下图

所以输入时x+人工噪声,标签是x,这样来对网络进行训练,这样的神经网络结构自然就具备了denosing的效果。

topic 4  线性自动编码器与主成分分析

所以前面讲的都是直接基于非线性映射的结构,而一般上我们常常是先通过线性的解释,然后再拓展至非线性。那么我们看看线性自动编码器是怎样的,看下图:

我们依然通过平方误差进行推导,推导过程见下图,总之就是一堆矩阵的运算,如果学过矩阵分析课程看起来并不复杂,实际上就是进行谱分解,看不懂也没关系,只要知道处理过程就好,求输入矩阵的最大特征值和其对应的特征向量,实际上这也是PCA处理的过程(PCA基于matlab的代码链接,小弟资源分不够,求个资源分勿怪)。

那么实际上,linear 的autoencoder实际上与主成分分析是非常相近的,只不过主成分分析具有统计学的说明。进行特征转换后的方差要大。我们把数据进行零均值化作为autoencoder的输入,结果就跟PCA一样了。具体的关系可以看下图说明:

*************************************************************************************************************************************

通过以上的介绍,相信对整个deep learning的架构有了一定认识,当然这里面介绍的大部分都是入门级的知识,不过有了一个guideline之后,再去对更加细节的设计方法进行学习时就能有更加宏观方向的把握。


转载于:https://www.cnblogs.com/huty/p/8519323.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/405422.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sockaddr和sockaddr_in的区别

From: http://www.it165.net/pro/html/201211/4066.html 初学者很容易对二者有困惑的感觉,下面来讲一下二者的区别。 sockaddr是在头文件 /usr/include/bits/socket.h 中定义的,如下: view sourceprint?1.struct sockaddr2.{3.__SOCKADDR_C…

[react] 什么时候使用状态管理器?

[react] 什么时候使用状态管理器? 1用户的使用方式复杂 2.不同身份的用户有不同的使用方式(比如普通用户和管理员) 3.多个用户之间可以协作 4.与服务器大量交互,或者使用了WebSocket 5.View要从多个来源获取数据 从组件角度看 1.…

FlexViewer2.3中拉帘Widget下载

http://www.giser.net/?p280 由于最新的ArcGIS API for flex2.x使用了Flex SDK4,因此造成了对之前ArcGIS API for flex1.x制 作的拉帘Widget无法使用,因此重新制作了拉帘工具供大家使用。 下载地址: Swipe 使用方法:将下载后的sw…

scanf sscanf 的用法

一、scanf函数 scanf() - 以屏幕(stdin)为输入源,提取输入指定格式的数据,返回提取的数据个数。 函数原型:int scanf( const char *format [,argument]... ); 二、sscanf函数 sscanf() - 从一个字符串中读进与指定格式相符的数据,非常适合…

spring ioc原理

IOC(DI):java程序员都知道:java程序中的每个业务逻辑 至少需要两个或以上的对象来协作完成,通常,每个对象在使用他的合作对象时,自己均要使用像new object() 这样的语法来…

五种I/O 模式——阻塞(默认IO模式),非阻塞(常用语管道),I/O多路复用(IO多路复用的应用场景),信号I/O,异步I/O

From: http://blog.163.com/xychenbaihuyeah/blog/static/13222965520112163171778/ 五种I/O 模式: 【1】 阻塞 I/O (Linux下的I/O操作默认是阻塞I/O,即open和socket创建的I/O都是阻塞I/O) 【2】 非阻塞 I/O (可以通过f…

【hive】Hive中的大宽表及其底层详细技术点

简介: 在大数据环境中,处理大规模数据集是常见的需求。为了满足这种需求,Hive引入了大宽表(Large Wide Table)的概念,它是一种在Hive中管理和处理大量列的数据表格。本文将详细介绍Hive中的大宽表概念以及其底层的详细…

[react] render函数中return如果没有使用()会有什么问题?

[react] render函数中return如果没有使用()会有什么问题? 我们在使用JSX语法书写react代码时,babel会将JSX语法编译成js,同时会在每行自动添加分号(;),如果return后换行了,那么就会…

小程序tabbar文字在服务器上不显示,小程序的tabbar不显示

1. tabbar 不显示刚开始给页面加tabbar时{"pages":["pages/index/index","pages/all/all","pages/relax/relax","pages/me/me","pages/wen/wen","pages/logs/logs"],"window":{"backgro…

Linux fprintf的用法

一、fprintf 函数描述 fprintf其作用是格式化打印,也叫格式化输出,可以指定输出到一个流文件中,即相输出流中写入数据。fprintf()函数根据指定的格式(format),向输出流(stream)写入数据(argument)。fprintf( )会根据参数format 字…

2015 7 18

ExecuteNonQuery返回的是受影响的行数ExecuteScalar返回的是第一行第一列的值 制作密码找回的冻结功能 一个变量 当点击提交密码问题答案时1 达到3次时 数据库中的时间项纪录为当前时间 返回首页 执行找回密码操作时 点击下一步 先进行判定 如果用户名存在 其当前日期-冻…

windows组件向导里没有internet 信息服务(iis) 的解决办法

From: http://blog.163.com/red419126/blog/static/18862284200882155215627/ 电脑要重装系统,借同事的xp光盘,一切顺利。却发现这个新系统添加删除组件向导里没有iis了。怎么办呢? 在运行中输入"c:\windows\inf\sysoc.inf"&…

Linux tm time_t timeval timespec以及与时间相关函数用法

一、时间类型 linux中编程通常需要用到时间变量&#xff0c;和相关的时间操作函数。常用的时间类型有&#xff1a; time_t 、struct timeval、struct timespec、struct tm。 在用到相关的类型和函数时&#xff0c;需要加上头文件&#xff1a;#include <time.h> …

Apache的prefork模式和worker模式

prefork模式 这个多路处理模块(MPM)实现了一个非线程型的、预派生的web服务器&#xff0c;它的工作方式类似于Apache 1.3。它适合于没有线程安全库&#xff0c;需要避免线程兼容性问题的系统。它是要求将每个请求相互独立的情况下最好的MPM&#xff0c;这样若一个请求出现问题就…

[react] 说说Context有哪些属性?

[react] 说说Context有哪些属性&#xff1f; context属于一种解决组件间层级过多传递数据的问题&#xff0c;避免了层层嵌套的通过props传递的形式&#xff0c;同时对于不需要使用到redux时&#xff0c;是一种解决方案&#xff0c;关于组件的复用性变差的问题&#xff0c;我觉…

艾泰路由器设置虚拟服务器,艾泰路由器设置步骤

艾泰路由器设置步骤艾泰科技路由器默认配置完之后就可以上网&#xff0c;内网私网地址通过WAN口的"NAT转换来上网。但某些特殊时候却不需要NAT模式&#xff0c;用户需要纯路由模式来转发&#xff0c;下面是小编整理的相关内容&#xff0c;欢迎阅读参考&#xff01;ReOS V2…

ubuntu 安装(install) pwntcha[一个做验证码识别的开源程序]

一、安装 1. sudo apt-get install libsdl1.2-dev libsdl1.2debian sudo apt-get install libsdl1.2-dev(比较大&#xff0c;10M左右) sudo apt-get install libsdl-image1.2-dev sudo apt-get install libsdl-mixer1.2-dev sudo apt-get install libsdl-ttf2.0-dev sudo apt-g…

IIS出现The specified module could not be found解决方法

From: http://www.cnblogs.com/hanxianlong/archive/2008/10/25/1319269.html 打开IIS 信息服务&#xff0c;在左侧找到自己的计算机&#xff0c;点右键&#xff0c;选择属性&#xff0c;在主属性中选编辑&#xff0c;打开“目录安全性”选项卡&#xff0c;单击“匿名访问和验…

嵌入式开发中模拟SPI的驱动

这里贴一下自己的模拟SPI驱动&#xff0c;移植的话需要实现SPI管脚的定义和初始化。 一、管脚初始化 MOSI_PIN&#xff1a;设置MOSI为输出模式SCK_PIN&#xff1a;设置SCK为输出模式CSN_PIN&#xff1a;设置CSN为输出模式MISO_PIN&#xff1a;设置MISO为输入模式MOSI_PIN_HIG…

开始整理资料

现在想想为什么这么晚才在CSDN安家&#xff0c;如果大一的时候就开始写博客了&#xff0c;记录生活的点点滴滴&#xff0c;那该有多好。 回去以前做过的许多事情&#xff0c;总是一知半解&#xff0c;如果当时能够想到写博客&#xff0c;那么理解程度就不是现在这个样子了。 知…