%\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$. 

\begin{algorithm}[th]
	\caption{Detailed description of CobBO(f, $\tau$, T)}
	\label{alg:top}
\begin{algorithmic}[1] 
\STATE $\mathcal{H}_{\tau} \leftarrow$ sample $\tau$ initial points and evaluate their values\\
\STATE $V_\tau, M_\tau \leftarrow$ the maximal point in $\mathcal{H}_{\tau}$\\
\STATE $q_{\tau} \leftarrow 0$, number of consecutive failed queries\\
\STATE $\pi_{\tau} \leftarrow$ uniform preference for coordinates\\
\FOR{$t \leftarrow \tau\; \mathrm{to}\; T$}
    \IF {
    % \rm{
    switch $\Omega_{t-1}$ by the backoff stopping rule %(Section~\ref{ss:backoff})
    % }
    }
    \STATE $\Omega_t \leftarrow$ Take a new subspace over a coordinate block $C_t$, satisfying $V_t\in \Omega_t$
    \ELSE
       \STATE $\Omega_t \leftarrow \Omega_{t-1}$ //conduct consistent query in the same subspace
    \ENDIF
   \IF{ $\Omega_{t}$ is not $\Omega_{t-1}$}
      \STATE \textbf{Stage 1}: use a simple kernel $K_1$ for the estimation function $R(\cdot, \cdot)$	
   \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{H}}_{t} \leftarrow$ $R\left( \hat{\mathcal{X}}_t, \mathcal{H}_t\right)$ //compute the means and variances of the virtual points by $K_1$ 
	                   % \Big{[}Smooth function values on $\hat{\mathcal{X}}_{t}$ by interpolation using $\mathcal{H}_t$\Big{]} 
	\ELSE
	\STATE $\hat{\mathcal{X}}_{t} \leftarrow \hat{\mathcal{X}}_{t-1}$,
	       $\hat{\mathcal{H}}_{t} \leftarrow \hat{\mathcal{H}}_{t-1}$
	       //stage 1 is not needed if remaining in the same subspace
	\ENDIF
\STATE \textbf{Stage 2}: use a sophisticated kernel $K_2$ for BO within $\Omega_t$
\STATE $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}$ by $K_2$; note that the points in $\hat{\mathcal{H}}_{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{H}}_t)}(x  | \hat{\mathcal{H}}_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 $\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}\}$
\ENDFOR 
\end{algorithmic}
\end{algorithm}
