%\textbf{Algorithm outline:}
% by the virtual points and their smoothed values
%$\hat{\mathcal{H}}_t$ that is generated from the true observations $\mathcal{H}_t$, to approximate $F$. 

\RestyleAlgo{boxruled}
\LinesNumbered
\vspace{-1.4mm}
\setlength{\dbltextfloatsep}{0pt}
\IncMargin{1.8em}
% \begin{figure*}
% \begin{multicols}{2}
\begin{algorithm*}[tbh]\vspace{1.0mm}\label{alg:top}
	\SetAlgoLined
	%\textbf{Parameter}: $T =\#$ total trials , $S=\#$ initial samples \\
	%initialization\;
	$\mathcal{H}_{\tau} \leftarrow$ sample $\tau$ initial points and evaluate their values\\
	$V_\tau, M_\tau \leftarrow$ Find the tuple with the maximal objective value in $\mathcal{H}_{\tau}$\\
	$q_{\tau} \leftarrow 0$ Initialize the number of consecutive failed queries\\
	$\pi_{\tau} \leftarrow$ Initialize a uniform preference distribution on the coordinates\\
	\For{$t \leftarrow \tau\; \mathrm{to}\; T$}{
        \uIf{\rm{switch $\Omega_{t-1}$ by the backoff stopping rule (Section~\ref{ss:backoff})}}{ 
	            \uIf{\rm{$q_t > \Theta$}}{
                    % $V_t, M_t \leftarrow$ Sample at random a tuple from the values of $\mathcal{H}_{\tau}$. Pick the furthest away from $V_{t-1}$ (Section~\ref{sec:algorithm})
                    $V_t, M_t \leftarrow$ Escape local maxima (Section~\ref{ss:escape})] \\
                    $q_t \leftarrow 0$
                }
              $K_t \leftarrow$ Update a virtual clock (Eq.~\ref{eq:virtual_clock})\\
              $\tilde{\Omega}_t \leftarrow$ Form trust regions on two different time scales (Section~\ref{ss:2tr}) \\
              %($K_t$, $y_t$, $M_{t-1}$, $q_t$ %(Algorithm~\ref{alg:trust_region})\\
              $C_t \leftarrow$ Sample a promising coordinate block according to $\pi_t$ (Section~\ref{ss:block})\\
	           $\Omega_t \leftarrow$ Take the subspace of $\tilde{\Omega}_t$ over the coordinate block $C_t$, such that $V_t\in \Omega_t$
	       %   $\Omega_t \leftarrow$ A subspace of $\tilde{\Omega}_t$ over a chosen coordinate block that includes $V_t$ (Section~\ref{ss:key_features})
        }
            \uElse{
    	        $\Omega_t \leftarrow \Omega_{t-1}$
            }
	            
	        $\hat{\mathcal{X}}_{t} \leftarrow$ $P_{\Omega_t}(\mathcal{X}_{t})$ \Big{[}Project $\mathcal{X}_{t}$ 
	                   onto $\Omega_t$ to obtain a set of virtual points (Eq.~\ref{eq:projection})\Big{]}\\
	        $\hat{\mathcal{H}}_{t} \leftarrow$ $R\left( \hat{\mathcal{X}}_t, \mathcal{H}_t\right)$ 
	                    \Big{[}Smooth function values on $\hat{\mathcal{X}}_{t}$ by interpolation using $\mathcal{H}_t$\Big{]}  \\
	        $p\left[ \hat{f}_{\Omega_t}(x) | \hat{\mathcal{H}}_{t} \right] \leftarrow$ Compute the posterior distribution of the Gaussian process in $\Omega_t$ conditional on $\hat{\mathcal{H}}_{t}$ \\
	        %${x}_{t+1} \leftarrow$ $\textrm{argmax}_x  \hat{f}_{\Omega_t}(x, \hat{\mathcal{H}}_{t})$ \Big{[}compute the next query point  in $\Omega_t$ \Big{]}\\
	        ${x}_{t+1} \leftarrow \textrm{argmax}_{x\in \Omega_t} Q_{ \hat{f} \sim p(\hat{f}|\hat{\mathcal{H}}_t)}(x  | \hat{\mathcal{H}}_t)$ 
	                         \Big{[} Suggest the next query point in $\Omega_t$ (Section~\ref{sec:algorithm})\Big{]}\\
	        %$\textrm{pivot}_t \leftarrow  \textrm{find} \; x^{+}$ such that $f(x^{+}) \geq  f(x_i), \forall i \in \{1, \cdots, t\}$\\
	        %$x_t \leftarrow$ construct the next query point in $\mathcal{X}$ using $\hat{x}^{\ast}_t$ and $\textrm{pivot}_t$\\
	        $y_{t+1} \leftarrow$ Evaluate the black-box function $y_{t+1} = f(x_{t+1})$\\
            % $\left(V_{t+1}, M_{t+1}\right) \leftarrow \left(x_{t+1}, y_{t+1}\right) \textbf{ if } y_{t+1} > M_t \textbf{ else } \left(V_t, M_t\right)$ [Update the best observed point]\\
            \uIf{$y_{t+1} > M_t$}{
                $V_{t+1} \leftarrow x_{t+1}$, $M_{t+1} \leftarrow y_{t+1}$, $q_{t+1} \leftarrow 0$
            }
            \uElse{
                $V_{t+1} \leftarrow V_t$, $M_{t+1} \leftarrow M_t$, $q_{t+1} \leftarrow q_t + 1$
            }
	        $\pi_{t+1} \leftarrow $ Update $\pi_{t}$ by a multiplicative weights update method (Eq.~\ref{eq:multiplicative_update})\\
	       % $\pi_{t+1} \leftarrow $ MW($\pi_t$, $C_t$, $y_{t+1}$, $M_t$) \Big{[} update $\pi_{t}$ by a multiplicative weights update method\Big{]}\\
	        $\mathcal{H}_{t+1} \leftarrow \mathcal{H}_{t} \bigcup \{(x_{t+1}, y_{t+1})\}$, $\mathcal{X}_{t+1} \leftarrow \mathcal{X}_{t} \bigcup \{x_{t+1}\}$
	        %\eIf{\rm{do drop-out}}
	        %{ conduct robust point filtering
	        %}
	  }
	\caption{CobBO(f, $\tau$, T)}
\end{algorithm*}

% \end{multicols}
% \end{figure*}