多层感知机

  • 一,多层感知机
    • 1.1 现在已有的门电路组合
    • 1.2 异或门的实现
  • 二,从与非门到计算机
  • 三,总结

一,多层感知机

  在上一篇深度学习——感知机(perceptron)图文详解中我们已经讨论完了简单感知机的原理和实现了,同时也知道了简单感知机的局限性了,不能表示异或门这点让人深感遗憾。今天我们就将介绍多层感知机,它可以通过“叠加层”来表示异或门。不过,我们先暂时不考虑叠加层具体是指什么,先从其他视角来思考一下异或门的问题

1.1 现在已有的门电路组合

  异或门的制作方法有很多,其中之一就是组合我们前面做好的与门、与非门、或门进行配置。这里,与门、与非门、或门用图1中的符号表示。

图1

  另外,图1中与非门前端的○表示反转输出的意思。那么,如果要实现异或门的话,需要如何配置与门、与非门和或门呢?是不是用与门、与非门、或门代替图2中的各个“?”,就可以实现异或门。

图2

  我们前面讲到的感知机的局限性,严格地讲,应该是“单层感知机无法表示异或门”或者“单层感知机无法分离非线性空间”。不过接下来我们就将看到通过组合感知机(叠加层)就可以实现异或门了。
  异或门可以通过图3所示的配置来实现。这里, x1和x2表示输入信号,y表示输出信号。 x1和x2是与非门和或门的输入,而与非门和或门的输出则是与门的输入。

图3

  现在,我们来确认一下图3的配置是否真正实现了异或门。这里,把s1作为与非门的输出,把s2作为或门的输出,填入真值表中。结果如图4所示,观察x1、 x2、 y,可以发现确实符合异或门的输出。

图4 异或门的真值表

1.2 异或门的实现

  下面我们试着用Python来实现图3所示的异或门。使用之前定义的AND函数、 NAND函数、 OR函数,可以像下面这样的实现。

def XOR(x1, x2):s1 = NAND(x1, x2)s2 = OR(x1, x2)y = AND(s1, s2)return y

这个XOR函数会输出预期的结果。

XOR(0, 0) # 输出0
XOR(1, 0) # 输出1
XOR(0, 1) # 输出1
XOR(1, 1) # 输出0

  这样,异或门的实现就完成了。下面我们试着用感知机的表示方法(明确地显示神经元)来表示这个异或门,结果如图5所示。如图5,异或门是一种多层结构的神经网络。这里,将最左边的一列称为第0层,中间的一列称为第1层,最右边的一列称为第2层。图5的感知机与前面介绍的与门、或门的感知机(上一篇中的图1)形状不同。实际上,与门、或门是单层感知机,而异或门是2层感知机。叠加了多层的感知机也称为多层感知机(multi-layered perceptron)。

图5 感知机表示异或门

  图5中的感知机总共由3层构成,但是因为拥有权重的层实质上只有2层(第0层和第1层之间,第1层和第2层之间),所以称为“2层感知机”。不过,也有的文献认为图5的感知机是由3层构成的,因而将其称为“3层感知机”。
  在图5所示的2层感知机中,先在第0层和第1层的神经元之间进行信号的传送和接收,然后在第1层和第2层之间进行信号的传送和接收,具体如下所示。
1.第0层的两个神经元接收输入信号,并将信号发送至第1层的神经元。
2.第1层的神经元将信号发送至第2层的神经元,第2层的神经元输出y。

  这种2层感知机的运行过程可以比作流水线的组装作业。第1段(第1层)的工人对传送过来的零件进行加工,完成后再传送给第2段(第2层)的工人。第2层的工人对第1层的工人传过来的零件进行加工,完成这个零件后出货(输出)。
  像这样,在异或门的感知机中,工人之间不断进行零件的传送。通过这样的结构(2层结构),感知机得以实现异或门。这可以解释为“单层感知机无法表示的东西,通过增加一层就可以解决”。也就是说,通过叠加层(加深层),感知机能进行更加灵活的表示。

二,从与非门到计算机

  多层感知机可以实现比之前见到的电路更复杂的电路。比如,进行加法运算的加法器也可以用感知机实现。此外,将二进制转换为十进制的编码器、满足某些条件就输出1的电路(用于等价检验的电路)等也可以用感知机表示。实际上,使用感知机是可以表示计算机的。计算机是处理信息的机器。向计算机中输入一些信息后,它会按照某种既定的方法进行处理,然后输出结果。所谓“按照某种既定的方法进行处理”是指,计算机和感知机一样,也有输入和输出,会按照某个既定的规则进行计算。人们一般会认为计算机内部进行的处理非常复杂,而实际上只需要通过与非门的组合,就能再现计算机进行的处理。这说明了什么?说明使用感知机也可以表示计算机。前面也介绍了,与非门可以使用感知机实现。也就是说,如果通过组合与非门可以实现计算机的话,那么通过组合感知机也可以表示计算机(感知机的组合可以通过叠加了多层的单层感知机来表示)。
  综上,多层感知机能够进行复杂的表示,甚至可以构建计算机。那么,什么构造的感知机才能表示计算机呢?层级多深才可以构建计算机呢?理论上可以说2层感知机就能构建计算机。这是因为,已有研究证明,2层感知机(严格地说是激活函数使用了非线性的sigmoid函数的感知机)可以表示任意函数。但是,使用2层感知机的构造,通过设定合适的权重来构建计算机是一件非常累人的事情。实际上,在用与非门等低层的元件构建计算机的情况下,分阶段地制作所需的零件(模块)会比较自然,即先实现与门和或门,然后实现半加器和全加器,接着实现算数逻辑单元(ALU),然后实现CPU。因此,通过感知机表示计算机时,使用叠加了多层的构造来实现是比较自然的流程。

三,总结

• 感知机是具有输入和输出的算法。给定一个输入后,将输出一个既定的值。
• 感知机将权重和偏置设定为参数。
• 使用感知机可以表示与门和或门等逻辑电路。
• 异或门无法通过单层感知机来表示。
• 使用2层感知机可以表示异或门。
• 单层感知机只能表示线性空间,而多层感知机可以表示非线性空间。
• 多层感知机(在理论上)可以表示计算机。
  结合上一篇,我们学习了感知机。感知机是一种非常简单的算法,要理解它的构造并不难,不过因为感知机是学习的神经网络的基础,因此弄明白感知机是非常重要的。

参考文献: 深度学习入门:基于Python的理论与实现Deep Learning from Scratch

深度学习——感知机:多层感知机(multi-layered perceptron)图文详解相关推荐

  1. 重磅!深度学习的顶级会议ICLR 2020 数据图文详解

    点上方蓝字计算机视觉联盟获取更多干货 在右上方 ··· 设为星标 ★,与你不见不散 编辑:Sophia 计算机视觉联盟  报道  | 公众号 CVLianMeng 转载于 :medium,机器之心,学 ...

  2. 深度学习之目标检测(十一)--DETR详解

    深度学习之目标检测(十一)-- DETR详解 目录 深度学习之目标检测(十一)-- DETR详解 1. 前言 2. DETR 框架 2.1 CNN Backbone 2.2 Transformer E ...

  3. 笔记 | 百度飞浆AI达人创造营:深度学习模型训练和关键参数调优详解

    笔记 | 百度飞浆AI达人创造营:深度学习模型训练和关键参数调优详解 针对特定场景任务从模型选择.模型训练.超参优化.效果展示这四个方面进行模型开发. 一.模型选择 从任务类型出发,选择最合适的模型. ...

  4. 深度学习模型训练和关键参数调优详解

    深度学习模型训练和关键参数调优详解 一.模型选择 1.回归任务 人脸关键点检测 2.分类任务 图像分类 3.场景任务 目标检测 人像分割 文字识别 二.模型训练 1.基于高层API训练模型 加载数据集 ...

  5. Keras深度学习实战(26)——文档向量详解

    Keras深度学习实战(26)--文档向量详解 0. 前言 1. 文档向量基本概念 2. 神经网络模型与数据集分析 2.1 模型分析 2.2 数据集介绍 3. 利用 Keras 构建神经网络模型生成文 ...

  6. 【深度学习】扩散模型(Diffusion Model)详解

    [深度学习]扩散模型(Diffusion Model)详解 文章目录 [深度学习]扩散模型(Diffusion Model)详解 1. 介绍 2. 具体方法 2.1 扩散过程 2.2 逆扩散过程 2. ...

  7. Keras深度学习实战(22)——生成对抗网络详解与实现

    Keras深度学习实战(22)--生成对抗网络详解与实现 0. 前言 1. 生成对抗网络原理 2. 模型分析 3. 利用生成对抗网络生成手写数字图像 小结 系列链接 0. 前言 生成对抗网络 (Gen ...

  8. Keras深度学习实战(21)——神经风格迁移详解

    Keras深度学习实战(21)--神经风格迁移详解 0. 前言 1. 神经风格迁移原理 2. 模型分析 3. 使用 Keras 实现神经风格迁移 小结 系列链接 0. 前言 在 DeepDream 图 ...

  9. 深度学习基础——多层感知机

    多层感知机(Multilayer Perceptron, MLP)是最简单的深度网络.本文回顾多层感知机的相关内容及一些基本概念术语. 多层感知机 为什么需要多层感知机 多层感知机是对线性回归的拓展和 ...

  10. 动手学深度学习之多层感知机

    多层感知机 多层感知机的基本知识 深度学习主要关注多层模型.本节将以多层感知机(multilayer perceptron,MLP)为例,介绍多层神经网络的概念. 隐藏层 下图展示了一个多层感知机的神 ...

最新文章

  1. 二分算法,选择,冒泡排序算法
  2. python基础(7)-函数命名空间作用域闭包
  3. python 什么是先验概率?
  4. 阿里公共DNS正式发布:223.5.5.5 223.6.6.6
  5. 链接在HTML的英文,英文:A链接标记ie下会自动补全href_HTML/Xhtml_网页制作
  6. python3虚拟环境使用教程_python虚拟环境完美部署教程
  7. Docker快速入门实践-纯干货文章
  8. 关于MQTT协议的说明
  9. 【转载】Kubernetes 加入Docker 平台,Mac和Windows开发者的福音
  10. Android开发笔记(七)初识Drawable
  11. Flex通过Java读取Excel(详细流程)----Excel在客户端(DataGrid动态根据Excel生成)
  12. 谷歌免费GPU训练星际2AI好难?你需要份debug指南
  13. mock SpringMVC 测试控制器方法
  14. mysql主从表单如何设计_如何快速的10分钟制作一张主从表单及功能
  15. 软件包管理器前端工具yum的使用
  16. 软件测试 测试用例笔记
  17. 关于foobar2000中Convolver,大家觉得哪个Impulse效果最好?
  18. HTML基础学习(菜鸟教程和W3school参考手册)
  19. scratch 编程 + 小学数学
  20. 【EmailCamel 国外邮件营销、美国邮件群发】邮件到达收件箱系列文章05:免费公共邮箱作为发件人的限制

热门文章

  1. php 跳转邮箱,JS简单实现点击跳转登陆邮箱功能的方法
  2. HashTab-查看哈希值小工具,一键插件文件md5值
  3. HTML+CSS+JS实现 ❤️ 立方体旋转图片切换特效❤️
  4. 谷歌邮箱lmap服务器填什么_SMTP和IMAP是什么?
  5. rabbitmq集群安装与配置(故障恢复)
  6. 基于线性表的图书信息管理系统
  7. excel填充遇到的坑
  8. 台式计算机打印机共享,电脑不能共享打印机怎么办 电脑设置共享打印机详细教程...
  9. live2d内嵌html,为你的博客博客/网页添加Live2d二次元老婆的插件/手动方法
  10. frameset和frame的使用方法