介绍
什么是机器学习?
有两种定义。Arthur Samuel如此描述机器学习:一个领域的研究,旨在研究,在不进行编程的情况下,让计算机具有学习能力。
Tom Mitchell给出了一个更为现代的定义:一个计算机程序从经验E以及评判标准P中学习如何完成任务T,随着E的累积,P得到提升。
例如,下棋游戏中:
E:在很多盘棋局中的经验
T:下棋任务
P:程序赢得下一盘棋的可能性
总体来说,任何机器学习问题可以分为监督学习(supervised learning)
和无监督学习(unsupervised learning)
监督学习
在监督学习中,给定一个数据集,并且我们已经知道输出看起来是什么样子的,知道数据和输出之间是存在联系的。
监督学习可分为“回归(regression)”
和“分类(classification)”
两种类型的问题。在回归问题中,我们试图预测连续的结果,换句话说,我们试图将输入变量映射到某种连续函数。在分类问题中,却试图预测离散结果,换句话说,我们试图将输入变量映射进离散的类别中。
例子1:
给定一组关于房子大小的数据,预估出价格。从大小推算价格的函数的输出是连续的,所以这是个回归问题。
如果换一种问法:“预估房价与指定价格的大小关系”。这个问题就转化为分类问题了,因为我们试图将房价分为两种离散的类别中(大于或小于)。
例子2:
a) 回归:给定一张男性或女性的照片,推算年龄。
b) 分类:给定一张男性或女性的照片,估计他/她是高中生还是大学生。另一个分类的例子:银行需要根据跟人信用历史,判断是否要给其贷款。
无监督学习
无监督学习是指在几乎对结果一无所知的情况下,趋近结果。在对输入数据的变量缺少必要的认识的情况下,从中获取一些结构。通过将数据中变量的关联,将数据进行聚类,从而获取这些结构。无监督学习对于预测结果是没有反馈的。
例如:
聚类:从1,000,000个不同的基因中,找到某种方式,能够自动将具有某种相似性或关联的基因进行分组,这些变量可能是寿命,位置,功能等。
非聚类:“鸡尾酒算法”,能否从嘈杂环境中识别不同的声音。(例如,在鸡尾酒会上,从混合的声音中区分人声或音乐声)
模型和代价函数
模型表示
这里以监督学习中的房子大小预测房价问题为例。使用
x(i)
指代输入变量(这里是房屋面积),
y(i)
指代输出或者我们需要预测的结果(这里是房屋价格)。元组(
x(i),y(i)
)是训练用例数据集,m
个训练用例
(x(i),y(i));i=1,...,m
称为训练数据集。注意,上标(i)
,并没有幂运算的功能。我们也会使用X
,表征输入数据集,Y
表征输出数据集。
稍微正规的解释一下监督学习是什么。监督学习的目标是,给定一个训练数据集,尝试学习一个函数h: X Y
,使得h(x)
成为好的预测y的函数。由于历史原因,这个h函数称为假设函数(hypothesis)
,下图说明了这个流程:
如果我们要预测的目标值是一个连续值时,例如房价预测问题,我们称这种机器学习问题为回归(regression)问题
;如果y值只在少数的离散值中取值(例如,假设给定面积,预测这是个house还是apartment),我们称为分类(classification)问题
。
代价函数
我们可以使用代价函数(cost function)
来衡量假设函数(hypothesis function)
的精准性。代价函数实际上计算的就是每一个经由假设函数计算而来的y,与实际的y的差值的平均值。当这个差值最小时,假设函数最优。
如果hypothesis function
如下:
h(x)=θ0+θ1x
这是一个线性函数,对于房价预测问题,我们的最终目的是通过算法,得到一组最优的
(θ0,θ1)
使得对所有的训练集合X(房屋面积)
,通过h(x)
计算得到的Y(房屋价格)
与实际的Y
偏差最小,即拟合度
最高。为了衡量h(x)
的拟合度,使用代价函数
J(θ0,θ1)
如下:
J(θ0,θ1)=12m∑i=1m(hθ(xi)−yi)2
通过观察,不难发现,该公式实际计算的是,y的方差的均值。并且这个均值越小,说明拟合度越高。所以算法推导
(θ0,θ1)
的过程,就是求
J(θ0,θ1)
最小值的过程。
直观的看,我们可以把训练数据集看成散落在一个x-y的二维坐标系中的点,试图找到一条直线(由
hθ(x)
定义),穿过这些点。最终的目的是,找到一条这样的一条直线,使得这些点离这条直线的垂直距离最近。理想状态下,这条直线能够穿过所有的点,这时
J(θ0,θ1)
为0。
这个代价函数也称为平法误差代价函数(Squared error function)
或均方误差(Mean squared error)
。将均方除以2,是为了梯度下降算法的计算。下图总结了代价函数
:
为了更直观的观察代价函数,我们假设,需要预测的变量只有一个
θ1
,那么h(x)
如下:
h(x)=θ1x
这将是一条经过原点的直线。那么容易想到,随着斜率
θ1
的变化,
J(θ1)
将呈现出一个如下类似抛物线的造型:
总能找到一个
θ1
使得
J(θ1)
最小。
如果有两个变量
J(θ0,θ1)
:
h(x)=θ0+θ1x
那么
J(θ0,θ1)
将同时受到两个变量的影响,这将是一个三维的图形:
因此,我们总能找到一组
(θ0,θ1)
,使得
J(θ0,θ1)
最小。用三维图观察并不直观,现在我们引入一种叫contour plot
的图。观察上面的三维图,我们用一个平行于底面的平面穿过曲面,与曲面相交,形成一个类似椭圆的闭环,随着这个平面高度的变化,将产生无数的类似椭圆的闭环,如果将这些椭圆闭环投影到底面,将形成一个类似靶环的图形,就跟下图的右图一样,这称为contour plot
:
在同一个环上的点,对应不同的
(θ0,θ1)
取值,但是他们的
J(θ0,θ1)
是相同的。而靶环
的中心点,就是能够使得
J(θ0,θ1)
最小的
(θ0,θ1)
取值:
梯度下降
现在我们有了hypothesis function
和用于衡量hypothesis function
中参数
(θ0,θ1)
取值拟合度的cost function
。现在将介绍第一个算法,称为Gradient Descent(梯度下降)
。算法的目的是找到一组变量
(θ0,θ1)
,使得他们的代价函数
J(θ0,θ1)
最小。我们把代价函数假想成如下的三维图,好似有一座座的山头,如果我们从某个山头的某处出发,往下走,走到最低点,每一步往哪个方向取决于当前往哪个方向走最优,我们可能会走到A点。如果换一个点出发,我们可能走到B点:
在决定下一步往哪里走的时候,我们采取的方式是,找到当前这个点的切线方向(切线即导数),切线方向告诉我们应该往哪个方向走;另一个影响因素是,每一步大小α
,这个参数我们称为learning rate学习速率
。单次梯度下降迭代得到的往往是局部最优解
,即上图的A,B两点是对于不同的起始点来说的最优解。
梯度下降算法描述如下:
重复如下步骤,直到收敛:
θj:=θj−α∂∂θjJ(θ0,θ1),j=0,1
上述公式中的:=
表示赋值,而不是数学意义上的判等。上式的迭代过程就是,从初始的
(θ0,θ1)
开始,对于每组
(θ0,θ1)
计算
J(θ0,θ1)
的导数,然后得到新的
(θ0,θ1)
,重复计算,直到
(θ0,θ1)
不再变化,即收敛。
为了更直观的展示算法,我们任然假设h(x)
只有一个参数
θ1
:
h(x)=θ1x
那么此时的算法可以描述为,重复如下过程直到收敛:
θ1:=θ1−α∂∂θjJ(θ1)
由于
J(θ1)
是关于
θ1
的二次函数,所以
∂∂θj
表示
θ1
所在点的切线斜率。从下图可以看出,当
θ1
在上升沿时,斜率为正数,这会使得
θ1
在迭代过程中逐渐减小;当
θ1
在下降沿时,斜率为负数,这会使得
θ1
在迭代过程中逐渐减增大,总之都是趋近于最低点的
θ1
。
所以可以看到,算法巧妙的使用导数,让迭代过程自动趋向于正确的方向。
在算法中,
α
是一个可调参数,当
α
太小时,每次迭代,
θ1
的变化很小,这样会算法的效率;而当
α
太大时,每次迭代,
θ1
的变化很大,这有可能会产生震荡,甚至无法收敛:
理想情况下,
∂∂θj
会在最低点,使得斜率为0,此时:
θ1:=θ1−α∗0
这样得到的新的
θ1
不变,这就是收敛。
再考虑有两个变量
(θ0,θ1)
的情况:
h(x)=θ0+θ1x
前面我们将原本三维的代价函数,绘制成了contour plot
,不难想象,在梯度下降算法的迭代过程中,
(θ0,θ1)
总是从远离靶心
的位置开始,向靠近靶心
的位置移动,最终收敛在靶心
:
有了直观的认知后,我们给出Gradient Descent(梯度下降)
的推导式,这样能够方便计算机进行计算:
重复如下过程,直到收敛:
θ0:=θ0−α1m∑i=1m(hθ(xi)−yi)
θ1:=θ1−α1m∑i=1m((hθ(xi)−yi)xi)
具体的推导过程省略。
共同学习,写下你的评论
评论加载中...
作者其他优质文章