import time
import numpy as np
import matplotlib.pyplot as plt

Nt_values = np.array([60,100,120,150,200,250,300,350,400,450,500,550,600])+1 #40,60
valeurs_de_Ns = ((Nt_values-1)/4).astype(int)*0+15
NbXp=10
Conv=0.007
print(Conv)
print(Nt_values)
print(valeurs_de_Ns)

temps_executionP =[]

for ivaleur in range(len(Nt_values)):
    print(Nt_values[ivaleur],flush=True)
    import PDMP
    PDMP.Ni=2
    PDMP.Nt=Nt_values[ivaleur]
    PDMP.T=10
    PDMP.Ns=valeurs_de_Ns[ivaleur]
    PDMP.Td=np.linspace(0,PDMP.T,PDMP.Nt)
    PDMP.Sd=np.linspace(0,1,PDMP.Ns)
    PDMP.dt=PDMP.Td[1]-PDMP.Td[0]
    PDMP.ds=PDMP.Sd[1]-PDMP.Sd[0]
    PDMP.lbd0=np.zeros(PDMP.Nt)
    s=[]
    for ezihhpe in range(NbXp):
       debut = time.time()
       PDMP.algo(Conv,1000,PDMP.Nt,PDMP.Ns,PDMP.b,PDMP.c,PDMP.psi,PDMP.Ilaw,0.1,np.zeros(PDMP.Nt)+0.069,prin=False,plot=False)
       fin = time.time()
       s.append(fin - debut)
       print(s,flush=True)
    temps_executionP.append([s])

temps_executionM =[]

for ivaleur in range(len(Nt_values)):
    print(Nt_values[ivaleur],flush=True)
    import MCOT
    NTime=10 #Number of hours
    MCOT.Nt=Nt_values[ivaleur] #4*NTime+1 #Number of points for the discretization in time
    MCOT.dt=NTime/(MCOT.Nt-1)
    MCOT.Ns=valeurs_de_Ns[ivaleur] #Number of points for the discretization in space
    MCOT.ds=1/(MCOT.Ns-1)

    MCOT.Td=np.linspace(0,NTime,MCOT.Nt) #Discretization of time
    MCOT.lbd0=np.zeros(MCOT.Nt)
    MCOT.cT=np.zeros((MCOT.Nt,MCOT.Nt)) #Discretization of the cost function c in the 1S-RCMOT problem
    for tx in range(MCOT.Nt):
        for ty in range(MCOT.Nt):
            MCOT.cT[tx,ty]=(tx*NTime/MCOT.Nt-ty*NTime/MCOT.Nt)**2

    vita=2/5
    dropout=0.75
    def b(i,s):
        if i==1:
            if s<dropout:
                return(vita)
            else:
                return(vita*(1-(s-dropout)/(1-dropout)))
        if i==0:
            return(0)
        if i==2:
            return(-b(1,1-s))

    MCOT.fT=np.zeros((MCOT.Nt,MCOT.Ns,MCOT.Nt)) #Discretization of the general moment f in the 1S-RCMOT problem, representing the global consumption
    for s in range(MCOT.Ns):
        for tc in range(MCOT.Nt):
            if s*MCOT.ds<=dropout:
                t0=int(tc+1+max(0,dropout-s*MCOT.ds)/(vita*MCOT.dt))
                for T in range(tc,min(MCOT.Nt,t0)):
                    MCOT.fT[T,s,tc]+=vita
                for T in range(t0,MCOT.Nt):
                    MCOT.fT[T,s,tc]+=vita*np.exp(4*vita*(t0*MCOT.dt-T*MCOT.dt))
            else:
                for T in range(tc,MCOT.Nt):
                    MCOT.fT[T,s,tc]+=vita*4*(1-s*MCOT.ds)*np.exp(4*vita*(tc*MCOT.dt-T*MCOT.dt))

    ### Definition of mu1 and mu2

    MCOT.mu0=np.zeros(MCOT.Ns) #Initial law for the arrival of EVs.

    for s in range(int(0.15/MCOT.ds)+1,MCOT.Ns):
        mea=0.15
        sigma=0.2
        MCOT.mu0[s]=(1 / (np.sqrt(2 * np.pi) * sigma)) * np.exp(-((s/(MCOT.Ns-1) - mea)**2) / (2 * sigma**2))

    MCOT.mu0=MCOT.mu0/np.sum(MCOT.mu0)

    MCOT.mu1=np.zeros((MCOT.Ns,MCOT.Nt))

    for t in range(0,MCOT.Nt):
        for s in range(0,MCOT.Ns):
            MCOT.mu1[s,0]=MCOT.mu0[s]

    MCOT.mu2=np.zeros((MCOT.Ns,MCOT.Nt))

    treshold=0.75
    for s in range(0,MCOT.Ns):
        for tc in range(0,MCOT.Nt-max(0,int((treshold-s*MCOT.ds)/(vita*MCOT.dt)))):
            MCOT.mu2[s,tc]=1
        if np.sum(MCOT.mu2[s])!=0:
            MCOT.mu2[s]=MCOT.mu2[s]*MCOT.mu0[s]/(np.sum(MCOT.mu2[s]))
    debut = time.time()  # Début du chronométrage
    MCOT.Algo(np.zeros(MCOT.Nt)*0+0.069,range(MCOT.Nt),Klimit=10000,Conv=Conv,plot=False,prin=False)
    fin = time.time()  # Fin du chronométrage
    temps_executionM.append(fin -debut)
    print(fin-debut)

# Affichage des résultats
np.save("ListePDMP"+str(Conv)+"Ns"+str(valeurs_de_Ns[0])+str(valeurs_de_Ns[1]),temps_executionP)
np.save("ListeMCOT"+str(Conv)+"Ns"+str(valeurs_de_Ns[0])+str(valeurs_de_Ns[1]),temps_executionM)
plt.errorbar(Nt_values,np.mean(temps_executionP,-1)[:,0],np.std(temps_executionP,-1)[:,0],label='PDMP')
plt.plot(Nt_values,temps_executionM,label='MCOT')
plt.legend()
plt.show()


