4 动态编程(Dynamic Programming, DP)

【上一篇 3 有限马尔可夫决策过程(Finite Markov Decision Processes)】【下一篇 5 蒙特卡洛方法 (Monte Carlo Method) 】

之前介绍的知识都是基础,从这次开始才真正开始介绍增强学习的解法方法。
  动态编程(Dynamic Programming, DP)这个词大家肯定都不陌生,在解决算法编程问题当中经常会用到,它的主要思想就是将一个复杂的问题分解成多个子问题,将子问题的解结合在一起就构成了原问题的解,它常常适合于解决具有如下两种属性的问题:
  (1)优化的子结构:优化解常常可以分解成子问题;
  (2)子问题有重叠:即子问题总是重复出现,该子问题的解可以保存下来重复利用。
  
  而马尔可夫决策过程就完美的符合这两点特性:
  (1)需要求解的 Bellman 方程提供了递归的分解形式;
  (2)Value function 需要存储和重用之前的解。

因此可以说 DP 可以用于求解马尔可夫模型的优化策略,但是由于 DP 问题需要环境的动态模型,并且计算复杂度较高,因此在增强学习中的应用并不广泛,但是它的思想在理论上还是非常重要的,是以后学习的一个理论基础。DP 算法的主要思想就是利用 value function 来寻找好的策略。
  
  这里先介绍一下后文中的符号表示(与之前的相同):
  假设状态集合、行为集合和 reward 集合分别为 S \mathcal{S} S A ( s ) \mathcal{A}(s) A(s) R \mathcal{R} R,动态性用概率 p ( s ’ , r ∣ s , a ) p(s’,r|s,a) p(s,rs,a) 来表示,其中 s ∈ S s\in\mathcal{S} sS a ∈ A ( s ) a\in\mathcal{A}(s) aA(s) r ∈ R r\in\mathcal{R} rR s ’ ∈ S + s’\in\mathcal{S}^+ sS+(若问题为 episodic,则 S + \mathcal{S}^+ S+ 指的是 S \mathcal{S} S 加上终止状态)。
  之前介绍过,若找到了满足 Bellman 优化方程的优化值函数 v ∗ v_* v 或者 q ∗ q_* q,就可以容易的获得优化的策略, v ∗ v_* v q ∗ q_* q 的表达式如下所示:
v ∗ ( s ) = m a x a E [ R t + 1 + γ v ∗ ( S t + 1 ) ∣ S t = s , A t = a ] = m a x a ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ v ∗ ( s ’ ) ] \begin{aligned} v_{\ast}(s) &= max_a{\Bbb E}[R_{t+1}+\gamma v_{\ast}(S_{t+1})|S_t=s,A_t=a] \\ &= max_a\sum_{s’,r}{p(s’,r|s,a)[r+\gamma v_{\ast}(s’)]} \end{aligned} v(s)=maxaE[Rt+1+γv(St+1)St=s,At=a]=maxas,rp(s,rs,a)[r+γv(s)]

q ∗ ( s , a ) = E [ R t + 1 + γ m a x a ’ q ∗ ( S t + 1 , a ’ ) ∣ S t = s , A t = a ] = ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ m a x a ’ q ∗ ( s ’ , a ’ ) ] \begin{aligned} q_{\ast}(s,a) &= {\Bbb E}[R_{t+1}+\gamma max_{a’}q_{\ast}(S_{t+1},a’) |S_t=s, A_t=a] \\ &= \sum_{s’,r}{p(s’,r|s,a)[r+\gamma max_{a’}q_{\ast}(s’,a’)]} \end{aligned} q(s,a)=E[Rt+1+γmaxaq(St+1,a)St=s,At=a]=s,rp(s,rs,a)[r+γmaxaq(s,a)]

1、Policy Evaluation

在DP中, p o l i c y   e v a l u a t i o n policy\ evaluation policy evaluation 指的是对任意规则 π \pi π 计算 state-value 函数 v π v_{\pi} vπ,也可以将这个称作是预测问题( p r e d i c t i o n   p r o b l e m prediction\ problem prediction problem)。在上一节的内容中提到 s ∈ S s\in\mathcal{S} sS 都有
v π ( s ) ≐ E π [ R t + 1 + γ R t + 2 + γ 2 R t + 3 + ⋯ ∣ S t = s ] = E π [ R t + 1 + γ v π ( S t + 1 ) ∣ S t = s ] = ∑ a π ( a ∣ s ) ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ v π ( s ’ ) ] \begin{aligned} v_{\pi}(s) &\doteq {\Bbb E}_{\pi}[R_{t+1}+\gamma R_{t+2}+\gamma ^2 R_{t+3}+\cdots | S_t=s] \\ &= {\Bbb E}_{\pi}[R_{t+1}+\gamma v_{\pi}(S_{t+1})| S_t=s] \\ &=\sum_a{\pi(a|s)}\sum_{s’,r}{p(s’,r|s,a)[r+\gamma v_{\pi}(s’)]} \end{aligned} vπ(s)Eπ[Rt+1+γRt+2+γ2Rt+3+St=s]=Eπ[Rt+1+γvπ(St+1)St=s]=aπ(as)s,rp(s,rs,a)[r+γvπ(s)]

从最后一个式子中可以看出, v π ( s ) v_{\pi}(s) vπ(s) 的计算还要依赖于 v π ( s ’ ) v_{\pi}(s’) vπ(s),对于这种情况,最常用的方法采用迭代的形式,不断地更新和逼近真实值。这里可以考虑一个近似的值函数序列 v 0 , v 1 , v 2 , ⋯ v_0,v_1,v_2,\cdots v0,v1,v2,,其中每个值函数都是从 S + \mathcal{S}^+ S+ R {\Bbb R} R 的映射,其中初始的近似值 v 0 v_0 v0 是任意选择的(终止状态的值为 0),之后的计算都是利用 v π v_{\pi} vπ 的 Bellman 方程来进行更新的:
v k + 1 ( s ) ≐ E π [ R t + 1 + γ v k ( S t + 1 ) ∣ S t = s ] = ∑ a π ( a ∣ s ) ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ v k ( s ’ ) ] \begin{aligned} v_{k+1}(s) &\doteq {\Bbb E}_{\pi}[R_{t+1}+\gamma v_{k}(S_{t+1})| S_t=s] \\ &=\sum_a{\pi(a|s)}\sum_{s’,r}{p(s’,r|s,a)[r+\gamma v_{k}(s’)]} \end{aligned} vk+1(s)Eπ[Rt+1+γvk(St+1)St=s]=aπ(as)s,rp(s,rs,a)[r+γvk(s)]

k → ∞ k \rightarrow \infty k 时,序列 { v k } \{v_k\} {vk} 会收敛于 v π v_{\pi} vπ,这个算法就称为是 i t e r a t i v e   p o l i c y   e v a l u a t i o n iterative \ policy \ evaluation iterative policy evaluation。整个过程可以描述为:
   v 0 → v 1 → v 2 → ⋯ → v π v_0 \rightarrow v_1 \rightarrow v_2 \rightarrow \cdots \rightarrow v_{\pi} v0v1v2vπ
  为了从 v k v_k vk 得到近似的 v k + 1 v_{k+1} vk+1,iterative policy evaluation 需要对每一个状态 s s s 做同样的操作:将 s s s 旧的 value 值换成计算得到的新的 value 值,将这种操作可以称为是 f u l l   b a c k u p full \ backup full backup,迭代策略评估的每一次迭代过程都需要把每个状态的 value 备份起来。
  迭代算法常用的停止准则是检测最大的状态变化量,整个过程的伪代码如下:

4 动态编程(Dynamic Programming, DP)_第1张图片

2、Policy Improvement

第一节中是计算每个 policy 的 value function,它的目的当然是为了找到更好的 policies,假设我们已经有了某个 π \pi π 的值函数 v π v_{\pi} vπ,那我们肯定想知道是否可以通过对规则 π \pi π 改进来得到更好的规则,改进的方式就是在改变在某个状态时的行为选择概率,即 a = π ( s ) a=\pi(s) a=π(s),我们肯定会想,在状态 s s s 时,我们依据当前的 v π ( s ) v_{\pi}(s) vπ(s) 到底是好还是不好呢?是否可以改进呢?那我们可以采用比较 q π ( s , a ) q_{\pi}(s,a) qπ(s,a) v π ( s ) v_{\pi}(s) vπ(s) 的方法,若 q π ( s , a ) q_{\pi}(s,a) qπ(s,a) v π ( s ) v_{\pi}(s) vπ(s) 大,那么采用“在状态 s s s 时选择行为 a a a,之后还遵从规则 π \pi π”就要比“无论什么状态下都遵从规则 π \pi π”要好。
  
  通常将这种理论称为是 p o l i c y   i m p r o v e m e n t   t h e o r e m policy \ improvement \ theorem policy improvement theorem,假设一对任意的规则 π \pi π π ’ \pi ’ π,若对所有的 s ∈ S s\in\mathcal{S} sS 都有:
q π ( s , π ’ ( s ) ) ≥ v π ( s ) q_{\pi}(s,\pi’(s)) \geq v_{\pi}(s) qπ(s,π(s))vπ(s)
  那么规则 π ’ \pi ’ π 一定比规则 π \pi π 更好或者相当,也就是说,对所有的状态 s ∈ S s\in\mathcal{S} sS 它的期望返回值都要高或者相当:
v π ’ ( s ) ≥ v π ( s ) v_{\pi’}(s) \geq v_{\pi}(s) vπ(s)vπ(s)
  回到我们之前的问题,我们如何对规则 π \pi π 进行改进呢?这里假设规则 π \pi π 是原始的规则,规则 π ’ \pi ’ π 是改进后的规则,这两个规则只有在 π ’ ( s ) = a ≠ π ( s ) \pi’(s)=a \neq \pi(s) π(s)=a̸=π(s) 不同,其他地方完全相同,若我们知道 q π ( s , a ) > v π ( s ) q_{\pi}(s,a)> v_{\pi}(s) qπ(s,a)>vπ(s),那我们就可以知道规则 π \pi π 比规则 π \pi π 要好,它的证明过程如下:

4 动态编程(Dynamic Programming, DP)_第2张图片

从中可以看出,只要改善一个状态的行为就可以对规则进行改进,自然而然地肯定会想,如果把所有的状态都改成可能的最好行为,那得到的规则会很好,也就是这样的一个 g r e e d y greedy greedy 规则 π \pi π
π ′ ( s ) ≐ a r g m a x a q π ( s , a ) = a r g m a x a E [ R t + 1 + γ v π ( S t + 1 ) ∣ S t = s , A t = a ]         ( 1 ) = a r g m a x a ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ v π ( s ’ ) ] \begin{aligned} {\pi}'(s) &\doteq argmax_a{q_{\pi}(s,a)} \\ &= argmax_a {\Bbb E} [R_{t+1}+\gamma v_{\pi}(S_{t+1})| S_t=s,A_t=a] \ \ \ \ \ \ \ (1)\\ &= argmax_a \sum_{s’,r}p(s’,r|s,a)[r+\gamma v_{\pi}(s’)] \end{aligned} π(s)argmaxaqπ(s,a)=argmaxaE[Rt+1+γvπ(St+1)St=s,At=a]       (1)=argmaxas,rp(s,rs,a)[r+γvπ(s)]

其中 a r g m a x a argmax_a argmaxa 指的是选择使后面式子最大的行为 a a a
  这种贪婪的规则依据 v π v_{\pi} vπ 选择短期内最好的行为,从结构上看,这种贪婪的规则满足 policy improvement theorem,因此比原始的规则要好,因此将这个过程就称为是 p o l i c y   i m p r o v e m e n t policy \ improvement policy improvement
  假设这个贪婪的规则 π ’ \pi’ π 并不比规则 π \pi π 好,而是两者相当,则 v π = v π ’ v_{\pi}= v_{\pi’} vπ=vπ,则根据公式(1)有:
v π ’ ( s ) = m a x a E [ R t + 1 + γ v π ’ ( S t + 1 ) ∣ S t = s , A t = a ] = m a x a ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ v π ’ ( s ’ ) ] \begin{aligned} v_{\pi’}(s) &= max_a {\Bbb E} [R_{t+1}+\gamma v_{\pi’}(S_{t+1})| S_t=s,A_t=a] \\ &= max_a \sum_{s’,r}p(s’,r|s,a)[r+\gamma v_{\pi’}(s’)] \end{aligned} vπ(s)=maxaE[Rt+1+γvπ(St+1)St=s,At=a]=maxas,rp(s,rs,a)[r+γvπ(s)]

这个方程与 Bellman 优化方程相同,因此 v π ’ ( s ) v_{\pi’}(s) vπ(s) 一定是 v ∗ v_{\ast} v,因此规则 π ’ \pi’ π 与规则 π \pi π 一定都是 optimal policies。因此,除非该规则已经是 optimal policies,否则 policy improvement 过程一定会给出一个严格更好的规则。

3、Policy Iteration

第一节介绍的是规则评价,第二节是规则改善,这里要将前两节结合到一起,从而得到下面的过程:
π 0 → E v π 0 → I π 1 → E v π 1 → I π 2 → E ⋯ → I π ∗ → E v π ∗ \pi_0 \xrightarrow{E} v_{\pi_0} \xrightarrow{I} \pi_1 \xrightarrow{E} v_{\pi_1} \xrightarrow{I} \pi_2 \xrightarrow{E} \cdots \xrightarrow{I} \pi_{\ast} \xrightarrow{E} v_{\pi_{\ast}} π0E vπ0I π1E vπ1I π2E I πE vπ
  其中, → E \xrightarrow{E} E 代表的是 policy evaluation, → I \xrightarrow{I} I 代表的是 policy improvement,并且该 improvement 保证是严格的提升。因为有限 MDP 只含有有限的规则,因此该过程最终一定会收敛到 optimal policy。这种查询过程就称为是 p o l i c y   i t e r a t i o n policy \ iteration policy iteration,完整的伪代码如下所示:

4 动态编程(Dynamic Programming, DP)_第3张图片

4、Value Iteration

Policy iteration 的一个缺点是在每次迭代中都要进行 policy evaluation,这个过程是非常耗时的,事实上该过程是可以缩短的,并且不会影响收敛,其中一种重要的方法就是 v a l u e i t e r a t i o n value iteration valueiteration,它可以写作是一个结合了 policy improvement 和删减的 policy evaluation 步骤的简单备份操作:
  
v k + 1 ( s ) ≐ m a x a E [ R t + 1 + γ v k ( S t + 1 ) ∣ S t = s , A t = a ] = m a x a ∑ s ’ , r p ( s ’ , r ∣ s , a ) [ r + γ v k ( s ’ ) ] \begin{aligned} v_{k+1}(s) &\doteq max_a {\Bbb E} [R_{t+1}+\gamma v_{k}(S_{t+1})| S_t=s,A_t=a] \\ &= max_a \sum_{s’,r}p(s’,r|s,a)[r+\gamma v_{k}(s’)] \end{aligned} vk+1(s)maxaE[Rt+1+γvk(St+1)St=s,At=a]=maxas,rp(s,rs,a)[r+γvk(s)]

对任意的 v 0 v_0 v0,序列 { v k } \{v_k\} {vk} 最终都可以收敛到 v ∗ v_{\ast} v
  
  算法的伪代码如下:

4 动态编程(Dynamic Programming, DP)_第4张图片

所有的 truncated policy iteration 算法都可以视为是 s w e e p sweep sweep 序列,其中一些使用的是 policy evaluation backups,另一些使用的是 value iteration backups。

5、Asynchronous Dynamic Programming 异步的动态编程

DP方法的一个主要缺点就是在于它需要遍历 MDP 过程的整个状态集合,即需要对 state set 进行 sweep,当状态集合很大时,一次 sweep 就需要耗费巨大。
  Asynchronous DP 方法替代了 iterative DP 算法,不是对状态集的系统地 sweep,这些方法会以任何顺序备份状态的 values,一些状态的 values 还有可能在其他状态第一次备份之前就备份了很多次。但为了正确收敛,异步算法必须继续备份所有的 values,异步 DP 在选择状态方面提供了很大的自由度。

6、Generalized Policy Iteration

广义的 policy iteration 可以用下图来表示:

4 动态编程(Dynamic Programming, DP)_第5张图片

Policy iteration 其实就是由两个连续的交互过程构成的:policy evaluation 和 policy improvement,在异步 DP 方法中,这两个过程是交错的。
  这里用 Generalized Policy Iteration (GPI)来代表这种一般化的思想,几乎所有的增强学习方法都可以描述为 GPI。在 GPI 中,policy evaluation 和 policy improvement 既是竞争的也是合作的。
  
  
  
参考文献
[1] Reinforcement Learning: An Introduction, Richard S. Sutton and Andrew G. Barto
[2] UCL Course on RL

你可能感兴趣的:(算法,强化学习)