from tests_functions import test_dim, test_rho, test_n, generate_gauss_paths, generate_laplace_paths, make_plot



# test dim, sigma = 1; mean = 0,2,4,6
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_dim_sigma1_mean0/',
# './results/test_dim_sigma1_mean2/',
# './results/test_dim_sigma1_mean4/',
# './results/test_dim_sigma1_mean6/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     #subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)

# # test dim, sigma = 0.1; mean = 0,2,4,6
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 0.1
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_dim_sigma0.1_mean0/',
# './results/test_dim_sigma0.1_mean2/',
# './results/test_dim_sigma0.1_mean4/',
# './results/test_dim_sigma0.1_mean6/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)


# # test dim, sigma = 10; mean = 0,2,4,6
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 10.0
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_dim_sigma10_mean0/',
# './results/test_dim_sigma10_mean2/',
# './results/test_dim_sigma10_mean4/',
# './results/test_dim_sigma10_mean6/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)


# # test rho, sigma = 1, d = 64, epsilon = 0.1, 0.2, 0.3, 0.4, 0.5
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# d = 64
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_rho_sigma1_mean0/',
# './results/test_rho_sigma1_mean2/',
# './results/test_rho_sigma1_mean4/',
# './results/test_rho_sigma1_mean6/']
# eps = [0.1, 0.3, 0.5, 0.7, 1.0]
# ps = [ep*ep*0.5 for ep in eps]
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_rho(mean0[i],sigma0,d,ps,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$\rho$','l2 error',xscale='log',yscale='log',basex=2,basey=2)


# # test n, sigma = 1, d = 64, epsilon = 1
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# d = 256
# nPaths = 100
# ns = [2000,4000,6000,8000]
# folder = ['./results/test_n_sigma1_mean0/',
# './results/test_n_sigma1_mean2/',
# './results/test_n_sigma1_mean4/',
# './results/test_n_sigma1_mean6/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_n(mean0[i],sigma0,d,p,nPaths,ns,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$n$','l2 error',xscale='log',yscale='log',basex=10,basey=2)


# #test dim, sigma = 1; mean = 0,2,4,6; laplace
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/testlap_dim_sigma1_mean0/',
# './results/testlap_dim_sigma1_mean2/',
# './results/testlap_dim_sigma1_mean4/',
# './results/testlap_dim_sigma1_mean6/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_laplace_paths,prefix='lap')
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)



# # test dim, sigma = 0.1; mean = 0,2,4,6
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 0.1
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_dim_sigma0.1_mean0_pp0.5/',
# './results/test_dim_sigma0.1_mean2_pp0.5/',
# './results/test_dim_sigma0.1_mean4_pp0.5/',
# './results/test_dim_sigma0.1_mean6_pp0.5/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)


# # test dim, sigma = 10; mean = 0,2,4,6
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 10.0
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_dim_sigma10_mean0_pp0.5/',
# './results/test_dim_sigma10_mean2_pp0.5/',
# './results/test_dim_sigma10_mean4_pp0.5/',
# './results/test_dim_sigma10_mean6_pp0.5/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)

# # test dim, sigma = 1; mean = 0,2,4,6
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# dims = [16,64,256,1024]
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_dim_sigma1_mean0_pp0.5/',
# './results/test_dim_sigma1_mean2_pp0.5/',
# './results/test_dim_sigma1_mean4_pp0.5/',
# './results/test_dim_sigma1_mean6_pp0.5/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)

# # test rho, sigma = 1, d = 64, epsilon = 0.1, 0.2, 0.3, 0.4, 0.5
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# d = 256
# nPaths = 100
# nSamples = 4000
# folder = ['./results/test_rho_sigma1_mean0_d256_pp0.5/',
# './results/test_rho_sigma1_mean2_d256_pp0.5/',
# './results/test_rho_sigma1_mean4_d256_pp0.5/',
# './results/test_rho_sigma1_mean6_d256_pp0.5/']
# eps = [0.1, 0.3, 0.5, 0.7, 1.0]
# ps = [ep*ep*0.5 for ep in eps]
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_rho(mean0[i],sigma0,d,ps,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$\rho$','l2 error',xscale='log',yscale='log',basex=2,basey=2)


# # test n, sigma = 1, d = 64, epsilon = 1
# mean0 = [0.0, 2.0, 4.0, 6.0]
# sigma0 = 1.0
# d = 256
# nPaths = 100
# ns = [2000,4000,6000,8000]
# folder = ['./results/test_n_sigma1_mean0_pp0.5/',
# './results/test_n_sigma1_mean2_pp0.5/',
# './results/test_n_sigma1_mean4_pp0.5/',
# './results/test_n_sigma1_mean6_pp0.5/']
# eps = 1.0
# p = eps*eps*0.5
# # r = 10*np.sqrt(d)*sigma, u = 2*r
# for i in range(len(mean0)):
#     subfolder=test_n(mean0[i],sigma0,d,p,nPaths,ns,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
#     #subfolder='/100paths_4000samples_16_4/'
#     make_plot(folder[i]+subfolder,'test.pdf',r'$n$','l2 error',xscale='log',yscale='log',basex=10,basey=2)


#--------------------------------------------------- n=3000 ----------------
# test dim, sigma = 0.1; mean = 0,2,4,6
mean0 = [0.0, 2.0, 4.0, 6.0]
sigma0 = 0.1
dims = [16,64,256,1024]
nPaths = 100
nSamples = 3000
folder = ['./results/test_dim_sigma0.1_mean0_pp0.5/',
'./results/test_dim_sigma0.1_mean2_pp0.5/',
'./results/test_dim_sigma0.1_mean4_pp0.5/',
'./results/test_dim_sigma0.1_mean6_pp0.5/']
eps = 1.0
p = eps*eps*0.5
# r = 10*np.sqrt(d)*sigma, u = 2*r
for i in range(len(mean0)):
    subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
    #subfolder='/100paths_4000samples_16_4/'
    make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)


# test dim, sigma = 10; mean = 0,2,4,6
mean0 = [0.0, 2.0, 4.0, 6.0]
sigma0 = 10.0
dims = [16,64,256,1024]
nPaths = 100
nSamples = 3000
folder = ['./results/test_dim_sigma10_mean0_pp0.5/',
'./results/test_dim_sigma10_mean2_pp0.5/',
'./results/test_dim_sigma10_mean4_pp0.5/',
'./results/test_dim_sigma10_mean6_pp0.5/']
eps = 1.0
p = eps*eps*0.5
# r = 10*np.sqrt(d)*sigma, u = 2*r
for i in range(len(mean0)):
    subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
    #subfolder='/100paths_4000samples_16_4/'
    make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)

# test dim, sigma = 1; mean = 0,2,4,6
mean0 = [0.0, 2.0, 4.0, 6.0]
sigma0 = 1.0
dims = [16,64,256,1024]
nPaths = 100
nSamples = 3000
folder = ['./results/test_dim_sigma1_mean0_pp0.5/',
'./results/test_dim_sigma1_mean2_pp0.5/',
'./results/test_dim_sigma1_mean4_pp0.5/',
'./results/test_dim_sigma1_mean6_pp0.5/']
eps = 1.0
p = eps*eps*0.5
# r = 10*np.sqrt(d)*sigma, u = 2*r
for i in range(len(mean0)):
    subfolder=test_dim(mean0[i],sigma0,dims,p,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
    #subfolder='/100paths_4000samples_16_4/'
    make_plot(folder[i]+subfolder,'test.pdf',r'$d$','l2 error',xscale='log',yscale='log',basex=2,basey=2)

# test rho, sigma = 1, d = 64, epsilon = 0.1, 0.2, 0.3, 0.4, 0.5
mean0 = [0.0, 2.0, 4.0, 6.0]
sigma0 = 1.0
d = 256
nPaths = 100
nSamples = 3000
folder = ['./results/test_rho_sigma1_mean0_d256_pp0.5/',
'./results/test_rho_sigma1_mean2_d256_pp0.5/',
'./results/test_rho_sigma1_mean4_d256_pp0.5/',
'./results/test_rho_sigma1_mean6_d256_pp0.5/']
eps = [0.1, 0.3, 0.5, 0.7, 1.0]
ps = [ep*ep*0.5 for ep in eps]
# r = 10*np.sqrt(d)*sigma, u = 2*r
for i in range(len(mean0)):
    subfolder=test_rho(mean0[i],sigma0,d,ps,nPaths,nSamples,bGenerate=True,folder=folder[i],generate_func=generate_gauss_paths)
    #subfolder='/100paths_4000samples_16_4/'
    make_plot(folder[i]+subfolder,'test.pdf',r'$\rho$','l2 error',xscale='log',yscale='log',basex=2,basey=2)

