from utils import *
from algorithms import *




# characterization of teh problem
dataset = "a1a"
T = 5
omega = 100.0

pagg = 9.0/10

A, b = get_data(dataset)
A = normalize_data(A)
A = rearrange_data(A, "random")


n, d = A.shape
K = int(100*n/T)
mu = 1e-6
v = (1 + 1e-6)*np.ones(n)
m = int(n/T)
x0 = np.zeros(d)
f, g = make_fg_logreg(A, b, mu)

alpha = get_stepsize_saga(v=np.ones(n), p=np.ones(n)/m, pagg=pagg, pwork=1, omega=omega, n=n, T=T, mu=mu)


def total_loss(X): return objective(f, psi_func, X, m, omega)


assert m*T == n


F, X, (aggregations, agg_fvals) = vr_lgd(total_loss, g, alpha, d, K, T, m, pagg, omega, method="SAGA", psvrg=0, skip_it=1, track_agg=True)

