亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用seaborn繪制強化學(xué)習(xí)中的圖片問題

 更新時間:2023年01月31日 10:29:28   作者:johnjim0816  
這篇文章主要介紹了使用seaborn繪制強化學(xué)習(xí)中的圖片問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

seaborn繪制強化學(xué)習(xí)中的圖片

seaborn可以說是matplotlib的升級版,使用seaborn繪制折線圖時參數(shù)數(shù)據(jù)可以傳遞ndarray或者pandas,方便又好看!

本篇用繪制強化學(xué)習(xí)中的rewards舉例,實際上也可以用來機器學(xué)習(xí)中的loss曲線,原理類似。

從一個簡單示例開始

import matplotlib.pyplot as plt
import numpy as np
import seaborn as sns # 導(dǎo)入模塊
sns.set() # 設(shè)置美化參數(shù),一般默認(rèn)就好

rewards = np.array([0, 0.1,0,0.2,0.4,0.5,0.6,0.9,0.9,0.9])
plt.plot(rewards)
plt.show()

如上首先導(dǎo)入seaborn模塊,并設(shè)置美化參數(shù)(aesthetic parameters)sns.set(),使用matplotlib.pyplot as plt就可以繪制一個基本的圖像:

使用sns.lineplot或者sns.relplot

實際上relplot包含lineplot和scatterplot,并通過kind傳參可以轉(zhuǎn)換為lineplot,

relplot(kind="line")等價于lineplot
relplot(kind="scatter")等價于scatterplot

然后再進(jìn)行適當(dāng)?shù)恼{(diào)整并加上x,y軸的label,如下:

import matplotlib.pyplot as plt
import numpy as np
import seaborn as sns; sns.set() # 因為sns.set()一般不用改,可以在導(dǎo)入模塊時順便設(shè)置好

rewards = np.array([0, 0.1,0,0.2,0.4,0.5,0.6,0.9,0.9,0.9])
sns.lineplot(x=range(len(rewards)),y=rewards)
# sns.relplot(x=range(len(rewards)),y=rewards,kind="line") # 與上面一行等價
plt.xlabel("episode")
plt.ylabel("reward")
plt.show()

最后呈現(xiàn)效果如下:

繪制rewards聚合圖

當(dāng)我們對同一實驗作出多次得到一組rewards時,如下:

rewards1 = np.array([0, 0.1,0,0.2,0.4,0.5,0.6,0.9,0.9,0.9])
rewards2 = np.array([0, 0,0.1,0.4,0.5,0.5,0.55,0.8,0.9,1])
rewards=np.vstack((rewards1,rewards2)) # 合并成二維數(shù)組

我們希望繪制出聚合圖,但是sns.lineplot無法輸入一維以上的數(shù)據(jù),我們可以將它們?nèi)哭D(zhuǎn)為一維,雖然有些難看:

import matplotlib.pyplot as plt
import numpy as np
import seaborn as sns; sns.set() # 因為sns.set()一般不用改,可以在導(dǎo)入模塊時順便設(shè)置好

rewards1 = np.array([0, 0.1,0,0.2,0.4,0.5,0.6,0.9,0.9,0.9])
rewards2 = np.array([0, 0,0.1,0.4,0.5,0.5,0.55,0.8,0.9,1])
rewards=np.concatenate((rewards1,rewards2)) # 合并數(shù)組
episode1=range(len(rewards1))
episode2=range(len(rewards2))
episode=np.concatenate((episode1,episode2))
sns.lineplot(x=episode,y=rewards)
plt.xlabel("episode")
plt.ylabel("reward")
plt.show()

結(jié)果如圖:

繪制出了帶聚合陰影的圖,實際上實際部分是seaborn默認(rèn)對同一x軸的多個y值即rewards做了均值,陰影部分表示多組rewards的范圍,可以使用sns.lineplot(x=episode,y=rewards,ci=None)去掉。

使用pandas傳參

上面都是用ndarray傳參,這樣一方面免不了與matplotlib.pyplot混雜的成分比如plt.xlabel,另外繪制rewards聚合圖,也比較麻煩。

既然使用pandas傳參,就需要先把array轉(zhuǎn)成DataFrame形式,如下:

import numpy as np
import pandas as pd
rewards1 = np.array([0, 0.1,0,0.2,0.4,0.5,0.6,0.9,0.9,0.9])
rewards2 = np.array([0, 0,0.1,0.4,0.5,0.5,0.55,0.8,0.9,1])
rewards=np.vstack((rewards1,rewards2)) # 合并數(shù)組
df = pd.DataFrame(rewards).melt(var_name='episode',value_name='reward') # 推薦這種轉(zhuǎn)換方法
print(df)

推薦上述轉(zhuǎn)化方法,這樣無論rewards多少維都不影響最終的繪圖方式,其中melt方法將所有維合并成一列,var_name='episode',value_name='reward'則更改對應(yīng)的列名,轉(zhuǎn)化結(jié)果如下:

   episode  reward
0        0     0.0
1        0     0.1
2        0     0.0
3        0     0.2
4        0     0.4
5        0     0.5
6        0     0.6
7        0     0.9
8        0     0.9
9        0     0.9

下面完整繪圖:

import seaborn as sns;sns.set()
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd

import pandas as pd
rewards1 = np.array([0, 0.1,0,0.2,0.4,0.5,0.6,0.9,0.9,0.9])
rewards2 = np.array([0, 0,0.1,0.4,0.5,0.5,0.55,0.8,0.9,1])
rewards=np.vstack((rewards1,rewards2)) # 合并數(shù)組
df = pd.DataFrame(rewards).melt(var_name='episode',value_name='reward')

sns.lineplot(x="episode", y="reward", data=df)
plt.show()

注意這里的x,y不再傳入數(shù)組,而是傳入DataFrame中對應(yīng)的列名,類似于python字典中的鍵

結(jié)果如下:

牛刀小試

最后繪制一個更為復(fù)雜的可以用于paper的繪制方法:

import seaborn as sns; sns.set()
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd

def get_data():
    '''獲取數(shù)據(jù)
    '''
    basecond = np.array([[18, 20, 19, 18, 13, 4, 1],[20, 17, 12, 9, 3, 0, 0],[20, 20, 20, 12, 5, 3, 0]])
    cond1 = np.array([[18, 19, 18, 19, 20, 15, 14],[19, 20, 18, 16, 20, 15, 9],[19, 20, 20, 20, 17, 10, 0]]) 
    cond2 = np.array([[20, 20, 20, 20, 19, 17, 4],[20, 20, 20, 20, 20, 19, 7],[19, 20, 20, 19, 19, 15, 2]]) 
    cond3 = np.array([[20, 20, 20, 20, 19, 17, 12],[18, 20, 19, 18, 13, 4, 1], [20, 19, 18, 17, 13, 2, 0]])    
    return basecond, cond1, cond2, cond3
    
data = get_data()
label = ['algo1', 'algo2', 'algo3', 'algo4']
df=[]
for i in range(len(data)):
    df.append(pd.DataFrame(data[i]).melt(var_name='episode',value_name='loss'))
    df[i]['algo']= label[i] 

df=pd.concat(df) # 合并
sns.lineplot(x="episode", y="loss", hue="algo", style="algo",data=df)
plt.title("some loss")
plt.show()

結(jié)果如下:

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • jupyter notebook指定啟動目錄的方法

    jupyter notebook指定啟動目錄的方法

    這篇文章主要介紹了jupyter notebook指定啟動目錄的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Python全棧之學(xué)習(xí)HTML

    Python全棧之學(xué)習(xí)HTML

    這篇文章主要為大家介紹了Python全棧之HTML,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • python 時間信息“2018-02-04 18:23:35“ 解析成字典形式的結(jié)果代碼詳解

    python 時間信息“2018-02-04 18:23:35“ 解析成字典形式的結(jié)果代碼詳解

    本文是類方法給大家介紹如何將python 時間信息“2018-02-04 18:23:35“ 解析成字典形式的結(jié)果,需要的朋友可以參考下
    2018-04-04
  • 深入分析python數(shù)據(jù)挖掘 Json結(jié)構(gòu)分析

    深入分析python數(shù)據(jù)挖掘 Json結(jié)構(gòu)分析

    這篇文章通過實例給大家分析總結(jié)了python數(shù)據(jù)挖掘以及Json結(jié)構(gòu)分析的相關(guān)知識點,對此有興趣的朋友參考下。
    2018-04-04
  • opencv3/C++圖像像素操作詳解

    opencv3/C++圖像像素操作詳解

    今天小編就為大家分享一篇opencv3/C++圖像像素操作詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • python動態(tài)監(jiān)控日志內(nèi)容的示例

    python動態(tài)監(jiān)控日志內(nèi)容的示例

    本文介紹如何使用Python動態(tài)監(jiān)控程序日志的內(nèi)容,這里的動態(tài)指的是日志文件不斷的追加新的日志內(nèi)容,動態(tài)監(jiān)控是指監(jiān)控日志新追加的日志內(nèi)容
    2014-02-02
  • 如何用Anaconda搭建虛擬環(huán)境并創(chuàng)建Django項目

    如何用Anaconda搭建虛擬環(huán)境并創(chuàng)建Django項目

    在本篇文章里小編給大家整理了關(guān)于如何用Anaconda搭建虛擬環(huán)境并創(chuàng)建Django項目的相關(guān)文章,需要的朋友們可以跟著學(xué)習(xí)下。
    2020-08-08
  • 超詳細(xì)Python文件操作命令知識

    超詳細(xì)Python文件操作命令知識

    最近在寫的程序頻繁地與文件操作打交道,所以想著給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于Python文件操作命令的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • 淺析python中numpy包中的argsort函數(shù)的使用

    淺析python中numpy包中的argsort函數(shù)的使用

    這篇文章主要介紹了python中numpy包中的argsort函數(shù)的使用,argsort()函數(shù)在模塊numpy.core.fromnumeric中,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2018-08-08
  • Python自動生產(chǎn)表情包

    Python自動生產(chǎn)表情包

    本文主要介紹了使用Python進(jìn)行簡單圖像處理的方法以及Python自動生產(chǎn)表情包的實例,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03

最新評論