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 = 1;



%% 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.02;


% 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 = [-6.6];
L0 = [0];


flg = 0;
% ini_ind = randi(length(K_plot));
ini_ind = find(K_plot==K0  & L_plot==L0);
plot(K_plot(ini_ind),L_plot(ini_ind),'rx','MarkerSize',15,'LineWidth',2)
step_len_1 = 10000;
step_len_2 = 1000;

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


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);
        
        %% 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))
            
            plot(K_tmp,Lp_tmp,'r.','MarkerSize',10,'LineWidth',2);

            L_tmp = Lp_tmp;
        end
        
        plot(K_tmp,Lp_tmp,'rs','MarkerSize',12,'LineWidth',2)

        
        
        for j = 1:step_len_1
            P_KL = solvePKL(A,B,C,Q,Ru,Rv,K_tmp,L_tmp);
            if isnan(P_KL)
                plot(K_space(end),Lp_tmp,'ro','MarkerSize',12,'LineWidth',2)
                flg = 1;
                break;
            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*L_tmp))
            
            if Kp_tmp <= K_space(end)
                plot(Kp_tmp,L_tmp,'r.','MarkerSize',10,'LineWidth',2);
            end
                        
            
            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,1) == 0
%             if abs(A-B*Kp_tmp-C*Lp_tmp)>1 || isnan(Lp_tmp)
%                 plot(Kp_tmp,Lp_tmp,'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;
  
        Kp_tmp
        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);



%% continue with first counterexample in LQG_run.m
max_iter = 10000;
eta_K = 0.00005;
eta_L = 0.00005;

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)




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(-6.75,-11,'r*','MarkerSize',12,'LineWidth',2)
plot(-6.75,-13,'rx','MarkerSize',12,'LineWidth',2)
plot(-6.75,-15,'rs','MarkerSize',12,'LineWidth',2)
plot(-6.75,-17,'ro','MarkerSize',12,'LineWidth',2)





