Coursera吴恩达《神经网络与深度学习》课程笔记(2)-- 神经网络基础之逻辑回归

红色石头的个人网站:redstonewill.com

上节课我们主要对深度学习(Deep Learning)的概念做了简要的概述。我们先从房价预测的例子出发,建立了标准的神经网络(Neural Network)模型结构。然后从监督式学习入手,介绍了Standard NN,CNN和RNN三种不同的神经网络模型。接着介绍了两种不同类型的数据集:Structured Data和Unstructured Data。最后,我们解释了近些年来深度学习性能优于传统机器学习的原因,归结为三个因素:Data,Computation和Algorithms。本节课,我们将开始介绍神经网络的基础:逻辑回归(Logistic Regression)。通过对逻辑回归模型结构的分析,为我们后面学习神经网络模型打下基础。

1. Binary Classification

我们知道逻辑回归模型一般用来解决二分类(Binary Classification)问题。二分类就是输出y只有{0,1}两个离散值(也有{-1,1}的情况)。我们以一个图像识别问题为例,判断图片中是否有猫存在,0代表noncat,1代表cat。主要是通过这个例子简要介绍神经网络模型中一些标准化的、有效率的处理方法和notations。

这里写图片描述

如上图所示,这是一个典型的二分类问题。一般来说,彩色图片包含RGB三个通道。例如该cat图片的尺寸为(64,64,3)。在神经网络模型中,我们首先要将图片输入x(维度是(64,64,3))转化为一维的特征向量(feature vector)。方法是每个通道一行一行取,再连接起来。由于64x64x3=12288,则转化后的输入特征向量维度为(12288,1)。此特征向量x是列向量,维度一般记为 nx n x

如果训练样本共有m张图片,那么整个训练样本X组成了矩阵,维度是( nx n x ,m)。注意,这里矩阵X的行 nx n x 代表了每个样本 x(i) x ( i ) 特征个数,列m代表了样本个数。这里,Andrew解释了X的维度之所以是( nx n x ,m)而不是(m, nx n x )的原因是为了之后矩阵运算的方便。算是Andrew给我们的一个小小的经验吧。而所有训练样本的输出Y也组成了一维的行向量,写成矩阵的形式后,它的维度就是(1,m)。

2. Logistic Regression

接下来我们就来介绍如何使用逻辑回归来解决二分类问题。逻辑回归中,预测值 h^=P(y=1 | x) h ^ = P ( y = 1   |   x ) 表示为1的概率,取值范围在[0,1]之间。这是其与二分类模型不同的地方。使用线性模型,引入参数w和b。权重w的维度是( nx n x ,1),b是一个常数项。这样,逻辑回归的线性预测输出可以写成:

y^=wTx+b y ^ = w T x + b

值得注意的是,很多其它机器学习资料中,可能把常数b当做 w0 w 0 处理,并引入 x0=1 x 0 = 1 。这样从维度上来看,x和w都会增加一维。但在本课程中,为了简化计算和便于理解,Andrew建议还是使用上式这种形式将w和b分开比较好。

上式的线性输出区间为整个实数范围,而逻辑回归要求输出范围在[0,1]之间,所以还需要对上式的线性函数输出进行处理。方法是引入Sigmoid函数,让输出限定在[0,1]之间。这样,逻辑回归的预测输出就可以完整写成:

y^=Sigmoid(wTx+b)=σ(wTx+b) y ^ = S i g m o i d ( w T x + b ) = σ ( w T x + b )

Sigmoid函数是一种非线性的S型函数,输出被限定在[0,1]之间,通常被用在神经网络中当作激活函数(Activation function)使用。Sigmoid函数的表达式和曲线如下所示:

Sigmoid(z)=11+ez S i g m o i d ( z ) = 1 1 + e − z

这里写图片描述

从Sigmoid函数曲线可以看出,当z值很大时,函数值趋向于1;当z值很小时,函数值趋向于0。且当z=0时,函数值为0.5。还有一点值得注意的是,Sigmoid函数的一阶导数可以用其自身表示:

σ(z)=σ(z)(1σ(z)) σ ′ ( z ) = σ ( z ) ( 1 − σ ( z ) )

这样,通过Sigmoid函数,就能够将逻辑回归的输出限定在[0,1]之间了。

3. Logistic Regression Cost Function

逻辑回归中,w和b都是未知参数,需要反复训练优化得到。因此,我们需要定义一个cost function,包含了参数w和b。通过优化cost function,当cost function取值最小时,得到对应的w和b。

提一下,对于m个训练样本,我们通常使用上标来表示对应的样本。例如 (x(i),y(i)) ( x ( i ) , y ( i ) ) 表示第i个样本。

如何定义所有m个样本的cost function呢?先从单个样本出发,我们希望该样本的预测值 y^ y ^ 与真实值越相似越好。我们把单个样本的cost function用Loss function来表示,根据以往经验,如果使用平方错误(squared error)来衡量,如下所示:

L(y^,y)=12(y^y)2 L ( y ^ , y ) = 1 2 ( y ^ − y ) 2

但是,对于逻辑回归,我们一般不使用平方错误来作为Loss function。原因是这种Loss function一般是non-convex的。non-convex函数在使用梯度下降算法时,容易得到局部最小值(local minumum),即局部最优化。而我们最优化的目标是计算得到全局最优化(Global optimization)。因此,我们一般选择的Loss function应该是convex的。

Loss function的原则和目的就是要衡量预测输出 y^ y ^ 与真实样本输出y的接近程度。平方错误其实也可以,只是它是non-convex的,不利于使用梯度下降算法来进行全局优化。因此,我们可以构建另外一种Loss function,且是convex的,如下所示:

L(y^,y)=(ylog y^+(1y)log (1y^)) L ( y ^ , y ) = − ( y l o g   y ^ + ( 1 − y ) l o g   ( 1 − y ^ ) )

我们来分析一下这个Loss function,它是衡量错误大小的,Loss function越小越好。

当y=1时, L(y^,y)=log y^ L ( y ^ , y ) = − l o g   y ^ 。如果 y^ y ^ 越接近1, L(y^,y)0 L ( y ^ , y ) ≈ 0 ,表示预测效果越好;如果 y^ y ^ 越接近0, L(y^,y)+ L ( y ^ , y ) ≈ + ∞ ,表示预测效果越差。这正是我们希望Loss function所实现的功能。

当y=0时, L(y^,y)=log (1y^) L ( y ^ , y ) = − l o g   ( 1 − y ^ ) 。如果 y^ y ^ 越接近0, L(y^,y)0 L ( y ^ , y ) ≈ 0 ,表示预测效果越好;如果 y^ y ^ 越接近1, L(y^,y)+ L ( y ^ , y ) ≈ + ∞ ,表示预测效果越差。这也正是我们希望Loss function所实现的功能。

因此,这个Loss function能够很好地反映预测输出 y^ y ^ 与真实样本输出y的接近程度,越接近的话,其Loss function值越小。而且这个函数是convex的。上面我们只是简要地分析为什么要使用这个Loss function,后面的课程中,我们将详细推导该Loss function是如何得到的。并不是凭空捏造的哦。。。

还要提一点的是,上面介绍的Loss function是针对单个样本的。那对于m个样本,我们定义Cost function,Cost function是m个样本的Loss function的平均值,反映了m个样本的预测输出 y^ y ^ 与真实样本输出y的平均接近程度。Cost function可表示为:

J(w,b)=1mi=1mL(y^(i),y(i))=1mi=1m[y(i)log y^(i)+(1y(i))log (1y^(i))] J ( w , b ) = 1 m ∑ i = 1 m L ( y ^ ( i ) , y ( i ) ) = − 1 m ∑ i = 1 m [ y ( i ) l o g   y ^ ( i ) + ( 1 − y ( i ) ) l o g   ( 1 − y ^ ( i ) ) ]

Cost function已经推导出来了,Cost function是关于待求系数w和b的函数。我们的目标就是迭代计算出最佳的w和b值,最小化Cost function,让Cost function尽可能地接近于零。

其实逻辑回归问题可以看成是一个简单的神经网络,只包含一个神经元。这也是我们这里先介绍逻辑回归的原因。

4. Gradient Descent

我们已经掌握了Cost function的表达式,接下来将使用梯度下降(Gradient Descent)算法来计算出合适的w和b值,从而最小化m个训练样本的Cost function,即J(w,b)。

由于J(w,b)是convex function,梯度下降算法是先随机选择一组参数w和b值,然后每次迭代的过程中分别沿着w和b的梯度(偏导数)的反方向前进一小步,不断修正w和b。每次迭代更新w和b后,都能让J(w,b)更接近全局最小值。梯度下降的过程如下图所示。

这里写图片描述

梯度下降算法每次迭代更新,w和b的修正表达式为:

w:=wαJ(w,b)w w := w − α ∂ J ( w , b ) ∂ w

b:=bαJ(w,b)b b := b − α ∂ J ( w , b ) ∂ b

上式中, α α 是学习因子(learning rate),表示梯度下降的步进长度。 α α 越大,w和b每次更新的“步伐”更大一些; α α 越小,w和b每次更新的“步伐”更小一些。在程序代码中,我们通常使用dw来表示 J(w,b)w ∂ J ( w , b ) ∂ w ,用db来表示 J(w,b)b ∂ J ( w , b ) ∂ b 。微积分里, dfdx d f d x 表示对单一变量求导数, fx ∂ f ∂ x 表示对多个变量中某个变量求偏导数。

梯度下降算法能够保证每次迭代w和b都能向着J(w,b)全局最小化的方向进行。其数学原理主要是运用泰勒一阶展开来证明的,可以参考我的另一篇博客中的Gradient Descent有提到如何推导:台湾大学林轩田机器学习基石课程学习笔记10 – Logistic Regression

5. Derivatives

这一部分的内容非常简单,Andrew主要是给对微积分、求导数不太清楚的同学介绍的。梯度或者导数一定程度上可以看成是斜率。关于求导数的方法这里就不再赘述了。

6. More Derivative Examples

Andrew给出了更加复杂的求导数的例子,略。

7. Computation graph

整个神经网络的训练过程实际上包含了两个过程:正向传播(Forward Propagation)和反向传播(Back Propagation)。正向传播是从输入到输出,由神经网络计算得到预测输出的过程;反向传播是从输出到输入,对参数w和b计算梯度的过程。下面,我们用计算图(Computation graph)的形式来理解这两个过程。

举个简单的例子,假如Cost function为J(a,b,c)=3(a+bc),包含a,b,c三个变量。我们用u表示bc,v表示a+u,则J=3v。它的计算图可以写成如下图所示:

这里写图片描述

令a=5,b=3,c=2,则u=bc=6,v=a+u=11,J=3v=33。计算图中,这种从左到右,从输入到输出的过程就对应着神经网络或者逻辑回归中输入与权重经过运算计算得到Cost function的正向过程。

8. Derivatives with a Computation Graph

上一部分介绍的是计算图的正向传播(Forward Propagation),下面我们来介绍其反向传播(Back Propagation),即计算输出对输入的偏导数。

还是上个计算图的例子,输入参数有3个,分别是a,b,c。

首先计算J对参数a的偏导数。从计算图上来看,从右到左,J是v的函数,v是a的函数。则利用求导技巧,可以得到:

Ja=Jvva=31=3 ∂ J ∂ a = ∂ J ∂ v ⋅ ∂ v ∂ a = 3 ⋅ 1 = 3

根据这种思想,然后计算J对参数b的偏导数。从计算图上来看,从右到左,J是v的函数,v是u的函数,u是b的函数。可以推导:

Jb=Jvvuub=31c=312=6 ∂ J ∂ b = ∂ J ∂ v ⋅ ∂ v ∂ u ⋅ ∂ u ∂ b = 3 ⋅ 1 ⋅ c = 3 ⋅ 1 ⋅ 2 = 6

最后计算J对参数c的偏导数。仍从计算图上来看,从右到左,J是v的函数,v是u的函数,u是c的函数。可以推导:

Jc=Jvvuuc=31b=313=9 ∂ J ∂ c = ∂ J ∂ v ⋅ ∂ v ∂ u ⋅ ∂ u ∂ c = 3 ⋅ 1 ⋅ b = 3 ⋅ 1 ⋅ 3 = 9

为了统一格式,在程序代码中,我们使用da,db,dc来表示J对参数a,b,c的偏导数。

这里写图片描述

9. Logistic Regression Gradient Descent

现在,我们将对逻辑回归进行梯度计算。对单个样本而言,逻辑回归Loss function表达式如下:

z=wTx+b z = w T x + b

y^=a=σ(z) y ^ = a = σ ( z )

L(a,y)=(ylog(a)+(1y)log(1a)) L ( a , y ) = − ( y l o g ( a ) + ( 1 − y ) l o g ( 1 − a ) )

首先,该逻辑回归的正向传播过程非常简单。根据上述公式,例如输入样本x有两个特征 (x1,x2) ( x 1 , x 2 ) ,相应的权重w维度也是2,即 (w1,w2) ( w 1 , w 2 ) 。则 z=w1x1+w2x2+b z = w 1 x 1 + w 2 x 2 + b ,最后的Loss function如下所示:

这里写图片描述

然后,计算该逻辑回归的反向传播过程,即由Loss function计算参数w和b的偏导数。推导过程如下:

da=La=ya+1y1a d a = ∂ L ∂ a = − y a + 1 − y 1 − a

dz=Lz=Laaz=(ya+1y1a)a(1a)=ay d z = ∂ L ∂ z = ∂ L ∂ a ⋅ ∂ a ∂ z = ( − y a + 1 − y 1 − a ) ⋅ a ( 1 − a ) = a − y

知道了dz之后,就可以直接对 w1 w 1 w2 w 2 和b进行求导了。

dw1=Lw1=Lzzw1=x1dz=x1(ay) d w 1 = ∂ L ∂ w 1 = ∂ L ∂ z ⋅ ∂ z ∂ w 1 = x 1 ⋅ d z = x 1 ( a − y )

dw2=Lw2=Lzzw2=x2dz=x2(ay) d w 2 = ∂ L ∂ w 2 = ∂ L ∂ z ⋅ ∂ z ∂ w 2 = x 2 ⋅ d z = x 2 ( a − y )

db=Lb=Lzzb=1dz=ay d b = ∂ L ∂ b = ∂ L ∂ z ⋅ ∂ z ∂ b = 1 ⋅ d z = a − y

则梯度下降算法可表示为:

w1:=w1α dw1 w 1 := w 1 − α   d w 1

w2:=w2α dw2 w 2 := w 2 − α   d w 2

b:=bα db b := b − α   d b

这里写图片描述

10. Gradient descent on m examples

上一部分讲的是对单个样本求偏导和梯度下降。如果有m个样本,其Cost function表达式如下:

z(i)=wTx(i)+b z ( i ) = w T x ( i ) + b

y^(i)=a(i)=σ(z(i)) y ^ ( i ) = a ( i ) = σ ( z ( i ) )

J(w,b)=1mi=1mL(y^(i),y(i))=1mi=1m[y(i)log y^(i)+(1y(i))log (1y^(i))] J ( w , b ) = 1 m ∑ i = 1 m L ( y ^ ( i ) , y ( i ) ) = − 1 m ∑ i = 1 m [ y ( i ) l o g   y ^ ( i ) + ( 1 − y ( i ) ) l o g   ( 1 − y ^ ( i ) ) ]

Cost function关于w和b的偏导数可以写成和平均的形式:

dw1=1mi=1mx(i)1(a(i)y(i)) d w 1 = 1 m ∑ i = 1 m x 1 ( i ) ( a ( i ) − y ( i ) )

dw2=1mi=1mx(i)2(a(i)y(i)) d w 2 = 1 m ∑ i = 1 m x 2 ( i ) ( a ( i ) − y ( i ) )

db=1mi=1m(a(i)y(i)) d b = 1 m ∑ i = 1 m ( a ( i ) − y ( i ) )

这样,每次迭代中w和b的梯度有m个训练样本计算平均值得到。其算法流程图如下所示:

J=0; dw1=0; dw2=0; db=0;
for i = 1 to m
    z(i) = wx(i)+b;
    a(i) = sigmoid(z(i));
    J += -[y(i)log(a(i))+(1-y(i))log(1-a(i));
    dz(i) = a(i)-y(i);
    dw1 += x1(i)dz(i);
    dw2 += x2(i)dz(i);
    db += dz(i);
J /= m;
dw1 /= m;
dw2 /= m;
db /= m;

经过每次迭代后,根据梯度下降算法,w和b都进行更新:

w1:=w1α dw1 w 1 := w 1 − α   d w 1

w2:=w2α dw2 w 2 := w 2 − α   d w 2

b:=bα db b := b − α   d b

这样经过n次迭代后,整个梯度下降算法就完成了。

值得一提的是,在上述的梯度下降算法中,我们是利用for循环对每个样本进行dw1,dw2和db的累加计算最后再求平均数的。在深度学习中,样本数量m通常很大,使用for循环会让神经网络程序运行得很慢。所以,我们应该尽量避免使用for循环操作,而使用矩阵运算,能够大大提高程序运行速度。关于vectorization的内容我们放在下次笔记中再说。

11. Summary

本节课的内容比较简单,主要介绍了神经网络的基础——逻辑回归。首先,我们介绍了二分类问题,以图片为例,将多维输入x转化为feature vector,输出y只有{0,1}两个离散值。接着,我们介绍了逻辑回归及其对应的Cost function形式。然后,我们介绍了梯度下降算法,并使用计算图的方式来讲述神经网络的正向传播和反向传播两个过程。最后,我们在逻辑回归中使用梯度下降算法,总结出最优化参数w和b的算法流程。

更多AI资源请关注公众号:红色石头的机器学习之路(ID:redstonewill)

这里写图片描述

  • 130
    点赞
  • 226
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 19
    评论
Coursera深度学习教程中文笔记 课程概述 这些课程专为已有一定基础(基本的编程知识,熟悉Python、对机器学习有基本了解), 想要尝试进入人工智能领域的计算机专业人士准备。介绍显示:“深度学习是科技业最热门 的技能之一,本课程将帮你掌握深度学习。” 在这5堂课中,学生将可以学习到深度学习基础,学会构建神经网络,并用在包括吴 恩达本人在内的多位业界顶尖专家指导下创建自己的机器学习项目。Deep Learning Specialization对卷积神经网络 (CNN)、递归神经网络 (RNN)、长短期记忆 (LSTM) 等深度学 习常用的网络结构、工具和知识都有涉及。 课程中也会有很多实操项目,帮助学生更好地应用自己学到的深度学习技术,解决真实 世界问题。这些项目将涵盖医疗、自动驾驶、和自然语言处理等时髦领域,以及音乐生成等 等。Coursera上有一些特定方向和知识的资料,但一直没有比较全面、深入浅出的深度学习 课程——《深度学习专业》的推出补上了这一空缺。 课程的语言是Python,使用的框架是Google开源的TensorFlow。最吸引人之处在于, 课程导师就是吴恩达本人,两名助教均来自斯坦福计算机系。完成课程所需时间根据不同的 学习进度,大约需要3-4个月左右。学生结课后,Coursera将授予他们Deep Learning Specialization结业证书。 “我们将帮助你掌握深度学习,理解如何应用深度学习,在人工智能业界开启你的职业 生涯。”吴恩达课程页面中提到。 本人黄海广博士,以前写过吴恩达老师的机器学习个人笔记。有朋友报名了课程,下载 了这次课程的视频给大家分享。Coursera的字幕不全,同学们在学习上感觉非常不方便,因 此我找志同道合的朋友翻译和整理字幕,中英文字幕来自于由我和曹骁威同学组织爱好者翻 译,希望对大家有所帮助。(备注:自网易公开课翻译深度学习课程后,我们不再翻译) 目前我正在组织团队整理中文笔记,由热心的朋友无偿帮忙制作整理,并持续更新。我 们的团队的劳动致力于AI在国内的推广,不会损害Coursera以及吴恩达老师的商业利益。 本人水平有限,如有公式、算法错误,请及时指出,发邮件给我,也可以加我qq。 黄海广

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

红色石头Will

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值