from matplotlib import pyplot as plt
import torch
import os
from utils.loadcolor import loadcolor
from matplotlib.ticker import ScalarFormatter

def getfigloglog(plott, plotf, ploterr, config_yaml, logpath, truncationnum, errbound = 1e-6):
    truncationnum = truncationnum*1e2
    savename = config_yaml["log"]["savename"]

    min_element = min(min(vector) for vector in plotf)
    plotf = [torch.tensor([element - min_element for element in vector]) for vector in plotf]

    histt1 = plott[0]; histt2 = plott[1]; histt3 = plott[2]; histt4 = plott[3]; histt5 = plott[4]
    histf1 = plotf[0]; histf2 = plotf[1]; histf3 = plotf[2]; histf4 = plotf[3]; histf5 = plotf[4]
    histerr1 = ploterr[0].squeeze(); histerr2 = ploterr[1].squeeze();
    histerr3 = ploterr[2].squeeze(); histerr4 = ploterr[3].squeeze();
    histerr5 = ploterr[4].squeeze()
    histf1[histerr1 > errbound] = histf1[0]
    histf2[histerr2 > errbound] = histf2[0]
    histf3[histerr3 > errbound] = histf3[0]
    histf4[histerr4 > errbound] = histf4[0]
    histf5[histerr5 > errbound] = histf5[0]


    pcolor = loadcolor()
    plt.figure(figsize=(8,6), dpi=80, facecolor='w')
    plt.subplots_adjust(left=0.15, right=0.9, bottom=0.15, top=0.9)


    plt.loglog(histt4.detach().numpy(), histf4.detach().numpy(), '-', linewidth=5, markersize=3, color=pcolor['red'].numpy(),label='GS-JOBCD')
    plt.loglog(histt5.detach().numpy(), histf5.detach().numpy(), '-', linewidth=5, markersize=3, color=pcolor['black'].numpy(),label='J-JOBCD')
    plt.loglog(histt3.detach().numpy(), histf3.detach().numpy(), ':', linewidth=5, markersize=3, color=pcolor['blue'].numpy(),label='CSDM')
    plt.loglog(histt2.detach().numpy(), histf2.detach().numpy(), '-.', linewidth=5, markersize=3, color=pcolor['green'].numpy(), label='ADMM')
    plt.loglog(histt1.detach().numpy(), histf1.detach().numpy(), '--', linewidth=5, markersize=3, color=pcolor['purple'].numpy(), label='UMCM')

    plt.gca().yaxis.set_major_formatter(ScalarFormatter(useMathText=True))
    plt.gca().ticklabel_format(style='sci', axis='y', scilimits=(0, 0), useOffset=False, useLocale=False,
                               useMathText=True)
    plt.gca().yaxis.get_offset_text().set_size('x-small')
    plt.gca().yaxis.get_major_formatter().set_powerlimits((0, 1))
    plt.gca().yaxis.get_major_formatter().set_scientific(True)
    plt.gca().yaxis.get_major_formatter().set_useOffset(False)
    plt.tick_params(axis='y', which='major', labelsize=10)

    hleg = plt.legend(fontsize=15,frameon=True, framealpha=1)
    hleg.set_title('', prop={'size': 15, 'weight': 'normal', 'family': 'times new Roman'})
    hleg.get_title().set_fontsize('15')

    plt.xlabel('Time (seconds)', fontsize=20)
    plt.ylabel('Objective', fontsize=20)
    plt.xticks(fontsize=17)
    plt.yticks(fontsize=17)

    plt.grid(True)
    plt.savefig(os.path.join(logpath, 'log{}.png'.format(savename)), format='png', dpi=300)
    plt.savefig(os.path.join(logpath, 'log{}.eps'.format(savename)), format='eps', dpi=300)
    plt.show()

