博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
吴恩达机器学习笔记-正规方程
阅读量:6094 次
发布时间:2019-06-20

本文共 2811 字,大约阅读时间需要 9 分钟。

在前面的学习中,我们一直使用的线性回归算法是梯度下降法,即为了最小化代价函数$J(\theta)$,我们需要通过迭代很多步来收敛到全局最小值。那么现在我们来学习一种新的解法来求解。即正规方程。正规方程提供了一种求$\theta$的解析解法,相比较迭代算法,我们可以直接一次性的求解出$\theta$的最优值。

我们首先举一个例子来帮助理解正规方程,我们假设有一个非常简单的代价函数$J(\theta)$,它就是一个实数$\theta$的函数:$J(\theta) = a\theta^2+b\theta+c$。所以现在假设数$\theta$只是一个标量,或者说数$\theta$只有一行,是一个数字不是向量。假设我们的代价函数J是这个实参数数$\theta$的二次函数,那么如何最小化一个二次函数呢。很常见的办法就是对函数求导,并导数为0,即求解$J''(\theta)=0$,这样就可以求得使得$J(\theta)$最小时$\theta$的值。但实际情况中,我们的数$\theta$往往不是一个实数,而是一个n+1维的向量,并且代价函数J是这个向量的函数,也就是:$J(\theta_0,\theta_1...\theta_n) = \frac{1}{2m}\sum_{i=1}^{m}(h_\theta(x^(i))-y^(i))^2$。那么如何最小化这个函数呢,微积分里我们学过偏导,即这里我们要对每个参数$\theta$求J的偏导数,但这个求导会非常复杂,因此实际上并不会真的对这个函数进行遍历所有的偏微分,这里只是告诉大家想要实现这个过程所需要知道的内容。

现在我们看看之前用过的房价的例子,数据集大小m=4,我们在额外的加上一列对应特征向量$x_0$,这一列取值永远为1:

Size(feet2) Number of bedrooms Number of floors Age of home(years) price(1000)
x0 x1 x2 x3 x4 y
1 2104 5 1 45 460
1 1416 3 2 40 232
1 1534 3 2 30 315
1 852 2 1 36 178

接下来我们就可以构建一个矩阵X,这个矩阵包含了训练样本的所有特征变量,X是个m*(n+1)维矩阵。对y,也就是我们预测的值,可以构建一个向量,y是个m维度的向量.m是训练样本数量, n是特征变量数:

$$ X = \begin{bmatrix} 1 && 2104 && 5 && 1 && 45 \\ 1 && 1416 && 3 && 2 && 40 \\ 1 && 1534 && 3 && 2 && 30 \\ 1 && 852 && 2 && 1 && 36 \end{bmatrix} $$

$$ Y = \begin{bmatrix} 460 \\ 232 \\ 315 \\ 178 \end{bmatrix} $$

如果我们用矩阵X和向量Y来计算的话,那么最终的结果如下等式:

$$ \theta = (X^TX)^{-1} X^Ty $$

假设我们有m个训练样本$x^(1),y^(1)$直到$x^(m),y^(m)$,特征变量数目为n,因此每个训练样本$X^(i)$可以看作一个向量:

$$ x^(i) = \begin{bmatrix} x_0^(i)\\ x_1^(i)\\ x_2^(i)\\ ...\\ x_n^(i)\\ \end{bmatrix} $$

接下来我们要构建矩阵X,构建矩阵X的方法也被称作设计矩阵。每个训练样本给出一个这样的特征向量,取第一个训练样本,也就是一个向量,取它的转置,最后是扁长的样子。让$x_1^T$作为我设计矩阵的第一行 然后第二个训练样本$x_2$进行转置 让它作为X的第二行。以此类推,直到最后一个训练样本取它的转置作为矩阵X的最后一行,这样矩阵 X 就是一个 m*(n+1) 维矩阵:

$$ X = \begin{bmatrix} ... && (x^(1))^T && ...\\ ... && (x^(2))^T && ...\\ ... && (x^(3))^T && ...\\ ...\\ ... && (x^(m))^T && ...\\ \end{bmatrix} $$

举个例子,假设我们只有一个特征变量,就是说除了$x_0$之外只有一个特征变量,而$x_0$始终为1,所以如果我的特征向量$x_i$等于1,也就是$x_0$和某个实际的特征变量$x_i$等于1,

$$ x^(i) = \begin{bmatrix} 1 \\ x^(i) \end{bmatrix} $$

那么按照上述的方法,设计矩阵就是这样:

$$ X = \begin{bmatrix} 1 && x_1^(1)\\ 1 && x_2^(1) \\ ... \\ 1 && x_m^(1) \end{bmatrix} $$

这样,就会是一个m*2维矩阵,而这里的向量y,则是一个m维向量:

$$ y = \begin{bmatrix} y^(1) \\ y^(2) \\ ... \\ y^(m) \end{bmatrix} $$

这样我们得到了矩阵X和向量Y的结果,因此就可以使用正规方程来求解$\theta$了。

$$ \theta = (X^TX)^{-1} X^Ty $$

之前我们在梯度下降的时候说过特征变量的特征缩放,即将所有的特征值缩小到类似的范围内。而如果使用正规方程的话,就不需要再进行特征缩放的操作了,但如果使用梯度下降法,就要根据不同特征的范围来判断是否需要使用特征缩放。

特征方程看起来相对于梯度下降要简单很多,但也不是万能的,这里我们列出这两个的特点来进行对比一下:

(懒得手写了就直接赋值吴恩达老师的图了==),这里就提一下两者的最后一个特点。由于矩阵X是m*(n+1)维的矩阵,当我们的特征值非常多的时候,计算$(X^TX)^{-1}$时候的计算量是非常庞大的,因此计算的速度会非常慢,但n的大小很显然跟梯度下降的速度没关系,所以梯度下降算法依然可以正常运行。这里吴恩达老师是建议在n=10000的时候就考虑一下是否要使用梯度下降法了,10000以下都可以使用正规方程,当然这里还是需要通过实际情况来决定。

最后也稍微说一点关于如果矩阵$X^TX$不可逆怎么办。出现这种情况的可能性大概有两种,一种是特征选的很多余了,比如选了房子的平方面积作为特征还选了房子的英尺计算的面积,这样就明显很多余了;还有一种是特征选的太多,比如你有10个样本,结果选了1000个特征,这显然也不适合,可以适当的删除一些特征或者以后会提到的正则化的线代方法。

以上,就是关于正规方程的一些简单介绍,针对吴恩达机器学习的正规方程那一章节。

转载地址:http://lcwza.baihongyu.com/

你可能感兴趣的文章
Response. AppendHeader使用大全及文件下载.net函数使用注意点(转载)
查看>>
Wait Functions
查看>>
代码描述10313 - Pay the Price
查看>>
jQuery最佳实践
查看>>
centos64i386下apache 403没有权限访问。
查看>>
下划线的学习5
查看>>
Spring Data JPA教程, 第六部分: Sorting(未翻译)
查看>>
重建二叉树
查看>>
企业管理软件开发之九 以数据绑定为基础的控件只读,创建时可写,必须大写,必须小写的原理与实现...
查看>>
批处理清理VS工程目录(递归删除Debug, Release, ipch目录及*.sdf文件)
查看>>
在Windows中监视IO性能
查看>>
thrift之TTransport层的缓存传输类TBufferedTransport和缓冲基类TBufferBase
查看>>
Oracle数据库日期范围查询的两种实现方式
查看>>
PHP魔术变量和魔术方法
查看>>
张子强_百度百科
查看>>
Windows下命令行下启动ORACLE服务
查看>>
从网络得到数据--Arduino+以太网
查看>>
删除重复记录(Mysql,SqlServer,Sqlite)
查看>>
vb sendmessage 详解1
查看>>
aaalogo写入中文出错的解决方法
查看>>