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



%% 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 = -9: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;

% The stepsize when N_L=1
% eta_K = 0.05;
% eta_L = 0.05;


% The stepsize when N_L=30
eta_K = 0.05;
eta_L = 0.01;


% 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));
% ini_ind = find(K_plot==-5  & L_plot==-6);
% plot(K_plot(ini_ind),L_plot(ini_ind),'rx','MarkerSize',15,'LineWidth',2)
step_len_1 = 1;
step_len_2 = 30;

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


granul = 1;

for i = 1:granul:length(K_plot)
    disp(i)
    %     for j = 1:granul:length(L_plot)
    K_tmp = K_plot(i);
    L_tmp = L_plot(i);
    
    %     K_tmp = K_plot(ini_ind);
    %     L_tmp = L_plot(ini_ind);
    
    %     K_tmp = -4.5;
    %     L_tmp = -3;
    
    flg = 0;
    
    for steps = 1:max_iter
        steps;
        
        
        %% 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 k = 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 k = 1:step_len_1
            P_KL = solvePKL(A,B,C,Q,Ru,Rv,K_tmp,L_tmp);
            if isnan(P_KL) || max(abs(eig(A-B*K_tmp-C*L_tmp)))>1
                %                     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;
        
        K_tmp;
        L_tmp;
        PKL(steps) = P_KL;
        Dist_NE(steps) = norm(K_tmp-Ks2,2)^2+norm(L_tmp-Ls2,2)^2;
    end
    
    if flg == 0
        plot(K_plot(i),L_plot(i),'k.','MarkerSize',6);
        %             break;
    end
    %     end
    %     pause;
end

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

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

plot(-8.55,-15,'r*','MarkerSize',12,'LineWidth',2)

save LQG_run_RARL_plot_Sec3_Primal_Dual_work_Region_Roc
