clear;

close all

[a1a_labels, a1a_features] = libsvmread('a1a');
% L2 penalty
K=10;
[n,~]=size(a1a_features);
nk=floor(n/K);
Xdata=cell(K,1);
Ydata=cell(K,1);
for i=1:K
  
    if i==K

        Xdata{i}=a1a_features((nk*(i-1)+1):end, :);
        Ydata{i}=a1a_labels((nk*(i-1)+1):end);

    else
        Xdata{i}=a1a_features((nk*(i-1)+1):(nk*i), :);
        Ydata{i}=a1a_labels((nk*(i-1)+1):(nk*i));

    end

end
max_eta=eigs(vertcat(Xdata{:})'*vertcat(Xdata{:}),1);
tau=0;
for k=1:K
    temp=eigs(Xdata{k}'*Xdata{k},1);
    if temp>tau
        tau=temp;
    end
end

eta=K*tau;


eta_list=[max_eta/5,max_eta/4,max_eta/3,max_eta/2,max_eta, eta];

fig1=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(fig1);
i=5;
for eta1=eta_list

     load(['.\Distributed PADMM with Q2\result_eta_',num2str(eta1),'.mat']);
     if i==0
         semilogy(gap, 'LineWidth', 2, 'DisplayName', '$\eta_2=\eta_2^*$'); % Magenta square
     else
         semilogy(gap, 'LineWidth', 2, 'DisplayName', ['$\eta_2=\eta_2^{**}/', num2str(i), '$']); % Magenta square
     end
     hold on;
     i=i-1;

end

ylabel( "Gap" );
xlabel("Rounds");
ylim([1e-6 1])

%title("Effect of \eta_2 for a fixed \rho ");
grid on;
legend('Interpreter', 'latex','Location', 'Best'); 
lgd.NumColumns  = 2;
lgd.Location  = "northeast";

set(gcf, 'PaperPositionMode', 'auto'); % Match paper size to figure
set(gcf, 'PaperUnits', 'inches', 'PaperSize', [6, 4]); % Set paper size to match figure
saveas(gcf, ".\Effect of parameters\pADMM2_eta.png");
hold off;


rho_list=[1e-1, 5e-1, 1e0, 5e0, 1e1, 5e1, 1e2];
f2=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(f2);
for rho1=rho_list
     load(['.\Distributed PADMM with Q2\result_rho_',num2str(rho1),'.mat']);
     semilogy(gap, 'LineWidth', 2, 'DisplayName', ['$\rho=', num2str(rho1),'$']); % Magenta square
     hold on;
     i=i+1;

end
ylabel( "Gap" );
xlabel("Rounds");
%title("Effect of \rho for a fixed \eta_2");
ylim([1e-6 1])

grid on;
lgd= legend('Interpreter', 'latex','Location', 'Best'); 
lgd.NumColumns  = 2;
lgd.Location  = "southwest";

set(gcf, 'PaperPositionMode', 'auto'); % Match paper size to figure
set(gcf, 'PaperUnits', 'inches', 'PaperSize', [6, 4]); % Set paper size to match figure
saveas(gcf, ".\Effect of parameters\pADMM2_rho.png");
hold off;