function [W_MH, W_Lap, L, A] = generate_graph_and_mixing(n, p)
    if nargin < 2
        p = 0.1;
    end
    connected = false;
    while ~connected
        A = rand(n) < p;
        A = triu(A, 1);
        A = A + A';               
        G = graph(A);
        connected = all(conncomp(G) == 1);
    end
    deg = sum(A, 2);
    D = diag(deg);
    L = D - A;
    W_MH = zeros(n);
    for i = 1:n
        for j = i+1:n
            if A(i,j) == 1
                w = 1 / (1 + max(deg(i), deg(j)));
                W_MH(i,j) = w;
                W_MH(j,i) = w;
            end
        end
        W_MH(i,i) = 1 - sum(W_MH(i, [1:i-1, i+1:n]));
    end
    sigma_max = svds(L, 1);   
    tau = 1.1 * sigma_max;   
    W_Lap = eye(n) - L / tau;

end
[labels, features] = libsvmread('a9a');  
%ProxMudag initialization
A=features;
n = size(A, 1);
%Initialization
K=30;
W=zeros(K,K);
[n,~]=size(features);
nk=floor(n/K);
Xdata=cell(K,1);
Ydata=cell(K,1);
for i=1:K
    if i==K
        Xdata{i}=features((nk*(i-1)+1):end, :);
        Ydata{i}=labels((nk*(i-1)+1):end);
    else
        Xdata{i}=features((nk*(i-1)+1):(nk*i), :);
        Ydata{i}=labels((nk*(i-1)+1):(nk*i));
    end
end
X = vertcat(Xdata{:});
Y = vertcat(Ydata{:});
AtA = full(X' * X); 
eigenvals = eig(AtA / n);
threshold = 1e-10;
positive_eigs = eigenvals(eigenvals > threshold);
L = max(positive_eigs);
mu = min(positive_eigs);
lambda=1/n;
[W,Q,~,~]=generate_graph_and_mixing(K,0.5);
epoch=30000;
[w, primal_loss, ~,~] = ProxMudag(Xdata, Ydata, lambda, 1,sqrt(mu/L),struct('penalty','l1','loss','ls','epoch',epoch),W,1);
f_opt=primal_loss(30000);
save('l1lsa9a.mat', 'f_opt','w');
load('l1a9a.mat');
epoch = 1000;
[~, loss1,~,dist1] = Prox_ADMM_Decentralized(Xdata, Ydata, lambda, 1,1, struct('penalty','l1','loss','ls','epoch',epoch),W,w);
[~, loss2, ~,dist2] = ProxMudag(Xdata, Ydata, lambda, 1,sqrt(mu/L),struct('penalty','l1','loss','ls','epoch',epoch),W,w);
[~, loss4, ~,dist4] = PG_EXTRA(Xdata, Ydata, lambda, 1,struct('penalty','l1','loss','ls','epoch',epoch),W,w);
[~, loss3, ~,dist3] = Decentralized_ACC_ADMM(Xdata, Ydata, lambda, 1,struct('penalty','l1','loss','ls','epoch',epoch),W,w);
figure;
losses = {loss1, loss2,loss4, loss3};
dists={dist1,dist2,dist4,dist3};
names = {'PDADMM', 'ProxMudag', 'PG-EXTRA','DS-ADMM'};
colors = ["#0072BD","#EDB120","#EDB120","#7E2F8E"];
for i = 1:length(losses)
    semilogy( losses{i}-f_opt, 'DisplayName', names{i}, ...
             'LineWidth', 1.5, 'Color', colors(i)); hold on;
end

xlabel('Iteration');
ylabel('Suboptimality');
ylim([1e-6, 1]);     
xlim([1, 1000]); 
legend('show');
grid on;
comm_mult = [1, 2,1, 2]; 
figure; hold on;
for i = 1:length(losses)
    comm_rounds = (1:length(losses{i})) * comm_mult(i);  
    subopt =losses{i}-f_opt   ;    
    semilogy(comm_rounds, subopt, 'DisplayName', names{i}, ...
             'LineWidth', 1.5, 'Color', colors(i)); hold on;
end
xlabel('Communication Rounds');
ylabel('Suboptimality');
set(gca, 'YScale', 'log');     
ylim([1e-6, 1]);     
xlim([1, 1000]);  
legend('show');
grid on;