import matplotlib.pyplot as plt


model_no_improvement={'train_accuracy': {1: 97.97666666666666, 2: 98.91883333333334, 3: 99.5185, 4: 99.78316666666666, 5: 99.87133333333333, 6: 99.90333333333332, 7: 99.91599999999998, 8: 99.92299999999997, 9: 99.926, 10: 99.92916666666665, 11: 99.93116666666667, 12: 99.93216666666667, 13: 99.93299999999999, 14: 99.93366666666668, 15: 99.93383333333334}, 'train_accuracy_avg': 99.68865555555557, 'test_accuracy': {1: 97.66000000000001, 2: 98.338, 3: 98.63499999999999, 4: 98.82200000000002, 5: 98.87499999999999, 6: 98.881, 7: 98.877, 8: 98.89600000000002, 9: 98.89399999999999, 10: 98.89599999999999, 11: 98.886, 12: 98.898, 13: 98.886, 14: 98.88799999999999, 15: 98.88899999999998}, 'test_accuracy_avg': 98.74806666666669, 'train_loss': {1: 0.06944032085950176, 2: 0.03743245371221254, 3: 0.01924152749038612, 4: 0.010735069604807846, 5: 0.007243315535569564, 6: 0.005844497018237598, 7: 0.005152066740356386, 8: 0.004783070590468901, 9: 0.004568268963062825, 10: 0.004428782533875977, 11: 0.004338394271510187, 12: 0.004278532280580063, 13: 0.004237892231761943, 14: 0.004208424106256182, 15: 0.00418921855652084}, 'train_loss_avg': 0.012674788966340578, 'test_loss': {1: 0.07542333206102252, 2: 0.05200897000968456, 3: 0.04184563072483986, 4: 0.03735076289641205, 5: 0.03582574039745377, 6: 0.035428908194475806, 7: 0.035439144374874894, 8: 0.03544887266028905, 9: 0.03542330996063538, 10: 0.03540355838844785, 11: 0.0354710016433266, 12: 0.03550369277210207, 13: 0.035461519668200055, 14: 0.03549085931267357, 15: 0.035498538134300615}, 'test_loss_avg': 0.03980158941324923, 'gradient_factor': 0.622, 'step_factor': 0.347}
#{'train_accuracy': {1: 98.76666666666667, 2: 99.38, 3: 99.65666666666667, 4: 99.79833333333333, 5: 99.845, 6: 99.91, 7: 99.92, 8: 99.92, 9: 99.93, 10: 99.93333333333334, 11: 99.93333333333334, 12: 99.94166666666666, 13: 99.94, 14: 99.93833333333333, 15: 99.93833333333333}, 'train_accuracy_avg': 99.78344444444444, 'test_accuracy': {1: 98.42, 2: 98.91, 3: 99.18, 4: 99.18, 5: 99.18, 6: 99.16, 7: 99.18, 8: 99.22, 9: 99.19, 10: 99.18, 11: 99.18, 12: 99.17, 13: 99.17, 14: 99.18, 15: 99.17}, 'test_accuracy_avg': 99.11133333333336, 'train_loss': {1: 0.041165707183505096, 2: 0.02145385516338671, 3: 0.01250126897857214, 4: 0.008149617409950589, 5: 0.006788799627948902, 6: 0.004878881136836329, 7: 0.004235639917083123, 8: 0.003767016392759979, 9: 0.003574761433201396, 10: 0.003391565308284286, 11: 0.003314745164435832, 12: 0.0032345641483248378, 13: 0.00318607368303686, 14: 0.0031490493557144268, 15: 0.0031278671725982954}, 'train_loss_avg': 0.008394627471709252, 'test_loss': {1: 0.04738136324826628, 2: 0.032902213632315394, 3: 0.02890658797752112, 4: 0.02686641118610278, 5: 0.030213901386153885, 6: 0.028269429397222122, 7: 0.02920075172552606, 8: 0.02880480834072223, 9: 0.029515128409501632, 10: 0.02962344908239611, 11: 0.03000298552098684, 12: 0.029985620394031322, 13: 0.029997285045993704, 14: 0.030060147574864096, 15: 0.03012070776318433}, 'test_loss_avg': 0.03079005271231919, 'gradient_factor': 0.622, 'step_factor': 0.347}

model_with_improvement={'train_accuracy': {1: 98.2865, 2: 99.19316666666666, 3: 99.67033333333333, 4: 99.89866666666666, 5: 99.94333333333336, 6: 99.95766666666668, 7: 99.96383333333334, 8: 99.96783333333335, 9: 99.96900000000001, 10: 99.97000000000001, 11: 99.97050000000002, 12: 99.97100000000002, 13: 99.97166666666668, 14: 99.97233333333335, 15: 99.97250000000001}, 'train_accuracy_avg': 99.77855555555561, 'test_accuracy': {1: 97.886, 2: 98.458, 3: 98.67000000000002, 4: 98.85400000000001, 5: 98.893, 6: 98.89800000000001, 7: 98.905, 8: 98.926, 9: 98.92000000000002, 10: 98.917, 11: 98.922, 12: 98.91499999999999, 13: 98.913, 14: 98.91999999999999, 15: 98.917}, 'test_accuracy_avg': 98.79426666666669, 'train_loss': {1: 0.058161792054101824, 2: 0.02855624870394046, 3: 0.013697742843578262, 4: 0.006652680430493008, 5: 0.004307595915322503, 6: 0.0035003653021296486, 7: 0.0030092087335589655, 8: 0.0028009694510713846, 9: 0.0026657823464755594, 10: 0.0025792930591323725, 11: 0.0025235179174062793, 12: 0.002486614492631828, 13: 0.002461890307047094, 14: 0.002444552369515101, 15: 0.002432671413440645}, 'train_loss_avg': 0.009218728355989662, 'test_loss': {1: 0.06657648827813566, 2: 0.0476872510878928, 3: 0.040786500928918834, 4: 0.03627792597173014, 5: 0.035822965068416666, 6: 0.03553503277255689, 7: 0.035607737489218125, 8: 0.035520336910474584, 9: 0.035660813155277866, 10: 0.035663140190610426, 11: 0.03574360469388775, 12: 0.03578467977591092, 13: 0.035783734683408404, 14: 0.03579738811442338, 15: 0.03581082527377818}, 'test_loss_avg': 0.038937228292976044, 'gradient_factor': 0.622, 'step_factor': 0.347}
#{'train_accuracy': {1: 98.62, 2: 99.45, 3: 99.72166666666666, 4: 99.84666666666666, 5: 99.85833333333333, 6: 99.93166666666667, 7: 99.945, 8: 99.95666666666666, 9: 99.96333333333334, 10: 99.965, 11: 99.96666666666667, 12: 99.96833333333333, 13: 99.96666666666667, 14: 99.96833333333333, 15: 99.97}, 'train_accuracy_avg': 99.80655555555555, 'test_accuracy': {1: 98.3, 2: 98.98, 3: 99.08, 4: 99.13, 5: 99.06, 6: 99.1, 7: 99.13, 8: 99.1, 9: 99.16, 10: 99.1, 11: 99.1, 12: 99.15, 13: 99.1, 14: 99.12, 15: 99.12}, 'test_accuracy_avg': 99.04866666666666, 'train_loss': {1: 0.04396352140661329, 2: 0.01883805236869181, 3: 0.010542816818249413, 4: 0.00632790901271704, 5: 0.005667783772872644, 6: 0.0034525658927479527, 7: 0.003022351724004208, 8: 0.0026861724083091154, 9: 0.0024853049068596497, 10: 0.002352449994084115, 11: 0.0023010677800442258, 12: 0.002245791958020595, 13: 0.002220040127074875, 14: 0.0021882519481293762, 15: 0.002172313718273532}, 'train_loss_avg': 0.007364426255779456, 'test_loss': {1: 0.05133132867682725, 2: 0.03085189452338964, 3: 0.028844947789702563, 4: 0.02801501118653687, 5: 0.03162168357688934, 6: 0.03043088177369209, 7: 0.03167821702576475, 8: 0.032032077857805416, 9: 0.032174361459567445, 10: 0.03256921468616056, 11: 0.03287390524407528, 12: 0.03296274820933932, 13: 0.03296636717769488, 14: 0.03303491956468788, 15: 0.03304918263196305}, 'test_loss_avg': 0.03296244942560642, 'gradient_factor': 0.622, 'step_factor': 0.347}


plot_param='train_accuracy'#'train_loss'#'train_accuracy'
plt.figure(1)

stats=[model_with_improvement,model_no_improvement]

for data in stats:
    #data=model_no_improvement
    x=[]
    y=[]
    for i in range(1000):
        if i in data[plot_param]:
            x.append(i)
            y.append(data[plot_param][i])
        elif i>0:
            break

    if data==model_no_improvement:
        plt.plot(x, y, color='blue',label="Basic Training")
    else:
        plt.plot(x,y,color='green',label="Improved Training")
#plt.title("Loss on training set (model1)")
plt.title("Average loss on training set (model2, 10 runs average)")
plt.title("Average accuracy on training set (model2, 10 runs average)")
plt.legend()
plt.show()