神经元是如何组成神经网络?

上节课我们讲解了,为什么需要神经网络?回答了机器学习深度学习,擅长解决哪类问题之后,这节课我们就要开始讲解神经网络的组成要素神经元,神经元具体是如何工作的?是如何组成神经网络,以及神经元的数学表达式。

首先我们来看一下什么是神经元,我们以生物体的神经元来做类比,比如人脑的神经元是如何工作和构成功?首先我们看到下面这副图。

神经元是如何组成神经网络?_第1张图片

如简单示意图所示,它是由树突、轴突,还有连接树突和轴突的细胞核来组成。树突负责接收其他神经元传过来的信号,由神经细胞核汇总树突传过来的信号量,如果信号量超过了一个阀值,则细胞核通过轴突把信号传递给其他神经元。具体的工作过程见下图:

神经元是如何组成神经网络?_第2张图片

神经细胞接收到树突传过来的信号之后,就开始变红并判断是不是应该输出信号,如果输入的信号之和小于阈值则不输出任何信号,反之则输出大小固定的信号。为什么有阈值这个要求,其实也非常好理解,我们看喜剧之所以会发笑,是因为神经脑细胞传递出来的这个信号超过了我们的笑点,所以我们就笑了,笑点就是阈值。输出信号就是笑和不笑,也可以这样表示,笑用1表示,不笑用0表示。

整个完整的过程可以由下面这个动图来进行演示:

神经元是如何组成神经网络?_第3张图片

整理神经元工作结构如下:

  1. 来自其他多个神经元的信号之和成为神经元的输入。

  2. 如果这个信号之和超过神经元固有的阈值,则点火。

  3. 神经元的输出信号可以用数字信号0和1来表示,即使有多个输出端,其值也是同一个。

在上述3点基础上,我们尝试用数学的方式来表达神经元的工作结构。

我们可以用数学式表示输入信号,由于输入信号是来自相邻神经元的输出信号,所以根据第3点输入信号,也可以用有、无两种信息表示,因此用变量X表示,输入信号时如下所示。

神经元是如何组成神经网络?_第4张图片

接下来我们用数学式表示输出信号,根据第3点输出信号可以用来表示点火与否的“有”“无”两种信息来表示,因此用变量y表示输出信号如下所示。

神经元是如何组成神经网络?_第5张图片

从第1点和第2点可知神经元点火与否是根据来自其他神经元的输入信号的和来判定的,但是这个求和的方式应该不是简单的求和,比如我们在看喜剧小品的过程中之所以会发笑,是因为我们到了演员浮夸的表演,而不仅仅是听到了台词,在看喜剧表演的过程中,很明显视神经细胞所发出的信号量要明显高于听觉带来的信号量,所以对于输入信号的和大脑是通过改变权重来求和的。那么这个改变权重来求和是如何用数学的方式来进行表达呢?仔细看下面这幅图。

神经元是如何组成神经网络?_第6张图片

我们得到了图中的公式1,W1X1+ W2X2 + W3X3 。

根根根据我们总结的第2点,神经元在信号之和超过阀值时点火不超过阀值时不点火,于是利用公式1,点火条件可以如下公式2表示。

神经元是如何组成神经网络?_第7张图片

下面呢,我们将点火条件公式2图形化,以神经元的输入信号之和为横轴神经元的输出信号,y为纵轴将公式2用图形表示出来,如下图所示。当输入信号之和小于θ时,y取值0,反之y取值1。

神经元是如何组成神经网络?_第8张图片

如果我们要用一个函数来表示这个图形就需要用到下面的单位阶跃函数。其图形如下图所示。

神经元是如何组成神经网络?_第9张图片

利用单位阶跃函数。公式2就可以用公式3来表示,

通过下面这个表格可以证明公式2和公式3是等价的。

最后还是给大家留个作业吧。

作业:如果你是产品经理,面向算法工程师提出实现神经元的需求,你要怎么提?如果你是算法工程师,你需要得到什么样的需求,才能够给出神经元的数学表示?

课程结束时,如果觉得课程GET到你了,请一键三连哟!

为了奖励童鞋阅读到最后,给出个彩蛋,推荐阅读《深度学习的数学》,本课程中很多知识点就是来自此书。

你可能感兴趣的:(深度学习,算法设计,神经网络,深度学习,机器学习,人工智能,抽象代数)