#!/usr/bin/env python
# coding: utf-8

from train import *
import random

if __name__ == '__main__':
    # ## Comparison between Linear and Non-linear Activations
    random.seed(84224)
    # Parameter
    n_asymptotic = [500, int(1e3), int(2e3), int(5e3), int(1e4), int(2e4), int(5e4)]
    #n_asymptotic = [int(2e5), int(3e5), int(5e5)]
    d = 10
    epsilon = 0.5
    epoch = 3
    bs = [0.1, 0.3, 0.5, 0.8, 1.0]

#Experiment 1: Equal Performance (Four Examples)
    # for i in [1, 2, 3, 4]:
    #     trainer(d, epsilon, epoch, n_asymptotic, i)

#Experiment 2: Performance - Transition Curve
    # mus = [0.00001, 0.00003, 0.00005, 0.00008, 0.0001, 0.0003, 0.0005, 0.0008, 0.001, 0.002, 0.003, 0.005, 0.008, 0.01, 0.02, 0.03, 0.04, 0.05, 0.08, 0.1, 0.2, 0.3, 0.4, 0.5, 0.8, 1, 3, 5, 10]
    # ps = [0.0030001, 0.0030003, 0.0030005, 0.0030008, 0.003001, 0.003003, 0.003005, 0.003008, 0.00301, 0.00302, 0.00303, 0.00305, 0.00308, 0.0031, 0.0035, 0.0040, 0.0045, 0.006, 0.008, 0.01, 0.02, 0.03, 0.05, 0.06, 0.08, 0.1, 0.3, 0.5, 1]
    # n=10000
    # q=0.003
    # trans_curve(d, epsilon, epoch, n, q, mus, ps)

#Experiment 3: Robustness Performance - Transition Curve
    # n=10000
    # ps = [0.003001, 0.00301, 0.00302, 0.00305, 0.0031, 0.0032, 0.0033, 0.0034, 0.0035, 0.0037, 0.0038, 0.0039, 0.0040, 0.0045, 0.006, 0.01, 0.05, 0.1, 1]
    # q=0.003
    # mu = float(0.01)
    # delta_mus = np.array([0.01, 0.03, 0.05, 0.1, 0.3, 0.5]) * mu
    # gamma = 0.01
    # train_robustness(d, epsilon, epoch, n, q, mu, delta_mus, ps, gamma)

#Experiment 4: Performance - large feature information
    # train_exp4(d, epsilon, epoch, n_asymptotic)

#Experiment 5: Performance - large feature information
    # train_laplacian(d, epsilon, epoch, n_asymptotic, bs)


    # mus = [0.00001, 0.00003, 0.00005, 0.00008, 0.0001, 0.0003, 0.0005, 0.0008, 0.001, 0.002, 0.003, 0.005, 0.008, 0.01, 0.02, 0.03, 0.04, 0.05, 0.08, 0.1, 0.2, 0.3, 0.4, 0.5, 0.8, 1, 3, 5, 10, 20]
    # ps = [0.0303, 0.0304, 0.0305, 0.0306, 0.0307, 0.0308, 0.031, 0.032, 0.033, 0.034, 0.035, 0.040, 0.045, 0.06, 0.08, 0.1, 0.2, 0.3, 0.5, 0.6, 0.8, 1]
    # n=20000
    # q=0.03
    # trans_curve(d, epsilon, epoch, n, q, mus, ps)

#Experiment 6: Performance - Transition Curve
    # mus = [0.0001, 0.0003, 0.0005, 0.0008, 0.001, 0.002, 0.003, 0.005, 0.008, 0.01, 0.02, 0.03, 0.04, 0.05, 0.08, 0.1, 0.2, 0.3, 0.4, 0.5, 0.8, 1, 3, 5, 10]
    # ps = [0.005001, 0.005003, 0.005005, 0.005008, 0.00501, 0.00502, 0.00503, 0.00505, 0.00508, 0.0051, 0.0055, 0.006, 0.008, 0.01, 0.02, 0.03, 0.05, 0.06, 0.08, 0.1, 0.3, 0.5, 1]
    # n=20000
    # q=0.005
    # trans_curve_Laplacian(d, epsilon, epoch, n, q, mus, ps, 1)

#Experiments 7: Performance - Transition Curve - Heterogeneous
    # mus = [0.0001, 0.0003, 0.0005, 0.0008, 0.001, 0.002, 0.003, 0.005, 0.008, 0.01, 0.02, 0.03, 0.04, 0.05, 0.08, 0.1, 0.2, 0.3, 0.4, 0.5, 0.8, 1, 3, 5, 10]
    # qs = [0.005001, 0.005003, 0.005005, 0.005008, 0.00501, 0.00502, 0.00503, 0.00505, 0.00508, 0.0051, 0.0055, 0.006, 0.008, 0.01, 0.02, 0.03, 0.05, 0.06, 0.08, 0.1, 0.3, 0.5, 1]
    # n=20000
    # p =0.005
    # trans_curve_Heter(d, epsilon, epoch, n, p, mus, qs)