% \algnewcommand{\IfThenElse}[3]{% \IfThenElse{<if>}{<then>}{<else>}
%   \State \algorithmicif\ #1\ \algorithmicthen\ #2\ \algorithmicelse\ #3}
  
\begin{algorithm}[tbh]\vspace{0.0mm}
    \label{alg:trust_region}
% 	\SetAlgoLined
    % \textbf{Input}: Current virtual Clock $K_t$\\
    \textbf{Parameters}: \\
    \hspace{0.5cm} Slow/fast thresholds $\kappa_{S/F}$ respectively\\
    \hspace{0.5cm} Slow/fast cycles $\tau_{S/F}$ respectively\\
    % Current observed value $y_t$ \\
    % Previous best value $M_{t-1}$ \\
    % Consecutive fails to improve $q_t$ \\
    \textbf{Init}: $\Omega_{S_0}, \Omega_{F_0} \leftarrow \Omega$ \\
    \uIf{$y_t > M_{t-1}$} {
        $\Omega_{S_t}, \Omega_{F_t} \leftarrow$ Double $\Omega_{S_{t-1}}$ around $V_t$% at each coordinate
    }
    \uElseIf{$mod\left(K_t, \kappa_S\right) = 0$}{
        $\Omega_{S_t} \leftarrow$ Halve $\Omega_{S_{t-1}}$ around $V_t$% at each coordinate
    }
    \uElse{
        $\Omega_{S_t} \leftarrow \Omega_{S_{t-1}}$
    }
    
    \uIf{$mod\left(q_t, \kappa_F\right) = 0$}{
        $\Omega_{F_t} \leftarrow$ Halve $\Omega_{F_{t-1}}$ around $V_t$% at each coordinate
    } 
    % \textbf{Alternation}:\\
    \uIf{$mod\left(q_t, \tau_S+\tau_F\right) < \tau_S$}{
         $\tilde{\Omega}_{t} \leftarrow \Omega_{S_t}$
     }
    \uElse{
         $\tilde{\Omega}_t \leftarrow \Omega_{F_t}$
    }
    % $\tilde{\Omega}_{t} \leftarrow \Omega_{S_t} \textbf{ If } mod\left(q_t, \tau_S+\tau_F\right) < \tau_S\textbf{ Else } \Omega_{F_t}\$
    % \IfThenElse {$mod\left(q_t, \tau_S+\tau_F\right) < \tau_S$}% If ...
    %   {$\Omega_{S_t}$}% ...then...
    %   {$\Omega_{F_t}$}% ...else...
      
    \textbf{Output}: Trust Region $\tilde{\Omega}_{t}$
	\caption{FormTrustRegions($K_t$,$y_t$,$M_{t-1}$,$q_t$)}
% 	\caption{FormTrustRegionsPolicy($K_t$, $\kappa_S$, $\kappa_F$, $\tau_S$, $\tau_F$, $y_t$, $M_{t-1}$, $q_t$)}
\end{algorithm}
\setlength{\textfloatsep}{0pt}

% \begin{algorithm}[tbh]\vspace{0.0mm}
%     \label{alg:trust_region}
% % 	\SetAlgoLined
%     \textbf{Input}: Current virtual Clock $K_t$\\
%     Slow/fast thresholds $\kappa_{S/F}$ respectively\\
%     % Fast threshold $\kappa_f$,\\
%     Slow/fast cycles $\tau_{S/F}$ respectively\\
%     Current observed value $y_t$ \\
%     Previous best values $M_{t-1}$ \\
%     Consecutive fails to improve $q_t$ \\
%     $\Omega_{S_0}, \Omega_{F_0} \leftarrow \Omega$ \\
   
%     \For{$B \in \{S, F\}$}{
%         \uIf{$y_t > M_{t-1}$}{
%             % $\Omega_{B_t} \leftarrow$ \Big{[}Enlarge $\Omega_{B_{t-1}}$ by doubling the space around $V_t$ at each coordinate\Big{]}
%             $\Omega_{B_t} \leftarrow$ Double $\Omega_{B_{t-1}}$ around $V_t$ at each coordinate
%         }
%         \uElseIf{$mod\left(K_t, \kappa_B\right) = 0$}{
%             % $\Omega_{B_t} \leftarrow$ \Big{[}Shrink $\Omega_{B_{t-1}}$ by halving the space around $V_t$ at each coordinate\Big{]}
%             $\Omega_{B_t} \leftarrow$ Halve $\Omega_{B_{t-1}}$ around $V_t$ at each coordinate
%         }
%         \uElse{
%             $\Omega_{B_t} \leftarrow \Omega_{B_{t-1}}$
%         }
%     }
    
%     \uIf{$mod\left(q_t, \tau_S+\tau_F\right) < \tau_S$}{
%          $\tilde{\Omega}_{t} \leftarrow \Omega_{S_t}$
%      }
%     \uElse{
%          $\tilde{\Omega}_t \leftarrow \Omega_{F_t}$
%     }
%     \textbf{Output}: Trust Region $\tilde{\Omega}_{t}$
% 	\caption{TrustRegionsPolicy($K_t$, $\kappa_S$, $\kappa_F$, $\tau_S$, $\tau_F$, $y_t$, $M_{t-1}$, $q_t$)}
% \end{algorithm}

% \begin{algorithm}[tbh]\vspace{0.0mm}
%     \label{alg:trust_region_2}
%     \textbf{Input}: Current virtual Clock $K_t$\\
%     Slow/fast thresholds $\kappa_{S/F}$ respectively\\
%     % Fast threshold $\kappa_f$,\\
%     Alternating cycle $\tau$\\
%     Current observed value $y_t$ \\
%     Previous best values $M_{t-1}$ \\
%     Consecutive fails to improve $q_t$ \\
% % 	\SetAlgoLined
%     % \quad ; \quad
%     % r \leftarrow mod\left(K_t, \kappa_S\right)$ \\
%     \For{$B \in \{S, F\}$}{
%         $n \leftarrow \floor{\frac{K_t}{\kappa_B}}$ \\
%     	\For{$d = 1,\dots, D$}{
%             $l^{(d)} \leftarrow \max\left(0, V_t^{(d)} - \frac{1}{2^{n}}\right)$ \\
%             $u^{(d)} \leftarrow \min\left(1, V_t^{(d)} + \frac{1}{2^{n}}\right)$ \\
%             $\Omega_B^{(d)} \leftarrow [l^{(d)}, u^{(d)}]$
%         }      
%     }
    
%     \uIf{$mod\left(q_t, \tau\right) = 0$}{
%         \uIf{$\tilde{\Omega} = \Omega_S$}{
%              $\tilde{\Omega} \leftarrow \Omega_F$
%         }
%         \uElse{
%              $\tilde{\Omega} \leftarrow \Omega_S$
%         }
%     }
%     \textbf{Output}: Trust Region $\tilde{\Omega}$
% 	\caption{TrustRegionsPolicy($K_t$, $\kappa_S$, $\kappa_F$, $\tau$, $y_t$, $M_{t-1}$, $q_t$)}
% \end{algorithm}