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 = [1.706488];
C = [0.1550808];
B = [-0.451892];

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

K_space = -10:0.5:4;
len_K_space = length(K_space);
L_space = -15:0.5:15;
len_L_space = length(L_space);
eta_space = 0:0.05:0.5;

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


% 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-0.1
%             figure(1)
            plot(K_tmp,L_tmp,'b.')
            K_plot = [K_plot K_tmp];
            L_plot = [L_plot L_tmp];
        end
    end
end


flg = 0;
% ini_ind = randi(length(K_plot));
ini_ind = find(K_plot==-4  & L_plot==0);
step_len_1 = 1;
step_len_2 = 1;

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);
        
        -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*inv(Rv-C'*P_KL_test*C)*C'*P_KL_test*(A-B*K_tmp))


        P_KL_test = my_gare_gv_L(A,B,C,Q, Ru,Rv,L_tmp);
        
        inv(Ru+B'*P_KL_test*B)*B'*P_KL_test*(A-C*L_tmp)
        
        Ru+B'*P_KL_test*B
        
        abs(A-B*inv(Ru+B'*P_KL_test*B)*B'*P_KL_test*(A-C*L_tmp)-C*L_tmp)


        
        
        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
        
        

        
        
        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






