多项式曲线拟合

利用多项式函数拟合数据点,多项式函数形式如下:
y(x, W) = w_0 + w_1 x + \cdots + w_m x^m = \sum_{i=0}^{m} {w_i x^i}

W = \left[ \begin{matrix} w_0 \\ w_1 \\ \vdots \\ w_m \end{matrix} \right]X = \left[ \begin{matrix} 1 & x_1 & \cdots & x_1^m \\ 1 & x_2 & \cdots & x_2^m \\ \vdots & \vdots & \ddots & \vdots\\ 1 & x_n & \cdots & x_n^m \end{matrix} \right]
则多项式函数可化为线性代数形式: y(x, W) = XW 为了评价拟合函数的优劣,需要建立损失函数,测量每个样本点目标值与预测值之间的误差,拟合的目标是让误差最小。计算误差时使用均方根误差E_{RMS} = \sqrt {\frac {E(W^*)}{N}}


最小二乘法

为了取得误差函数的最小值,直接令函数的导数等于0,可以得到唯一解。此解称为解析解。
不带正则项的解析解
误差函数为:
E(W) = \frac 1 2 \sum_{n=1}^{N} {(y(x_n, W) - t_n)^2} = \frac 1 2 (XW - T)^{\top}(XW - T)对其求导得:
\frac {\partial E(W)}{\partial W} = {X^{\top}XW - X^{\top}T}令导数等于0,得:
W = (X^{\top}X)^{-1}X^{\top}T 可以通过矩阵运算直接目标函数:W = (X.T * X).I * X.T * T

随着阶数越高,误差越小,但是过拟合越来越严重:

观察计算出来的W,会看到,阶数越高,多项式的系数越大的离谱
为了解决过拟合问题,可以增加样本数据,也可以加入正则项(惩罚项)
下图为9阶多项式在n = 15, 30, 60, 100时的拟合情况,可以看到曲线随着数据的增加拟合得越接近正弦曲线。

带正则项的解析解
误差函数变成:
这里的m+1为W中元素的个数,,主要是为了平衡高阶多项式项更多带来的影响,不加对下面W的求解也没有影响

\lambda,也就是正则系数,是一个超参数,需要设置一个较好的值才能得到较好的结果。这里取的是0.005

求导:
\frac {\partial \widetilde E (W)}{\partial W} = \frac 1 {m+1}({(X^{\top}X + \lambda E_{m+1})W - X^{\top}T}) 求出W:
W = (X^{\top}X + \lambda E_{m+1})^{-1}X^{\top}T 同样可以直接由矩阵运算求得W = (X.T * X + lambda * np.eye(m+1)).I * X.T * T

由于加上了正则项,高阶多项式没有出现明显的过拟合

多项式系数的大小也较为正常:

最小二乘法看似简单,但是涉及到矩阵求逆运算,当数据规模较大时,矩阵求逆速度较慢,因此需要其他优化方法,如梯度下降法,共轭梯度法,牛顿法等。

梯度下降法

梯度下降法的原理可以看这篇文章:深入浅出--梯度下降法及其实现

拟合的目标时让误差函数值最小,也就是找函数图像的最低点,沿着曲线梯度的反方向一直走,一定会走到一个局部最低点,也就是局部最优解,在二次型,即为全局最优解。

def gradient(W, X, T):
    '''在带正则项的最小二乘函数中计算W处的梯度'''
    return (1 / X.shape[1]) * (X.T * X * W - X.T * T + lambd * W)
def gradient_descent(X, T: '目标值', learning_rate):
    '''进行梯度下降的迭代'''
    # 初始化W为全为0的列向量
    W = np.mat(np.zeros(X.shape[1])).T
    grad = gradient(W, X, T)
    while np.all(np.absolute(grad) > 1e-9):
        W = W - learning_rate * grad
        grad = gradient(W, X, T)
    return W

拟合的曲线与带正则项的解析解几乎一致

但是阶数越高,迭代的次数越多,速度越慢,进行十几万次迭代的时间约为十几秒

阶数 0 1 2 3 4 5 6
迭代次数 28 352 8337 93643 133747 160849 181179

共轭梯度法

该方法解决的是二次函数极值问题\min \limits_{x \in R^n} \frac 1 2 x^{\top}Qx - b^{\top}x
其中Q为正定矩阵,本问题中Q = \frac 1 {m+1}(X^{\top}X + \lambda E_{m+1})

共轭梯度法每次沿着一个方向找到该方向的极小值,后面在沿着其他方向求极小值,由于寻找的方向两两共轭,后面的查找不会影响前面已经查找过的方向的最小值,理论上n次求极小值就可以得到n为问题的极小值。

共轭梯度法理解起来比较难,不过编程实现按步骤来就可以了:

def conjugate_gradient(X, T):
    '''进行共轭梯度下降的迭代'''
    Q = (1 / X.shape[1]) * (X.T * X + lambd * np.mat(np.eye(X.shape[1])))
    W = np.mat(np.zeros(X.shape[1])).T
    
    r = -gradient(W, X, T)
    p = r
    for i in range(1, X.shape[1]):
        a = float((r.T * r) / (p.T * Q * p))
        r_prev = r
        W = W + a * p
        r = r - a * Q * p
        p = r + float((r.T * r) / (r_prev.T * r_prev)) * p
    return W

共轭梯度法拟合的情况也很好,几乎与带正则项的解析解相同,并且速度要比梯度下降法快很多。
附:矩阵求导用到的公式有

  1. \frac {\partial {\mathbf {a}}^{\top }{\mathbf {x}}}{\partial {\mathbf {x}}} = \frac {\partial {\mathbf {x}}^{\top }{\mathbf {a}}}{\partial {\mathbf {x}}} = {\mathbf {a}}
  2. \frac {\partial {\mathbf {x}}^{\top}{\mathbf {x}}}{\partial {\mathbf {x}}} = 2\mathbf{x}
  3. \frac {\partial {\mathbf {x^{\top}Ax}}}{\partial {\mathbf {x}}} = 2\mathbf{Ax}(A为对称矩阵)

参考:
深入浅出--梯度下降法及其实现 -简书
梯度下降法和共轭梯度法有何异同?-知乎

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容