知识基础DQN参考我的博文:https://tianjuewudi.gitee.io/2021/07/16/qiang-hua-xue-xi-shi-jian-jiao-xue/#toc-heading-19
DQN复习
我们利用神经网络来代替表格法,我们可以输入S并输出多个Q,每个Q对应一个A。神经网络只需要储存有限的网络参数,我们的任务就是不断调整这些参数,使得输入输出符合我们的预期,而且状态可以泛化,相似的状态输出也差不多。
DQN有两大创新点,一个是经验回放,一个是固定Q目标。经验回放是指探索的数据特征形成一组组数据,并且可以随机打乱,使得神经网络可以重复多次地进行学习。这样可以打乱样本的关联性,而且能提高样本利用率。固定Q目标是指我们把Q值固定一段时间来训练参数,我们需要另外一个一样的网络(target Q网络),Q网络的作用是产生一个Q预测值,直接用来决策产生action。而target Q是产生一个Q目标值,我们通过这个目标值的$Q_{t+1}$计算Q网络$Q_{t}$,target Q往往固定一段时间来使Q网络得到充分训练。
DQN的缺陷
使用了 max 操作,Q-learning、DQN算法都会过高估计(overestimate)Q值。
DDQN与DQN的异同
DDQN和DQN一样,也有一样的两个Q网络结构。下面是DQN的更新公式
$$
Q_m(S_{t},a_t) = Q_m(S_{t},a_t)+ \eta * (R_{t+1} + γ \max_a Q_t(S_ {t+1} ,a) - Q_m(s_t,a_t))
$$
DDQN采用的是一种使更新公式更稳定的方法:
$$
a_m = arg \max_a Q_m(s_{t+1},a)
$$
$$
Q_m(S_{t},a_t) = Q_m(S_{t},a_t)+ \eta * (R_{t+1} + γ Q_t(S_ {t+1} ,a_m) - Q_m(s_t,a_t))
$$
也就是说DDQN与DQN的不同之处在于用来更新Q网络的Target Q中$Q(S_{t+1},a)$的选择方式,DQN直接用Target Q网络中t+1时刻可选Q的最大值用来更新,而DDQN用的是根据Q网络t+1时刻的最大Q来选择对应的action,然后用这个action来对应决定Target Q网络中的Q值,这样更新的Q值就会小于等于DQN更新的Q值,改善overestimate的问题。