强化学习-学习笔记9 | Multi-Step-TD-Target
这篇笔记依然属于TD算法的范畴。Multi-Step-TD-Target 是对 TD算法的改进。
9. Multi-Step-TD-Target
9.1 Review Sarsa & Q-Learning
- Sarsa
- 训练 动作价值函数 ;
- TD Target 是
- Q-Learning
- 训练 最优动作价值函数 Q-star;
- TD Target 是
- 注意,两种算法的 TD Target 的 r 部分 都只有一个奖励
- 如果用多个奖励,那么 RL 的效果会更好;Multi-Step-TD-Target就是基于这种考虑提出的。
在第一篇强化学习的基础概念篇中,就提到过,agent 会观测到以下这个轨迹:
我们之前只使用一个 transition 来记录动作、奖励,并且更新 TD-Target。一个 transition 包括,只有一个奖励 。(如上图蓝框所示)。
这样算出来的 TD Target 就是 One Step TD Target。
其实我们也可以一次使用多个 transition 中的奖励,得到的 TD Target 就是 Multi-Step-TD-Target。如下图蓝框选择了两个 transition,同理接下来可以选后两个 transition 。
9.2 多步折扣回报
Multi-Step Return.
折扣回报公式为:;
这个式子建立了 t 时刻和 t+1 时刻的 U 的关系,为了得到多步折扣回报,我们递归使用这个式子:
这样,我们就可以包含两个奖励,同理我们可以有三个奖励......递归下去,包含 m个奖励为:
即:回报 等于 m 个奖励的加权和,再加上 ,后面这一项称为 多步回报。
现在我们推出了 多步的 的公式,进一步可以推出 多步 的公式,即分别对等式两侧求期望,使随机变量具体化:
-
Sarsa 的 m-step TD target:
注意:m=1 时,就是之前我们熟知的标准 TD Target。
多步的 TD Target 效果要比 单步 好。
-
Q-Learning 的 m-step TD target:
同样,m=1时,就是之前的TD Target。
9.3 单步 与 多步 的对比
-
单步 TD Target 中,只使用一个奖励 ;
-
如果用多步TD Target,则会使用多个奖励:
联想一下第二篇 价值学习 的旅途的例子,如果真实走过的路程占比越高,不考虑 “成本” 的情况下,对于旅程花费时间的估计可靠性会更高。
-
m 是一个超参数,需要手动调整,如果调的合适,效果会好很多。
x. 参考教程
本文作者:climerecho
本文链接:https://www.cnblogs.com/Roboduster/p/16456065.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步