clear all
clc
close all



% rnd_s = randi(100000);
% rng(rnd_s);

% rng(1396);


d = 1;
k = 1;

% A = [0.99106488, 0.0816012, 0.05;...
%     0.0541349, 0.990121, 0.0708383;...
%     0.08,0.04,0.990132655];
% B = [-0.8900150808;-0.880096;0.667345];
% C = [0.8510150808;-0.751096;-0.791345];
%
%
% Ru = 1*eye(k);
% gamma = sqrt(1);
% Rv = gamma^2*eye(k);
% Q = 1*eye(d);


%% Hard case
A = [2.7];
C = [-0.15];
B = [-0.45];

%% Easy case
% A = [-1.106488];
% B = [1];
% C = [1];

Ru = eye(k);
gamma = 1.44;
Rv = gamma^2*eye(k);
Q = eye(d);



max_iter = 10000;



%% iterative dare
P2 = my_gare(A,B,C,Q,Ru,Rv)

eig(-Rv+C'*P2*C)

Ks2 = (Ru+B'*P2*B-B'*P2*C*((-Rv+C'*P2*C)\(C'*P2*B)))\(B'*P2*A-(B'*P2*C/(-Rv+C'*P2*C))*C'*P2*A)
Ls2 = (-Rv+C'*P2*C-C'*P2*B*((Ru+B'*P2*B)\(B'*P2*C)))\(C'*P2*A-(C'*P2*B/(Ru+B'*P2*B))*B'*P2*A)



P22 = solvePKL(A,B,C,Q,Ru,Rv,Ks2,Ls2)

K_space = -7:0.05:-3;
len_K_space = length(K_space);
L_space = -15:0.5:20;
len_L_space = length(L_space);
% eta_space = 0:0.0000000005:0.5;
% eta_space = 0:0.0005:0.5;


% eta_K = eta_space(2);
% eta_L = eta_space(2)./1;

eta_K = 0.00005;
eta_L = 0.0002;


% figure(1)
h = figure
hold on
L_line_space = (A-B.*K_space-1)./C;
L_line_space_2 = (A-B.*K_space+1)./C;
plot(K_space,L_line_space,'-k')
plot(K_space,L_line_space_2,'-k')
% figure(2)
% hold on
K_plot = [];
L_plot = [];



for i = 1:len_K_space
    for j = 1:len_L_space
        K_tmp = K_space(i);
        L_tmp = L_space(j);
        if abs(A-B*K_tmp-C*L_tmp)<1
            %             figure(1)
            plot(K_tmp,L_tmp,'b.','MarkerSize',15)
            if abs(A-B*K_tmp)<1
                plot(K_tmp,L_tmp,'c.','MarkerSize',15)
                sys = ss((A-B*K_tmp),C,(Q+K_tmp'*Ru*K_tmp)^(1/2),0,[]);
                Hinf_test = hinfnorm(sys,1e-6);
                if Hinf_test^2<Rv
                    plot(K_tmp,L_tmp,'g.','MarkerSize',15)
                end
            end
            K_plot = [K_plot K_tmp];
            L_plot = [L_plot L_tmp];
        end
    end
end


flg = 0;
% ini_ind = randi(length(K_plot));
K0 = [-4.6];
L0 = [0];

ini_ind = find(K_plot==K0  & L_plot==L0);
plot(K_plot(ini_ind),L_plot(ini_ind),'rx','MarkerSize',15,'LineWidth',2)
% PKL = zeros(100000000,1);
PKL = zeros(max_iter,1);
Dist_NE = zeros(max_iter,1);

sys = ss((A-B*K0),C,(Q+K0'*Ru*K0)^(1/2),0,[]);
hinfnorm(sys,1e-6)

% P_KL_test = my_gare_gv_K(A,B,C,Q, Ru,Rv,K0);

% L_K0 = -inv(Rv-C'*P_KL_test*C)*C'*P_KL_test*(A-B*K0)

% Rv-C'*P_KL_test*C
% Ru+B'*P_KL_test*B


for steps = 1:max_iter
    steps
    %     for i = 1:length(K_plot)
    %     for i = len7th(K_plot)-7:length(K_plot)-7
    for i = ini_ind:ini_ind
        K_tmp = K_plot(i);
        L_tmp = L_plot(i);
        P_KL = solvePKL(A,B,C,Q,Ru,Rv,K_tmp,L_tmp);
        
        % Gauss-Newton
        %                 Kp_tmp = K_tmp - eta_K*2*((Ru+B'*P_KL*B)\((Ru+B'*P_KL*B)*K_tmp-B'*P_KL*(A-C*L_tmp)))
        %         Kp_tmp = K_tmp
        %         Lp_tmp = L_tmp + eta_L*2*((Rv-C'*P_KL*C)\((-Rv+C'*P_KL*C)*L_tmp-C'*P_KL*(A-B*K_tmp)))
        
        
        %         % Natural PG
        %         Kp_tmp = K_tmp - eta_K*2*((Ru+B'*P_KL*B)*K_tmp-B'*P_KL*(A-C*L_tmp))
        Kp_tmp = K_tmp
        if isnan(P_KL)
            Lp_tmp = L_tmp;
        else
            Lp_tmp = L_tmp + eta_L*2*((-Rv+C'*P_KL*C)*L_tmp-C'*P_KL*(A-B*K_tmp))
        end
        
        
        %         plot(Kp_tmp,Lp_tmp,'r.')
        %         if mod(steps,100000) == 0
        if mod(steps,100) == 0
            if abs(A-B*Kp_tmp-C*Lp_tmp)>1 || isnan(Lp_tmp)
                plot(Kp_tmp,(A-B.*Kp_tmp-1)./C,'ro','MarkerSize',12,'LineWidth',2)
                flg = 1;
                break;
            else
                abs(A-B*Kp_tmp-C*Lp_tmp)<=1
                plot(Kp_tmp,Lp_tmp,'r.','MarkerSize',10,'LineWidth',2);
            end
        end
        K_plot(i) = Kp_tmp;
        L_plot(i) = Lp_tmp;
        
        if abs(A-B*Kp_tmp-C*Lp_tmp)<1 && flg == 1
            pause;
            flg = 2;
        end
        Kp_tmp
        Lp_tmp
        %         A-B*Kp_tmp-C*Lp_tmp
        PKL(steps) = P_KL;
        Dist_NE(steps) = norm(K_tmp-Ks2,2)^2+norm(L_tmp-Ls2,2)^2;
        
    end
    if flg == 1
        break;
    end
    %     pause;
end

plot(Ks2,Ls2,'r*','MarkerSize',12,'LineWidth',2)


xlabel('$K$','Interpreter','latex')
ylabel('$L$','Interpreter','latex')
set(gca,'FontSize', 16);

%% robustify the controller

max_iter = 1000;

K0 = Robustify_K(K0,A,B,C,Q,Ru,Rv,h);
L0 = 0;

eta_K = 0.0008;
eta_L = 0.0008;

PKL = zeros(max_iter,1);
Dist_NE = zeros(max_iter,1)


sys = ss((A-B*K0),C,(Q+K0'*Ru*K0)^(1/2),0,[]);
hinfnorm(sys,1e-6)

% P_KL_test = my_gare_gv_K(A,B,C,Q, Ru,Rv,K0);

% L_K0 = -inv(Rv-C'*P_KL_test*C)*C'*P_KL_test*(A-B*K0)

% Rv-C'*P_KL_test*C
% Ru+B'*P_KL_test*B

K_tmp = K0;
L_tmp = L0;

for steps = 1:max_iter
    steps

    P_KL = solvePKL(A,B,C,Q,Ru,Rv,K_tmp,L_tmp);
    
    % Gauss-Newton
    %                 Kp_tmp = K_tmp - eta_K*2*((Ru+B'*P_KL*B)\((Ru+B'*P_KL*B)*K_tmp-B'*P_KL*(A-C*L_tmp)))
    %         Kp_tmp = K_tmp
    %         Lp_tmp = L_tmp + eta_L*2*((Rv-C'*P_KL*C)\((-Rv+C'*P_KL*C)*L_tmp-C'*P_KL*(A-B*K_tmp)))
    
    
    %         % Natural PG
    Kp_tmp = K_tmp - eta_K*2*((Ru+B'*P_KL*B)*K_tmp-B'*P_KL*(A-C*L_tmp))
    
    if isnan(P_KL)
        Lp_tmp = L_tmp;
    else
        Lp_tmp = L_tmp + eta_L*2*((-Rv+C'*P_KL*C)*L_tmp-C'*P_KL*(A-B*K_tmp))
    end
    
    %         plot(Kp_tmp,Lp_tmp,'r.')
    %         if mod(steps,100000) == 0
    if mod(steps,100) == 0
        if abs(A-B*Kp_tmp-C*Lp_tmp)>1 || isnan(Lp_tmp)
            plot(Kp_tmp,Lp_tmp,'ko','MarkerSize',12,'LineWidth',2)
            flg = 1;
            break;
        else
            abs(A-B*Kp_tmp-C*Lp_tmp)<=1
            plot(Kp_tmp,Lp_tmp,'k.','MarkerSize',10,'LineWidth',2);
        end
    end
    K_tmp = Kp_tmp;
    L_tmp = Lp_tmp;
    
    if abs(A-B*Kp_tmp-C*Lp_tmp)<1 && flg == 1
        pause;
        flg = 2;
    end
    Kp_tmp
    Lp_tmp
    %         A-B*Kp_tmp-C*Lp_tmp
    PKL(steps) = P_KL;
    Dist_NE(steps) = norm(K_tmp-Ks2,2)^2+norm(L_tmp-Ls2,2)^2;
    
end
%     pause;
 

figure
plot(PKL,'-*','MarkerSize',3,'LineWidth',2)
set(gca,'FontSize', 16);


figure
plot(Dist_NE,'-*','MarkerSize',3,'LineWidth',2)
set(gca,'FontSize', 16);


figure(h)
plot(-6.75,-11,'r*','MarkerSize',12,'LineWidth',2)
plot(-6.75,-14,'rx','MarkerSize',12,'LineWidth',2)
plot(-6.75,-17,'kx','MarkerSize',12,'LineWidth',2)


save LQG_res
 

 



