import numpy
import math




for N in [1000,2000,3000,4000,5000,6000,7000,8000,9000,10000,11000,12000,13000,14000,15000,16000,17000,18000,19000,20000]:
    print('N_T=',N)
    d = 1000
    T = 2
    cur_risk_ave=0
    no_cur_risk_ave=0
    erm_risk_ave=0
    for __ in range(5000000):
        w=numpy.zeros(1000)
        for t in range(1,T+1):
            if t<T:
                Var=1
            else:
                Var=10
            if t<T:
                Nt = 1500
            else:
                Nt = N
            true_mean = numpy.zeros(1000)
            if t<T:
                true_mean[0] = 1
            else:
                true_mean[0] = 2
            dist = numpy.linalg.norm(w - true_mean)
            alpha = (Var*d/Nt)/(dist**2+Var*d/Nt)
            empirical_average = true_mean + math.sqrt(Var/Nt)*numpy.random.randn(1000)
            w = alpha*w + (1-alpha)*empirical_average
        cur_risk = numpy.linalg.norm(w - true_mean)**2
        cur_risk_ave += cur_risk/5000000
        empirical_average = true_mean + math.sqrt(Var/N)*numpy.random.randn(1000)
        dist = numpy.linalg.norm(true_mean)
        alpha = (Var*d/N)/(dist**2+Var*d/N)
        no_cur_risk = numpy.linalg.norm((1-alpha)*empirical_average - true_mean)**2
        no_cur_risk_ave += no_cur_risk/5000000
        erm_risk = numpy.linalg.norm(empirical_average - true_mean)**2
        erm_risk_ave += erm_risk/5000000
    print('Tasks 1 & 3 ',' cur risk',cur_risk_ave,'no cur RERM risk',no_cur_risk_ave,'no cur ERM risk',erm_risk_ave)
    



for N in [1000,2000,3000,4000,5000,6000,7000,8000,9000,10000,11000,12000,13000,14000,15000,16000,17000,18000,19000,20000]:
    print('N_T=',N)
    d = 1000
    T = 2
    cur_risk_ave=0
    for __ in range(5000000):
        w=numpy.zeros(1000)
        for t in range(1,T+1):
            if t<T:
                Var=3
            else:
                Var=10
            if t<T:
                Nt = 1500
            else:
                Nt = N
            true_mean = numpy.zeros(1000)
            if t<T:
                true_mean[0] = 1.5
            else:
                true_mean[0] = 2
            dist = numpy.linalg.norm(w - true_mean)
            alpha = (Var*d/Nt)/(dist**2+Var*d/Nt)
            empirical_average = true_mean + math.sqrt(Var/Nt)*numpy.random.randn(1000)
            w = alpha*w + (1-alpha)*empirical_average
        cur_risk = numpy.linalg.norm(w - true_mean)**2
        cur_risk_ave += cur_risk/5000000
    print('Tasks 2 & 3 ',' cur risk',cur_risk_ave)




for N in [1000,2000,3000,4000,5000,6000,7000,8000,9000,10000,11000,12000,13000,14000,15000,16000,17000,18000,19000,20000]:
    print('N_T=',N)
    d = 1000
    T = 3
    cur_risk_ave=0
    for __ in range(5000000):
        w=numpy.zeros(1000)
        for t in range(1,T+1):
            if t==1:
                Var=1
            elif t==2:
                Var=3
            else:
                Var=10
            if t<T:
                Nt = 1500
            else:
                Nt = N
            true_mean = numpy.zeros(1000)
            if t==1:
                true_mean[0] = 1
            elif t==2:
                true_mean[0] = 1.5
            else:
                true_mean[0] = 2
            dist = numpy.linalg.norm(w - true_mean)
            alpha = (Var*d/Nt)/(dist**2+Var*d/Nt)
            empirical_average = true_mean + math.sqrt(Var/Nt)*numpy.random.randn(1000)
            w = alpha*w + (1-alpha)*empirical_average
        cur_risk = numpy.linalg.norm(w - true_mean)**2
        cur_risk_ave += cur_risk/5000000
    print('Tasks 1 & 2 & 3 ','T=',T,' cur risk',cur_risk_ave)
