#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import colormaps 
import matplotlib
matplotlib.use('agg')

resdf = pd.read_csv('sim_out/box_width_sim.csv')
#print("Jettisoned big N.")
#resdf = resdf[resdf['N']<1e6]

Ps = sorted(list(set(resdf['P'])))
Ds = sorted(list(set(resdf['D'])))

#cm = colormaps['autumn']
cm = colormaps['spring']

ncol = 3
nrow = int(np.ceil(len(Ps)/3))

fig = plt.figure(figsize=[2*ncol,2*nrow])
for pi, P in enumerate(Ps):
    cdf = resdf[resdf['P']==P]
    plt.subplot(nrow,ncol,pi+1)

    # Group by depth
    cdfi = cdf.groupby(['N','P','D'], as_index = False).mean()

    #cols = cdf['D'] / max(cdf['D'])
    for D in Ds:
        dcdf = cdfi[cdfi['D']==D]
        plt.plot(dcdf['N'], dcdf['IP'], c = cm(D/max(Ds)), label = int(D))

    # Overall
    cdfo = cdf.groupby(['N','P'], as_index = False).mean()
    plt.plot(cdfo['N'], cdfo['IP'], c = 'black', label = 'A')

    plt.title('P='+str(int(P)))
    plt.legend(prop={'size':5})
    plt.ylim(0,1)
    plt.xscale('log')
plt.tight_layout()
plt.savefig('width_sim.pdf')
plt.close()
