w0=1;
x0=1;
y0=1;
z0=1;
a0=1;

q=1;
b0=-1/q;


rho=5;

mux=1;
muy=1;
muz=1;
mua=1;
mub=1;

iteration=80;
deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_z=zeros(iteration,1);
deri_a=zeros(iteration,1);
deri_b=zeros(iteration,1);

deri_f=zeros(iteration,1);
deri_else=zeros(iteration,1);
L=zeros(iteration,1);
L_star=zeros(iteration,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)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
    deri_y(i)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
    deri_z(i)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
    deri_a(i)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
    deri_b(i)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
    deri_w(i)=abs(x*y-z*a+q*b+1);
    L(i)=(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(L(1:iteration/4)-L(iteration),'LineWidth',2)
hold on
q=10;
b0=-1/q;




deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_z=zeros(iteration,1);
deri_a=zeros(iteration,1);
deri_b=zeros(iteration,1);

deri_f=zeros(iteration,1);
deri_else=zeros(iteration,1);
L=zeros(iteration,1);
L_star=zeros(iteration,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)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
    deri_y(i)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
    deri_z(i)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
    deri_a(i)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
    deri_b(i)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
    deri_w(i)=abs(x*y-z*a+q*b+1);
    L(i)=(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(L(1:7)-L(iteration),'LineWidth',2)
hold on

q=1000;
b0=-1/q;




deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_z=zeros(iteration,1);
deri_a=zeros(iteration,1);
deri_b=zeros(iteration,1);

deri_f=zeros(iteration,1);
deri_else=zeros(iteration,1);
L=zeros(iteration,1);
L_star=zeros(iteration,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)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
    deri_y(i)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
    deri_z(i)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
    deri_a(i)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
    deri_b(i)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
    deri_w(i)=abs(x*y-z*a+q*b+1);
    L(i)=(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(L(1:7)-L(iteration),'LineWidth',2)
hold on



q=100;
b0=-1/q;



deri_w=zeros(iteration,1);
deri_x=zeros(iteration,1);
deri_y=zeros(iteration,1);
deri_z=zeros(iteration,1);
deri_a=zeros(iteration,1);
deri_b=zeros(iteration,1);

deri_f=zeros(iteration,1);
deri_else=zeros(iteration,1);
L=zeros(iteration,1);
L_star=zeros(iteration,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)=abs(mux*x+(w+rho*(x*y-z*a+q*b+1))*y);
    deri_y(i)=abs(muy*y+(w+rho*(x*y-z*a+q*b+1))*x);
    deri_z(i)=abs(muz*z+(w-rho*(x*y-z*a+q*b+1))*a);
    deri_a(i)=abs(mua*a+(w-rho*(x*y-z*a+q*b+1))*z);
    deri_b(i)=abs(mub*b+q*w+q*rho*(x*y-z*a+q*b+1));
    deri_w(i)=abs(x*y-z*a+q*b+1);
    L(i)=(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(L(1:10)-L(iteration),'LineWidth',2)
set(gca, 'YScale', 'log')
grid on;
legend('q=1','q=10','q=1000','q=100')
xlabel('#Iterations t','FontSize',14)
ylabel('$$L^t-L^\star$$','Interpreter','latex','FontSize',14)
%plot(L)
% Result=L-L_star;
% plot(log(Result(1:10000)));

% plot(log(deri_x))
% hold on
% plot(log(deri_y))
% plot(log(deri_z))
% plot(log(deri_a))
% plot(log(deri_b))
% plot(log(deri_w))

% hold on
% 
% x_star=x;
% y_star=y;
% z_star=z;
% a_star=a;
% x=x0;
% y=y0;
% z=z0;
% w=w0;
% a=a0;
% for i=1:iteration
%     x=(rho*y*(z+a+1)-w*y+mux*u)/(mux+rho*y^2);
%     y=(rho*x*(z+a+1)-w*x+muy*v)/(muy+rho*x^2);
%     z=(w+rho*(x*y-a-1))/(muz+rho);
%     a=(w+rho*(x*y-z-1))/(mua+rho);
%     w=w+rho*(x*y-z-a-1); 
%     if i>=2
%         deri_x(i-1)=abs((x-x1)/(x-x_star));
%         deri_y(i-1)=abs((y-y1)/(y-y_star));
%         deri_z(i-1)=abs((z-z1)/(z-z_star));
%         deri_a(i-1)=abs((a-a1)/(a-a_star));
%     end
%     x1=x;
%     y1=y;
%     z1=z;
%     a1=a;
% 
% end
% plot(log(deri_a+deri_z+deri_y+deri_x))


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
