知行编程网知行编程网  2022-02-25 09:00 知行编程网 隐藏边栏 |   抢沙发  2 
文章评分 0 次,平均分 0.0
回归:从精灵宝可梦说起

今天我们用一个预测宝可梦(pokemons)进化后过的CP值(战斗力)的例子,来讲讲什么是Regression。

Regression-pokemons

回归:从精灵宝可梦说起

如上图所示,我们的目标是找到一个函数‘f’,input一只宝可梦,output是他进化后的cp值。 那么如何寻找这个函数 f 就成了问题的关键!

Models:建立模型

我们在这里建立一个Linear model:

y = b + w * x

它是infinite的,可能为

f1: y = 10.0 + 9.0 ∙ x;

f2: y = 9.8 + 9.2 ∙ x;

f3: y = - 0.8 - 1.2 ∙ x

……

不同的b、w,得到的 f 不尽相同,而下面,我们就要找到最能契合要求的一个 f 。

Goodness of function

已知10个宝可梦的进化情况,将其作为training data。据此我们建立一个二维坐标轴,如图所示。

回归:从精灵宝可梦说起

通过上图可以看出,似乎有一个函数能够拟合这些坐标点,而这就是我们想要的。为了选出最契合的 f ,我们要建立一个Loss function L ,它是函数的函数。

回归:从精灵宝可梦说起

如果我们将 f 的 w 和 b 作为两轴,则在下图中每一点都代表一个 function f 。而颜色代表output的大小,也就代表该function f 参数的好坏。

回归:从精灵宝可梦说起

易理解,smallest点做对应的函数 f 就是我们想要的

Best Function

我们刚刚提到最拟合的 f ,他可能是 y = 0.6x +0.8,这个就叫做best function。

那么我们该用什么方法在Loss Function下找到它呢?这个L(w,b)smallest该如何计算呢?

首先容易想到的,在本案例中,我们可以用线性代数的基本公式来直接计算出最佳w和b。

回归:从精灵宝可梦说起

除了这种方法,当特征值非常多时,我们就要用到梯度下降法来进行计算。

回归:从精灵宝可梦说起

当我们在L(w)的二维平面中时,我们必须要找到函数的最低点

首先随机选取一个点w0,计算微分也就是斜率,如果为正,则减小w,如果为负,则增大w。

而这有另一个问题,每次要增加或减少多少w值呢,有两个因素影响。第一,即微分值,如果微分值很大或很小,表示此处非常陡峭,那么证明距离最低点还有很远的距离,所以移动的距离就很大。第二个因素是我们事先自主定义的常数项 η 值,即步长。

回归:从精灵宝可梦说起

按照这个模式,不断重复,经过非常多的参数更新后,能达到一个最低点。

当我们有多个feature时,即不仅有 w 还有 b ,同样不会影响梯度下降过程,展示出来就是这样的:

回归:从精灵宝可梦说起

说到这里大家可能会担心,会不会产生下图左半部分的哪种情况,即不同的起始位置,找到的最低点是不一样的,那么这里的解释是,在我们案例的Linear regression中,不会出现这种可能性,而全都是右图哪种形式,即只有一个大坑,放心往里走就好。

回归:从精灵宝可梦说起

通过这种方式,我们就能得到想要的 function f ,来解决我们的需求。

How’s the results

通过上面的计算,我们成功得到了一个如图函数 f,接下来就会发现,并不是所有的点都能拟合函数,这就会造成很大的预测不准的情况,通过Loss Function也能看出,最优解的值依然很大,测试数据的表现也不好,所以我们就要想办法优化。

回归:从精灵宝可梦说起

很容易想到,刚刚我们用了一次方程作为model,二次方程会不会更好一些呢,三次方程、四次方程呢?

于是我们做了以下实验,用同样的方法,放到多次方程中。

回归:从精灵宝可梦说起

回归:从精灵宝可梦说起

Overfitting

通过上面四幅图可以看出,虽然当我们增加函数次数时,可以使training data的Average Error越来越小,但是Test data的表现却不尽如人意,甚至在五次方程时,大大超出了我们的预估,那么这种现象就叫做overfitting。

回归:从精灵宝可梦说起

所以,function不是越复杂越好,所以我们要选择一个最合适的,由上图可以看出,在三次方程中表现最好。

有一个万能的提高准确率的好方法——收集更多的数据。 

为您推荐

带你理解朴素贝叶斯分类算法

聊一聊激活函数

基础篇|一文搞懂RNN(循环神经网络)

什么是马尔科夫过程

 

 

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写

发表评论

表情 格式 链接 私密 签到
扫一扫二维码分享