\begin{algorithm}[th]
	\caption{Detailed description of CobBO(f, $\tau$, T)}
	\label{alg:top}
\begin{algorithmic}[1] 
\STATE $\mathcal{W}_{\tau} \leftarrow$ Sample $t=\tau$ initial points and evaluate their values
\STATE $V_\tau, M_\tau \leftarrow$ The maximal point in $\mathcal{W}_{\tau}$
\STATE $q_{\tau} \leftarrow 0$ // Number of consecutive failed queries
\STATE $\pi_{\tau} \leftarrow$ Uniform preference for coordinates
\WHILE{$t < T$}
\STATE \textbf{Stage 1}: Use a computation-efficient coarse kernel $K_1$ for the estimation function $R(\cdot, \cdot)$	
   \STATE   $\Omega_t \leftarrow$ Induce a new subspace over the coordinate block $C_t$, such that $V_t\in \Omega_t$
   \STATE $\hat{\mathcal{X}}_{t} \leftarrow$ $P_{\Omega_t}(\mathcal{X}_{t})$ 
    // Form virtual points %$\mathcal{X}_{t}$
	                   %onto $\Omega_t$ to obtain a set of virtual points (Eq.~\ref{eq:projection})\Big{]}
    \STATE $\hat{\mathcal{W}}_{t} \leftarrow$ $R\left( \hat{\mathcal{X}}_t, \mathcal{W}_t\right)$ // Compute the means (and optional variances) of the virtual points by $K_1$ 
	                   % \Big{[}Smooth function values on $\hat{\mathcal{X}}_{t}$ by interpolation using $\mathcal{H}_t$\Big{]} 
	                   
\STATE \textbf{Stage 2}: Use a flexible kernel $K_2$ for BO within $\Omega_t$ for consistent queries
\REPEAT
\STATE $p\left[ \hat{f}_{\Omega_t}(x) | \hat{\mathcal{W}}_{t} \right] \leftarrow$ Compute the posterior distribution of the Gaussian process in $\Omega_t$ conditional on $\hat{\mathcal{W}}_{t}$ by $K_2$; Note that the points in $\hat{\mathcal{W}}_{t}$ could have non-zero variances
\STATE ${x}_{t+1} \leftarrow \textrm{argmax}_{x\in \Omega_t} Q_{ \hat{f} \sim p(\hat{f}|\hat{\mathcal{W}}_t)}(x  | \hat{\mathcal{W}}_t)$ // Keep using $K_2$
        %  \Big{[} Suggest the next query in $\Omega_t$ (Section~\ref{sec:algorithm})\Big{]}
\STATE $y_{t+1} = f(x_{t+1})$
% \STATE $y_{t+1} \leftarrow$ Evaluate the black-box function $y_{t+1} = f(x_{t+1})$
\IF{$y_{t+1} > M_t$}
\STATE  $V_{t+1} \leftarrow x_{t+1}$, $M_{t+1} \leftarrow y_{t+1}$, $q_{t+1} \leftarrow 0$
\ELSE
    \STATE $V_{t+1} \leftarrow V_t$, $M_{t+1} \leftarrow M_t$, $q_{t+1} \leftarrow q_t + 1$
\ENDIF 
% \STATE $\pi_{t+1} \leftarrow $ Update $\pi_{t}$ by a multiplicative weights update method (Eq.~\ref{eq:multiplicative_update})
\STATE Update $\pi_{t}$ according to Eq.~(\ref{eq:multiplicative_update})
\STATE $\Omega_{t+1} \leftarrow \Omega_{t}$ // Remain in the same subspace for the next query
\STATE $\mathcal{W}_{t+1} \leftarrow \mathcal{W}_{t} \bigcup \{(x_{t+1}, y_{t+1})\}$,\\ $\mathcal{W}_{t+1} \leftarrow \mathcal{X}_{t} \bigcup \{x_{t+1}\}$, $\qquad t\leftarrow t+1$
\UNTIL{The backoff stopping rule is met (Section~\ref{ss:backoff})} $\rightarrow$ Switch to a different subspace
\ENDWHILE
\end{algorithmic}
\end{algorithm}