(其实是专业课作业 感觉算法岗面试可能会问,来存一下档)

友链:RL | Value Iteration 的收敛性证明


问题:证明 Policy Iteration 收敛性

Please prove that Policy Iteration algorithm could terminate within finite steps under discrete state, discrete action and discounted reward settings.

Answer:

0 Background - 背景

First of all, let's review what is Policy Iteration. It includes two steps:

  • 1 - Policy Evaluation:

    • For an initial policy \(\pi_1\) and an initial value function \(V_0\), we use Bellman Operator \(B_{\pi_1}V(s)=E_{a\sim\pi(a|s)}[r(s,a)+\gamma E_{s'\sim p(s'|s,a)}V(s')]\) to get the accurate value function \(V_1\) for policy \(\pi_1\).
    • In practice, we repeatedly use the Bellman operator \(B_{\pi_1}\) to update the value function the from its initial value \(V_0\), until it reaches \(B_{\pi_1}V(s)=V(s)\) for all s. We denote the \(V\) satisfying the above equation as \(V_1\), so \(V_1\) is the corresponding value function of policy \(\pi_1\).
  • 2 - Policy Improvement:
    • We can get a policy \(\pi_2\) better than the previous policy \(\pi_1\) use its value function \(V_1\). For all state \(s\), \(\pi_2(s)=\arg\max_a[r(s,a)+\gamma E_{s'\sim p(s'|s,a)}V_1(s')]\).
  • Iteration:
    • After getting \(\pi_2\), we calculate its value function \(V_2\) using Bellman Operator \(B_{\pi_2}\); Then, we can get a better policy \(\pi_3\) using value function \(V_2\) ... Finally, the iterated policy \(\pi_{k+1}\) will be the same as its previous policy \(\pi_k\), and at that time, we get the optimal policy \(\pi_k\).

在最开始,先回顾一下 Policy Iteration(策略迭代)的定义:

  • 它包含两部分:1. Policy Evaluation(策略评估),2. Policy Improvement(策略改进)。
  • 第一步是去求解给定策略的 value function,第二步是基于该 value function 做 a = argmax [r+γV(s')],得到一个更好的新策略。
  • 这样不断迭代,不断得到更好的新策略;如果某次迭代,新策略 = 上一次的策略,那么策略收敛到了最优策略。

In the following sections, we will demonstrate two keypoints for the convergence guarantee of Policy Iteration:

  • First, the value function will converge to the value function of the given policy during the Policy Evaluation.
  • Second, we can use finite Policy Iteration steps to get the optimal policy.

接下来,我们会证明两件事情:1. 策略评估环节的值函数真的能收敛,2. 策略改进环节能通过有限次迭代得到最优策略。

1 Policy Evaluation converges to the value function of the given policy - 策略评估的值函数会收敛到给定策略的值函数

What we want to prove is that, through the Policy Evaluation ,we can always get the corresponding value function \(V_i\) for a specific policy \(\pi_i\). To prove this, we have to point out that, the Bellman Operator \(B_\pi\) is a Contraction Mapping. The proof is as follows (similar to homework 4):

\[\begin{aligned}
& |B_\pi V_1(s)-B_\pi V_2(s)| \\
&= \bigg|E_{a\sim\pi(a|s)}\big[r(s,a)+\gamma E_{s'\sim p(s'|s,a)}[V_1(s')]
-r(s,a)-\gamma E_{s'\sim p(s'|s,a)}[V_2(s')] \big]\bigg| \\
&= \gamma\bigg|E_{a\sim\pi(a|s)} E_{s'\sim p(s'|s,a)}[V_1(s')-V_2(s')]\bigg| \\
&\le \gamma\bigg|E_{a\sim\pi(a|s),s'\sim p(s'|s,a)}\max_s [V_1(s)-V_2(s)]\bigg| \\
&= \gamma|V_1-V_2|_\infty
\end{aligned}
\tag1
\]

If the Bellman Operator \(B_\pi\) is a Contraction Mapping, we can use the Banach fixed point theorem to obtain the convergence guarantee. It is the same as the proof in homework 4, so won't go into detail here.

我们希望证明,策略评估真的能得到特定策略的 value function。需要证明 Bellman Operator \(B_\pi\) 是压缩映射(Contraction Mapping)(通过一通放缩就能得到了),然后使用巴纳赫不动点定理,即可得到 Policy Evaluation 的收敛保证(见 上次作业)。

2 Policy Improvement will converge to the optimal policy - 策略改进的策略会收敛到最优策略

Then, we need to prove the effectiveness of Policy Improvement. The proof includes two parts: 1. Policy Improvement will get a better policy than the previous one; 2. It will finally converge to the optimal policy after finite steps.

证明完 Policy Evaluation 能得到 value function 后,我们要去证明 Policy Improvement 的有效性。证明分为两步:1. 证明每次 Policy Improvement 都能得到更好的策略;2. 证明有限步 Policy Improvement 后就能收敛到最优策略。

2.1 Policy Improvement will push the policy better - 策略改进总能让策略性能提升

To show this, we need to unfold the iteration process that repeatedly conducts the Bellman Operator \(B_{\pi_{i+1}}\) in the value function \(V_{i+1}\) using the previous value function \(V_i\).

想要证明 Policy Improvement 总能通过 a = argmax Q(s,a) 得到更好的策略(或至少不会变的更差),我们想证明的是,新策略 \(\pi_{i+1}\) 的 value function \(V_{i+1}\) 大于等于旧策略 \(\pi_i\) 的 value function \(V_i\)。为此,我们需要把 Policy Evaluation 求解 \(V_{i+1}\) 的过程中,反复使用 Bellman Operator \(B_{\pi_{i+1}}\) 的过程进行展开。

Consider the following policy: we use the improved policy \(\pi_{i+1}\) for the current step, and then use policy \(\pi_i\) for the remaining episode, then the value function will be:

\[V_{i+1}^{(1)}(s)=\arg\max_a[r(s,a)+E_{s'\sim p(s'|s,a)}\gamma V(s')]\ge V_i(s).
\tag2
\]

Then, at the state \(s'\), we continue to use the improved policy \(\pi_{i+1}\), changing value function into

\[V_{i+1}^{(2)}(s)=\arg\max_a[r(s,a)+E_{s';a'\sim\pi_{i+1}(s')}[r(s',a')+E_{s''}V_i(s'')]]\ge V_{i+1}^{(1)}\ge V_i(s).
\tag3
\]

Now, we can infer that, if we continue to use the improved policy \(\pi_{i+1}\) till the episode ends, we can get the value function \(V_{i+1}\) which satisfies the following inequality:

\[V_{i+1}(s)=V_{i+1}^{(m)}(s)\ge V_{i+1}^{(m-1)}(s)\ge\cdots\ge V_{i+1}^{(1)}(s)\ge V_{i}(s).
\tag4
\]

Thus, we obtain the conclusion that, the performance of the improved policy is better or no worse than the previous one.

  • 先考虑这样一种策略:在当前决策,我们使用新策略 \(\pi_{i+1}\) 得到新 state \(s'\),然后继续使用旧策略 \(\pi_i\)。这样得到的 value function \(V_{i+1}^{(1)}(s)\) 如上文的公式 (2) 所示。
  • 然后,我们使用两步新策略 \(\pi_{i+1}\) ,也就是在得到新 state \(s'\) 后继续使用 \(\pi_{i+1}\) ,这样得到的 value function \(V_{i+1}^{(2)}(s)\) 如上文的公式 (3) 所示,有 \(V_{i+1}^{(2)}(s)\ge V_{i+1}^{(2)}(s)\)。
  • 这样,一直使用新策略 \(\pi_{i+1}\),无穷无尽地继续下去,就能得到新策略 \(\pi_{i+1}\) 的 value function \(V_{i+1}(s)\) !可以得到公式 (4) 的不等式,即,新 value function 一定大于等于旧 value function,得证。

2.2 Policy Improvement will converge to the optimal policy - 策略改进会收敛到最优策略

It is actually very simple: If the state space and action space are all discrete and finite, then we have a finite number of policies. If the policy cannot converge to the optimal policy, then there is only one possibility called "policy oscillation", which means that, when we get policy \(\pi_{a}\) and its value function \(V_a\), the improved policy based on \(V_a\) is \(\pi_b\); we get policy \(\pi_{b}\) and its value function \(V_b\), the improved policy based on \(V_b\) turns back to \(\pi_a\), (or more oscillated policies \(\pi_a,\pi_b,\pi_c,\cdots\)).

证明 Policy Improvement 会收敛到最优策略,其实非常简单:因为 state space 和 action space 都是离散、有限的,因此策略的数量也有限,一直迭代,总会收敛到最优策略。除非碰到了“策略震荡”(policy oscillation)的情况:策略一直在比如说 \(\pi_a\) 和 \(\pi_b\) 间震荡(当然也可能在更多策略间震荡),\(\pi_a\) Policy Improvement 得到 \(\pi_b\),\(\pi_b\) Policy Improvement 得到 \(\pi_a\),如此循环往复。

However, it contradicts with the guarantee that Policy Improvement can always get a better (or no worse) policy. If the improved policy is better, we will get \(V_a\lt V_b\lt V_a\), which is obviously wrong. If the improved policy is as good as the previous one, then the oscillated policies are all optimal policies, so we have obtained the optimal policy.

然而,“策略震荡”现象与 2.1 节所说,Policy Improvement 一定能得到更好的策略(或至少不更差的策略)相矛盾。如果能得到更好的策略,那么 \(\pi_a,\pi_b\) 的 value function 满足 \(V_a\lt V_b\lt V_a\),显然是不对的。如果这些策略一样好,那么它们已经是最优策略了,我们就得到了最优策略。

Reference - 参考资料

RL 基础 | Policy Iteration 的收敛性证明的更多相关文章

  1. K-Means算法的收敛性和如何快速收敛超大的KMeans?

    不多说,直接上干货! 面试很容易被问的:K-Means算法的收敛性. 在网上查阅了很多资料,并没有看到很清晰的解释,所以希望可以从K-Means与EM算法的关系,以及EM算法本身的收敛性证明中找到蛛丝 ...

  2. 再论EM算法的收敛性和K-Means的收敛性

    标签(空格分隔): 机器学习 (最近被一波波的笔试+面试淹没了,但是在有两次面试时被问到了同一个问题:K-Means算法的收敛性.在网上查阅了很多资料,并没有看到很清晰的解释,所以希望可以从K-Mea ...

  3. [ML从入门到入门] 支持向量机:从SVM的推导过程到SMO的收敛性讨论

    前言 支持向量机(Support Vector Machine,SVM)在70年代由苏联人 Vladimir Vapnik 提出,主要用于处理二分类问题,也就是研究如何区分两类事物. 本文主要介绍支持 ...

  4. 【题解】CF24D Broken Robots(收敛性)

    [题解]CF24D Broken Robots http://codeforces.com/problemset/problem/24/D 解1(不会写,口胡的) 获得一个比较显然的转移式子 \(dp ...

  5. 51nod1674:区间的价值2(分治,利用&和|的收敛性)

    lyk拥有一个区间. 它规定一个区间的价值为这个区间中所有数and起来的值与这个区间所有数or起来的值的乘积. 例如3个数2,3,6.它们and起来的值为2,or起来的值为7,这个区间对答案的贡献为2 ...

  6. Policy Improvement and Policy Iteration

    From the last post, we know how to evaluate a policy. But that's not enough, because the purpose of ...

  7. 2020-BUAA OO-面向对象设计与构造-HW11中对ageVar采用缓存优化的等价性证明(包括溢出情况)

    HW11中对ageVar采用缓存优化的等价性证明(包括溢出情况) 概要 我们知道,第三次作业里age上限变为2000,而如果缓存年龄的平方和,2000*2000*800 > 2147483647 ...

  8. CSS+DIV入门第一天基础视频 CSS选择器层叠性和继承性

    大家好,我是小强老师, 现在网上的CSS+DIV视频,要么讲的太深,要么太浅,很多初学的同学们总是遇到困难,今天小强老师专门给大家准备了css课程的视频.带你从零基础学习CSS+DIV一直到能独立完成 ...

  9. java并发基础(六)--- 活跃性、性能与可伸缩性

    <java并发编程实战>的第9章主要介绍GUI编程,在实际开发中实在很少见到,所以这一章的笔记暂时先放一放,从第10章开始到第12章是第三部分,也就是活跃性.性能.与测试,这部分的知识偏理 ...

  10. 【Java并发基础】安全性、活跃性与性能问题

    前言 Java的多线程是一把双刃剑,使用好它可以使我们的程序更高效,但是出现并发问题时,我们的程序将会变得非常糟糕.并发编程中需要注意三方面的问题,分别是安全性.活跃性和性能问题. 安全性问题 我们经 ...

随机推荐

  1. C语言基础-结构体基础

    文章目录 前言 1.结构体的创建 1.1 第一种方法 1.2 第二种方法 1.3 全局结构体和局部结构体的声明 2.结构体的使用 2.1 局部结构体的声明 & 初始化 2.1.1 指针方法 2 ...

  2. 进程相关API

    ID与句柄 如果我们成功创建一个进程,CreateProcess函数会给我们返回一个结构体,包括四个数 据:进程编号(ID).进程句柄.线程编号(ID).线程句柄. 进程ID其实我们早见过了,通常我们 ...

  3. 论文解读(BERT-DAAT)《Adversarial and Domain-Aware BERT for Cross-Domain Sentiment Analysis》

    论文信息 论文标题:Adversarial and Domain-Aware BERT for Cross-Domain Sentiment Analysis论文作者:论文来源:2020 ACL论文地 ...

  4. java反射newInstance()带删除线的问题

    从java9开始,newInstance()方法不建议使用导致idea自动画了条删除横线 解决方法: //改用getDeclaredConstructor().newInstance() Object ...

  5. 利用IPV6随时访问家中影音Jellyfin

    本文章主要记录通过ipv6实现家庭影音中心在互联网上的访问. 之前很多方案都是通过第三方进行内网穿透,实际体验不是很好.目前ipv6发展迅速,完全可以取代这种以ipv4为中心的内网资源外网访问的方式. ...

  6. 文心一言 VS 讯飞星火 VS chatgpt (81)-- 算法导论7.4 6题

    六.如果用go语言,考虑对 PARTITION 过程做这样的修改:从数组 A 中随机选出三个元素,并用这三个元素的中位数(即这三个元素按大小排在中间的值)对数组进行划分.求以a 的函数形式表示的.最坏 ...

  7. pytest-xdist分布式测试原理浅析

    pytest-xdist执行流程: 解析命令行参数:pytest-xdist 会解析命令行参数,获取用户指定的分发模式.进程数.主机列表等信息. 加载测试用例:pytest-xdist 会加载所有的 ...

  8. 详细讲解js实现电梯导航

    场景 对于某一个页面内容繁多, 如果我们滚动的时间较长,为了增加用户体验. 我们需要实现点击某一个按钮,然后滚动到对应的区域. 滚动的时候,右侧对应的分类实现高亮 其实,这个功能就2个步骤: 1.点击 ...

  9. QA|重写了元素定位后报错xx object has no attribute 'find_element'|网页计算器自动化测试实战

    代码如下: 1 # basepage.py 2 3 from selenium import webdriver 4 5 6 class BasePage(): 7 """ ...

  10. Go语句与表达式深度解析:全案例手册

    关注公众号[TechLeadCloud],分享互联网架构.云服务技术的全维度知识.作者拥有10+年互联网服务架构.AI产品研发经验.团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资 ...