做者:YJLAugus 博客: https://www.cnblogs.com/yjlaugus 項目地址:https://github.com/YJLAugus/Reinforcement-Learning-Notes,若是感受對您有所幫助,煩請點個⭐Star。html
隨機變量(Random Variable),一般用大寫字母來表示一個隨機事件。好比看下面的例子:git
\(X\): 河水是鹹的github
\(Y\): 井水是甜的dom
很顯然,\(X\), \(Y\)兩個隨機事件是沒有關係的。也就是說\(X\)和\(Y\)之間是相互獨立的。記做:ide
對於一類隨機變量來講,它們之間存在着某種關係。好比:函數
\(S_{t}\):表示在 \(t\) 時刻某支股票的價格,那麼 \(S_{t+1}\) 和 \(S_t\) 之間必定是有關係的,至於具體什麼樣的關係,這裏原先不作深究,但有一點能夠肯定,二者之間必定存在的一種關係。隨着時間 \(t\) 的變化,能夠寫出下面的形式:學習
這樣就生成了一組隨機變量,它們之間存在着一種至關複雜的關係,也就是說,各個隨機變量之間存在着關係,即不相互獨立。由此,咱們會把按照某個時間或者次序上的一組不相互獨立的隨機變量的這樣一個總體做爲研究對象。這樣的話,也就引出了另外的一個概念:隨機過程(Stochastic Process)。也就是說隨機過程的研究對象不在是單個的隨機變量,而是一組隨機變量,而且這一組隨機變量之間存在着一種很是緊密的關係(不相互獨立)。記做:ui
馬爾科夫鏈(Markov Chain)即馬爾可夫過程,是一種特殊的隨機過程——具有馬爾可夫性的隨機過程。spa
馬爾可夫鏈/過程 即知足馬爾可夫性質的隨機過程,記做:code
狀態空間模型(State Space Model),常應用於 HMM,Kalman Filterm Particle Filter,關於這幾種這裏不作討論。在這裏就是指馬爾可夫鏈 + 觀測變量,即Markov Chain + Obervation
如上圖所示,s1-s2-s3爲馬爾可夫鏈,a1, a2, a3爲觀測變量,以a2爲例,a2只和s2有關和s1, s3無關。狀態空間模型能夠說是由馬爾可夫鏈演化而來的模型。記做:
馬爾可夫獎勵過程(Markov Reward Process),即馬爾可夫鏈+獎勵,即:Markov Chain + Reward
。以下圖:
舉個例子,好比說你買了一支股票,而後你天天就會有「收益」,固然了這裏的收益是泛化的概念,收益有多是正的,也有多是負的,有可能多,有可能少,總之從今天的狀態\(S_t\) 到明天的狀態 \(S_{s+1}\) ,會有一個reward
。記做:
馬爾可夫決策過程(Markov Decision Process),即馬爾可夫獎勵過程的基礎上加上action
,即:Markov Chain + Reward + action
。若是還用剛纔的股票爲例子的話,咱們只能天天看到股票價格的上漲或者降低,而後看到本身的收益,可是沒法操做股票的價格的,只有看到份,只是一個「小散戶」。這裏的馬爾可夫決策過程至關於政策的制定者,至關於一個操盤手,能夠根據不一樣的狀態而指定一些政策,也就至關於 action。
在馬爾可夫決策過程當中,全部的狀態是咱們當作離散的,有限的集合。全部的行爲也是離散有限的集合。記做:
對於上述公式簡單說明,\(S_t\) 用來表示某一個時刻的狀態。\(A_{(s)}\) 表示在某一個狀態時候的行爲 ,這個行爲必定是基於某個狀態而言的,假設在\(t\) 時刻的狀態爲\(S\) 此時的action
記做 \(A_t\) 。\(R_t 和 R_{(t+1)}\) 只是記法不一樣,好比下面的例子:從\(S_t\)狀態通過 \(A_t\) 到\(S_{t+1}\)狀態,得到的獎勵通常記做\(R_{(t+1)}\)。 也就是說\(S_t\), \(A_t\) ,\(R_{(t+1)}\) 是配對使用的。
馬爾可夫鏈只有一個量——狀態。好比 \(S\in(s_1,s_2,s_3,s_4,s_5,s_6,s_7,s_8,s_9,s_{10})\) ,在狀態集合中一共有十個狀態,每一個狀態之間能夠互相轉化,便可以從一個狀態轉移到另一個狀態,固然,「另外的狀態」 也有多是當前狀態自己。以下圖所示,s1狀態到能夠轉移到s2狀態,s1狀態也能夠轉移到本身當前的狀態,固然s1也有可能轉移到s3,s4,s5,狀態,下圖中沒有給出。
根據上面的例子,咱們能夠把全部的狀態寫成矩陣的形式,就成了狀態轉移矩陣。用狀態轉移矩陣來描述馬爾可夫鏈的動態特性。以上面的狀態集合\(S\in(s_1,s_2,s_3,s_4,s_5,s_6,s_7,s_8,s_9,s_{10})\) 爲例,可得一個 \(10\times10\) 的矩陣。以下圖所示:
由上面的例子可知,在狀態轉移的過程當中,對於下一個狀態轉移是有機率的,好比說s1轉移到到s1狀態的機率多是0.5,s1有0.3的機率轉移到s2狀態。⻢爾科夫過程是⼀個⼆元組(S, P) , 且滿⾜: S是有限狀態集合, P是狀態轉移機率。 可得:
一個簡單的例子:如圖2.2所⽰爲⼀個學⽣的7種狀態{娛樂, 課程1, 課程2, 課程3, 考過, 睡覺, 論⽂}, 每種狀態之間的轉換機率如圖所⽰。 則該⽣從課程 1 開始⼀天可能的狀態序列爲:
在 MPR 中,打個比喻,更像是隨波逐流的小船,沒有人爲的干預,小船能夠在大海中隨波逐流。
在MDP中,打個比喻,更像是有人劃的小船,這裏相比較MRP中的小船來講,多了「人划船槳」的概念,能夠認爲控制船的走向。這裏咱們看下面的圖:
s1狀態到s2狀態的過程,agent從s1發出action A1,使得s1狀態轉移到s2狀態,並從s2狀態獲得一個R2的獎勵。其實就是下圖所示的一個過程。這是一個動態的過程,由此,引出動態函數。
動態函數: The function \(p\) defines the dynamics of the MDP. 這是書上的原話,也就說,這個動態函數定義了MDP的動態特性
,動態函數以下:
狀態轉移函數: 咱們去掉 \(r\) ,也就是reward
,動態函數也就成了狀態轉移函數。
reward
的動態性: 在 s 和 a 選定後,r 也有多是不一樣的,即 r 也是隨機變量。可是,大多數狀況在 s 和 a 選定後 r 是相同的,這裏只作簡單的介紹。在MDP中,即馬爾可夫決策過程,最重要的固然是策略(Policy),用 \(\pi\) 來表示。在策略中其主要做用的就是action
,也即 \(A_t\),須要指出的必定是,action 必定是基於某一狀態 S 時。看下面的例子:
即,當 \(S_t = S\) 狀態時,不管 \(t\) 取何值,只要遇到 \(S\) 狀態就 選定 \(a_1\) 這個 action ,這就是一種策略,而且是肯定性策略。
肯定性策略:也就是說和時間 \(t\) 已經沒有關係了,只和這個狀態有關,只要遇到這個狀態,就作出這樣的選擇。
隨機性策略:與肯定性策略相對,當遇到 \(S\) 狀態時,可能選擇 \(a_1\) ,可能選擇 \(a_2\),也可能選擇 \(a_3\)。只是選擇action的機率不一樣。以下圖,就是兩種不一樣的策略:
從上面兩天圖中,由於一個策略是基於一個狀態而言的,在 \(S\) 狀態,可能選擇 \(a_1\) ,可能選擇 \(a_2\),也可能選擇 \(a_3\),故三個 action
之間是或的關係,因此說以上是兩個策略,而不要誤覺得是6個策略。
故策略可分爲肯定性策略和隨機性策略兩種。
對於隨機性策略而言,給定一個 \(s\) ,選擇一個 \(a\) ,也就是條件機率了。
肯定性策略能夠看做是一種特殊的隨機性策略,以上表-Policy1爲例,選擇a1的機率爲1,選擇a2,a3的機率都爲0。
在全部的策略中必定存在至少一個最優策略,並且在強化學習中,reward
的得到有延遲性(delay),舉雅達利遊戲中,不少遊戲只有到結束的時候纔會知道是否贏了或者輸了,纔會獲得反饋,也就是reward
,因此這就是獎勵得到延遲。當選定一個狀態 \(S_t\) 時,選定action \(A_t\) ,由於獎勵延遲的緣由可能對後續的 \(S_{t+1}\) 等狀態都會產生影響。這樣,就不能用當前的reward來衡量策略的好壞、優劣。這裏引入了回報和價值函數的概念。
而是後續多個reward的加和,也就是回報,用 \(G_t\) 表示 \(t\) 時刻的回報。
如上圖所示,此時的「回報」能夠表示爲:\(G_t = R_{t+1} + R_{t+2}+ \ ...\ +R_T\)
值得注意的是,\(T\) 多是有限的,也有多是無限的。
舉例:張三對李四作了行爲,對李四形成了傷害,李四在當天就能感覺到傷害,並且,這個傷害明天,後頭都仍是有的,可是,時間是最好的良藥,隨着時間的推移,李四對於張三對本身形成的傷害感受沒有那麼大了,會有一個wei折扣,用 \(\gamma\) 來表示。故真正的回報表示爲:
用 \(G_t\) 來衡量一個策略的好壞,\(G_t\) 大的策略就好,反之。
可是使用 \(G_t\) 也不能很好的衡量策略的好壞,好比一個最大的問題是,在給定一個狀態後,選擇一個肯定的action後(這裏仍是在隨機策略的角度),進入的下一個狀態也是隨機的。以下圖所示:把左側的過程放大,只給出a3下的隨機狀態,a1,a2也是有一樣的狀況,這裏勝率。
舉個例子,就像咱們給一盆花澆水,水是多了仍是少了,對於這盆花來講咱們是不得知的,可能會少,也可能會多。這個花的狀態變化也就是隨機的了。從上面的例子得知,若是仍是用 \(G_t\) 來對一個策略來進行評估的話,至少有9中狀況(隨機策略,3個action選一種)。
\(G_t\) 只能評估的是一個「分叉」而已(圖中綠色分支
)。而不能更好的進行評估。以下圖所示:
由於回報不能很好的對策略進行一個評估,由此引入了另一個概念——價值函數。
在指定一個狀態 \(s\) ,採起一個隨機策略
\(\pi\) ,而後加權平均,以上圖爲例,把9 個分叉(\(G_t\))加權平均。也就是指望 \(E\)。故得出價值函數:
上面提到的的價值函數實際上是其中的一種,確切的能夠稱爲 狀態價值函數
,用\(v_\pi(s)\) 來表示只和狀態有關係。初次以外還有另一種價值函數,那就是狀態動做價值函數
,用\(q_\pi(s,a)\)這裏引入的action
。故價值函數能夠分爲下面的兩種:
從上面的公式中,咱們能夠得知,在 \(v_\pi(s)\) 中,只有 \(s\) 是自變量,一個 \(\pi\) 其實就是一個狀態\(s\) 和一個action的一個映射。故,只要\(\pi\) 肯定了,那麼\(s,a\) 也就肯定了,即此時的 \(\pi\) 對狀態 \(s\) 是有限制做用的。可是,在 \(q_\pi(s,a)\) 中,子變量爲\(s,a\) 兩個,這兩個自變量之間是沒有特定的關係的。也就是說,\(s\)和\(a\) 都在變,沒法肯定一個映射(策略) \(\pi\) ,那麼也就是說在 \(q_\pi\) 中的\(\pi\) 對於\(s\) 是沒有約束的。
仍是以上圖爲例,對於 s 狀態,在隨機策略中有三種 action 選擇,分別是 \(\pi(a_1 \mid s)\),\(\pi(a_1 \mid s)\),\(\pi(a_1 \mid s)\),三種action(行爲)對應的價值函數(此時爲動做價值函數)爲 \(q_\pi(s,a_1)\), \(q_\pi(s,a_2)\), \(q_\pi(s,a_3)\)。那麼此時的 \(v_\pi(s)\) 就等於各個action的動做狀態價值函數的加和,即:
這樣一來咱們就得出了 \(v_\pi(s)\) 和 \(q_\pi(s,a)\) 之間的關係,若條件已知,就能夠直接計算出 \(v_\pi\)。
對於某個狀態 \(s\) 來講,\(v_\pi \leq \underset{a}{max}\ q_\pi(s,a)\) ,\(v_\pi(s)\) 是一個加權平均,實際上就是一個平均值,固然要小於等於\(\ q_\pi(s,a)\)的最大值。\(v_\pi(s)\)只有所有是最大值的時候,二者纔有可能相等。好比 5,5,5,平均值是5,最大值也是5;3,4,5而言,平均值爲4,可是最大值爲5。注意的是,4是乘上權值後的值,換句話說也就是乘了一個機率(\(\pi(a\mid s)\))。
從下面圖中可得,在 \(q_\pi(s,a)\) 位置,(一個action)狀態轉移只能向「箭頭」方向轉移,而不能向上。若是想從下面的狀態轉移到上面的狀態,那必須還要另一個action。狀況是同樣的,就按下圖來講明,通過a3後到達狀態s',此時的狀態函數就是 \(v_\pi(s’)\)。
上面的圖可知: 在肯定了s 後,由隨機策略action,引發「分叉」,同理,以a3爲例,由於系統狀態轉移的隨機性,也會引發分叉,也就是 s' 的狀態也是不肯定的。還有一點 r 也又不肯定性,以下圖藍色虛線部分。
由咱們前面提到的公式也可得知:s' 和 r 都是隨機的。好比說s,a ,s' 都是給定的,r也是不肯定的。
這樣一來,可得一條藍色通路的回報:
(1)式是怎麼來的呢?以上圖爲例,在 \(q_\pi(s,a)\) 處往下走,選定一個 r ,再往下到達一個狀態s', 此時在往下仍是一樣的狀態,就是俄羅斯套娃,以此類推。關於其中的 $\gamma v_\pi(s') $ ,來自於 \(G_t\)。看下面的式子:
由於 \(v_\pi(s)\) 來自 \(G_t\) ,故類比得(1)式。
由於走每條藍色的通路也都是由機率的,故咱們須要乘上機率,同時累加求和,一個是多條藍色通路另外一個是多個s'。故得:\(q_\pi(s,a)\) 和 \(v_\pi(s')\) 之間的關係 以下:
這樣咱們獲得兩個式子:
(4)式帶入(3)得:
(3)式帶入(4)得:
關於(6)式能夠看下圖,更容易理解:
(5)式和(6)式 被稱爲貝爾曼指望方程。
一個實例:
例子是一個學生學習考試的MDP。裏面實心圓位置是起點,方框那個位置是終點。上面的動做有study, Pub, Facebook, Quit, Sleep,每一個狀態動做對應的即時獎勵R已經標出來了。咱們的目標是找到最優的狀態動做價值函數或者狀態價值函數,進而找出最優的策略。
爲了方便,咱們假設衰減因子 \(\gamma =1, \pi(a|s) = 0.5\) 。對於終點方框位置,因爲其沒有下一個狀態,也沒有當前狀態的動做,所以其狀態價值函數爲0,對於其餘的狀態(圓圈)按照從上到下,從左到右的順序定義其狀態價值函數分別是 \(v_1,v_2,v_3,v_4\) ,根據(5)式 :
對於\(v_1\)位置,咱們有:\(v_1 = 0.5*(-1+v_1) +0.5*(0+v_2)\)
對於\(v_2\)位置,咱們有:\(v_2 = 0.5*(-1+v_1) +0.5*(-2+v_3)\)
對於\(v_3\)位置,咱們有:\(v_3 = 0.5*(0+0) +0.5*(-2+v_4)\)
對於\(v_4\)位置,咱們有:\(v_4 = 0.5*(10+0) +0.5*(1+0.2*v_2+0.4*v_3+0.4*v_4)\)
解出這個方程組能夠獲得 \(v_1=-2.3, v_2=-1.3, v_3=2.7, v_4=7.4\), 即每一個狀態的價值函數以下圖:
從上面能夠看出,針對一個特定狀體,狀態價值函數計算都是基於下一個狀態而言的,通俗的講,按照「出箭頭」的方向計算當前狀態的價值函數。
可以使得 \(v\) 達到最大值的那個 \(\pi\) ,這個 \(\pi\) 被成爲最優策略,進而獲得最優狀態價值函數。同理獲得最優狀態動做價值函數。
記 \(\pi_* = \underset{\pi}{argmax} \ v_\pi(s) = \underset{\pi}{argmax} \ q_\pi(s,a)\),含義是 \(\pi_*\) 可使得 $ v_*(s)$達到最大值,一樣的,也可使得
\(q_\pi(s,a)\) 達到最大值。
由以上公式得:
值得注意的一點是$ v_*(s)$ 強調的是,無論你採用的是什麼策略,只要狀態價值函數達到最大值,而 \(v_{\pi_*}(s)\) 則更爲強調的是 \(\pi\) ,達到最大的狀態價值函數所採起的最優的那個 \(\pi\)
此時,咱們再探討一下\(v_{\pi_*}(s)\) 和 \(q_{\pi_*}(s,a)\) 的關係。在貝爾曼指望方程中,咱們提到過 \(v_\pi(s) \leq \underset{a}{max}\ q_\pi(s,a)\) ,那麼在這裏是否是也由相似的關係\(v_{\pi_*}(s)\leq \underset{a}{max}\ q_\pi(s,a)\) 成立?咱們知道 \(v_{\pi_*}(s)\) 是一種策略,而且是最優的策略,\(q_{\pi_*}(s,a)\) 是表明一個「分支」,由於 \(v_{\pi_*}(s)\) 是一個加權平均值,但一樣的,和\(v_\pi(s)\) 不一樣的是,\(v_{\pi_*}(s)\) 是最優策略的加權平均,那麼是否是能夠把小於號去掉,寫成下面的形式:
假定 \(v_{\pi_*}(s)\leq \underset{a}{max}\ q_\pi(s,a)\) 中的 \(\pi_*\) 仍是一個普通的策略,那麼必定知足 \(v_{\pi_*}(s)\leq \underset{a}{max}\ q_\pi(s,a)\) ,這一點咱們已經提到過,若是說 \(v_{\pi_*}(s)< \underset{a}{max}\ q_\pi(s,a)\) ,說明\(v_{\pi_*}(s)\) 還有提升的空間,並非最優策略,這和條件矛盾了。因此這個小於不成立,得證:\(v_{\pi_*}(s)= \underset{a}{max}\ q_\pi(s,a)\)
詳細證實過程以下:
其實,上面的式子是由 (3)式
演變而來的。\(v_{\pi_*}(s)\) 直接取最大值時候和 \(\underset{a}{max}\ q_\pi(s,a)\) 的最大值是相等的。也就是此時不用加權平均了,直接是 \(v_\pi(a) = q_\pi(s,a)\) 。那麼從原先的(4)式能不能也得出類似
的結論,把求和符號去掉,直接等於最大值呢?答案是否認的,由於\(v_{\pi_*}(s)= \underset{a}{max}\ q_\pi(s,a)\) 是做用在action
上的,在公式中也能夠看出,換句話說,咱們對於下圖的a1,a2,a3這裏是能夠控制的。可是對於下圖中的藍色虛線部分,系統狀態轉移是沒法控制的。
因此,原先的兩組公式(3)、(4)並 結合(7)、(8)
並進行一個推導,得出另外的兩組公式(9)、(10)以下:
(10)式帶入(9)式得:
(9)式帶入(10)式得:
(11)、(12)被稱爲貝爾曼最優方程。
一個實例:仍是以上面的例子講解,咱們此次以動做價值函數 \(q_*(s,a)\) 爲例來求解 $v_(s),q_(s,a) $
根據(12)式
可得方程組以下:
而後求出全部的 \(q_*(s,a)\),而後再利用 \(v_*(s) = \underset{a'}{max}q_*(s,a)\),就能夠求出全部的 \(v_*(s)\),最終結果以下圖所示:
詳細的計算過程能夠看下視頻 的簡單分析。https://www.bilibili.com/video/BV1Fi4y157vR/
https://www.bilibili.com/video/BV1RA411q7wt
http://www.javashuo.com/article/p-cahukyzm-gg.html
https://www.davidsilver.uk/wp-content/uploads/2020/03/MDP.pdf