深度学习讲稿(21)

4.3.1 改进冷热法--梯度下降法

冷热法每次更新权重都要重新算一次,而且每次更新的权重改变虽然有一定的伸缩,但实际上更新权重完全没有依据,就是靠左右碰撞试错来搜索更新的路径。

那么能不能改进这种算法,让它学习的效率变好呢?

当然可以。要改进算法,首先需要看到算法的局限性。冷热法是能够发现局域最优解的,但局限在于以下两点:

  1. 每次更新权重的方向不确定。
  2. 每次更新权重的大小依赖于初始猜测。

如果我们能够打破以上的两个局限性,我们就找到了比冷热法更优秀的算法,而梯度下降法就是这样的更优秀的算法。

比如我们看如下的代码:

weight = 0.5
goal_pred = 0.8
input = 0.5

learning_rate = 0.8

for iteration in range(50):
    pred = input * weight
    error = (pred - goal_pred)**2
    direction_and_amount = (pred - goal_pred) * input
    weight -= learning_rate * direction_and_amount

    print("Error:" + str(error) + "  Prediction: " + str(pred))

上面的代码中,最重要的一句在for循环中的第三行,即:

direction_and_amount = (pred - goal_pred) * input

它是更新权重的最重要的依据。我们看到这一项完全不依赖于初始的设定值weight,它只和上一次的weight相关。而且下一步更新权重的正负号也完全确定,不需要探索两个方向。这说明这个算法的确解决了冷热法的两大局限。

尝试运行上面的代码,你会发现,在区区50步内,误差已经小到十亿分之一的量级。这说明上面的算法惊人地高效。

那么究竟这一项是如何想出来的呢?

人类不同于机器,从代码看学习的算法总是太过繁琐且不够直观。所以为了让我们看清楚上面的代码的内在含义。我们把上面的代码用函数的方法来表达出来。

实际上,我们目前遇到的学习问题无非是给定输入和输出,调整中间的函数,使得输入和输出匹配。这种问题事实上我们早就接触过了。

你可以先回忆一下函数的定义。函数是什么?

函数建立了定义域和值域之间的映射。它把定义域中的点映射到值域中的点。

这与我们需要学习的问题并无不同,我们就是在找这样的映射函数。所以我们把这个学习问题转换为一个代数问题:

给定x的值为0.5,y的值为0.8,求y对x的依赖关系。

你可能很快就能写出如下的解答:
y = \frac{0.8}{0.5} x = 1.6 x \quad (4.1)
的确,这是一个非常简单的一次函数求逆的过程,而且我们可以直接一步就得到精确解,误差为零。但是这样的可以严格求解的问题并不多见,绝大多数的问题实际上无非严格求解。在现实世界,我们不能期待0误差的结果。所以我们需要好好利用误差来调节我们的函数。我们现在假定不知道上面的精确解,只知道如下的待定的映射函数形式:
y = wx \quad (4.2)
需要迭代求解的是权重w。利用y的给定值y_0 = 0.8,我们写出误差函数:
E[y]=(y-y_0)^2 =(y-0.8)^2 \quad (4.3)
要使得上面的误差最小,我们注意到误差函数实际上是一个关于y的二次函数。也就是说,我们每次预测,其误差都可以在这个二次函数上找到一个点来对应。很自然地,如果我们每次预测都向这个二次函数的最低点走一步,那么最终我们会走到这个二次函数的底部。 也就达成了预测的目标。

答案呼之欲出了!我们需要做的就是沿着当前点的切线下降!

假如第一步我们猜测的y的值是:
y_1 = w_1 x , \quad (4.4)
那么第二步就是:
y_2 = \left[w_1 - \alpha * \left(\frac{dE[y]}{dy}\vert_{y=y_1}\right)\right]\times x \quad (4.5)
上式看上去很可怕,但是其实就是在说沿着当前点的切线下降。其中\frac{dE[y]}{dy}\vert_{y=y_1}就是在y_1这个预测点处的误差函数的斜率,或者叫导数。\alpha就是学习速率,也就是代码中的那个 learning_rate 。负号代表是下降的意思。

这个式子非常非常重要,请你仔细思考其背后的意义。这个章节中其它的所有东西你都可以含糊带过,但一定要理解这个式子。它贯穿了深度学习的始终。它就是梯度下降法的本质。

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

推荐阅读更多精彩内容