My blog in AI ---神经网络,神经元(neural network,nervecell)
尽管我们有很多经验丰富的软件开发人员,但是利用hard code的方法,要解决一些问题,我们的程序员还是优点捉襟见肘,这些问题包括,识别手写数字照片上的数字;分辨一张彩色照片上是否有一只猫咪;准确理解老婆说的“男人说话要是算数,母猪也会上树”这句话的真实含义,等等。这些我们人类处理起来得心应手的问题,计算机程序处理起来却显得很笨拙。
当然,有问题就要去寻找解决方案。其实在很早的时候,我们的计算机科学家前辈们就开始做了这方面的研究,提出的理论和算法有SVM,神经网络等。但是在那个GPU还没有发明,移动互联网还没有普及的年代,相关的算法并不能取得很好的效果,这方面的研究也就没有引起业界的重视。近年来,随着计算机计算能力的增强和大数据时代数据的爆发性增长,神经网络在解决上述问题的过程中取得了非常出色的成绩,例如,像google alpha战胜李世石这样的标志性事件。神经网络在向未来的AI时代开进的过程中,可谓是出尽了风头,前景一片光明。
对于神经网络,全称应该是人工神经网络,是对生物神经网络的模拟。大概的,对生物神经网络的模拟主要分为3个部分,即结构,神经元和突触。首先,我们从神经元聊起。
1神经元
1.1 感知器
要理解一个事物,我感觉最好的办法就是理解他的发展过程。从他的发展历史来看,就能更加深入的理解他为什么是这个样子。
对神经元,我想从感知器聊起。感知器是早期神经网络中的神经元的模型,用来模拟神经元对事件的决策。感知器在上个世纪60年代由Frank Rosenblatt发明,虽然现在使用更为广泛的是S型神经元、ReLU等,但是了解感知器,能够对这门技术的发展有一个更好的理解。
感知器是这样一个简单的模型,如下图所示:

感知器接受若干个输入,产生一个输出,输出的计算方式如下:

, 这是一个向量的形式,表示对所有的输入给不同的权重,输入到感知器中;b是一个阈值(偏置),可以用来表示感知器输出0或者1的难易程度。
例如,我们要用感知器来决策周末要不要去爬山,输入有这么3项,分别为周末的天气晴朗(x1),女朋友想去(x2),有基友相约开黑(x3)。输出1表示要去爬山。
如果我们觉得天气晴朗是最关键的因素,那么我们可以设置w1 = 5, w2=1, w3=-1, b= -1
如果我们觉得有基友约开黑这种事情千万不能错过的话,可以设置权重和偏置为 w1 = 1 w2=1, w3=-5, b= -1
总的来说,通过感知器,设置不同的权重和偏置,我们可以对不同的事情做出不同的决策。通过修改权重和偏置,我们可以找到最适合我们应用的感知器模型,用来解决现实的问题。
但是感知器有它的问题,因为训练神经网络的核心在于得到网络中合适的权重和偏置,通常我们需要不断的调整权重和偏置,使得训练样本的结果不断的接近正确的结果。这就需要一个对权重和偏置的微小调整对输出的影响也是微小的(是不是感觉有点懵,没关系,先跳过,后面介绍了梯度下降和反向传播算法你就豁然开朗了)。我们把输入Z=wx+b, 画出输入与输出的曲线,如图:

从图中可以看出,感知器的曲线是非连续的,在Z=0时有一个阶跃。当我们改变权重和偏置使得Z从正数变成负数或者从负数变成正数时,会对输出造成一个反转。这样会使得神经网络的训练变得非常困难。由此,S型神经元随之提出。
1.2 S型神经元
S型神经元其实与感知器非常的相似,模型也大致如下:

区别在于,S型神经元引入了一个激活函数,sigmoid function, 该函数的定义为:

对S型神经元,可以更为清晰的表示其输出为:

我们先看看S型神经元的曲线:

从图中可以看出,S型神经元是连续的,比感知器要平滑。
S型神经元有很多的优势:
My blog in AI ---神经网络,神经元(neural network,nervecell)的更多相关文章
- 递归神经网络(Recursive Neural Network, RNN)
信息往往还存在着诸如树结构.图结构等更复杂的结构.这就需要用到递归神经网络 (Recursive Neural Network, RNN),巧合的是递归神经网络的缩写和循环神经网络一样,也是RNN,递 ...
- 卷积神经网络(Convolutional Neural Network, CNN)简析
目录 1 神经网络 2 卷积神经网络 2.1 局部感知 2.2 参数共享 2.3 多卷积核 2.4 Down-pooling 2.5 多层卷积 3 ImageNet-2010网络结构 4 DeepID ...
- 深度学习FPGA实现基础知识10(Deep Learning(深度学习)卷积神经网络(Convolutional Neural Network,CNN))
需求说明:深度学习FPGA实现知识储备 来自:http://blog.csdn.net/stdcoutzyx/article/details/41596663 说明:图文并茂,言简意赅. 自今年七月份 ...
- 人工神经网络 Artificial Neural Network
2017-12-18 23:42:33 一.什么是深度学习 深度学习(deep neural network)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高 ...
- [C4] 前馈神经网络(Feedforward Neural Network)
前馈神经网络(Feedforward Neural Network - BP) 常见的前馈神经网络 感知器网络 感知器(又叫感知机)是最简单的前馈网络,它主要用于模式分类,也可用在基于模式分类的学习控 ...
- 详解循环神经网络(Recurrent Neural Network)
本文结构: 模型 训练算法 基于 RNN 的语言模型例子 代码实现 1. 模型 和全连接网络的区别 更细致到向量级的连接图 为什么循环神经网络可以往前看任意多个输入值 循环神经网络种类繁多,今天只看最 ...
- 脉冲神经网络Spiking neural network
(原文地址:维基百科) 简单介绍: 脉冲神经网络Spiking neuralnetworks (SNNs)是第三代神经网络模型,其模拟神经元更加接近实际,除此之外,把时间信息的影响也考虑当中.思路是这 ...
- My blog in AI ---神经网络,网络架构
上一篇博文中,我们介绍了神经网络中的神经元,那么该如何组织起来这些神经元,才能发挥出最好的效果去解决现实中的问题呢? 这是一个复杂的问题,在工程中,神经网络的架构也是训练的也是一种超参数,本节先在理论 ...
- 【原创】深度神经网络(Deep Neural Network, DNN)
线性模型通过特征间的现行组合来表达“结果-特征集合”之间的对应关系.由于线性模型的表达能力有限,在实践中,只能通过增加“特征计算”的复杂度来优化模型.比如,在广告CTR预估应用中,除了“标题长度.描述 ...
随机推荐
- JS开启浏览器全屏模式,需要手动触发
<html > <meta charset="UTF-8"> <body> <button onclick="launchFul ...
- soj1767.传纸条
这道题目想了一会儿觉得不知道如何下手,上网看了下资料,原来这道是一道非常经典的题目. 设 f [ k ][ i ][ j ] 表示第 k 步,第 1 条路径走到第 i 行,第 2 条路径走到第 j 行 ...
- 网页制作中最有用的免费Ajax和JavaScript代码库
网上看到的一篇小文,挺有用的,收藏在这. 本文中,我整理了12个免费的Ajax和JavaScript代码库,可以帮助Web开发人员将应用程序提升到一个新水平. Ajax Instant Messeng ...
- [csp-201509-3]模板生成系统
#include<bits/stdc++.h> using namespace std; ; string a[N],b[N],c[N]; int main() { //freopen(& ...
- 20155305乔磊2016-2017-2《Java程序设计》第八周学习总结
20155305乔磊2016-2017-2<Java程序设计>第八周学习总结 教材学习内容总结 通用API 日志API 1.java.util.logging包提供了日志功能相关类与接口, ...
- NameValuePair方式传参数
今天工作中联调外部的一个接口用post方式传输,我按照文档封装参数成Jason字符串传入,但是对方一直接受参数为空,折腾了半天也没找到问题.很苦恼,检查代码都没有错误,可是为什么对方接受参数为空呢?然 ...
- 【数据库】SQL经典面试题 - 行列转换二 - 列转行
本帖子是行转列的一个逆向操作——列转行,看下面一个面试题 面试题2: 柠檬班第30期学生要毕业了,他们的Linux.MySQL.Java成绩数据表 tb_lemon_grade_column中, 表中 ...
- 双击CAD对象,显示自定义对话框实现方法
class TlsApplication : IExtensionApplication { void IExtensionApplication.Initialize() { TTest.Start ...
- 零值比较--BOOL,int,float,指针变量与零值比较的if语句
这是程序员面试的一道常见题,也是个C++基础问题.若只在大学里看过几本基础的编程入门书,看见这道题可能会觉得奇怪,不就是和0比较吗,直接拿出来比就是了,其实非也.下文引自google搜索结果,出处不详 ...
- Oracle 11.2.0.4在线(Online mode)打补丁14084247解决WRH$_ACTIVE_SESSION_HISTORY不会自动切割的问题
安装了Oracle Database Release 11.2.0.4之后,发现WRH$_ACTIVE_SESSION_HISTORY始终不会自动分割删除, 后来才发现需要应用补丁:14084 ...