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;


tau_list=[tau/6, tau/5, tau/4, tau/3, tau/2, tau];


fig1=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(fig1);
fontsize(16,"points")
i=6;
for tau1=tau_list

     load(['.\Linearized Consensus ADMM\result_tau_',num2str(tau1),'.mat']);
     semilogy(gap, 'LineWidth', 2, 'DisplayName', ['$\tau=\tau^*/', num2str(i), '$']); % Magenta square
     
     hold on;
     i=i-1;

end

ylabel( "Gap" );
xlabel("Rounds");
ylim([1e-6 1])

%title("Effect of \tau for a fixed \beta ");
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\LADMM_tau.png");
hold off;


beta_list=[1e-4, 1e-3, 1e-2, 1e-1,1e0 , 1e1];
f2=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(f2);
fontsize(16,"points")

for beta1=beta_list
     load(['.\Linearized Consensus ADMM\result_beta_',num2str(beta1),'.mat']);
     semilogy(gap, 'LineWidth', 2, 'DisplayName', ['$\beta=', num2str(beta1),'$']); % Magenta square
     hold on;
     i=i+1;

end
ylabel( "Gap" );
xlabel("Rounds");
ylim([1e-6 1])
%title("Effect of \beta for a fixed \tau");

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\LADMM_beta.png");
hold off;