import matplotlib.pyplot as plt
import numpy as np
from util import *

from algs import *

dim = 1000
mini_dim = 1
A = construct_matrix_deterministic(dim, mini_dim)
print(type(A))
b = construct_vector_deterministic(dim)
f = construct_f_deterministic(A, b)


batch_size = dim
x = list(np.zeros(dim))
print(x)

# np.random.seed(10)

repeat = 10

# np.random.seed(11)

"""=================== Perturbed Approximate Gradient Descent (PAGD)  ==================="""

# pagd_vals = []
# pagd_complexity = []
# for i in range(repeat):
#     complexity, vals = pagd(f, x, iters=160, L=10)
#     pagd_vals.append(vals)
#     pagd_complexity.append(complexity)
# np.savez('data_mean_1000/pagd', pagd_complexity=pagd_complexity, pagd_vals=pagd_vals)


"""=================== ZO Perturbed AGD ==================="""

# zo_p_agd_vals = []
# zo_p_agd_complexity = []
# for i in range(repeat):
#     complexity, vals = zo_p_agd(f, x, iters=80, L=10, rho=1)
#     zo_p_agd_vals.append(vals)
#     zo_p_agd_complexity.append(complexity)
# np.savez('data_mean_1000/zo_p_agd', zo_p_agd_complexity=zo_p_agd_complexity, zo_p_agd_vals=zo_p_agd_vals)


"""=================== ZO Perturbed AGD with ANCF==================="""

# zo_p_agd_ancf_vals = []
# zo_p_agd_ancf_complexity = []
# for i in range(repeat):
#     complexity, vals = zo_p_agd_ancf(f, x, iters=80, L=10, rho=1)
#     zo_p_agd_ancf_vals.append(vals)
#     zo_p_agd_ancf_complexity.append(complexity)
# np.savez('data_mean_1000/zo_p_agd_ancf', zo_p_agd_ancf_complexity=zo_p_agd_ancf_complexity, zo_p_agd_ancf_vals=zo_p_agd_ancf_vals)


