    
\begin{algorithm}[tb]
    % \algnewcommand\algorithmicinput{\textbuf{Input:}}
    % \algnewcommand\Input{\item[\algorithmicinput]}
    % \algnewcommand\algorithmicoutput{\textbuf{Output:}}
    % \algnewcommand\Output{\item[\algorithmicoutput]}
   
    \algnewcommand\INPUT{\item[{\textbf{Input:}}]}
    \algnewcommand\OUTPUT{\item[{\textbf{Output:}}]}
    \caption{The \name Algorithm}
	\label{algorithm1}
	\begin{algorithmic}[1]
	    \INPUT Input text $x =\{w_1,w_2,...,w_n\}$, target classifier $f$, substitution rate $p$, number of votes $k$, stopword selection portion $s$.
	   % , Vocab $V$
	    \OUTPUT Detection result and restored label
	    \State Calculate the stopword set $\mathcal{W}$ containing the top $s$ high frequency words in the training set
	    
	    \State Initialize converted text set $\mathcal{X}=\emptyset$
	    \For{$i=1 \to k$} \Comment{Randomized Substitution}
	        \State Initialize a new text $x_i = x$
	        \State Randomly sample $n\cdot p$ words for $\mathcal{P}$ from $x_i / \mathcal{W}$
	        \For{each word $w_t \in \mathcal{P}$ }
    	        \State Randomly select a synonym $\hat{w}_t^j \in \mathcal{S}(w_t)$
                \State Substitute  $w_t \in x_i$ with $\hat{w}_t^j$
	        \EndFor
	        \State $\mathcal{X} = \mathcal{X} \cup {x_i}$
	    \EndFor
	    \State Calculate the prediction label for input text $x$: $\bar{y} = \argmax f(x)$ \Comment{Vote \& Detection}
	    \State Calculate the voted label: $\bar{y}_{v} = \argmax \sum_{i=1}^k{f(x_i)}$
	    \If{$\bar{y} = \bar{y}_{v}$} 
	        \State \Return False, $\bar{y}$ \Comment{Benign sample}
	    \EndIf
        \State \Return True, $\bar{y}_{v}$ \Comment{Adversarial example}
	    
% 	Initialize $x^{0}_{adv} \leftarrow x$ \;
% 	$perturb \leftarrow random(-\epsilon, \epsilon)$ \;
% 	$g \leftarrow 0$ \; $\alpha \leftarrow \epsilon / K $\;
% 	\For{$i \rightarrow 1$ \KwTo $K$}{$x^{i}_{adv} \leftarrow x + perturb$ \;$p \leftarrow 0$\; 
% 	\For{$j \rightarrow 1$ \KwTo $N$}{
% 	Randomly pick a $shift$ from $[-T, T]$\;
% 	$head \leftarrow x^{i}_{adv}[shift:]$\;
% 	$tail \leftarrow x^{i}_{adv}[:shift]$\;$ x_{new} \leftarrow concat(head,tail)$\; 
% 	Obtain the gradient $\nabla_{x} J(x_{new},y)$\;
% 	Update $p$ by applying the sign gradient as:
% 	$$ p \leftarrow p+\alpha \cdot sign(\nabla_{x}J(x_{new},y));$$}
% 	$ p \leftarrow p/N $\;$ perturb \leftarrow perturb+p $\;}
%     $x_{adv} \leftarrow Clip^{\epsilon}_{x}\{x+perturb\} $\;
%     \Return $x_{adv}$
    \end{algorithmic}
\end{algorithm}