\begin{figure}[!h]
    \centering
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.15\textheight]{figures/latents_true.png} \\
    \scriptsize \textbf{A.} \textit{True graph ($Z_{5a}$ latent; $\z_1$ in red)}
    \end{tabular}} 
    %%
    \centering
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.15\textheight]{figures/fci_oracle.png} \\
    \scriptsize \textbf{B.} \textit{FCI with oracle}
    \end{tabular}} 
    %%
    \centering
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.15\textheight]{figures/pc_oracle.png} \\
    \scriptsize \textbf{C.} \textit{PC with oracle}
    \end{tabular}} 
    \\
    %%
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.11\textheight]{figures/fci_latent_z5a.png} \\
    \scriptsize \textbf{D.} \textit{FCI (discrete; $n = 50\mathsf{k})$}
    \end{tabular}} 
    %%
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.11\textheight]{figures/seed_2.png} \\
    \scriptsize \textbf{E.} \textit{FCI (discrete; $n = 50\mathsf{k})$}
    \end{tabular}}
    %%
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.11\textheight]{figures/seed_1.png} \\
    \scriptsize \textbf{F.} \textit{FCI (discrete; $n = 50\mathsf{k})$}
    \end{tabular}} \\
    %%
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.11\textheight]{figures/fci_causallearn_fisherz_alpha001.png} \\
    \scriptsize \textbf{G.} \textit{FCI (continuous; $n = 50\mathsf{k})$}
    \end{tabular}} 
    %%
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.11\textheight]{figures/pc_causallearn_fisherz_alpha001.png} \\
    \scriptsize \textbf{H.} \textit{PC (continuous; $n = 50\mathsf{k})$}
    \end{tabular}}
    %%
    \fbox{\begin{tabular}{@{}c@{}}
    \includegraphics[height=0.11\textheight]{figures/pc_dodiscover_50k_fisherz_alpa001_script.png} \\
    \scriptsize \textbf{I.} \textit{PC (continuous; $n = 50\mathsf{k})$}
    \end{tabular}}
    %%
    \caption{Failure modes of PC and FCI for causal partitioning under finite samples. Though PC and FCI return a valid adjustment set (VAS) when provided with an oracle (\textbf{B}, \textbf{C}), both algorithms fail to provide VAS for discrete and continuous data samples. Though the correlation coefficient for $X$ and $Z_1$ was moderate for all examples ($\in [0.25,0.36]$) and both parametric and nonparametric (mutual information)  tests demonstrated marginal dependence, neither algorithm could  reliably detect the edge between $X$ and $Z_1$ (\textbf{D}, \textbf{E}). Even when FCI inferred edges between $Z_1$, $X$, and $Y$ (\textbf{F}), the bidirected edges $Y \leftrightarrow Z_1 \leftrightarrow X$ imply that $Z_1$ is an M-collider, not a confounder. Unreliable results might be attributable to cascading errors due to the ordering of tests \citep{colombo_order-independent_2014}. Discrete data (\textbf{D}–\textbf{F}) feature linear causal mechanisms and Bernoulli noise (chi-square tests; $\alpha = 0.001$). Continuous data (\textbf{G}–\textbf{I}) feature linear causal mechanisms and Gaussian noise (Fisher-z tests; $\alpha = 0.001$). Varying $\alpha$ did not improve causal partitioning. LDP successfully identified a VAS for both discrete and continuous instantiations. Graphs produced with \href{https://www.pywhy.org/dodiscover/dev/index.html}{\texttt{dodiscover}} (\textbf{B}, \textbf{C}, \textbf{I}) and  \href{https://causal-learn.readthedocs.io/en/latest/index.html}{\texttt{causal-learn}} (\textbf{D}–\textbf{H}).}
    \label{fig:fci_finite}
\end{figure}