

q=10;
b0=-1/q;


rho=0.1;

mux=1;
muy=1;
muz=1;
mua=1;
mub=1;

num_exper=1;

iteration=100;
deri_w=zeros(iteration,num_exper);
deri_x=zeros(iteration,num_exper);
deri_y=zeros(iteration,num_exper);
deri_z=zeros(iteration,num_exper);
deri_a=zeros(iteration,num_exper);
deri_b=zeros(iteration,num_exper);

deri_f=zeros(iteration,num_exper);
deri_else=zeros(iteration,num_exper);
L=zeros(iteration,num_exper);
L_star=zeros(iteration,num_exper);

for k=1:num_exper

    w0=1;
    x0=1;
    y0=1;
    z0=1;
    a0=1;
    
    
    x=x0;
    
    y=y0;
    
    z=z0;
    
    a=a0;
    
    b=b0;
    w=w0;
    
    
    for i=1:iteration
        x=((-w+rho*(z*a-q*b-1))*y)/(mux+rho*y^2);
        y=((-w+rho*(z*a-q*b-1))*x)/(muy+rho*x^2);
        z=((w+rho*(x*y+q*b+1))*a)/(muz+rho*a^2);
        a=((w+rho*(x*y+q*b+1))*z)/(mua+rho*z^2);
        b=q*(-w-rho*(x*y-z*a+1))/(mub+q^2*rho);
        w=w+rho*(x*y-z*a+q*b+1); 
        deri_x(i,k)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
        deri_y(i,k)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
        deri_z(i,k)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
        deri_a(i,k)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
        deri_b(i,k)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
        deri_w(i,k)=abs(x*y-z*a+q*b+1);
        L(i,k)=(mux*x^2+muy*y^2+muz*z^2+mua*a^2+mub*b^2)/2+w*(x*y-z*a+q*b+1)+rho/2*(x*y-z*a+q*b+1)^2;
    end
end
plot(deri_w(1:15,:)+deri_x(1:15,:)+deri_y(1:15,:)+deri_z(1:15,:)+deri_a(1:15,:)+deri_b(1:15,:),'LineWidth',2)
hold on


    w0=rand;
    x0=rand;
    y0=rand;
    z0=rand;
    a0=rand;
    
    
    x=x0;
    
    y=y0;
    
    z=z0;
    
    a=a0;
    
    b=b0;
    w=w0;
    deri_w=zeros(iteration,num_exper);
    deri_x=zeros(iteration,num_exper);
    deri_y=zeros(iteration,num_exper);
    deri_z=zeros(iteration,num_exper);
    deri_a=zeros(iteration,num_exper);
    deri_b=zeros(iteration,num_exper);
    
    
    for i=1:iteration
        x=((-w+rho*(z*a-q*b-1))*y+mux*x)/(mux+1+rho*y^2);
        y=((-w+rho*(z*a-q*b-1))*x+muy*y)/(muy+1+rho*x^2);
        z=((w+rho*(x*y+q*b+1))*a+muz*z)/(muz+1+rho*a^2);
        a=((w+rho*(x*y+q*b+1))*z+mua*a)/(mua+1+rho*z^2);
        b=(q*(-w-rho*(x*y-z*a+1))+mub*b)/(mub+1+q^2*rho);
        w=w+rho*(x*y-z*a+q*b+1); 
        deri_x(i,k)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
        deri_y(i,k)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
        deri_z(i,k)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
        deri_a(i,k)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
        deri_b(i,k)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
        deri_w(i,k)=abs(x*y-z*a+q*b+1);
        L(i,k)=(mux*x^2+muy*y^2+muz*z^2+mua*a^2+mub*b^2)/2+w*(x*y-z*a+q*b+1)+rho/2*(x*y-z*a+q*b+1)^2;
    end
plot(deri_w(1:50)+deri_x(1:50)+deri_y(1:50)+deri_z(1:50)+deri_a(1:50)+deri_b(1:50),'LineWidth',2)

for k=1:num_exper

    w0=rand;
    x0=rand;
    y0=rand;
    z0=rand;
    a0=rand;
    
    x=x0;
    
    y=y0;
    
    z=z0;
    
    a=a0;
    
    b=b0;
    
    w=w0;
    deri_w=zeros(iteration,num_exper);
    deri_x=zeros(iteration,num_exper);
    deri_y=zeros(iteration,num_exper);
    deri_z=zeros(iteration,num_exper);
    deri_a=zeros(iteration,num_exper);
    deri_b=zeros(iteration,num_exper);
    alpha=0.04;
    
    for i=1:iteration
        x=x-alpha*(mux*x+(w+rho*(x*y-z*a+q*b+1))*y)/(2+i^(1/3));
        y=y-alpha*(muy*y+(w+rho*(x*y-z*a+q*b+1))*x)/(2+i^(1/3));
        z=z-alpha*(muz*z+(w-rho*(x*y-z*a+q*b+1))*a)/(2+i^(1/3));
        a=a-alpha*(mua*a+(w-rho*(x*y-z*a+q*b+1))*z)/(2+i^(1/3));
        b=b-alpha*(mub*b+q*w+q*rho*(x*y-z*a+q*b+1))/(2+i^(1/3));
        w=w+rho*(x*y-z*a+q*b+1)*(1+i^(1/3)); 
        deri_x(i,k)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
        deri_y(i,k)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
        deri_z(i,k)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
        deri_a(i,k)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
        deri_b(i,k)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
        deri_w(i,k)=abs(x*y-z*a+q*b+1);
    end
end

plot(deri_w+deri_x+deri_y+deri_z+deri_a+deri_b,'LineWidth',2)

set(gca, 'YScale', 'log')
grid on
legend('ADMM','PADMM','IPDS-ADMM')
xlabel('#Iterations k')
ylabel('$$L^k-L^\star$$','Interpreter','latex')
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


q=1;
w0=1;
x0=1;
y0=1;
z0=1;
a0=1;
x=x0;

y=y0;


b=b0;

w=w0;
deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_b=zeros(iteration,1);
alpha=0.01;

for i=1:iteration
    x=q*(-w-rho*(q*y+q*b+1))/(mux+q^2*rho);
    y=q*(-w-rho*(q*x+q*b+1))/(muy+q^2*rho);
    b=q*(-w-rho*(q*x+q*y+1))/(mub+q^2*rho);
    w=w+rho*(q*x+q*y+q*b+1); 
    deri_x(i)=abs(mux*x+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_y(i)=abs(muy*y+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_b(i)=abs(mub*b+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_w(i)=abs(q*x+q*y+q*b+1);
end

plot(deri_w+deri_x+deri_y+deri_b,'LineWidth',2)
hold on

q=1;
x=x0;

y=y0;


b=b0;

w=w0;
deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_b=zeros(iteration,1);


for i=1:iteration
    x=(q*(-w-rho*(q*y+q*b+1))+2*mux*x)/(mux+2+q^2*rho);
    y=(q*(-w-rho*(q*x+q*b+1))+2*muy*y)/(muy+2+q^2*rho);
    b=(q*(-w-rho*(q*x+q*y+1))+2*mub*b)/(mub+2+q^2*rho);
    w=w+rho*(q*x+q*y+q*b+1); 
    deri_x(i)=abs(mux*x+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_y(i)=abs(muy*y+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_b(i)=abs(mub*b+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_w(i)=abs(q*x+q*y+q*b+1);
end

plot(deri_w+deri_x+deri_y+deri_b,'LineWidth',2)
hold on

x=1;

y=1;


b=1;

w=1;

q=1;

deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_b=zeros(iteration,1);
alpha=2;

for i=1:iteration
    x=x-alpha*(mux*x+q*w+q*rho*(q*x+q*y+q*b+1))/(2+i^(1/3));
    y=y-alpha*(muy*y+q*w+q*rho*(q*x+q*y+q*b+1))/(2+i^(1/3));
    b=b-alpha*(mub*b+q*w+q*rho*(q*x+q*y+q*b+1))/(2+i^(1/3));
    w=w+rho*(q*x+q*y+q*b+1)*(1+i^(1/3)); 
    deri_x(i)=abs(mux*x+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_y(i)=abs(muy*y+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_b(i)=abs(mub*b+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_w(i)=abs(q*x+q*y+q*b+1);
end
plot(deri_w+deri_x+deri_y+deri_b,'LineWidth',2)


grid on
legend('ADMM','PADMM','IPDS-ADMM')
set(gca, 'YScale', 'log')
xlabel('#Iterations k')
ylabel('$$L^k-L^\star$$','Interpreter','latex')

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
x=1;

y=1;


b=1;

w=1;
deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_b=zeros(iteration,1);
alpha=0.1;

for i=1:iteration

    for j=1:iteration
        x=x-alpha*(mux*x+4*sin(2*x)+q*w+q*rho*(q*x+q*y+q*b+1));
    end
    y=q*(-w-rho*(q*x+q*b+1))/(muy+q^2*rho);
    b=q*(-w-rho*(q*x+q*y+1))/(mub+q^2*rho);
    w=w+rho*(q*x+q*y+q*b+1); 
    deri_x(i)=abs(mux*x+4*sin(2*x)+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_y(i)=abs(muy*y+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_b(i)=abs(mub*b+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_w(i)=abs(q*x+q*y+q*b+1);
end
plot(deri_w+deri_x+deri_y+deri_b,'LineWidth',2)

hold on





x=x0;

y=y0;


b=b0;

w=w0;
deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_b=zeros(iteration,1);
alpha=0.1;

for i=1:iteration
    x1=x;
    for j=1:iteration
        x=x-alpha*(mux*x+4*sin(2*x)+q*w+q*rho*(q*x+q*y+q*b+1)+4*(x-x1));
    end
    y=(q*(-w-rho*(q*x+q*b+1))+4*y)/(muy+4+q^2*rho);
    b=(q*(-w-rho*(q*x+q*y+1))+4*b)/(mub+4+q^2*rho);
    w=w+rho*(q*x+q*y+q*b+1); 
    deri_x(i)=abs(mux*x+4*sin(2*x)+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_y(i)=abs(muy*y+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_b(i)=abs(mub*b+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_w(i)=abs(q*x+q*y+q*b+1);
end
plot(deri_w+deri_x+deri_y+deri_b,'LineWidth',2)

hold on



q=1;
x=1;

y=1;


b=1;

w=1;
deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_b=zeros(iteration,1);
alpha=1;
rho=1;
for i=1:iteration
    x=x-alpha*(mux*x+4*sin(2*x)+q*w+q*rho*(q*x+q*y+q*b+1))/(2+i^(1/3));
    y=y-alpha*(muy*y+q*w+q*rho*(q*x+q*y+q*b+1))/(2+i^(1/3));
    b=b-alpha*(mub*b+q*w+q*rho*(q*x+q*y+q*b+1))/(2+i^(1/3));
    w=w+rho*(q*x+q*y+q*b+1)*(1+i^(1/3)); 
    deri_x(i)=abs(mux*x+4*sin(2*x)+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_y(i)=abs(muy*y+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_b(i)=abs(mub*b+q*w+q*rho*(q*x+q*y+q*b+1));
    deri_w(i)=abs(q*x+q*y+q*b+1);
end
plot(deri_w+deri_x+deri_y+deri_b,'LineWidth',2)

grid on
legend('ADMM','PADMM','IPDS-ADMM')
set(gca, 'YScale', 'log')
xlabel('#Iterations k')
ylabel('$$L^k-L^\star$$','Interpreter','latex')






function f=myfun(x,y,z,a,mux,muy,muz,mua,w,rho,u,v)
    f=(mux*(x-u)^2+muy*(y-v)^2+muz*z^2+mua*a^2)/2+w*(x*y-z-a-1)+rho/2*(x*y-z-a-1)^2;
end

function [deriw,derix,deriy,deriz,deria,L2]=update(x,y,z,a,mux,muy,muz,mua,w,rho)
    deriw=abs(x*y-z-a-1);
    derix=abs(mux*x+w*y+rho*y*(x*y-z-a-1));
    deriy=abs(muy*y+w*x+rho*x*(x*y-z-a-1));
    deriz=abs(muz*z-w-rho*(x*y-z-a-1));
    deria=abs(mua*a-w-rho*(x*y-z-a-1));
    L2=(mux*x^2+muy*y^2+muz*z^2+mua*a^2)/2+w*(x*y-z-a-1)+rho/2*(x*y-z-a-1)^2;
end
