

% w8a data analysis

load('w8a.mat');
% L2 penalty
K=60;
[n,~]=size(w8a_features);
nk=floor(n/K);
Xdata=cell(K,1);
Ydata=cell(K,1);
for i=1:K
  
    if i==K

        Xdata{i}=w8a_features((nk*(i-1)+1):end, :);
        Ydata{i}=w8a_labels((nk*(i-1)+1):end);

    else
        Xdata{i}=w8a_features((nk*(i-1)+1):(nk*i), :);
        Ydata{i}=w8a_labels((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;

num_rounds=[250, 500, 750];
Lambdas=[0.1/n, 1/n, 10/n];

for lambda=Lambdas
    
    for round=num_rounds
        
        % Ridge Regression
        [w1, primal_loss1, dual_loss1, gap1, criterion1] = CoCoA(Xdata, Ydata, lambda, K, 1, struct('penalty','l2','loss','svm','epoch',round));
        [w2, primal_loss2, dual_loss2, gap2, criterion2] = Primal_LADMM(Xdata, Ydata, lambda, 0.5e-3, tau,struct('penalty','l2','loss','svm','epoch',round));
        [w3, primal_loss3, dual_loss3, gap3, criterion3] = DLADMM(Xdata, Ydata, lambda, 1/(K*0.5e-3), eta ,struct('penalty','l2','loss','svm','epoch',round));
        [w4, primal_loss4, dual_loss4, gap4, criterion4] = Consensus_ADMM(Xdata, Ydata, lambda, 1/(1500*K),struct('penalty','l2','loss','svm','epoch',round));
        [w5, primal_loss5, dual_loss5, gap5, criterion5] = PJADMM(Xdata, Ydata, lambda, 1500, K, struct('penalty','l2','loss','svm','epoch',round));
        save(['w8a_l2_',num2str(lambda),'_',num2str(round),'.mat'],'gap5','gap4','gap3','gap2','gap1');

        % Lasso Regression
        [w2, primal_loss2, dual_loss2, gap1, criterion2] = Primal_LADMM(Xdata, Ydata, lambda, 0.5e-3, tau,struct('penalty','l1','loss','svm','epoch', round));
        [w3, primal_loss3, dual_loss3, gap2, criterion3] = DLADMM(Xdata, Ydata, lambda, 1/(K*0.5e-3), eta ,struct('penalty','l1','loss','svm','epoch', round));
        [w4, primal_loss4, dual_loss4, gap3, criterion4] = Consensus_ADMM(Xdata, Ydata, lambda, 1/(1500*K),struct('penalty','l1','loss','svm','epoch', round));
        [w5, primal_loss5, dual_loss5, gap4, criterion5] = PJADMM(Xdata, Ydata, lambda, 1500, K, struct('penalty','l1','loss','svm','epoch', round));
        save(['w8a_l1_',num2str(lambda),'_',num2str(round),'.mat'],'gap4','gap3','gap2','gap1');
    
    end

end




