感知机(Perceptron)为什么不能表示异或(XOR)
1.感知机不能表示异或
在很早之前学Pattern Recognition相关课程的时候,老师在课堂上就说过感知机遇到的一个大问题就是无法表示异或问题(XOR)。后来接触深度学习相关的内容,开头部分肯定会提到感知机,提到感知机也必会提到不能表示异或的问题。正好抽出点时间,稍微搞明白一下为什么感知机不能表示异或。
2.感知机的数学定义
感知机到底是什么呢?首先来看一下他的数学定义:
假设输入空间(即样本的特征空间)为
此函数被称为感知机。其中,
感知机是一种线性分类模型,属于判别模型。
3.异或是线性不可分
异或之所以重要,是因为它相对于其他逻辑关系,例如与(AND), 或(OR)等,异或是线性不可分的。
由这幅简单的示意图可以看出来,and(与)、or(或)、not and(与非)等运算很容易用一条直线分开,但是异或运算中,图示的1,2,3条许仙都无法分开,异或运算就是典型的非线性问题!
具体的数学证明过程可以看后面的参考内容
参考文献:
1.https://zh.wikipedia.org/wiki/%E6%84%9F%E7%9F%A5%E5%99%A8
2.https://www.zybuluo.com/ArrowLLL/note/827264 有数学证明过程
3.https://zhuanlan.zhihu.com/p/30155870