function figcount = plot_x_u(alg_settings_cell,...
                        out_data_cell, group_settings, master_settings)
% *************************************************************************
% *************************************************************************
% *************************************************************************
%
% PLOT STATE TRAJECTORY x(t) AND CONTROL SIGNAL u(t) 
%
% [ ***** ANONYMIZED ***** ]  
%
% 2021-11-06
%
% This program, given a specified algorithm and data, plots state
% trajectory and control signal.
%
% *************************************************************************
%
% INPUTS
%
% *************************************************************************
%
% alg_settings_cell     (Cell, each entry a Struct) Algorithm 
%                       settings/parameters for subsequent execution
%                       according to desired preset (fields vary by
%                       algorithm, see respective algorithm .m-file for
%                       details).
% out_data_cell         (Cell, each entry a Struct) Output data generated
%                       by the algorithm (fields vary by algorithm, see
%                       respective algorithm .m-file for details).
% group_settings        (Struct) contains preset group settings.
%                       Has the following fields:
%   savefigs            (Boolean) 1 = save figures to PDF. 0 = don't save.
%   relpath             (String) relative file path of folder to save plots
%                       to, if they are to be saved.
%   dolegend            (Boolean) 1 = include preset group legend on plots.
%                       0 = don't include legend.
%   lgnd                (Cell, each entry a string, optional) If dolegend =
%                       1, then this contains the legend to include in the
%                       plots.
%   sys_plot_settings   (Struct) contains system plot settings. See
%                       config_sys.m for details.
%   preset_group        (String) Tag of the current preset group being
%                       executed.
%
% *************************************************************************
%
% OUTPUTS
%
% *************************************************************************
%
% 
%
% *************************************************************************
% *************************************************************************
% *************************************************************************

% *************************************************************************
% *************************************************************************
% *************************************************************************
%
% INITIALIZATION
% 
% *************************************************************************
% *************************************************************************
% *************************************************************************

% Unpack plot settings
savefigs = group_settings.savefigs;
relpath = group_settings.relpath;
dolegend = group_settings.dolegend;
% do_individual_plots = group_settings.do_individual_plots;
sys_plot_settings = master_settings.sys_plot_settings;
figcount = group_settings.figcount;

% Master plot formatting settings
psett_master = master_settings.psett_master;

% Check if user desired to add a custom caption to the end of each plot
% title
docaption = isfield(group_settings, 'caption');
if docaption   
    caption = group_settings.caption;
end

% Check if user desired preset-specific formatting
do_indiv_sett = isfield(group_settings, 'indiv_sett_cell');
if do_indiv_sett   
    indiv_sett_cell = group_settings.indiv_sett_cell;
end

% Number of designs to plot for
numpresets = size(alg_settings_cell,1);

% Tag of design being executed
designtag = master_settings.designtag;

% System names
sysnames = master_settings.sysnames;

% Current system being executed
systag = master_settings.systag;

% Extract system
sys = master_settings.sys;

% Extract plot time window
tsim_plot = group_settings.tsim_plot;

% Get total system order. This includes the n-state variables, as well as
% any unknown dynamic variables
% sys_order = size(out_data_cell{1}.xmat, 2);
sys_order = sys.n;

% State trajectory x(t) unit scaling. E.g., if x_1(t) is angular
% displacement but is desired in degrees, declare the field 'sclvec' and
% put sclvec(1) = 180/pi.
x_sclvec = sys_plot_settings.x_sclvec;

% Control u(t) unit scaling
u_sclvec = sys_plot_settings.u_sclvec;

% Time axis label
tlabel = psett_master.tlabel;

% Legend for all states in one plot
x_t_state_lgd = sys_plot_settings.x_t_state_lgd;

% ***********************
%
% EXTRACT LEGEND IF USER SPECIFIED
%  

% Extract legend, if user specified
if dolegend
    lgnd = group_settings.lgnd;
end


% ***********************
%
% CHECK IF STATE TRAJECTORY DATA PRESENT
%  

do_plots = isfield(out_data_cell{1},'xmat');

% Custom settings
custom_sett = psett_master.custom_sett;

% Do title (=1) or not (=0)
do_ttl = psett_master.do_ttl;


%%
% *************************************************************************
% *************************************************************************
% *************************************************************************
%
% BEGIN MAIN
% 
% *************************************************************************
% *************************************************************************
% *************************************************************************

% Only plot if there is data present
if do_plots

%%
% *************************************************************************
% *************************************************************************
% *************************************************************************
%
% STATE TRAJECTORY PLOTS
% 
% *************************************************************************
% *************************************************************************
% *************************************************************************


% *************************************************************************
% *************************************************************************
%
% INDIVIDUAL STATES
% 
% *************************************************************************
% *************************************************************************


for i = 1:sys_order
   
    % Open new figure
    figure(figcount);
    
    % Preliminary settings
    hold on
    
    % Extract scaling for x_i
    x_scl = x_sclvec(i);
    
    % Plot state trajectory x_i(t) for each preset in the group
    for j = 1:numpresets
        
        % Extract data from current preset
        tvec = out_data_cell{j}.tvec;
        x_i_t = out_data_cell{j}.xmat(:,i);
        
        % Plot
        h_fig = plot(tvec, x_scl * x_i_t);
        
%         % Keep track of how to window time axis
%         tmax = max(tmax, tvec(end));

    end
    
    % Title, labels
    ttl = sys_plot_settings.x_t_title{i};
    if docaption
        ttl = [ttl caption];
    end
    if do_ttl
        title(ttl);
    end
    xlabel(tlabel);
    xlim([0 tsim_plot]);
    % y limits
    switch systag
        case sysnames.hsv
            if i == 2
                ylim([0 1.25])
            end                       
        case sysnames.pendulum
            if i == 1
                ylim([0 180])
            end
            if i == 2
                ylim([-500 0])
            end             
    end
    ylabel(sys_plot_settings.x_t_ylabel{i});
    
    % Legend
    if dolegend
        lgd = legend(lgnd);             % Create legend
    end

    % Format plot
    p_sett.figcount = figcount;
    p_sett.custom_sett = custom_sett;
    if do_indiv_sett
        p_sett.indiv_sett_cell = indiv_sett_cell;
    end
    plot_format(p_sett); 

    % SAVE PLOT
    if savefigs
        filename = sys_plot_settings.x_t_filename{i};
        savepdf(figcount, relpath, filename); 
    end
    
    % Increment figure counter
    figcount = figcount + 1; 
    
end

% *************************************************************************
% *************************************************************************
%
% ALL STATES
% 
% *************************************************************************
% *************************************************************************


% Open new figure
figure(figcount);

% Preliminary settings
hold on

% Plot state trajectory x(t) for each preset in the group
for j = 1:numpresets

    % Extract data from current preset
    tvec = out_data_cell{j}.tvec;
    x_t = out_data_cell{j}.xmat;
    
    % Scale 
    for i = 1:sys.n
        x_t(:,i) = x_t(:,i) * x_sclvec(i);
    end

    % Plot
    h_fig = plot(tvec, x_t);

end

% Title, labels
ttl = 'State Trajectory $x(t)$';
if docaption
    ttl = [ttl caption];
end
if do_ttl
    title(ttl);
end
xlabel(tlabel);
xlim([0 tsim_plot]);
ylabel('$x(t)$');

% Legend
lgd = legend(x_t_state_lgd{1:sys_order});

% Format plot
p_settall.figcount = figcount;
P_sett.custom_sett = custom_sett;
plot_format(p_settall); 

% SAVE PLOT
if savefigs
    filename = 'x_t_all';
    savepdf(figcount, relpath, filename); 
end

% Increment figure counter
figcount = figcount + 1; 





%%
% *************************************************************************
% *************************************************************************
% *************************************************************************
%
% CONTROL SIGNAL PLOTS
% 
% *************************************************************************
% *************************************************************************
% *************************************************************************


for i = 1:sys.m
   
    % Open new figure
    figure(figcount);
    
    % Preliminary settings
    hold on

    % Extract scaling for u_i
    u_i_scl = u_sclvec(i);

    % Plot control u(t) for each preset in the group
    for j = 1:numpresets
        
        % Extract data from current preset
        tvec = out_data_cell{j}.tvec;
        u_i_t = out_data_cell{j}.umat(:,i);
        
        % Plot
        h_fig = plot(tvec, u_i_scl * u_i_t);

    end
    
    % Title, axes labels
    ttl = sys_plot_settings.u_t_title{i};
    if docaption
        ttl = [ttl caption];
    end
    if do_ttl
        title(ttl);
    end
    xlabel(tlabel);
    xlim([0 tsim_plot]);
    ylabel(sys_plot_settings.u_t_ylabel{i});
    
    % Legend
    if dolegend
        lgd = legend(lgnd);             % Create legend
    end
    
    % Format plot
    p_sett.figcount = figcount;
    P_sett.custom_sett = custom_sett;
    if do_indiv_sett
        p_sett.indiv_sett_cell = indiv_sett_cell;
    end    
    plot_format(p_sett); 
    
    % SAVE PLOT
    if savefigs
        filename = sys_plot_settings.u_t_filename{i};
        savepdf(figcount, relpath, filename); 
    end
    
    % Increment figure counter
    figcount = figcount + 1; 
    
end

end                 % END if do_plots
