![强化学习](https://wfqqreader-1252317822.image.myqcloud.com/cover/245/34233245/b_34233245.jpg)
2.2 贝尔曼方程
马尔可夫决策过程为强化学习问题提供了基本的理论框架,几乎所有的强化学习问题都可以用马尔可夫决策过程(MDP)进行建模。2.1.3节介绍了马尔可夫决策过程的基本概念,本节介绍在求解马尔可夫决策过程问题时用到的最基础的方程——贝尔曼方程。可以说贝尔曼方程是强化学习算法的基石,因为后续章节介绍的几乎所有的算法,如动态规划、蒙特卡罗、时序差分等强化学习方法,都是基于贝尔曼方程来求解最优策略的。
贝尔曼方程(Bellman Equation),也称为动态规划方程,由理查·贝尔曼(Richard Bellman)发现。贝尔曼方程可以求解具有某种最优性质的问题,其基本思想是将待求解问题分解成若干个子问题,从这些子问题的解得到原问题的解。
本节介绍两类贝尔曼方程,分别为贝尔曼期望方程和贝尔曼最优方程。贝尔曼期望方程表达了当前值函数(或行为值函数)和它后继值函数(或行为值函数)的关系,以及值函数和行为值函数之间的关系。贝尔曼最优方程表达了当前最优值函数(或最优行为值函数)和它后继最优值函数(或最优行为值函数)的关系,以及最优值函数和最优行为值函数之间的关系。贝尔曼方程为后续各类以迭代方式求解值函数的方法打开了大门,如果知道下一个状态的值,就能很容易求解当前状态的值。
2.2.1 贝尔曼期望方程
1.贝尔曼方程推导
在介绍贝尔曼期望方程之前,先回顾值函数的定义。状态值函数Vπ(s)表示从状态s开始,遵循当前策略π时所获得的期望回报,数学表示如下:
Vπ(s)=Eπ[Gt|St=s]=Eπ[Rt+1+γ Rt+2+…|St=s]
对Vπ(s)的定义公式进行推导:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P45_20645.jpg?sign=1738863073-Dwijk1EZJ98gTP3cRVaIAwXghmyRNhXz-0-2506ad51ac83b63f05d694a7baa99a1e)
最后一行将Gt+1变成了V(St+1),因为回报的期望等于回报期望的期望。经过推导将Vπ(s)分解为两部分,第一项是该状态下立即回报的期望,该项是常数项,因此立即回报期望等于立即回报Rt+1本身;第二项是下一时刻状态值函数的折扣期望。
同样地,Qπ(s,a)的贝尔曼期望方程为
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_20649.jpg?sign=1738863073-00JPdgpxQV6KlOifCNhKbNKbJlZk7EAZ-0-874188ab8c166a5143e2169d9320cc78)
以上就是贝尔曼方程的最初形式。
2.贝尔曼期望方程
本节通过图形化的方式推导出贝尔曼期望方程的其他四种表达形式,这四种方程分别给出了状态值函数、行为值函数之间存在的关系。如图2-4所示,空心圆圈表示状态,实心圆点表示动作,状态指向动作表示在该状态下采取某种动作。动作指向状态表示在某动作下发生了状态转变。
(1)基于状态s,采取动作a,求取Vπ(s)。
由图2-4可见,在遵循策略π时,状态s的值函数体现为在该状态下采取所有可能行为的价值Qπ(s,a)(行为值函数)与行为发生概率π(a|s)的乘积的和。数学表达式描述如下:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_20651.jpg?sign=1738863073-ANQNv1jwPFvDMOTjl66dhZX3Q8fLO0A2-0-6233b487ab9f51ee0065f0fc1e436f4d)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_1490.jpg?sign=1738863073-hLYUxLVDbZjwcFHgbfZtwwAQeOt9G9oW-0-4fbe5a93bccaf928c12282acd96a927b)
图2-4 求取Vπ(s)
(2)采取行为a,状态转变至s',求取Qπ(s,a)。
类似地,行为值函数也可以表示成状态值函数的形式。
在遵循策略π时,行为状态价值Qπ(s,a)体现为两项之和,如图2-5所示。第一项是采取行为a后,获得的立即回报,第二项是所有可能的状态值Vπ(s')乘以状态转移概率
带衰减求和。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_20652.jpg?sign=1738863073-rQgC6eqVigNBjsDmJmbbjR4jRB9N1373-0-06040f64ba1ee8adbc9c0fc78854c250)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_1493.jpg?sign=1738863073-UBuFaXEM69BsVDcc0idADQowV1XYwWH2-0-70d7642543b570dfad905c37de029867)
图2-5 求取Qπ(s,a)
(3)基于状态s,采取行为a,状态转变至s',求取Vπ(s)。
如图2-6所示,将(1)和(2)的结果组合起来,可以得到Vπ的第二种表示方法。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_20654.jpg?sign=1738863073-JfEQZzQq27A52NWMDiaYmyvFIAInH8HI-0-e7ff148848f5bc49226c3aebec50b509)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P47_1505.jpg?sign=1738863073-35t0CMxho0i8emuEyKEGsi0kWfwzuegR-0-d04346432cda07e77ca7073d96f71dc9)
图2-6 求取Vπ(s)
(4)采取行为a,状态转变至s',采取行为a',求取Qπ(s,a)。
如图2-7所示,同样将(1)和(2)的结果组合,得到Qπ(s,a)的第二种表示方法。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P46_20656.jpg?sign=1738863073-cWMpM81t5B67InJ4IUiRHeP2NpEK2P7X-0-9f5425a7d68f0b3ba05f0ac70f17ea7a)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P47_1508.jpg?sign=1738863073-mzfW1A1slFm76A3PaWWvnLJOLfZ4hmrg-0-705e82d332fa5826d0798b10095a9542)
图2-7 求取Qπ(s,a)
可通过求职马尔可夫决策过程例子对上述四种贝尔曼期望方程进行验证。如图2-8所示,圈内状态下面的数字表示状态对应的值函数,线条上Q××表示状态行为对对应的行为值函数。策略为随机策略,折扣因子γ为1,状态转移概率如未特殊说明,为1。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P47_1512.jpg?sign=1738863073-Xbovdmw0hVsLhr9tTpPvnch7I7IqfLGJ-0-6413db85c185744b65aef896f1e6b582)
图2-8 求职马尔可夫决策过程
(1)验证Vπ(s)和Vπ(s')关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P47_20668.jpg?sign=1738863073-JLYwzfON0U7dxKLshlMUceYgLtssLsTa-0-fb16d6afdf149868d92602b4aef608f6)
假设选择状态“强化学习”为研究对象,则此状态对应值函数V4表示当前状态值函数Vπ(s),V4的下继状态值函数V1、V2、V5表示下一步状态值函数Vπ(s')。
已知V4=6.562 5,V1=14.281 25,V2=0,V5=9.406 25,状态转换概率均为1/3。
根据公式,有
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P48_20669.jpg?sign=1738863073-QlieoWTL9qr2D2uZFWVXVxac5xkIuxVG-0-9ba287884344a2abb6135820dd5b670e)
则公式得以验证。
(2)验证Qπ(s,a)和Qπ(s',a')关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P48_20671.jpg?sign=1738863073-OO7LVsvM2I8XV4pcQfWHOqZFj2D6on2n-0-6c538907849f75568799a1d6ea1960a4)
假设选择状态“本职工作”为研究对象,则继续本职工作对应的状态行为对为(1,1),行为值函数为Q11。令Q11表示当前行为值函数Qπ(s,a),则Q11的下继行为值函数Q11、Q12表示下一步的行为值函数Q(s',a')。已知Q11=14.281 25,=0,Q12=14.281 25,分别将各个取值代入公式,有
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P48_20673.jpg?sign=1738863073-8tRgHa7p2be8C64YS3jzhzXvFHibNzvK-0-285f9a7749e19c13e0c6bb3348b7ccd7)
则公式得以验证。
(3)验证Vπ(s)和Qπ(s,a)关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P48_20675.jpg?sign=1738863073-1VvKbs3dK819JS9emnKQ6hwLgo3nTwq2-0-1714f5fd86d3b6bf1f944b1c12c13b22)
继续选择状态“强化学习”为研究对象,则此状态对应值函数V4表示当前状态值函数Vπ(s),下继行为值函数Q41、Q42、Q43表示Qπ(s,a)。已知V4=6.5625,Q41=4.2812,Q42=8,Q43=7.406 25。根据公式,有:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P48_20677.jpg?sign=1738863073-OJP1ohX4UT7JGFoyvobCAGCilhGAPVT9-0-49f1834541a353eb2c566a5ee42d5296)
则公式得以验证。
(4)验证Qπ(s,a)和Vπ(s')关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P48_20679.jpg?sign=1738863073-hNaSPtItmyZo7qjAE2ArGPzdYuhPCEYV-0-8fd53eb39f043bba933c2fbc54bc46a2)
假设选择状态“本职工作”为研究对象,则继续本职工作对应的状态行为对为(1,1),行为值函数为Q11。令Q11表示当前行为值函数Qπ(s,a)。下继值函数V1表示Vπ(s')。已知Q11=14.281 25,V1=14.281 25。根据公式,有:
Q11=0+1*1*V1=0+1*1*14.281 25=14.281 25
则公式得以验证。
3.贝尔曼期望方程矩阵形式
贝尔曼期望方程的矩阵形式表示为:
Vπ=Rπ+γ PπVπ
其中,Vπ为状态值矩阵;Rπ为回报矩阵;Pπ为状态转移矩阵;γ为折算因子,是一个常数。
结合矩阵的具体表达形式,可表示为:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P49_20696.jpg?sign=1738863073-8uFjO8mnEDTG3mgrdMi9y15nVSm499oh-0-b5894d564ad58b0c0615a124981e1b25)
对上述矩阵直接求解:
Vπ=Rπ+γ PπVπ
(I-γ Pπ)Vπ=Rπ
Vπ=(I-γ Pπ)-1Rπ
注意 在进行矩阵求解时,要求(I-γ Pπ)可逆。
也可以针对式(V(s)和V(s')关系式,Q(s,a)和Q(s',a')关系式)列线性方程组,方程组中唯一的未知数是值函数(或行为值函数),其未知数的个数与方程组的个数一致,可求解。
下面以求职马尔可夫决策过程模型为例列线性方程组进行求解。设:[V1,V2,V3,V4,V5]=[本职工作,人工智能工作,机器学习,强化学习,深度强化]
使用公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P49_20700.jpg?sign=1738863073-BJ5eGt37LjYxvTE9PmU7uDTS2UU9BNhK-0-64c40cdb7280b9aa0d784a6ace7c86d2)
根据公式可以列出方程组:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P49_20702.jpg?sign=1738863073-WDdNaXPZPGHu6Bg7BcPIE7Dqjeb1BK5c-0-3015a1d443cd48a583fee9108056f596)
求解方程组可得
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P49_20704.jpg?sign=1738863073-llZqqs7yRL5AFoTQQAUAxSx3ArGvevMP-0-e5695012d2036b1f1dab2e9211cf99db)
直接求解仅适用于小规模的MDP。大规模求解通常使用迭代法,常用的迭代方法有动态规划、蒙特卡罗、时序差分,后面会逐步讲解这些方法。
2.2.2 贝尔曼最优方程
贝尔曼最优方程表达的是当前最优值函数(或最优行为值函数)和它后继最优值函数(或最优行为值函数)的关系,以及最优值函数和最优行为值函数之间的关系。
其中,最优值函数V*(s)是指在所有策略中最大的值函数,即
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_20707.jpg?sign=1738863073-IOrEH39bk8I8tikpfMe2wo970VEabIwi-0-446fa57d484e8ff56d19dfbbce14062d)
相应地,最优行为值函数Q*(s,a)是指所有策略中最大的行为值函数,即
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_20709.jpg?sign=1738863073-U12NXs9z2D1DnGcA09Z0DtNxDkvxgoGN-0-4d5dbac2d1f9e28e03d899f2955b4c5d)
接下来本节继续通过图形化的方式推导贝尔曼最优方程的四种表达形式,这四种表达形式分别给出了最优状态值函数、行为值函数之间的关系。同样地,空心圆圈表示状态,实心圆点表示动作,状态指向动作表示在该状态下采取某种行为。动作指向状态表示在某动作下,发生了状态转变。
(1)基于状态s,采取动作a,求取V*(s)。
如图2-9所示,当前状态的最优值函数V*(s)等于从该状态s出发,采取的所有行为中对应的那个最大的行为值函数。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_20711.jpg?sign=1738863073-hK7a2zQH99DeFon4c3RbxXmy1M4OdS5B-0-b5ad6260e4acfc9586a7592470e5331f)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_1619.jpg?sign=1738863073-XeFYDQuXW92LSrM36QFVP4ejNFoJsXPx-0-7678809c33d8c361c254ab4d2b8be990)
图2-9 求取V*(s)
(2)采取行为a,状态转变至s',求取Q*(s,a)。
如图2-10所示,在某个状态s下,采取某个行为的最优价值Q*(s,a)由两部分组成,一部分是离开状态s的立即回报,另一部分则是所有能到达的状态s'的最优状态价值V*(s')按出现概率求和:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_20715.jpg?sign=1738863073-WjqbV5j6uzlWjZEAhfJ6CayAVKQxtGSy-0-6f806232c1ea54127e4a23295212c57b)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_1622.jpg?sign=1738863073-O3n6KfID4S6QqWFGcwKCWbwiDpMCh0S7-0-e12da2740dc5aad8afc7c5c6dd87cd22)
图2-10 求取Q*(s,a)
(3)基于状态s,采取行为a,状态转变至s',求取V*(s)。
如图2-11所示,将(1)和(2)的结果组合起来,得到V*(s)。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_20717.jpg?sign=1738863073-f03zSAXN6oeWvW5EvWWqpVEVDB1F7nLM-0-78b10477f8d2d4bfe208a5903d93cae5)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P51_1636.jpg?sign=1738863073-74kZSODVysAOkZvgvvml9ShjVc19TyYl-0-d88332f875b86c2075df01748c351cac)
图2-11 求取V*(s)
(4)采取行为a,状态转变至s',采取行为a',求取Q*(s,a)。
如图2-12所示,将(1)和(2)的结果组合起来,得到Q*(s,a)。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P50_20719.jpg?sign=1738863073-g5fmVvLXtvqOTvaXTHOBUOCxUucXPxGl-0-fc808a22d204199a1ed7a3c8c04f8671)
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P51_1639.jpg?sign=1738863073-6ol5mlgYT4wc0qJLVZcnXKkQro7tRrcy-0-d3c06b914e03fdf8732b2e5a60423993)
图2-12 求取Q*(s,a)
同样可以用求职马尔可夫决策过程的例子来验证上述四个公式。假设已经求得最优值函数和最优行为值函数,如图2-13和图2-14所示。
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P51_1643.jpg?sign=1738863073-xXI9tRZxMlBb5oObJjCEL27j7VVRQoXg-0-e0b5621a572d63529a6d8d396f39017d)
图2-13 最优值函数
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P52_1666.jpg?sign=1738863073-EXO1CtAsaIV50Fbzaau5edRnDiVyIvvb-0-4cabfb4365a0da17b621046b4ccc6c6b)
图2-14 最优行为值函数
(1)验证V*(s)和V*(s')关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P51_20726.jpg?sign=1738863073-3721q5geUW6BJaWMXMpSvnmxvX1D5AjV-0-3b5288c5504123e9e92837278e8fe9f1)
假设以状态“本职工作”作为研究状态,表示最优值函数V*(s),
的下继状态值函数
表示后继最优值函数V*(s')。已知
,根据公式,有
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P51_20735.jpg?sign=1738863073-fYQW3ePIMYmh99NVUBgN1cqtWybZv2Kj-0-1b795e83256d2a9e0b56451cbf9d43cf)
则公式得以验证。
(2)验证Q*(s,a)和Q*(s',a')关系公式
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P51_20737.jpg?sign=1738863073-c7YXBUdHRdi2aj5mqThuUf4ZFsss82ej-0-71368cb809b46a00b616f4cd4912405c)
继续选择状态“本职工作”为研究对象,则继续本职工作对应的状态行为对为(1,1),行为值函数为Q11。令表示当前最优行为值函数Q*(s,a),
的下继行为值函数
、
表示后继最优行为值函数Q*(s',a')。
根据公式,有
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P52_20747.jpg?sign=1738863073-HgVE4cGVUFYhUTU9tBA2lKzO9zEbCg0f-0-c6ee7ecd12d7fa934a0ec749b0d651fd)
则公式得以验证。
(3)验证Q*(s)和Q*(s,a)关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P52_20749.jpg?sign=1738863073-uIMg9GnTPYu5ABgTJM518W8u5G6gPDFP-0-bbb741b8a920f0117ffddccd8b7b26c2)
继续以状态“本职工作”作为研究状态,表示最优值函数V*(s),
的下继行为值函数
表示Q*(s,a)。
根据公式,有:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P52_20758.jpg?sign=1738863073-CMSNHc3Pg9YbmP3jHAzUZHr2ZnGZzxq7-0-98455cae2e18980b46c05e5d35dbbc11)
则公式得以验证。
(4)验证Q*(s,a)和V*(s')关系公式:
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P52_20760.jpg?sign=1738863073-mwby1jVApxGJ6tcVFrKyNy4WQueBPpfU-0-076913fe425f8488c839e9768bc5b6f8)
继续选择状态“本职工作”为研究对象,令表示当前最优行为值函数Q*(s,a),
的下继值函数
表示V*(s')。
根据公式,有
![](https://epubservercos.yuewen.com/C17FFE/18320967008553606/epubprivate/OEBPS/Images/Figure-P53_20773.jpg?sign=1738863073-w2iOUo3w92gcq3njErfbNGarokZGqxXE-0-18d3cd84f71b60468af6a570e275f4b2)
则公式得以验证。
贝尔曼最优方程是非线性的,没有固定的解决方案,只能通过一些迭代方法来解决,如价值迭代、策略迭代、Q学习、Sarsa等,后续会逐步展开讲解。