一文讲清神经网络、BP神经网络、深度学习的关系

原创文章,转载请说明来自《老饼讲解神经网络》:www.bbbdata.com/nn

关于《老饼讲解神经网络》:

本网结构化讲解神经网络的知识,原理和代码。

重现matlab神经网络工具箱的算法,是学习神经网络的好助手。 


凡是模仿人的神经网络构建出来的数学模型,都叫神经网络。
神经网络是人工智能的一个主力算法。

神经网络可以归为三块:
(1) BP神经网络
(2) 深度学习。
(3) 其它神经网络

一. 一般神经网络:

一句话概括: 除BP神经网络,深度学习外的人工神经网络。
介绍:
出现得最早,起源于1940+年,该类神经网络非常多,
今天你根据生物神经网络构建一个模型,明天我根据生物神经网络构建一个,可以说是百舸争流。

经典代表:感知机、Hopfield神经网络、径向基神经网络....等等。

二.BP神经网络

一句话概括:人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。

介绍:
大家研究着各种神经网络,研究得不亦乐乎,

突然,
1986年,
来了两个家伙Romelhart 和Mcclelland,
提出了一个特殊的结构,并命名:BP神经网络,

BP神经网络提出后,瞬间崛起后当了主力军。
以致于几乎成为了《神经网络》的代名词,

为什么拎出来特别划为一类?
因为它实在太出名了,在不特指时,往往说神经网络都是指BP神经网络(这一种结构的神经网络)。

它的结构以下:

大家印象中的神经网络是不是都是这种结构?
但其实它只是BP神经网络的特有的结构,
神经网络有千万种结构,只是BP神经网络太普及了,现在大家几乎把BP神经网络结构=神经网络结构,
实际BP神经网络结构仅是神经网络结构的一种。

三. 深度学习

一句话概括:深度学习可以看作是BP神经网络的一种加强版。解决输入极极多的问题。

介绍:
(1)BP在解决多输入时受挫
BP神经网络虽然很牛X,但当要处理图象,音频,文字等问题时,却SB了,

因为这类问题的输入极多(例如一个50*50像素的图象,就有2500个输入 ),
而BP神经网络的参数会随着输入个数指数增长(假设有100个隐节点,则2500个输入在第一层的权重参数就有2500*100个),

参数个数量级太爆炸,导致BP在求解时,很难找到优秀解,就挂B了。

(2)根据业务特性去冗解决问题
这本来是个没办法的事,但偏偏图象,音频这些问题,它的输入存在很严重的相关性(例如相邻像素的值总是相近的),
因此,可以根据这个业务特性,进行输入个数压缩,或者在求解时根据这个业务特性进行特殊讨巧(例如相邻输入对应的权重参数共享),
使BP神经网络又可以解决这类问题了。

(3)颁发新名
问题解决了,BP还是BP,但毕竟,有少许变种了!
不管怎么样,解决了新问题了,得显示牛B,挂个名: 深度学习!

就这样,2006年,开启了全民深度学习年代!不懂点深度学习都不好意思说自己做人工智能。

(4)再掀高潮: 2016年,alpha go的出现,深度学习秀足了风头,开启了全民超级深度学习模式~!
(5)总 结:总的来说,深度学习底层还是BP,你可以把深度学习当成 《专用于解决输入极极多,且输入变量之间有极强相关性的问题》的BP神经网络。


四、总结

(1)神经网络:凡是模仿人的神经网络构建出来的数学模型,都叫神经网络
(2)BP神经网络:神经网络最经典的代表就是BP神经网络,能解决很多问题。
(3)深度学习:深度学习可以看作《加强版BP神经网络》,专用于解决输入极极多,且输入变量之间有极强相关性的问题。
(4)其它神经网络:除了BP神经网络外,还有很多杂七杂八的神经网络,经典的有感知机、Hopfield神经网络、径向基神经网络等等。


相关文章

​《BP神经网络梯度推导》

​​​​​​《BP神经网络提取的数学表达式》

《一个BP的完整建模流程》

  • 26
    点赞
  • 92
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
在Matlab中实现一个两层神经网络可以按照以下步骤进行: 1. 首先,导入所需的库和数据集。你可以使用Matlab内置的神经网络工具箱来实现神经网络。导入你的训练集和测试集数据。 2. 接下来,定义网络的结构。一个两层的神经网络主要由输入层、隐藏层和输出层组成。定义网络的输入层节点数、隐藏层节点数和输出层节点数。 3. 创建和初始化网络的权重矩阵。权重矩阵是网络中连接不同层的权重参数。可以使用随机初始化或者其他方法来初始化权重矩阵。 4. 定义并选择合适的激活函数。激活函数在神经网络中用于实现非线性映射,常用的激活函数有sigmoid、ReLU、tanh等。 5. 实现前向传播算法。前向传播算法是神经网络中的一种计算方法,用于从输入层到输出层计算网络的输出值。 6. 实现反向传播算法。反向传播算法用于根据网络的输出和期望输出更新权重矩阵,从而减小网络的误差。 7. 训练神经网络。使用训练集数据进行多次迭代训练,通过不断更新权重矩阵,使网络的输出与期望输出更加接近。 8. 验证和测试神经网络。使用测试集数据验证网络的性能和准确度。 请注意,以上只是一个基本的框架,具体的实现方式可能会因为你的具体需求或数据集的特点而有所不同。你可以参考中的推导过程和《简单的二层BP神经网络-实现逻辑与门(Matlab和Python)》一文中的实现方法来详细了解具体的代码实现细节。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值