深入探索TD3算法的推理过程

之前初步探索了强化学习TD3算法。

https://blog.csdn.net/liliang199/article/details/158321952

TD3是解决DDPG中因函数近似误差导致的Q值过高估计问题。

这里进一步分析TD3算法的理论推导过程,尝试从新的角度理解TD3算法。

1 TD3流程

TD3流程如下所示

TD3算法主要围绕Critic(价值网络)和Actor(策略网络)的更新展开。

2 Critic网络推导

Critic网络的目标是构建更可靠的学习目标,准确评估状态-动作对的价值

在TD3中,这一步的推导引入了前两项关键改进。

2.1 目标策略平滑

目标策略平滑(Target Policy Smoothing),作用是防止Critic对某些动作产生过高估计,使价值估计更平滑。

计算目标值时,不会直接使用目标策略网络输出的下一个动作,而是给它添加一个截断的噪声

这里是从均值为0、标准差为的正态分布中采样,并截断在范围内。

相当于在目标动作周围构建了一个邻域,要求Critic对这个邻域内的动作都给出相近的价值估计。

2.2 截断双Q学习

截断双Q学习(Clipped Double Q-Learning)直接解决单估计器带来的过高估计问题。

TD3维护两个Critic网络,以及对应的目标网络

在计算目标值时,对于由目标策略平滑得到的动作,两个目标Critic网络分别给出估计值。

TD3取其中的较小值作为最终的目标值。这一取小操作是抑制过高估计的关键。

其中,是奖励,是折扣因子,表示是否结束。

2.3 Critic网络的损失函数

得到了目标值 后,两个Critic网络的更新方式就是标准的回归问题。

它们损失函数是均方误差MSE,目标是让自己的预测值尽可能地接近目标值

3 Actor网络推导

Actor的目标是找到能最大化价值的动作。这一步的推导引入了第三项关键改进:延迟更新。

3.1 延迟的策略更新

即Delayed Policy Updates,在Critic的价值估计尚未稳定时,避免Actor盲目地迎合可能错误的估计,从而减少震荡和发散。

Actor的更新频率低于Critic。通常,每更新2次Critic,才更新1次Actor。这确保了Actor总是在一个相对准确的价值函数面上进行梯度上升。

3.2 Actor网络策略梯度

当轮到Actor更新时,它使用其中一个Critic,通常为的输出来指导自己。

其目标是最大化期望回报。在实际计算中,通过对采样批次求平均来近似梯度。

直观感觉,对于采样状态,Actor输出动作获得Critic 即评分尽可能高。

4 参数更新训练流程

最后,整个网络的参数更新方式如下,这使得上述推导能够闭环:

1)Critic网络

通过最小化各自的损失函数来更新参数,

2)Actor网络

通过最大化即最小化 来更新参数

3)目标网络更新

采用软更新,即Polyak Averaging方式,缓慢地将当前网络的参数复制给目标网络,以稳定训练。

其中是一个很小的数(如 0.005)。

reference


Twin-Delayed DDPG (TD3)

https://skrl.readthedocs.io/en/develop/api/agents/td3.html

Twin Delayed DDPG

https://spinningup.readthedocs.io/zh-cn/latest/algorithms/td3.html#pseudocode

强化学习算法TD3的探索和学习

https://blog.csdn.net/liliang199/article/details/158321952

Twin-Delayed Deep Deterministic (TD3) Policy Gradient Agent

https://kr.mathworks.com/help/reinforcement-learning/ug/td3-agents.html#mw_367f0ae0-3ed0-4317-9e26-01f22c6a8d29

强化学习之图解PPO算法和TD3算法

https://www.e-com-net.com/article/1544100607541972992.htm

相关推荐
Gofarlic_oms117 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
AI+程序员在路上18 小时前
VS Code 完全使用指南:下载、安装、核心功能与 内置AI 编程助手实战
开发语言·人工智能·windows·开源
invicinble18 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
niucloud-admin18 小时前
PHP V6 单商户常见问题——如何修改访问域名默认跳转端口
php
catchadmin18 小时前
使用 PHP TrueAsync 改造 Laravel 协程异步化的可行路径
开发语言·php·laravel
wbs_scy18 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
郑州光合科技余经理19 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
niucloud-admin20 小时前
PHP V6 单商户常见问题——在线升级版本失败后如何回退版本数据
php
南子北游20 小时前
Python学习(基础语法1)
开发语言·python·学习