\begin{table*}[!ht]
    \centering
    \begin{adjustbox}{max width=\textwidth}
    \begin{tabular}{l c c c c c c}
    %%%%%%%%%%%%%%%%%%%%%
    % BERNOULLI
    %%%%%%%%%%%%%%%%%%%%%
    \toprule[1pt]
         & \multicolumn{6}{c}{\fontfamily{cmr}\textsc{\textbf{10-node graph with bernoulli noise}}}  \\ 
         %%%
        \cmidrule(lr){2-7} 
        %%%
         & \multicolumn{2}{c}{\textsc{Linear}} & \multicolumn{2}{c}{\textsc{Quadratic}} & \multicolumn{2}{c}{\textsc{Cube Root}} \\
         %%%
         \cmidrule(lr){2-3} \cmidrule(lr){4-5} \cmidrule(lr){6-7} 
        %%%
        $n$ & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} & \textsc{$X \to Y$ } & \textsc{$X \not\to Y$} \\
        %%%
        \hline
         $100$ & 21.4 (20.1-22.6) & 16.4 (15.2-17.5) & 36.4 (34.9-37.8) & 34.8 (33.7-35.8) & 25.8 (24.1-27.4) & 20.2 (18.7-21.8) \\
         $500$ & 58.8 (55.2-62.3) & 67.0 (62.7-71.3) & 92.0 (89.7-94.3) & 59.5 (54.5-64.5) & 65.2 (62.0-68.5) & 74.4 (71.6-77.1) \\
         $1k$ & 86.1 (83.6-88.6) & 89.2 (86.5-92.0) & 99.8 (99.3-100) & 99.2 (98.2-100) & 97.2 (95.8-98.7) & 98.0 (96.7-99.3) \\
         $5k$ & 99.9 (99.6-100) & 99.9 (99.6-100) & 100 (100-100) & 100 (100-100) & 99.9 (99.6-100) & 99.8 (99.3-100) \\
         $10k$ & 100 (100-100) & 99.9 (99.6-100) & 100 (100-100) & 100 (100-100) & 99.6 (99.1-100) & 99.9 (99.6-100) \\
    \toprule[1pt]
    %%%%%%%%%%%%%%%%%%%%%
    % HYPERGEOMETRIC
    %%%%%%%%%%%%%%%%%%%%%
    & \multicolumn{6}{c}{\fontfamily{cmr}\textsc{\textbf{10-node graph with hypergeometric noise}}} \\ 
         %%%
        \cmidrule(lr){2-7} 
        %%%
         & \multicolumn{2}{c}{\textsc{Linear}} & \multicolumn{2}{c}{\textsc{Quadratic}} & \multicolumn{2}{c}{\textsc{Cube Root}} \\
         %%%
         \cmidrule(lr){2-3} \cmidrule(lr){4-5} \cmidrule(lr){6-7} 
        %%%
        $n$ & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} \\
        %%%
        \hline
         $100$ & 20.4 (18.8-22.0) & 15.6 (14.3-17.0) & 31.2 (29.9-32.6) & 31.4 (29.9-32.9) & 23.0 (21.7-24.3) & 18.4 (16.9-19.8) \\
         $500$ & 68.1 (64.7-71.6) & 43.1 (39.5-46.7) & 85.5 (82.7-88.3) & 83.0 (80.7-85.3) & 70.6 (67.7-73.5) & 56.9 (54.5-59.2) \\
         $1k$ & 92.4 (90.1-94.6) & 78.5 (74.7-82.3) & 97.8 (96.3-99.2) & 98.5 (97.2-99.8) & 95.5 (94.3-96.7) & 87.6 (84.9-90.3) \\
         $5k$ & 100 (100-100) & 98.9 (97.9-99.8) & 99.2 (98.0-100) & 100 (100-100) & 99.2 (98.5-100) & 100 (100-100) \\
         $10k$ & 99.9 (99.6-100) & 99.8 (99.4-100) & 99.8 (99.4-100) & 100 (100-100) & 99.8 (99.3-100) & 100 (100-100) \\
    \bottomrule[1pt]
    \end{tabular}
    \end{adjustbox}
    \caption{Partition label accuracy of Algorithm \ref{alg:method} on a 10-node DAG (Figure \ref{fig:ten_node_dag}) across discrete noise distributions, linear and nonlinar causal mechanisms, and sample sizes ($n$). All DAGs feature one node per partition ($\z_1 - \z_8$). Reported values are partition label accuracy averaged over 100 DAGs (i.e., 800 variables total, excluding all exposure-outcome pairs). The 95\% confidence interval is reported in parentheses. Data generating processes where $X$ is a direct cause of $Y$ are denoted by $X \to Y$, with $X \not\to Y$ denoting no direct causal effect of $X$ on $Y$. Independence was determined by chi-square tests ($\alpha = 0.001$). All experiments were run on a 2017 MacBook with 2.9 GHz Quad-Core Intel Core i7. } 
    \label{tab:results_ten_node_dag}
\end{table*}

\begin{table}[!h]
    \centering
    \begin{adjustbox}{max width=\textwidth}
    \begin{tabular}{l c c c c c c}
    %%%%%%%%%%%%%%%%%%%%%
    % CONTINUOUS NOISE
    %%%%%%%%%%%%%%%%%%%%%
    \toprule[1pt]
        %%%
        & \multicolumn{6}{c}{\fontfamily{cmr}\textsc{\textbf{10-node graph with continuous noise}}} \\
        \cmidrule(lr){2-7}
        %%%
         & \multicolumn{2}{c}{\textsc{Gaussian $|$ Linear}} & \multicolumn{2}{c}{\textsc{Uniform $|$ Linear}} & \multicolumn{2}{c}{\textsc{Exponential $|$ Linear}} \\
         %%%
         \cmidrule(lr){2-3} \cmidrule(lr){4-5} \cmidrule(lr){6-7} 
        %%%
        $n$ & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} & \textsc{$X \to Y$} & \textsc{$X \not\to Y$} \\
        %%%
        \hline
         $100$ & 64.8 (60.7-68.8) & 66.5 (63.0-70.0) &  65.5 (61.4-69.6) & 67.9 (64.6-71.1) & 61.0 (56.9-65.1) & 63.6 (60.2-67.0) \\
         $500$ & 96.1 (94.4-97.8) & 94.6 (92.8-96.5) & 97.8 (96.6-98.9) & 94.2 (92.2-96.3) & 95.2 (93.5-97.0) & 93.6 (91.3-95.9) \\
         $1k$ & 99.2 (98.7-99.8) & 98.5 (97.5-99.5) & 99.0 (98.3-99.7) & 98.8 (97.8-99.7) & 99.8 (99.4-100) & 98.5 (97.4-99.6) \\
         $5k$ & 100 (100-100) & 99.9 (99.6-100) & 99.6 (98.9-100) & 99.8 (99.3-100) & 99.5 (98.7-100) & 99.9 (99.6-100) \\
         $10k$ & 99.9 (99.6-100) & 99.9 (99.6-100) & 100 (100-100) & 100 (100-100) & 100 (100-100) & 100 (100-100) \\
    \bottomrule[1pt]
    \end{tabular}
    \end{adjustbox}
    \caption{Partition label accuracy of Algorithm \ref{alg:method} on a 10-node DAG (Figure \ref{fig:ten_node_dag}) across continuous noise distributions, linear causal mechanisms, and sample sizes ($n$). All DAGs feature one node per partition ($\z_1 - \z_8$). Reported values are partition label accuracy averaged over 100 DAGs (i.e., 800 variables total, excluding all exposure-outcome pairs). The 95\% confidence interval is reported in parentheses. Data generating processes where $X$ is a direct cause of $Y$ are denoted by $X \to Y$, with $X \not\to Y$ denoting no direct causal effect of $X$ on $Y$. Independence was determined by Fisher-z tests ($\alpha = 0.001$). All experiments were run on a 2017 MacBook with 2.9 GHz Quad-Core Intel Core i7. }
    \label{tab:results_continuous}
\end{table}