基于Value的强化学习算法

在文章强化学习与马尔可夫决策中,介绍了使用马尔可夫决策模型对强化学习的过程进行建模,本篇文章将介绍基于这一模型而引出的一些强化学习的经典算法。

Q-learning

Q-learning是强化学习的经典算法之一,它是一个value-based算法,同时也是一个model-free的算法。这里的Q指的是动作价值,即当前状态s下,通过策略\pi采取动作a之后,能够获得的奖励r

算法原理

该算法的主要思想很简单。假设强化学习过程中所有状态的集合为S,动作空间为A。首先建立一张Q值表,记录强化学习过程中每一个时刻t的状态s_t\epsilon S下,采取不同的动作a_i\epsilon A的收益。一张Q值表的示例如下:

state a1 a2
s1 q(s1,a1) q(s1,a2)
s2 q(s2,a1) q(s2,a2)
s3 q(s3,a1) q(s3,a2)

之后,根据这一张Q值表来选取能够获得最大的收益的动作,一般是通过\epsilon-greedy的方式选取当前状态下,Q值最大的动作。

Q-learning的整个迭代过程实际上就是去更新这张Q值表,当Q值表收敛时,通过\epsilon-greedy选取的Q值就是最优动作价值函数q_*(s,a),其对应的策略就是最优策略\pi_*(a|s)

这里需要注意的是,由于Q-learning是model-free的算法,因此不用考虑环境的状态转移模型,也就不用关心状态价值函数v_\pi(s)

Q-learning是使用时序差分TD来更新Q值表的,时序差分的更新公式如下:
Q(S,A)+\alpha(R+\gamma\max_aQ(S',a)-Q(S,A))
其中R+\gamma\max_aQ(S',a)表示TD目标,R+\gamma\max_aQ(S',a)-Q(S,A)是TD误差。

算法流程

image

随机初始化所有的状态S和动作对应的价值𝑄。 对于终止状态其𝑄值初始化为0。然后执行下面的流程,迭代T次。

  1. 初始化S为当前状态序列的第一个状态。

  2. \epsilon-greedy在当前状态S选择出动作A

  3. 在状态S执行当前动作A,得到新状态S'和奖励R

  4. 更新价值函数Q(S,A):
    Q(S,A)+\alpha(R+\gamma\max_aQ(S',a)-Q(S,A))

  5. S=S'A=A'

  6. 如果S是终止状态,当前轮迭代完毕,否则转到步骤2。

SARSA

SARSA和Q-learning非常相似,除了价值函数的更新方式,其他都是一模一样。其算法流程如下:

image
  1. 初始化S为当前状态序列的第一个状态。

  2. \epsilon-greedy在当前状态S选择出动作A

  3. 在状态S执行当前动作A,得到新状态S'和奖励R

  4. \epsilon-greedy在新状态S'选择出动作A'

  5. 更新价值函数Q(S,A):
    Q(S,A)+\alpha(R+\gamma Q(S',A')-Q(S,A))

  6. S=S'A=A'

  7. 如果S是终止状态,当前轮迭代完毕,否则转到步骤2。

两者的不同之处是上述第4步和第5步。

Q-learning在根据当前状态S下执行动作A之后,直接用贪婪算法选择在新状态S'下,回报最大的动作a对应的Q值来更新Q值表,但是这个动作a没有被立刻执行,真正在新状态S'下执行的动作是根据更新之后的Q值表选择出来的。

反观SARSA,使用的是\epsilon-greedy从新状态S'下选择出动作A',再更新完Q值表之后,SARSA在下一轮迭代中更是直接去执行了动作A',基本上是“说到做到”。因此,两者在新状态S下得到的Q值会有一些差别。

由于SARSA这种“说到做到”的特性,因此被称为在线学习算法,而Q-learning这一类的算法,被称为离线学习算法。

Sarsa(lambda)

Sarsa(lambda)是Sarsa的增强版。与普通的Sarsa不同,Sarsa(lambda)在更新完当前状态SQ值之后,还会将之前所走过的所有状态的Q值一起给更新了。也就是说,Sarsa(lambda)不但思考纠正当前状态的选择,还对以往的记忆状态进行反思纠正。因此,Sarsa(lambda)的收敛速度,比普通的Sarsa快。其算法流程如下:

image

其中E(S,A)是一个矩阵,用来保存其经历过的所有状态的信息。参数\lambda是一个值为[0,1]的衰减值,通过\lambda对矩阵E(S,A)进行更新,增强离当前状态比较近的记忆,疏远那些太久之前的记忆。

由于Sarsa(lambda)会保存状态记忆,因此除了提高收敛速度之外,还可以解决在训练过程中,智能体反复执行无意义动作的问题,例如老鼠在寻找奶酪的时候,绕着柱子转圈圈的行为就没什么意义了。怎么解决呢,在E(s,a)←E(s,a)+1这一步之前,直接将矩阵E(S,A)中这个状态s对应的行置为0即可。

最后,无论是Q-learning还是Sarsa,都是基于Q值表去解决强化学习的问题,因此他们都是基于value的方法。

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

推荐阅读更多精彩内容