A=1;
n=5;
n_input=3;

eta=0.05;
iteration=2000;
iteration_inner=100;

num_k=50;
obj_iteration=zeros([iteration,num_k]);
distance=zeros([iteration,num_k]);
ratio=zeros([iteration,num_k]);
obj_G=obj_iteration;

for k=1:num_k
    k
    B_n=zeros(1,n*n_input);
    for i=1:n*n_input
        B_n(i)=1/(n*n_input)*rand;
    end
    Q=rand;
    R=zeros(n*n_input);
    for i=1:n*n_input
        R(i,i)=rand;
    end
    B=B_n;
    [P_star,K_star]=idare(A,B,Q,R);
    K_init=1*zeros(n*n_input,1);
    for i=1:n*n_input
        K_init(i)=1/(n*n_input)*rand;
    end
    K=K_init;

    for i= 1:iteration
        K2=K;
        P=(Q+K'*R*K)/(1-(A-B_n*K)^2);
        df=2*((R+B'*P*B)*K-B'*P*A)/(1-(A-B*K)^2);
        dg=zeros(n*n_input,1);
        for j=1:n
            Kj=K((j-1)*n_input+1:j*n_input);
            Aj=A-[B_n(1,1:(j-1)*n_input),B_n(j*n_input+1:n*n_input)]*[K(1:(j-1)*n_input,1);K(j*n_input+1:n*n_input)];
            Bj=B_n((j-1)*n_input+1:j*n_input);
            Rj=R((j-1)*n_input+1:j*n_input,(j-1)*n_input+1:j*n_input);
            Qj=Q+[K(1:(j-1)*n_input,1);K(j*n_input+1:n*n_input,1)]'*blkdiag(R(1:(j-1)*n_input,1:(j-1)*n_input),R(j*n_input+1:n*n_input,j*n_input+1:n*n_input))*[K(1:(j-1)*n_input,1);K(j*n_input+1:n*n_input,1)];
            for l=1:iteration_inner
                Pj=(Qj+Kj'*Rj*Kj)/(1-(Aj-Bj*Kj)^2);
                dfj=2*((Rj+Bj'*Pj*Bj)*Kj-Bj'*Pj*Aj)/(1-(Aj-Bj*Kj)^2);
                Kj=Kj-eta*dfj;
            end
            K2((j-1)*n_input+1:j*n_input)=Kj;
            P2=(Q+K2'*R*K2)/(1-(A-B_n*K2)^2);
            dg=dg+2/n*((R+B'*P*B)*K2-B'*P*A)/(1-(A-B*K2)^2);
            Pj_opt=idare(Aj,Bj,Qj,Rj);
            Kj_opt=(Rj+Bj'*Pj_opt*Bj)^(-1)*Bj'*Pj_opt*Aj;
            Kg=[K(1:(j-1)*n_input,1);Kj_opt;K(j*n_input+1:n*n_input,1)];
            Pg=(Q+Kg'*R*Kg)/(1-(A-B_n*Kg)^2);
            obj_G(i,k)=obj_G(i,k)+Pg/n;
        end
        obj_iteration(i,k)=P;
        it=ceil(rand*n);
        kt=0;
        K((it-1)*n_input+1:it*n_input)=K((it-1)*n_input+1:it*n_input)-eta*(df((it-1)*n_input+1:it*n_input)+kt*dg((it-1)*n_input+1:it*n_input));
        
        distance(i,k)=norm(K-K_star,'fro');
        ratio(i,k)=df'*dg/(df'*df);
    end 
end
varplot(ratio,'LineWidth',2);
% varplot(obj_iteration-obj_G,'LineWidth',2)
% set(gca, 'YScale', 'log')
xlabel('#Iterations t')
ylabel('$$\rho$$','Interpreter','latex')


