\begin{algorithm}[!h]
\caption{\textit{Local Discovery by Partitioning (LDP)} %A constraint-based procedure to partition a background dataset $\z$ into subsets defined by their relation to an exposure $X$ and outcome $Y$.
} \label{alg:method}
\begin{algorithmic}[1]
{\INPUT $X$, $Y$, $\z$, independence test, significance level $\alpha$
\OUTPUT (1) VAS, if identifiable; (2) partition labels (as intermediate results)
%\begin{itemize}[noitemsep,topsep=0pt]
%    \item $\z_1$: Confounders for $\{X,Y\}$ and their proxies.
%    \item $\z_4$: Non-descendants of $Y$ s.t. $Y \nind Z_4 \land X \ind Z_4$.
%    \item $\z_5$: Instrumental variables and their proxies.
%    \item $\z_7$: Descendants of $X$ where $Y \ind Z_7 \, | \, X$.
%    \item $\z_8$: Variables with no active paths to $\{X,Y\}$.
%    \item $\z_{\textsc{Post}}$: Post-treatment partitions $\{\z_2, \z_3,\z_6\}$.
%\end{itemize}
\vspace{3mm}

%\vspace{1mm}
\color{black}
\STATE Copy $\z' \gets \z$

%\vspace{1mm}

\FOR{all $Z \in \z'$} 

    %%%%%%%%%%%%%
    % STEP 1
    %%%%%%%%%%%%%

   % \vspace{-2mm}
% \addtocounter{ALC@line}{-1}
\COMMENT{\textsc{\color{MidnightBlue} Step 1: Test for $\z_8$ }}
    % \begin{flushleft}
    % \textsc{\color{MidnightBlue} $\triangleright$ Step 1: Test for $\z_8$ }
    % \end{flushleft}
        % \vspace{-3mm}

    \STATE \textbf{if} {$X \ind Z$ and $Y \ind Z$} \textbf{then} $Z \in \z_8$
    
    %%%%%%%%%%%%%
    % STEP 2
    %%%%%%%%%%%%%

   % \vspace{-2mm}
   %  \begin{flushleft}
    \COMMENT{\textsc{\color{MidnightBlue}Step 2: Test for $\z_4$}}
    % \end{flushleft}
    %     \vspace{-3mm}
    
    \STATE \textbf{else if} {$X \ind Z$ and $X \nind Z | Y$} \textbf{then} $Z \in \z_4$

    %%%%%%%%%%%%%
    % STEP 3
    %%%%%%%%%%%%%
    
   % \vspace{-2mm}
   %  \begin{flushleft}
    \COMMENT{\textsc{\color{MidnightBlue} Step 3: Test for $\z_{5,7}$}}
    % \end{flushleft}
    % \vspace{-3mm}
    
    \STATE \textbf{else if} {$Y \nind Z$ and $Y \ind Z | X$} \textbf{then} $Z \in \z_{5,7}$
\ENDFOR
\STATE $\z' \gets \z' \setminus \z_4 \cup \z_{5,7} \cup \z_8$ 

%\vspace{2mm}

%%%%%%%%%%%%%
% STEP 4
%%%%%%%%%%%%%

    % \begin{flushleft}
    \COMMENT{\textsc{\color{MidnightBlue} Step 4: Test for $\z_{\textsc{Post}}$}}
    % \end{flushleft}
    % \vspace{-3mm}

\IF{$|\z_4| > 0$ }
\FOR{all $Z \in \z'$} 
        \STATE \textbf{if} {$\exists \; Z_4 \in \z_4$: $Z \nind Z_4$ or $Z \ind Z_4 | X \cup Y$}
        \textbf{then} $Z \in \z_{\textsc{Post}}$
    \ENDFOR
\ENDIF
\STATE $\z' \gets \z' \setminus \z_{\textsc{Post}}$

%\vspace{2mm}

%%%%%%%%%%%%%
% STEP 5
%%%%%%%%%%%%%

% \begin{flushleft}
\COMMENT{\textsc{\color{MidnightBlue} Step 5: Test for $\z_{\textsc{Mix}}$}}
% \end{flushleft}
    % \vspace{-3mm}
    
\FOR{all $Z \in \z'$} 
    \IF{$Y \nind Z$ and $Y \ind Z|X \cup \z' \setminus Z$}
        \STATE $Z \in \z_{1,2,3,5} \in \z_{\textsc{Mix}}$
    \ENDIF
\ENDFOR
\STATE $\z' \gets \z' \setminus \z_{\textsc{Mix}}$

%\vspace{2mm}

%%%%%%%%%%%%%
% STEP 6
%%%%%%%%%%%%%

% \begin{flushleft}
\COMMENT{\textsc{\color{MidnightBlue} Step 6: Split $\z_{\textsc{Mix}}$ between $\z_{1,5}$, $\z_7$, $\z_{\textsc{Post}}$}}
% \end{flushleft}
%     \vspace{-3mm}
\STATE $\z_{\textsc{Mix}} \gets \z_{\textsc{Mix}} \cup \z_{5,7}$
\IF{$|\z_{\textsc{Mix}}| > 0$ and $|\z'| > 0$}
\FOR{all $Z \in \z'$} 
    \IF{$\exists \; Z_{\textsc{Mix}} \in \z_{\textsc{Mix}}$: $Z_{\textsc{Mix}} \ind Z$ and $Z_{\textsc{Mix}} \nind Z | X$}
        \STATE $Z \in \z_{1}$, $Z_{\textsc{Mix}} \in \z_{1,5} \notin \z_{\textsc{Mix}}$ 
    \ENDIF
    \STATE \textbf{else} {$Z \in \z_{\textsc{Post}}$}
\ENDFOR
\FOR{all $Z_{\textsc{Mix}} \in \z_{\textsc{Mix}}$}   
    %\IF 
    \STATE \textbf{if} {$\exists \; Z_{\textsc{1,5}} \in \z_{\textsc{1,5}}$: $Z_{\textsc{1,5}} \ind Z_{\textsc{Mix}}$} \textbf{then} $Z_{\textsc{Mix}} \in \z_{1}$
    %\ENDIF
    \STATE \textbf{else} $Z_{\textsc{Mix}} \in \z_{\textsc{Post}}$
\ENDFOR
\ENDIF
\STATE \textbf{if} $|\z_{1,5} \cup \z_1| > 0 $ \textbf{then} $\z_7 \gets \z_{5,7}$ 

%\vspace{2mm}

%%%%%%%%%%%%%
% STEP 7
%%%%%%%%%%%%%

% \begin{flushleft}
\COMMENT{\textsc{\color{MidnightBlue} Step 7: Finalize $\z_{1}$ and $\z_{5}$}} 
% \end{flushleft}
%     \vspace{-3mm}
\IF{$|\z_{1,5}| > 0$ and $|\z_{1}| > 0$}
% \label{alg_line:25}
\FOR{all $Z_{1,5} \in \z_{1,5}$} 
    \STATE \textbf{if} {$\exists \; Z_{1} \in \z_1$: $Z_{1,5} \nind Z_{1}$} \textbf{then} $Z_{1,5} \in \z_{1}$
    \STATE \textbf{else} $Z_{1,5} \in \z_{5}$
\ENDFOR
\ENDIF
%\IF{$|\z_{5}| > 0$}
%\FOR{$Z_{5} \in \z_{5}$}
    %\IF{$Z_{5} \nind X | \z_{5} \cup \z_{\textsc{Post}} \setminus Z_{5}$}
    %    \STATE{$Z_{5} \in \z_{5 \in adj(X)}$ and $\z_1$ is a VAS}
    
%    \ENDIF
%\ENDFOR
%\ENDIF
%\STATE $\z' \gets \z' \setminus \z_1 \cup \z_5 \cup \z_{\textsc{Post}}$

\COMMENT{\textsc{\color{MidnightBlue} Step 8: Test for VAS ($\z_5$ criterion)}} 
\STATE{\textbf{if} $\exists \; Z_5 \in \z_5$: $Z_5 \ind Y | X \cup \z_1$ \textbf{then} VAS  $\gets \z_1$}
\STATE{\textbf{else} VAS $\gets$ \{not identifiable\}}

\vspace{2mm}

\STATE \{not identifiable\} $\gets \z \notin \z_1, \z_4, \z_5, \z_7, \z_8, \z_{\textsc{Post}}$

%%%%%%%%%%%%%
% END
%%%%%%%%%%%%%

\STATE \textbf{return} VAS and intermediate partition results
} % end small
\end{algorithmic}
\end{algorithm} 
