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.706488];
% C = [-0.150808];
% B = [0.451892];
A = [2.7];
C = [-0.15];
B = [-0.45];


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

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



max_iter = 100;



%% 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)

% set an initial K0, calculate Hinf under it, and then perturb the Hinf
% bound
K0 = -8;

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

% HinfNK0 = norm(sys,Inf,1e-6);
HinfNK0 = hinfnorm(sys,1e-6)

Rv = HinfNK0^2*eye(k)*(1+1e-2);


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 = -9:0.5:-3;
len_K_space = length(K_space);
L_space = -15:1:20;
len_L_space = length(L_space);
% eta_space = 0:0.00005:0.5;
% 
% eta_K = eta_space(2)./1;
% eta_L = eta_space(2)./1;

eta_K = 0.0005;
eta_L = 0.0005;



% figure(1)
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.')
            if abs(A-B*K_tmp)<1
                plot(K_tmp,L_tmp,'g.')
            end
            K_plot = [K_plot K_tmp];
            L_plot = [L_plot L_tmp];
        end
    end
end


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

flg = 0;
% ini_ind = randi(length(K_plot));
ini_ind = find(K_plot==K_ini  & L_plot==0);
step_len_1 = 200;
step_len_2 = 200;

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


for steps = 1:length(PKL)
    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);
        
        %% test if the (K,L) pair yields well-defined riccati equations
        
        P_KL_test = my_gare_gv_K(A,B,C,Q, Ru,Rv,K_tmp);
        test_L_gv_K = (-Rv+C'*P_KL_test*C)\(C'*P_KL_test*(A-B*K_tmp));
        
%         -inv(Rv-C'*P_KL_test*C)*C'*P_KL_test*(A-B*K_tmp)
        
        Rv-C'*P_KL_test*C
        
        abs(A-B*K_tmp-C*test_L_gv_K)





        
        
        for j = 1:step_len_2
            P_KL = solvePKL(A,B,C,Q,Ru,Rv,K_tmp,L_tmp);
            
            % Gauss-Newton
%             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
            Lp_tmp = L_tmp + eta_L*2*((-Rv+C'*P_KL*C)*L_tmp-C'*P_KL*(A-B*K_tmp))
            
            L_tmp = Lp_tmp;
        end
        
        
        
        P_KL_test = my_gare_gv_L(A,B,C,Q, Ru,Rv,L_tmp);
        
        test_L_gv_K = (Ru+B'*P_KL_test*B)\B'*P_KL_test*(A-C*L_tmp);
        
        
        Ru+B'*P_KL_test*B
        
        abs(A-B*test_L_gv_K-C*L_tmp)
        
        
        for j = 1:step_len_1
            P_KL = solvePKL(A,B,C,Q,Ru,Rv,K_tmp,L_tmp);
            if isnan(P_KL)
                pause;
            end
            
            % 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)))
            
            % Natural PG
%             Kp_tmp = K_tmp - eta_K*2*((Ru+B'*P_KL*B)*K_tmp-B'*P_KL*(A-C*Lp_tmp))
            
            K_tmp = Kp_tmp;
        end

        

        
        
        
        L_tmp = Lp_tmp;
        K_tmp = Kp_tmp;

        
%         plot(Kp_tmp,Lp_tmp,'r.')
        P_KL = solvePKL(A,B,C,Q,Ru,Rv,Kp_tmp,Lp_tmp);
        
        if mod(steps,10) == 0
            plot(Kp_tmp,Lp_tmp,'r.');
        end
        K_plot(i) = Kp_tmp;
        L_plot(i) = Lp_tmp;
        if abs(A-B*Kp_tmp-C*Lp_tmp)>1 
            plot(Kp_tmp,Lp_tmp,'r.','MarkerSize',20)
            pause;
            flg = 1;
        end
        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;
end



xlabel('K')
ylabel('L')

figure
plot(PKL,'-*')

figure
plot(Dist_NE,'-*')


save LQG_res






