

clear;
close all
load("ridge_with_iid.mat");

colors=["#0072BD","#D95319","#EDB120","#7E2F8E","#77AC30"];
fig1=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(fig1);
legend_names=["CoCoA-PD", "LinConsensus-PD", "Proximal-2-PD", "Consensus-PD", "Proximal-1-PD"];
for i=1:5
    semilogy(eval(strcat("gap", num2str(i))),'Color',colors(i),'MarkerFaceColor',colors(i),'MarkerEdgeColor',colors(i), 'LineWidth', 2,'DisplayName', legend_names(i)); % Magenta square
    hold on;
end
%title("RR IID")

ylabel( "Gap" );
xlabel("Rounds");
ylim([1e-20 1])

grid on;
legend('Interpreter', 'latex','Location', 'Best'); 

set(gcf, 'PaperPositionMode', 'auto'); % Match paper size to figure
set(gcf, 'PaperUnits', 'inches', 'PaperSize', [3, 2]); % Set paper size to match figure
saveas(gcf, "ridge_with_iid.png");
hold off;



load("ridge_with_non_iid.mat");

colors=["#0072BD","#D95319","#EDB120","#7E2F8E","#77AC30"];
fig2=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(fig2);
legend_names=["CoCoA-PD", "LinConsensus-PD", "Proximal-2-PD", "Consensus-PD", "Proximal-1-PD"];

for i=1:5
    semilogy(eval(strcat("gap", num2str(i))),'Color',colors(i),'MarkerFaceColor',colors(i),'MarkerEdgeColor',colors(i), 'LineWidth', 2,'DisplayName', legend_names(i)); % Magenta square
    hold on;
end
%title("RR non-IID")
ylim([1e-20 1])

ylabel( "Gap" );
xlabel("Rounds");
grid on;
%legend('Interpreter', 'latex','Location', 'Best'); 

set(gcf, 'PaperPositionMode', 'auto'); % Match paper size to figure
set(gcf, 'PaperUnits', 'inches', 'PaperSize', [3, 2]); % Set paper size to match figure
saveas(gcf, "ridge_with_non_iid.png");
hold off;



load("lasso_with_iid.mat");

colors=["#D95319","#EDB120","#7E2F8E","#77AC30"];
fig3=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(fig3);
legend_names=["LinConsensus-PD", "Proximal-2-PD", "Consensus-PD", "Proximal-1-PD"];

for i=1:4
    semilogy(eval(strcat("gap", num2str(i))),'Color',colors(i),'MarkerFaceColor',colors(i),'MarkerEdgeColor',colors(i), 'LineWidth', 2,'DisplayName', legend_names(i)); % Magenta square
    hold on;
end
%title("LASSO IID")
ylim([1e-20  1])

ylabel( "Gap" );
xlabel("Rounds");
grid on;
%legend('Interpreter', 'latex','Location', 'Best'); 

set(gcf, 'PaperPositionMode', 'auto'); % Match paper size to figure
set(gcf, 'PaperUnits', 'inches', 'PaperSize', [3, 2]); % Set paper size to match figure
saveas(gcf, "lasso_with_iid.png");
hold off;





load("lasso_with_non_iid.mat");

colors=["#D95319","#EDB120","#7E2F8E","#77AC30"];
fig4=figure('Units', 'inches', 'Position', [1, 1, 3, 2]); % Set figure size (e.g., 6x4 inches)
figure(fig4);
legend_names=["LinConsensus-PD", "Proximal-2-PD", "Consensus-PD", "Proximal-1-PD"];

for i=1:4
    semilogy(eval(strcat("gap", num2str(i))),'Color',colors(i),'MarkerFaceColor',colors(i),'MarkerEdgeColor',colors(i), 'LineWidth', 2,'DisplayName', legend_names(i)); % Magenta square
    hold on;
end
%title("LASSO non-IID")
ylim([1e-20 1])

ylabel( "Gap" );
xlabel("Rounds");
grid on;
%legend('Interpreter', 'latex','Location', 'Best'); 

set(gcf, 'PaperPositionMode', 'auto'); % Match paper size to figure
set(gcf, 'PaperUnits', 'inches', 'PaperSize', [3, 2]); % Set paper size to match figure
saveas(gcf, "lasso_with_non_iid.png");
hold off;