


% w8a data analysis
clc
clear variables
load('real-sim.mat');
K=100;
[n,~]=size(b);
nk=floor(n/K);
Xdata=cell(K,1);
Ydata=cell(K,1);
for i=1:K  
    if i==K
        Xdata{i}=A((nk*(i-1)+1):end, :);
        Ydata{i}=b((nk*(i-1)+1):end);
    else
        Xdata{i}=A((nk*(i-1)+1):(nk*i), :);
        Ydata{i}=b((nk*(i-1)+1):(nk*i));
    end
end



tau=0;
for k=1:K
    temp=eigs(Xdata{k}'*Xdata{k},1);
    if temp>tau
        tau=temp;
    end
end

eta=K*tau;



totalrun = 3 * 5 * 2;

test = false;
w = cell(3*5*2,1);
primal_loss  = cell(3*5*2,1);
dual_loss = cell(3*5*2,1);
gap = cell(3*5*2,1);
criterion = cell(3*5*2,1);
round = 500;

parfor runid = 1:totalrun
    Lambdas=[0.1/n, 1/n, 10/n];
    ilam(runid) = ceil(runid / (2*5));
    runid1 = mod(runid-1, 2*5)+1;
    j(runid) = ceil(runid1/5); 
    jj = j(runid);
    i(runid) = mod(runid1-1, 5)+1;
    ii = i(runid);
    lambda=Lambdas(ilam(runid));
    parmatrix = [K, 1; 1e-5, tau;  1/(K*1e-5), eta; 1/(4000*K), nan; 4000, K]; 
    
    if test
        fprintf("%d,%d,%d,%d\n", ilam(runid),j(runid),i(runid));
    else
        if jj == 1
            [w{runid}, primal_loss{runid}, dual_loss{runid}, gap{runid}, criterion{runid}] = ...
                runmethod(ii,Xdata, Ydata, lambda, parmatrix(ii,1), parmatrix(ii,2), struct('penalty','l2','loss','svm','epoch', round));
        else
            if ii ~= 1
                [w{runid}, primal_loss{runid}, dual_loss{runid}, gap{runid}, criterion{runid}] = ...
                    runmethod(ii,Xdata, Ydata, lambda, parmatrix(ii,1), parmatrix(ii,2), struct('penalty','l1','loss','svm','epoch', round));
            end
        end
    end
end



