python繪制lost損失曲線加方差范圍的操作方法
1. 導(dǎo)入必要的包
我使用了seaborn,通過sns.set_style可以讓繪制出來的圖更漂亮,而且可以切換不同的類型
import re
import seaborn as sns
import matplotlib.pyplot as plt
import matplotlib.cm as cm
import shutil
import os
sns.set_style('whitegrid')
2. 數(shù)據(jù)的獲?。商^此步)
我用的數(shù)據(jù)是通過深度強化得到的回報曲線。數(shù)據(jù)結(jié)構(gòu)如下所示,我所需要的是從train開始的部分,分別對應(yīng)總的回報,平均回報和回報的方差。我采用了re.findall的正則表達式去提取我所需要的數(shù)據(jù),具體的操作方式可以查看源碼。
10-15 22:23:15 DATA/traffic DEBUG train 0 totalreward : -99477.0 ReturnAvg : -102.55360824742269 ReturnStd : 34.34301970480272
10-15 22:23:29 DATA/traffic DEBUG train 1 totalreward : -83131.0 ReturnAvg : -85.70206185567011 ReturnStd : 53.442993000985545
file_path = 'log.txt'
content = []
with open(file_path, 'r') as f:
for line in f.readlines():
line = line.strip('\n')
content.append(line)
iter = []
totalreward = []
returnavg = []
returnstd = []
for line in content:
str1 = re.findall('train.+', line)
v = [float(x) for x in re.findall('-?\d+.?\d+|\d+', str1[0])]
iter.append(v[0])
totalreward.append(v[1])
returnavg.append(v[2])
returnstd.append(v[3])
3. 回報繪制
直接將圖像保存到Plot的文件夾,這里保存不了jpg格式,一直保存,最后將其保存為png格式成功。設(shè)置分辨率為1000,其實差不多,只是線更清楚了。
color = cm.viridis(0.5)
f, ax = plt.subplots(1,1)
ax.plot(iter, totalreward, color=color)
ax.legend()
ax.set_xlabel('Iteration')
ax.set_ylabel('Return')
exp_dir = 'Plot/'
if not os.path.exists(exp_dir):
os.makedirs(exp_dir, exist_ok=True)
else:
os.makedirs(exp_dir, exist_ok=True)
f.savefig(os.path.join('Plot', 'reward' + '.png'), dpi=1000)
曲線如下圖,可通過plt.show()顯示出來,或者直接在console輸入f并回車

4.含有方差的平均回報繪制
在強化學(xué)習(xí)的論文中,我們經(jīng)??吹揭粭l收斂線,周圍還有淺淺的范圍線,那些范圍線就是方差。繪制代碼如下,主要包含了fill_between.
color = cm.viridis(0.7)
f, ax = plt.subplots(1,1)
ax.plot(iter, returnavg, color=color)
r1 = list(map(lambda x: x[0]-x[1], zip(returnavg, returnstd)))
r2 = list(map(lambda x: x[0]+x[1], zip(returnavg, returnstd)))
ax.fill_between(iter, r1, r2, color=color, alpha=0.2)
ax.legend()
ax.set_xlabel('Iteration')
ax.set_ylabel('Return')
exp_dir = 'Plot/'
if not os.path.exists(exp_dir):
os.makedirs(exp_dir, exist_ok=True)
f.savefig(os.path.join('Plot', 'avgreward' + '.png'), dpi=50)
結(jié)果如下

可以看到深綠色上下包裹著淺綠色的線,這就是fill_between的作用,其中可以調(diào)節(jié)alpha來改變顏色深度。
到此這篇關(guān)于python繪制lost損失曲線加方差范圍的文章就介紹到這了,更多相關(guān)python損失曲線 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
scikit-learn處理缺失數(shù)據(jù)的方法與實踐
scikit-learn作為Python中廣泛使用的機器學(xué)習(xí)庫,提供了多種工具和技術(shù)來幫助我們處理缺失數(shù)據(jù),本文將詳細介紹sklearn處理缺失數(shù)據(jù)的方法,并提供實際的代碼示例,需要的朋友可以參考下2024-06-06
python爬蟲框架scrapy實戰(zhàn)之爬取京東商城進階篇
這篇文章主要給大家介紹了利用python爬蟲框架scrapy爬取京東商城的相關(guān)資料,文中給出了詳細的代碼介紹供大家參考學(xué)習(xí),并在文末給出了完整的代碼,需要的朋友們可以參考學(xué)習(xí),下面來一起看看吧。2017-04-04
Python的Twisted框架上手前所必須了解的異步編程思想
Twisted是Python世界中人氣最高的framework之一,異步的工作模式使其名揚天下,這里為大家總結(jié)了Python的Twisted框架上手前所必須了解的異步編程思想,需要的朋友可以參考下2016-05-05
Python網(wǎng)絡(luò)編程之TCP套接字簡單用法示例
這篇文章主要介紹了Python網(wǎng)絡(luò)編程之TCP套接字簡單用法,結(jié)合實例形式分析了TCP套接字的功能及客戶端、服務(wù)器端具體實現(xiàn)方法,需要的朋友可以參考下2018-04-04
PyTorch一小時掌握之a(chǎn)utograd機制篇
這篇文章主要介紹了PyTorch一小時掌握之a(chǎn)utograd機制篇,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09

