深度强化学习(王树森)笔记06

2024-01-29 21:12

本文主要是介绍深度强化学习(王树森)笔记06,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

深度强化学习(DRL)

本文是学习笔记,如有侵权,请联系删除。本文在ChatGPT辅助下完成。

参考链接

Deep Reinforcement Learning官方链接:https://github.com/wangshusen/DRL

源代码链接:https://github.com/DeepRLChinese/DeepRL-Chinese

B站视频:【王树森】深度强化学习(DRL)

豆瓣: 深度强化学习

文章目录

  • 深度强化学习(DRL)
  • 蒙特卡洛估计
  • 后记

蒙特卡洛估计

ChatGPT对蒙特卡洛方法的介绍

蒙特卡洛方法是一类基于随机抽样和统计学原理的数值计算方法,其核心思想是通过随机抽样来近似解决问题。这种方法在强化学习、优化问题、概率估计等领域都有广泛的应用。以下是关于蒙特卡洛方法的一些基本概念:

  1. 基本思想
  • 随机抽样: 蒙特卡洛方法利用随机抽样的方式来近似计算某个问题的数值解。通过大量的随机样本,可以得到对问题的概率分布、期望值等进行估计的结果。
  1. 应用领域
  • 强化学习: 在强化学习中,蒙特卡洛方法用于估计状态值、动作值,以及计算策略的期望回报。通过采样多条轨迹,可以近似地计算期望值。

  • 数值积分: 蒙特卡洛方法可以用于估计复杂函数的积分值。通过在函数定义域内随机采样,计算函数值的平均值,可以得到积分的近似值。

  • 概率估计: 蒙特卡洛方法在概率估计中也有应用,例如通过采样估计随机变量的期望、方差等统计量。

  1. 算法步骤

    1. 随机抽样: 根据问题的特性,通过随机抽样生成一系列样本点。

    2. 计算统计量: 对每个样本点进行计算,得到需要估计的统计量,例如期望值、方差等。

    3. 平均估计: 对所有样本点计算的统计量进行平均,得到最终的近似解。

  2. 优缺点

  • 优点: 蒙特卡洛方法是一种通用的数值计算方法,对于复杂问题具有很强的适应性。它不依赖于问题的具体形式,而是通过随机抽样来逼近解。

  • 缺点: 收敛速度相对较慢,特别是在维度较高的问题中,需要大量的样本才能获得准确的估计。同时,对于一些问题,可能存在抽样偏差。

总体而言,蒙特卡洛方法是一种强大的数值计算工具,尤其在面对复杂、高维度的问题时显示出其优越性。

蒙特卡洛(Monte Carlo) 是一大类随机算法 (randomized algorithms) 的总称,它们通过随机样本来估算真实值。本节用几个例子讲解蒙特卡洛算法。

例一:近似 π \pi π

我们都知道圆周率 π \pi π 约等于 3.1415927。现在假装我们不知道 π, 而是要想办法近似估算 π \pi π 值。假设我们有 (伪) 随机数生成器,我们能不能用随机样本来近似 π 呢?这一小节讨论使用蒙特卡洛如何近似 π \pi π 值。

假设我们有一个 (伪)随机数生成器,可以均匀牛成 -1 到 +1 之间的数。每次生成两个随机数,一个作为 x x x,另一个作为 y y y。于是每次生成了一个平面坐标系中的点 ( x , y ) (x,y) (x,y) , 见图 2.3(左)。因为 x x x y y y 都是在 [-1,1] 区间 上均匀分布,所 [ − 1 , 1 ] × [ − 1 , 1 ] [-1,1]\times[-1,1] [1,1]×[1,1] 这个正方形内的点被抽到的概率是相同的。我们重复抽样 n n n 次,得到了 n n n 个正方形内的点。

在这里插入图片描述

如图2.3(右)所示,蓝色正方形里面包含一个绿色的圆,圆心是(0,0),半径等于1。刚才随机生成的 n n n个点有些落在圆外面,有些落在圆里面。

请问一个点落在圆里面的概率有多大呢?

由于抽样是均匀的,因此这个概率显然是圆的面积与正方形面积的比值。正方形的面积是边长的平方,即 a 1 = 2 2 = 4 a_1=2^2=4 a1=22=4。圆的面积是 π \pi π 乘以半径的平方,即 a 2 = π × 1 2 = π a_{2}=\pi\times1^{2}=\pi a2=π×12=π。 那么一个点落在圆里面的概率就是
p = a 2 a 1 = π 4 . p\:=\:\frac{a_{2}}{a_{1}}\:=\:\frac{\pi}{4}. p=a1a2=4π.

设我们随机抽样了 n n n个点,设圆内的点的数量为随机变量 M M M。显然, M M M 的期望等于

E [ M ] = p n = π n 4 . \mathbb{E}\big[M\big]\:=\:pn\:=\:\frac{\pi n}{4}. E[M]=pn=4πn.

注意,这只是期望,并不是实际发生的结果。如果你抽 n = 5 n=5 n=5个点,那么期望有 E [ M ] = 5 π 4 \mathbb{E}[M]=\frac{5\pi}4 E[M]=45π 个点落在圆内。但实际观测值 m m m 可能等于 0、1、2、3、4、5 中的任何一个。

给定一个点的坐标 ( x , y ) (x,y) (x,y),如何判断该点是否在圆内呢?已知圆心在原点,半径等于1,我们用一下圆的方程。如果 ( x , y ) (x,y) (x,y) 满足:

x 2 + y 2 ≤ 1 , x^2+y^2\:\leq\:1, x2+y21,
则说明 ( x , y ) (x,y) (x,y) 落在圆里面;反之,点就在圆外面。
我们均匀随机抽样得到 n n n个点,通过圆的方程对每个点做判别,发现有 m m m 个点落在圆里面。如果 n n n 非常大,那么随机变量 M M M 的真实观测值 m m m 就会非常接近期望 E [ M ] = π n 4 E[M]=\frac{\pi n}4 E[M]=4πn:
m ≈ π n 4 . m\:\approx\:\frac{\pi n}{4}. m4πn.

由此得到:

π ≈ 4 m n . \pi\approx\frac{4m}n. πn4m.

我们可以依据这个公式做编程实现。下面是伪代码:

  1. 初始化 m = 0 m=0 m=0。用户指定样本数量 n n n 的大小。 n n n 越大,精度越高,但是计算量越大。
  2. 把下面的步骤重复 n n n 次:

​ (a). 从区间[-1,1]上做两次均匀随机抽样得到实数 x x x y y y

​ (b). 如果 x 2 + y 2 ≤ 1 x^2+y^2\leq1 x2+y21, 那么 m ← m + 1 m\leftarrow m+1 mm+1

  1. 返回 4 m n \frac{4m}{n} n4m 作为对 π \pi π 的估计。

大数定律保证了蒙特卡洛的正确性:当 n n n 趋于无穷, 4 m n \frac{4m}n n4m 趋于 π \pi π。其实还能进一步用概率不等式分析误差的上界。比如使用 Bernstein 不等式,可以证明出下面结论:

∣ 4 m n − π ∣ = O ( 1 n ) . \left|\frac{4m}{n}-\pi\right|=O\Big(\frac{1}{\sqrt{n}}\Big). n4mπ =O(n 1).

这个不等式说明 4 m n \frac{4m}n n4m (即对 π \pi π 的估计) 会收敛到 π \pi π, 收敛率是 1 n \frac1{\sqrt n} n 1。然而这个收敛率并不快:样本数量 n n n 增加一万倍,精度才能提高一百倍。

例二:估算阴影部分面积

图2.4中有正方形、圆、扇形,几个形状相交。 请估算阴影部分面积。这个问题常见于初中数学竞赛。假如你不会微积分,也不会几何技巧,你是否有办法近似估算阴影部分面积呢?用蒙特卡洛可以很容易解决这个问题。

在这里插入图片描述

图 2.5 中绿色圆的圆心是 (1,1), 半径等于 1;蓝色扇形的圆心是 (0,0)、半径等于2。目的点 ( x , y ) (x,y) (x,y) 在绿色的圆中,而不在蓝色的扇形中。

在这里插入图片描述

利用圆的方程可以判定点 ( x , y ) (x,y) (x,y) 是否在绿色圆里面。如果 ( x , y ) (x,y) (x,y) 满足方程

( x − 1 ) 2 + ( y − 1 ) 2 ≤ 1 , ( 2.1 ) (x-1)^2\:+\:(y-1)^2\:\leq\:1, \quad{(2.1)} (x1)2+(y1)21,(2.1)

则说明 ( x , y ) (x,y) (x,y) 在绿色圆里面。

利用扇形的方程可以判定点 ( x , y ) (x,y) (x,y) 是否在蓝色扇形外面。如果点 ( x , y ) (x,y) (x,y) 满足方程
x 2 + y 2 > 2 2 , ( 2.2 ) x^{2}\:+\:y^{2}\:>\:2^{2},\quad{(2.2)} x2+y2>22,(2.2)
则说明 ( x , y ) (x,y) (x,y) 在蓝色扇形外面。

如果一个点同时满足方程 (2.1)和 (2.2), 那么这个点一定在阴影区域内。从 [ 0 , 2 ] × [ 0 , 2 ] [0,2]\times[0,2] [0,2]×[0,2] 这个正方形中做随机抽样,得到 n n n 个点。然后用两个方程筛选落在阴影部分的点。

我们在正方形 [ 0 , 2 ] × [ 0 , 2 ] [0,2]\times[0,2] [0,2]×[0,2] 中随机均匀抽样,得到的点有一定概率会落在阴影部分。我们来计算这个概率。正方形的边长等于2,所以面积 a 1 = 4 a_{1}=4 a1=4。设阴影部分面积为 a 2 a_{2} a2。那么点落在阴影部分概率是

p = a 2 a 1 = a 2 4 . p=\frac{a_2}{a_1}=\frac{a_2}{4}. p=a1a2=4a2.

我们从正方形中随机抽 n n n个点,设有 M M M 个点落在阴影部分内( M M M 是个随机变量)。每个点落在阴影部分的概率是 p p p,所以 M M M 的期望等于

E [ M ] = n p = n a 2 4 . \mathbb{E}[M]\:=\:np\:=\:\frac{na_{2}}{4}. E[M]=np=4na2.

用方程 (2.1)和 (2.2) 对 n n n 个点做筛选,发现实际上有 m m m 个点落在阴影部分内 ( m m m 是随机变量 M M M 的观测值)。如果 n n n 很大,那么 m m m 会比较接近期望 E [ M ] = n a 2 4 \mathbb{E}[M]=\frac{na_2}4 E[M]=4na2, 即

m ≈ n a 2 4 . m\:\approx\:\frac{na_{2}}{4}. m4na2.

也即:

a 2 ≈ 4 m n . a_{2}\approx\frac{4m}{n}. a2n4m.

这个公式就是对阴影部分面积的估计。我们依据这个公式做编程实现。下面是伪代码:

  1. 初始化 m = 0 m=0 m=0。用户指定样本数量 n n n 的大小。 n n n 越大,精度越高,但是计算量越大。

  2. 把下面的步骤重复 n n n 次:
    (a). 从区间 [0,2] 上均匀随机抽样得到 x x x; 再做一次均匀随机抽样,得到 y y y
    (b). 如果 ( x − 1 ) 2 + ( y − 1 ) 2 ≤ 1 (x-1)^2+(y-1)^2\leq1 (x1)2+(y1)21 x 2 + y 2 > 4 x^2+y^2>4 x2+y2>4 两个不等式都成立,那么让 m ← m + 1 。 m\leftarrow m+1_{\text{。}} mm+1

  3. 返回 4 m n \frac{4m}{n} n4m 作为对阴影部分面积的估计。

例三:近似定积分

近似求积分是蒙特卡洛最重要的应用之一,在科学和工程中有广泛的应用。举个例子,给定一个函数:
f ( x ) = 1 1 + ( sin ⁡ x ) ⋅ ( ln ⁡ x ) 2 , f(x)\:=\:\frac{1}{1+(\sin x)\cdot(\ln x)^2}, f(x)=1+(sinx)(lnx)21,

要求计算 f f f 在区间 0.8 到 3 上的定积分:

I = ∫ 0.8 3 f ( x ) d x . I\:=\:\int_{0.8}^{3}f(x)\:d\:x. I=0.83f(x)dx.

有很多科学和工程问题需要计算定积分,而函数 f ( x ) f(x) f(x) 可能很复杂,求定积分会很困难, 甚至有可能不存在解析解。如果求解析解很困难,或者解析解不存在,则可以用蒙特卡洛近似计算数值解。

一元函数的定积分是相对比较简单的问题。一元函数的意思是变量 x x x 是个标量。给定一元函数 f ( x ) f(x) f(x), 求函数在 a a a b b b 区间上的定积分:
I = ∫ a b f ( x ) d x . I\:=\:\int_{a}^{b}f(x)\:d\:x. I=abf(x)dx.

蒙特卡洛方法通过下面的步骤近似定积分:
1.在区间 [ a , b ] [a,b] [a,b] 上做随机抽样,得到 n n n 个样本,记作: x 1 , ⋯ , x n x_1,\cdots,x_n x1,,xn。样本数量 n n n 由用户自己定, n n n 越大,计算量越大,近似越准确。

  1. 对函数值 f ( x 1 ) , ⋯ , f ( x n ) f(x_1),\cdots,f(x_n) f(x1),,f(xn) 求平均,再乘以区间长度 b − a : b-a: ba:

q n = ( b − a ) ⋅ 1 n ∑ i = 1 n f ( x i ) . q_n\:=\:(b-a)\cdot\frac{1}{n}\sum_{i=1}^{n}f(x_i). qn=(ba)n1i=1nf(xi).

  1. 返回 q n q_n qn 作为定积分 I I I 的估计值。

多元函数的定积分要复杂一些。设 f : R d ↦ R f:\mathbb{R}^d\mapsto\mathbb{R} f:RdR 是一个多元函数,变量 x x x d d d 维向量。要求计算 f f f 在集合 Ω \Omega Ω 上的定积分:
I = ∫ Ω f ( x ) d x . I\:=\:\int_{\Omega}f(\boldsymbol{x})\:d\:\boldsymbol{x}. I=Ωf(x)dx.

蒙特卡洛方法通过下面的步骤近似定积分:

  1. 在集合 Ω 上做均匀随机抽样,得到 n n n 个样本,记作向量 x 1 , ⋯ , x n x_1,\cdots,x_n x1,,xn。样本数量 n n n 由用户自己定, n n n 越大,计算量越大,近似越准确。

  2. 计算集合 Ω \Omega Ω 的体积: v = ∫ Ω d x . v=\int_\Omega d\boldsymbol{x}. v=Ωdx.

  3. 对函数值 f ( x 1 ) , ⋯ , f ( x n ) f(x_1),\cdots,f(x_n) f(x1),,f(xn) 求平均,再乘以 Ω \Omega Ω 的体积 v v v:

q n = v ⋅ 1 n ∑ i = 1 n f ( x i ) . ( 2.3 ) q_{n}\:=\:v\cdot\frac{1}{n}\sum_{i=1}^{n}f(x_{i}). \quad{(2.3)} qn=vn1i=1nf(xi).(2.3)

  1. 返回 q n q_n qn 作为定积分 I I I 的估计值。

注意,算法第二步需要求 Ω \Omega Ω 的体积。如果 Ω \Omega Ω 是长方体、球体等规则形状,那么可以解析地算出体积 v v v。可是如果 Ω \Omega Ω 是不规则形状,那么就需要定积分求 Ω \Omega Ω 的体积 v v v, 这是比较困难的。可以用类似于上一小节“求阴影部分面积”的方法近似计算体积 v v v

举例讲解多元函数的蒙特卡洛积分:这个例子中被积分的函数是二元函数:

f ( x , y ) = { 1 , if x 2 + y 2 ≤ 1 ; 0 , otherwise . ( 2.4 ) \left.f\big(x,y\big)\:=\:\left\{\begin{array}{ll}1,&\text{if}\:x^2+y^2\leq1;\\0,&\text{otherwise}.\end{array}\right.\right. \quad{(2.4)} f(x,y)={1,0,ifx2+y21;otherwise.(2.4)

直观地说,如果点 ( x , y ) (x,y) (x,y) 落在右图的绿色圆内,那么函数值就是 1; 否则函数值就是 0。定义集合 Ω = \Omega= Ω= [ − 1 , 1 ] × [ − 1 , 1 ] [-1,1]\times[-1,1] [1,1]×[1,1], 即右图中蓝色的正方形,它的面积是 v = 4 v=4 v=4

在这里插入图片描述

定积分
I = ∫ Ω f ( x , y ) d x d y I\:=\:\int_{\Omega}\:f\big(x,y\big)\:dx\:dy I=Ωf(x,y)dxdy

等于多少呢?很显然,定积分等于圆的面积,即 π ⋅ 1 2 = π \pi\cdot1^2=\pi π12=π。因此,定积分 I = π I=\pi I=π。用蒙特卡洛求出 I I I,就得到了 π \pi π。从集合 Ω = [ − 1 , 1 ] × [ − 1 , 1 ] \Omega=[-1,1]\times[-1,1] Ω=[1,1]×[1,1]上均匀随机抽样 n n n 个点,记作 ( x 1 , y 1 ) , ⋯ , ( x n , y n ) (x_1,y_1),\cdots,(x_n,y_n) (x1,y1),,(xn,yn)。应用公式(2.3), 可得

q n = v ⋅ 1 n ∑ i = 1 n f ( x i , y i ) = 4 n ∑ i = 1 n f ( x i , y i ) . ( 2.5 ) q_{n}\:=\:v\cdot\frac{1}{n}\sum_{i=1}^{n}f(x_{i},y_{i})\:=\:\frac{4}{n}\sum_{i=1}^{n}f(x_{i},y_{i}). \quad{(2.5)} qn=vn1i=1nf(xi,yi)=n4i=1nf(xi,yi).(2.5)

q n q_n qn 作为对定积分 I = π I=\pi I=π 的近似。这与前面近似 π \pi π 的算法完全相同,区别在于此处的算法是从另一个角度推导出的。

例四:近似期望

蒙特卡洛还可以用来近似期望,这在整本书中会反复应用。设 X X X d d d 维随机变量,它的取值范围是集合 Ω ⊂ R d \Omega\subset\mathbb{R}^d ΩRd。函数 p ( x ) p(\boldsymbol{x}) p(x) X X X 的概率密度函数。设 f : Ω ↦ R f:\Omega\mapsto\mathbb{R} f:ΩR 是任意的多元函数,它关于变量 X X X 的期望是:
E X ∼ p ( ⋅ ) [ f ( X ) ] = ∫ Ω p ( x ) ⋅ f ( x ) d x . \mathbb{E}_{X\sim p(\cdot)}\Big[f(X)\Big]\:=\:\int_{\Omega}p(\boldsymbol{x})\cdot f(\boldsymbol{x})\:d\:\boldsymbol{x}. EXp()[f(X)]=Ωp(x)f(x)dx.

由于期望是定积分,所以可以按照上一小节的方法,用蒙特卡洛求定积分。上一小节在集合 Ω \Omega Ω上做均匀抽样,用得到的样本近似上面公式中的定积分。

下面介绍一种更好的算法。既然我们知道概率密度函数 p ( x ) p(x) p(x), 我们最好是按照 p ( x ) p(x) p(x) 做非均匀抽样,而不是均匀抽样。按照 p ( x ) p(x) p(x) 做非均匀抽样,可以比均匀抽样有更快的收敛。具体步骤如下:

  1. 按照概率密度函数 p ( x ) p(x) p(x),在集合 Ω \Omega Ω 上做非均匀随机抽样,得到 n n n 个样本,记作向量 x 1 , ⋯ , x n ∼ p ( ⋅ ) x_1,\cdots,x_n\sim p(\cdot) x1,,xnp()。样本数量 n n n 由用户自己定, n n n 越大,计算量越大;近似越准确。
  2. 对函数值 f ( x 1 ) , ⋯ , f ( x n ) f(x_1),\cdots,f(x_n) f(x1),,f(xn) 求平均:

q n = 1 n ∑ i = 1 n f ( x i ) . q_{n}\:=\:\frac{1}{n}\sum_{i=1}^{n}f\left(x_{i}\right). qn=n1i=1nf(xi).

  1. 返回 q n q_n qn 作为期望 E X ∼ p ( ⋅ ) [ f ( X ) ] \mathbb{E}_{X\sim p(\cdot)}[f(X)] EXp()[f(X)] 的估计值。

注 如果按照上述方式做编程实现,需要储存函数值 f ( x 1 ) , ⋯ , f ( x n ) f(x_1),\cdots,f(x_n) f(x1),,f(xn)。但用如下的方式做编程实现,可以减小内存开销。初始化 q 0 = 0 q_0=0 q0=0。从 t = 1 t=1 t=1 n n n,依次计算
q t = ( 1 − 1 t ) ⋅ q t − 1 + 1 t ⋅ f ( x t ) . ( 2.6 ) q_{t}\:=\:\left(1-\frac{1}{t}\right)\cdot q_{t-1}\:+\:\frac{1}{t}\cdot f\left(x_{t}\right). \quad{(2.6)} qt=(1t1)qt1+t1f(xt).(2.6)
不难证明,这样得到的 q n q_n qn 等于 1 n ∑ i = 1 n f ( x i ) \frac1n\sum_{i=1}^nf(x_i) n1i=1nf(xi)。这样无需存储所有的 f ( x 1 ) , ⋯ , f ( x n ) f(x_1),\cdots,f(x_n) f(x1),,f(xn)。可以进一步把公式(2.6) 中的 1 t \frac1t t1 替换成 α t \alpha_t αt, 得到公式:

q t = ( 1 − α t ) ⋅ q t − 1 + α t ⋅ f ( x t ) . q_{t}\:=\:\left(1-\alpha_{t}\right)\cdot q_{t-1}\:+\:\alpha_{t}\cdot f(x_{t}). qt=(1αt)qt1+αtf(xt).

这个公式叫做 Robbins-Monro 算法,其中 α n \alpha_n αn 称为学习步长或学习率。只要 α t \alpha_t αt 满足下面的性质,就能保证算法的正确性:

lim ⁡ n → ∞ ∑ t = 1 n α t = ∞ 和 lim ⁡ n → ∞ ∑ t = 1 n α t 2 < ∞ . \lim_{n\to\infty}\:\sum_{t=1}^{n}\alpha_{t}\:=\:\infty\quad\text{和}\quad\lim_{n\to\infty}\:\sum_{t=1}^{n}\alpha_{t}^{2}\:<\:\infty. nlimt=1nαt=nlimt=1nαt2<∞.

显然, α t = 1 t \alpha_t=\frac1t αt=t1 满足上述性质。Robbins-Monro 算法可以应用在 Q 学习算法中。

例五:随机梯度

我们可以用蒙特卡洛近似期望来理解随机梯度算法。

设随机变量 X X X 为一个数据样本,令 w w w 为神经网络的参数。设 p ( x ) p(\boldsymbol{x}) p(x) 为随机变量 X X X 的概率密度函数。定义损失函数 L ( X ; w ) L(X;\boldsymbol{w}) L(X;w)。它的值越小,意味着模型做出的预测越准确;反之,它的值越大,则意味着模型做出的预测越差。因此,我们希望调整神经网络的参数 w w w, 使得损失函数的期望尽量小。神经网络的训练可以定义为这样的优化问题:

min ⁡ w E X ∼ p ( ⋅ ) [ L ( X ; w ) ] . \min_{\boldsymbol{w}}\:\mathbb{E}_{X\sim p(\cdot)}\Big[L(X;\boldsymbol{w})\Big]. wminEXp()[L(X;w)].

目标函数 E X [ L ( X ; w ) ] \mathbb{E}_X[L(X;\boldsymbol{w})] EX[L(X;w)] 关于 w w w 的梯度是:

g ≜ ∇ w E X ∼ p ( ⋅ ) [ L ( X ; w ) ] = E X ∼ p ( ⋅ ) [ ∇ w L ( X ; w ) ] . ( 2.7 ) \boldsymbol{g}\triangleq\:\nabla_{\boldsymbol{w}}\mathbb{E}_{X\sim p(\cdot)}\Big[\:L(X;\boldsymbol{w})\:\Big]\:=\:\mathbb{E}_{X\sim p(\cdot)}\Big[\:\nabla_{\boldsymbol{w}}\:L(X;\boldsymbol{w})\:\Big]. \quad{(2.7)} gwEXp()[L(X;w)]=EXp()[wL(X;w)].(2.7)

可以做梯度下降更新 w w w, 以减小目标函数 E X [ L ( X ; w ) ] \mathbb{E}_X[L(X;\boldsymbol{w})] EX[L(X;w)]:
w ← w − α ⋅ g . w\gets w-\alpha\cdot g. wwαg.
此处的 α \alpha α被称作学习率 (learning rate)。直接计算梯度 g g g 通常会比较慢。为了加速计算, 可以对期望

g = E X ∼ p ( ⋅ ) [ ∇ w L ( X ; w ) ] g=\mathbb E_{X\sim p(\cdot)}\Big[\nabla_{\boldsymbol{w}}L(X;\boldsymbol{w})\Big] g=EXp()[wL(X;w)]

做蒙特卡洛近似,把得到的近似梯度 g ~ \tilde{g} g~ 称作随机梯度 (stochastic gradient), 用 g ~ \tilde{g} g~ 代替 g g g 来更新 w w w

  1. 根据概率密度函数 p ( x ) p(\boldsymbol{x}) p(x) 做随机抽样,得到 B B B 个样本,记作 x ~ 1 , … , x ~ B \tilde{x}_1,\ldots,\tilde{x}_B x~1,,x~B
  2. 计算梯度 ∇ w L ( x ~ j ; w ) \nabla_{\boldsymbol{w}}L(\tilde{\boldsymbol{x}}_j;\boldsymbol{w}) wL(x~j;w), ∀ j = 1 , … , B \forall j=1,\ldots,B j=1,,B。对它们求平均:

g ~ = 1 B ∑ j = 1 B ∇ w L ( x ~ j ; w ) . \tilde{\boldsymbol{g}}\:=\:\frac{1}{B}\sum_{j=1}^{B}\nabla_{\boldsymbol{w}}L(\tilde{\boldsymbol{x}}_{j};\boldsymbol{w}). g~=B1j=1BwL(x~j;w).

​ 我们称 g ~ \tilde{g} g~随机梯度。因为 E [ g ~ ] = g \mathbb{E}[\tilde{g}]=g E[g~]=g,它是 g g g 的一个无偏估计。
3. 做随机梯度下降更新 w : w: w:

w ← w − α ⋅ g ~ . w\:\leftarrow\:w\:-\:\alpha\cdot\tilde{\boldsymbol{g}}. wwαg~.

样本数量 B B B 称作批量大小 (batch size), 通常是一个比较小的正整数,比如 1、8、16、32。所以我们称之为最小批 (mini-batch) SGD

在实际应用中,样本真实的概率密度函数 p ( x ) p(\boldsymbol{x}) p(x) 一般是未知的。在训练神经网络的时候,我们通常会收集一个训练数据集 X = { x 1 , ⋯ , x n } X=\{x_1,\cdots,x_n\} X={x1,,xn}, 并求解这样一个经验风险最小化 (empirical risk minimization) 问题:
min ⁡ w 1 n ∑ i = 1 n L ( x i ; w ) . ( 2.8 ) \min_{\boldsymbol{w}}\:\frac{1}{n}\sum_{i=1}^{n}L(\boldsymbol{x}_{i};\boldsymbol{w}).\quad{(2.8)} wminn1i=1nL(xi;w).(2.8)

这相当于我们用下面这个概率质量函数代替真实的 p ( x ) : p(x): p(x):

p ( x ) = { 1 n , 如果  x ∈ X ; 0 , 如果  x ∉ X . \left.p(\boldsymbol{x})\:=\:\left\{\begin{array}{ll}\frac{1}{n},&\text{如果 }x\in\mathcal{X};\\0,&\text{如果 }x\not\in\mathcal{X}.\end{array}\right.\right. p(x)={n1,0,如果 xX;如果 xX.

公式的意思是随机变量 X X X 的取值是 n n n 个数据点中的一个,概率都是 1 n \frac1n n1。那么最小批 SGD 的每一轮都从集合 { x 1 , ⋯ , x n } \{x_1,\cdots,x_n\} {x1,,xn} 中均匀随机抽取 B B B 个样本,计算随机梯度,更新模型参数 w ∘ w_{\circ} w

总结

本文详细讲解了蒙特卡洛的应用。其中最重要的知识点是蒙特卡洛近似期望:设 X X X 是随机变量, x x x 是观测值,蒙特卡洛用 f ( x ) f(x) f(x) 近似期望 E [ f ( X ) ] \mathbb{E}[f(X)] E[f(X)]。强化学习中的 Q 学习、SARSA、策略梯度等算法都需要这样用蒙特卡洛近似期望。

后记

截至2024年1月28日18点38分,完成Monte Carlo Algorithms这节的学习。主要学习用蒙特卡洛方法求随机梯度,对后续强化学习算法的学习有帮助。

这篇关于深度强化学习(王树森)笔记06的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/658197

相关文章

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识