zjowowen's picture
init space
079c32c
# Code Reference: https://github.com/OptMLGroup/DeepBeerInventory-RL.
import os
import numpy as np
import matplotlib
matplotlib.use('Agg')
import matplotlib.pyplot as plt
from pylab import *
# plotting
def plotting(plt, data, colori, pltLabel):
# plt.hold(True)
for i in range(np.shape(data)[0]):
plt.subplot(4, 5, 5 * i + 1)
plt.plot(np.transpose(data[i])[0, :], np.transpose(data[i])[1, :], colori, label=pltLabel)
plt.xlabel('Time')
plt.ylabel('IL')
plt.grid(True)
plt.subplot(4, 5, 5 * i + 2)
plt.plot(np.transpose(data[i])[0, :], np.transpose(data[i])[2, :], colori, label=pltLabel)
plt.xlabel('Time')
plt.ylabel('OO')
plt.grid(True)
plt.subplot(4, 5, 5 * i + 3)
plt.plot(np.transpose(data[i])[0, :], np.transpose(data[i])[3, :], colori, label=pltLabel)
plt.xlabel('Time')
plt.ylabel('a')
plt.grid(True)
plt.subplot(4, 5, 5 * i + 4)
plt.plot(np.transpose(data[i])[0, :], np.transpose(data[i])[5, :], colori, label=pltLabel)
plt.xlabel('Time')
plt.ylabel('OUTL')
plt.grid(True)
plt.subplot(4, 5, 5 * i + 5)
plt.plot(np.transpose(data[i])[0, :], -1 * np.transpose(data[i])[4, :], colori, label=pltLabel)
plt.xlabel('Time')
plt.ylabel('r')
plt.grid(True)
return plt
def savePlot(players, curGame, Rsltdnn, RsltFrmu, RsltOptm, RsltRnd, config, m):
#add title to plot
if config.if_titled_figure:
plt.suptitle(
"sum OurPolicy=" + str(round(sum(Rsltdnn), 2)) + "; sum Strm=" + str(round(sum(RsltFrmu), 2)) +
"; sum BS=" + str(round(sum(RsltOptm), 2)) + "; sum Rnd=" + str(round(sum(RsltRnd), 2)) + "\n" +
"Ag OurPolicy=" + str([round(Rsltdnn[i], 2) for i in range(config.NoAgent)]) + "; Ag Strm=" +
str([round(RsltFrmu[i], 2) for i in range(config.NoAgent)]) + "; Ag BS=" +
str([round(RsltOptm[i], 2) for i in range(config.NoAgent)]) + "; Ag Rnd=" +
str([round(RsltRnd[i], 2) for i in range(config.NoAgent)]),
fontsize=12
)
#insert legend to the figure
legend = plt.legend(bbox_to_anchor=(-1.4, -.165, 1., -.102), shadow=True, ncol=4)
# configures spaces between subplots
plt.subplots_adjust(left=None, bottom=None, right=None, top=None, wspace=.5, hspace=.5)
# save the figure
path = os.path.join(config.figure_dir, 'saved_figures/')
if not os.path.exists(path):
os.mkdir(path)
plt.savefig(path + str(curGame) + '-' + str(m) + '.png', format='png')
print("figure" + str(curGame) + ".png saved in folder \"saved_figures\"")
plt.close(curGame)