%blom_190

%\documentclass{uai2022} % for initial submission
\documentclass[accepted]{uai2022} % after acceptance, for a revised
                                  % version; also before submission to
                                  % see how the non-anonymous paper
                                  % would look like
%% There is a class option to choose the math font
% \documentclass[mathfont=ptmx]{uai2022} % ptmx math instead of Computer
                                         % Modern (has noticeable issues)
% \documentclass[mathfont=newtx]{uai2022} % newtx fonts (improves upon
                                          % ptmx; less tested, no support)
% NOTE: Only keep *one* line above as appropriate, as it will be replaced
%       automatically for papers to be published. Do not make any other
%       change above this note for an accepted version.

%% Choose your variant of English; be consistent
\usepackage[american]{babel}
% \usepackage[british]{babel}

%% Some suggested packages, as needed:
\usepackage{natbib} % has a nice set of citation styles and commands
    \bibliographystyle{plainnat}
    \renewcommand{\bibsection}{\subsubsection*{References}}
\usepackage{mathtools} % amsmath with fixes and additions
% \usepackage{siunitx} % for proper typesetting of numbers and units
\usepackage{booktabs} % commands to create good-looking tables
\usepackage{tikz} % nice language for creating drawings and diagrams

%% Provided macros
% \smaller: Because the class footnote size is essentially LaTeX's \small,
%           redefining \footnotesize, we provide the original \footnotesize
%           using this macro.
%           (Use only sparingly, e.g., in drawings, as it is quite small.)

%\usepackage{hyperref}       % hyperlinks
\usepackage{url}            % simple URL typesetting
\usepackage{amsfonts}       % blackboard math symbols


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Mathematics
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\usepackage{amsmath}
\usepackage{amssymb}
\usepackage{mathrsfs}
\usepackage{amsthm}
\usepackage{thmtools}
\usepackage{thm-restate}
\usepackage{mathtools}
\usepackage{bbm}
\usepackage{centernot}


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Figures and tables
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\usepackage{float}
\usepackage{caption}
\usepackage{subcaption}
\usepackage{color}
\usepackage{xcolor}
\usepackage{tabularx}
\usepackage[ruled,vlined]{algorithm2e}
\usepackage{tikz}
\usepackage{tkz-graph}
\usepackage{pgfplots}
\usepackage{pgffor}
\usetikzlibrary{arrows,arrows.meta,fit,automata,matrix,calc,patterns,decorations,decorations.markings,shapes,positioning}

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% External references
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%\usepackage{xr-hyper}
\usepackage{xr}
\externaldocument{blom_190}
%\usepackage{nameref}
%\usepackage{zref-xr,zref-user}
%\zxrsetup{toltxlabel}
%\zexternaldocument*{blom_190}

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Lists
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\usepackage{enumitem}

% Define theorem styles
\theoremstyle{plain}
\newtheorem{theorem}{Theorem}
\newtheorem*{theorem*}{Theorem}
\newtheorem{proposition}{Proposition}
\newtheorem*{proposition*}{Proposition}
\newtheorem{lemma}{Lemma}
\newtheorem{corollary}{Corollary}
\theoremstyle{definition}
\newtheorem{definition}{Definition}
\newtheorem{assumption}{Assumption}
\newtheorem{condition}{Condition}
\newtheorem{remarkx}{Remark}
\newtheorem*{remarkxx}{Remark}
\newtheorem{examplex}{Example}
\newtheorem*{examplexx}{Example}

% From stackoverflow https://tex.stackexchange.com/questions/391443/new-theorem-environment-with-manual-theorem-number
\theoremstyle{plain}
\newtheorem{manualtheoreminner}{Theorem}
\newenvironment{manualtheorem}[1]{%
  \renewcommand\themanualtheoreminner{#1}%
  \manualtheoreminner
}{\endmanualtheoreminner}

% Add closing triangle to examples and remarks.
\newenvironment{remark}
{\pushQED{\qed}\renewcommand{\qedsymbol}{$\triangle$}\remarkx}
{\popQED\endremarkx}
\newenvironment{remark*}
{\pushQED{\qed}\renewcommand{\qedsymbol}{$\triangle$}\remarkxx}
{\popQED\endremarkxx}

\newenvironment{example}
{\pushQED{\qed}\renewcommand{\qedsymbol}{$\triangle$}\examplex}
{\popQED\endexamplex}
\newenvironment{example*}
{\pushQED{\qed}\renewcommand{\qedsymbol}{$\triangle$}\examplexx}
{\popQED\endexamplexx}

% Extra operators and notation
\renewcommand{\S}{\mathcal{S}}
\newcommand{\B}[1]{\boldsymbol{{#1}}}
\newcommand{\tuple}[1]{\langle {#1} \rangle}
\renewcommand{\P}{\mathbb{P}}
\newcommand{\I}{\mathcal{I}}
\newcommand{\J}{\mathcal{J}}
\newcommand{\K}{\mathcal{K}}
\newcommand{\M}{M}
\newcommand{\X}{\mathcal{X}}
\newcommand{\E}{\mathcal{E}}
\newcommand{\U}{\mathcal{U}}
\newcommand{\Y}{\mathcal{Y}}
\newcommand{\G}{\mathcal{G}}
\newcommand{\R}{\mathbb{R}}
\newcommand{\BG}{\mathcal{B}}
\newcommand{\V}{\mathcal{V}}
\newcommand{\F}{\mathcal{F}}
\newcommand{\pa}[2]{\mathrm{pa}_{{#1}}({#2})}
\newcommand{\adj}[2]{\mathrm{adj}_{#1}(#2)}
\newcommand{\an}[2]{\mathrm{an}_{{#1}}({#2})}
\newcommand{\de}[2]{\mathrm{de}_{{#1}}({#2})}
\newcommand{\ch}[2]{\mathrm{ch}_{{#1}}({#2})}
\renewcommand{\sc}[2]{\mathrm{sc}_{{#1}}({#2})}
\newcommand{\mpr}[2]{{#1} \dashrightarrow {#2}}

\newcommand{\sigsep}[1]{\overset{\sigma}{\underset{{#1}}{\perp}}}
\newcommand{\dsep}[1]{\overset{d}{\underset{{#1}}{\perp}}}
\newcommand{\indep}{\mathrel{\perp\mspace{-10mu}\perp}}
\newcommand{\dep}{\centernot{\indep}}
\newcommand{\ind}[1]{\underset{{#1}}{\indep}}
\newcommand{\given}{\,|\,}
\renewcommand{\pm}[1]{\boldsymbol{M}({#1})}
\newcommand{\Sc}[1]{\mathrm{sc}({#1})}
\newcommand{\iv}[1]{\mathrm{do}({#1})}
\newcommand{\Clust}{\mathcal{V}}
\newcommand{\clust}[1]{\mathrm{Clust}({#1})}

\newcommand\Joris[1]{{\color{red}#1}}

\renewcommand{\theequation}{\arabic{equation}*}
\renewcommand{\thefigure}{\arabic{figure}*}
% comment the following lines if you don't use hyperref
\renewcommand{\theHequation}{\arabic{equation}*}
\renewcommand{\theHfigure}{\arabic{figure}*}

\title{Robustness of Model Predictions under Extension (Supplementary Material)}

% The standard author block has changed for UAI 2022 to provide
% more space for long author lists and allow for complex affiliations
%
% All author information is automatically removed by the class for the
% anonymous submission version of your paper, so you can already add your
% information below.
%
% Add authors
\author[1]{\href{mailto:<tineke_blom@hotmail.com>}{Tineke~Blom}{}}
\author[2]{\href{mailto:<j.m.mooij@uva.nl>}{Joris M.~Mooij}{}}
% Add affiliations after the authors
\affil[1]{%
    Informatics Institute\\
    University of Amsterdam\\
    The Netherlands
}
\affil[2]{%
    Korteweg-De Vries Institute for Mathematics\\
    University of Amsterdam\\
    The Netherlands
}
  
\begin{document}
\onecolumn
\maketitle

This supplementary material contains the material that did not fit into the main paper because of space constraints.
A graphical illustration of the causal ordering algorithm applied to the equations of a cyclic model is provided in the first section. The second section contains more details on the signaling cascade model. The third section contains the proofs of the results in the main paper.

\appendix

\section{Causal Ordering Algorithm Applied to a Cyclic Model}
\label{sec:supplement:example}

In this supplementary section we demonstrate how the causal ordering algorithm works on a set of equations for a cyclic model. The algorithm is also presented graphically. Consider the following equations for endogenous variables $\B{X}$ and exogenous random variables $\B{U}$:
\begin{align}
f_1:\qquad & g_1(X_{v_1}, U_{w_1}) = 0, \label{eq:f1}\\
f_2:\qquad & g_2(X_{v_2}, X_{v_1}, X_{v_4}, U_{w_2}) = 0,\\
f_3:\qquad & g_3(X_{v_3}, X_{v_2}, U_{w_3}) = 0,\\
f_4:\qquad & g_4(X_{v_4}, X_{v_3}, U_{w_4}) = 0,\\
f_5:\qquad & g_5(X_{v_5}, X_{v_4}, U_{w_5}) = 0. \label{eq:f5}
\end{align}

The associated bipartite graph in Figure~\ref{fig:supplement bipartite graph} consists of variable vertices $V=\{v_1,\ldots,v_5\}$ and equation vertices $F=\{f_1,\ldots,f_5\}$. There is an edge between a variable vertex and an equation vertex whenever that variable appears in the equation. The associated bipartite graph has exactly two perfect matchings:
\begin{align*}
M_1 = \{(v_1-f_1), (v_2-f_2), (v_3-f_3), (v_4-f_4), (v_5-f_5)\},\\
M_2 = \{(v_1-f_1), (v_2-f_3), (v_3-f_4), (v_4-f_2), (v_5-f_5)\}.
\end{align*}
Application of the first step of the causal ordering algorithm results either
in the directed graph in Figure~\ref{fig:supplement directed graph 1} or that
in Figure~\ref{fig:supplement directed graph 2}, depending on the choice of the
perfect matching. The segmentation of vertices into strongly connected
components, which takes place in the second step of the algorithm, results in
the clusters $\{v_1\}$, $\{f_1\}$, $\{v_2,v_3,v_4,f_2,f_3,f_4\}$, $\{v_5\}$,
and $\{f_5\}$. To construct the clusters of the causal ordering graph we add
$S_i\cup M(S_i)$ to a cluster set $\V$ for each $S_i$ in the segmentation. The
segmentation of vertices into strongly connected components is displayed in
Figures \ref{fig:supplement strongly connected components 1} and
\ref{fig:supplement strongly connected components 2}. Notice that the
segmentation in Figure~\ref{fig:supplement strongly connected components 1} is
the same as that in Figure~\ref{fig:supplement strongly connected components 2}.
It is known that the segmentation into strongly connected components is
unique (i.e.\ it does not depend on the choice of the perfect matching) \citep{Pothen1990,Blom2020}. 
The cluster set $\V$ for the causal ordering graph in Figure~\ref{fig:supplement causal ordering graph} is constructed by merging clusters in the segmented graph whenever two clusters contain vertices that are matched and by adding exogenous variables as singleton clusters. The edge set $\E$ for the causal ordering graph is obtained by adding edges $(v\to C)$ from an endogenous vertex $v$ to a cluster $C$, whenever $v\notin C$ and there is an edge from $v$ to $f\in C$ in the directed graph. We also add edges from exogenous vertices to clusters that contain equations in which the corresponding exogenous random variables appear.

\begin{figure}[ht]
\centering
\begin{subfigure}[b]{0.3\linewidth}
  \centering
  \begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
  \GraphInit[vstyle=Normal]
  \SetGraphUnit{1}
  \Vertex[L=$v_1$, x=0.0, y=0.0] {v1}
  \Vertex[L=$v_2$, x=1.0, y=0.0] {v2}
  \Vertex[L=$v_3$, x=2.0, y=0.0] {v3}
  \Vertex[L=$v_4$, x=3.0, y=0.0] {v4}
  \Vertex[L=$v_5$, x=4.0, y=0.0] {v5}

  \Vertex[L=$f_1$, x=0.0, y=-1.4] {f1}
  \Vertex[L=$f_2$, x=1.0, y=-1.4] {f2}
  \Vertex[L=$f_3$, x=2.0, y=-1.4] {f3}
  \Vertex[L=$f_4$, x=3.0, y=-1.4] {f4}
  \Vertex[L=$f_5$, x=4.0, y=-1.4] {f5}

  \draw[EdgeStyle, style={-}](v1) to (f1);
  \draw[EdgeStyle, style={-}](v2) to (f2);
  \draw[EdgeStyle, style={-}](v3) to (f3);
  \draw[EdgeStyle, style={-}](v4) to (f4);
  \draw[EdgeStyle, style={-}](v5) to (f5);
  \draw[EdgeStyle, style={-}](v1) to (f2);
  \draw[EdgeStyle, style={-}](v2) to (f3);
  \draw[EdgeStyle, style={-}](v3) to (f4);
  \draw[EdgeStyle, style={-}](v4) to (f5);
  \draw[EdgeStyle, style={-}](v4) to (f2);
  \end{tikzpicture}
  \caption{Bipartite graph.}
  \label{fig:supplement bipartite graph}
\end{subfigure}\hfill
\begin{subfigure}[b]{0.3\linewidth}
  \centering
  \begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
  \GraphInit[vstyle=Normal]
  \SetGraphUnit{1}
  \Vertex[L=$v_1$, x=0.0, y=0.0] {v1}
  \Vertex[L=$v_2$, x=1.0, y=0.0] {v2}
  \Vertex[L=$v_3$, x=2.0, y=0.0] {v3}
  \Vertex[L=$v_4$, x=3.0, y=0.0] {v4}
  \Vertex[L=$v_5$, x=4.0, y=0.0] {v5}

  \Vertex[L=$f_1$, x=0.0, y=-1.4] {f1}
  \Vertex[L=$f_2$, x=1.0, y=-1.4] {f2}
  \Vertex[L=$f_3$, x=2.0, y=-1.4] {f3}
  \Vertex[L=$f_4$, x=3.0, y=-1.4] {f4}
  \Vertex[L=$f_5$, x=4.0, y=-1.4] {f5}

  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v1) to (f1);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v2) to (f2);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v3) to (f3);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v4) to (f4);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v5) to (f5);
  \draw[EdgeStyle, style={-stealth, gray}](v1) to (f2);
  \draw[EdgeStyle, style={-stealth, gray}](v2) to (f3);
  \draw[EdgeStyle, style={-stealth, gray}](v3) to (f4);
  \draw[EdgeStyle, style={-stealth, gray}](v4) to (f5);
  \draw[EdgeStyle, style={-stealth, gray}](v4) to (f2);
  \end{tikzpicture}
  \caption{Directed graph ($M_1$).}
  \label{fig:supplement directed graph 1}
\end{subfigure}\hfill
\begin{subfigure}[b]{0.3\linewidth}
%  \vspace{2mm}
  \centering
  \begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
  \GraphInit[vstyle=Normal]
  \SetGraphUnit{1}
  \Vertex[L=$v_1$, x=0.0, y=0.0] {v1}
  \Vertex[L=$v_2$, x=1.0, y=0.0] {v2}
  \Vertex[L=$v_3$, x=2.0, y=0.0] {v3}
  \Vertex[L=$v_4$, x=3.0, y=0.0] {v4}
  \Vertex[L=$v_5$, x=4.0, y=0.0] {v5}

  \Vertex[L=$f_1$, x=0.0, y=-1.4] {f1}
  \Vertex[L=$f_2$, x=1.0, y=-1.4] {f2}
  \Vertex[L=$f_3$, x=2.0, y=-1.4] {f3}
  \Vertex[L=$f_4$, x=3.0, y=-1.4] {f4}
  \Vertex[L=$f_5$, x=4.0, y=-1.4] {f5}

  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v1) to (f1);
  \draw[EdgeStyle, style={-stealth}](v2) to (f2);
  \draw[EdgeStyle, style={-stealth}](v3) to (f3);
  \draw[EdgeStyle, style={-stealth}](v4) to (f4);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v5) to (f5);
  \draw[EdgeStyle, style={-stealth}](v1) to (f2);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v2) to (f3);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v3) to (f4);
  \draw[EdgeStyle, style={-stealth}](v4) to (f5);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v4) to (f2);
  \end{tikzpicture}
  \caption{Directed graph ($M_2$).}
  \label{fig:supplement directed graph 2}
\end{subfigure}%

\medskip
\begin{subfigure}[b]{0.3\linewidth}
  \centering
  \begin{tikzpicture}[scale=0.65,every node/.style={transform shape}]
  \GraphInit[vstyle=Normal]
  \SetGraphUnit{1}
  \Vertex[L=$v_1$, x=0.0, y=0.0] {v1}
  \Vertex[L=$v_2$, x=1.2, y=0.0] {v2}
  \Vertex[L=$v_3$, x=2.2, y=0.0] {v3}
  \Vertex[L=$v_4$, x=3.2, y=0.0] {v4}
  \Vertex[L=$v_5$, x=4.4, y=0.0] {v5}

  \Vertex[L=$f_1$, x=0.0, y=-1.4] {f1}
  \Vertex[L=$f_2$, x=1.2, y=-1.4] {f2}
  \Vertex[L=$f_3$, x=2.2, y=-1.4] {f3}
  \Vertex[L=$f_4$, x=3.2, y=-1.4] {f4}
  \Vertex[L=$f_5$, x=4.4, y=-1.4] {f5}

  \node[draw=black, fit=(v1), inner sep=0.1cm ]{};
  \node[draw=black, fit=(f1), inner sep=0.1cm ]{};
  \node[draw=black, fit=(v2) (f2) (v3) (f3) (v4) (f4), inner sep=0.1cm ]{};
  \node[draw=black, fit=(v5), inner sep=0.1cm ]{};
  \node[draw=black, fit=(f5), inner sep=0.1cm ]{};

  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v1) to (f1);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v2) to (f2);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v3) to (f3);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v4) to (f4);
  \draw[EdgeStyle, style={stealth-, blue, ultra thick}](v5) to (f5);
  \draw[EdgeStyle, style={-stealth, gray}](v1) to (f2);
  \draw[EdgeStyle, style={-stealth, gray}](v2) to (f3);
  \draw[EdgeStyle, style={-stealth, gray}](v3) to (f4);
  \draw[EdgeStyle, style={-stealth, gray}](v4) to (f5);
  \draw[EdgeStyle, style={-stealth, gray}](v4) to (f2);
  \end{tikzpicture}
  \caption{Segmentation ($M_1$)}
  \label{fig:supplement strongly connected components 1}
\end{subfigure}\hfill
\begin{subfigure}[b]{0.3\linewidth}
%  \vspace{2mm}
  \centering
  \begin{tikzpicture}[scale=0.65,every node/.style={transform shape}]
  \GraphInit[vstyle=Normal]
  \SetGraphUnit{1}
  \Vertex[L=$v_1$, x=0.0, y=0.0] {v1}
  \Vertex[L=$v_2$, x=1.2, y=0.0] {v2}
  \Vertex[L=$v_3$, x=2.2, y=0.0] {v3}
  \Vertex[L=$v_4$, x=3.2, y=0.0] {v4}
  \Vertex[L=$v_5$, x=4.4, y=0.0] {v5}

  \Vertex[L=$f_1$, x=0.0, y=-1.4] {f1}
  \Vertex[L=$f_2$, x=1.2, y=-1.4] {f2}
  \Vertex[L=$f_3$, x=2.2, y=-1.4] {f3}
  \Vertex[L=$f_4$, x=3.2, y=-1.4] {f4}
  \Vertex[L=$f_5$, x=4.4, y=-1.4] {f5}

  \node[draw=black, fit=(v1), inner sep=0.1cm ]{};
  \node[draw=black, fit=(f1), inner sep=0.1cm ]{};
  \node[draw=black, fit=(v2) (f2) (v3) (f3) (v4) (f4), inner sep=0.1cm ]{};
  \node[draw=black, fit=(v5), inner sep=0.1cm ]{};
  \node[draw=black, fit=(f5), inner sep=0.1cm ]{};

  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v1) to (f1);
  \draw[EdgeStyle, style={-stealth}](v2) to (f2);
  \draw[EdgeStyle, style={-stealth}](v3) to (f3);
  \draw[EdgeStyle, style={-stealth}](v4) to (f4);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v5) to (f5);
  \draw[EdgeStyle, style={-stealth}](v1) to (f2);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v2) to (f3);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v3) to (f4);
  \draw[EdgeStyle, style={-stealth}](v4) to (f5);
  \draw[EdgeStyle, style={stealth-, orange, ultra thick}](v4) to (f2);
  \end{tikzpicture}
  \caption{Segmentation ($M_2$)}
  \label{fig:supplement strongly connected components 2}
\end{subfigure}\hfill
\begin{subfigure}[b]{0.3\linewidth}
%  \vspace{2mm}
  \centering
  \begin{tikzpicture}[scale=0.65,every node/.style={transform shape}]
  \GraphInit[vstyle=Normal]
  \SetGraphUnit{1}
  \Vertex[L=$v_1$, x=0.0, y=0.0] {v1}
  \Vertex[L=$v_2$, x=1.2, y=0.0] {v2}
  \Vertex[L=$v_3$, x=2.2, y=0.0] {v3}
  \Vertex[L=$v_4$, x=3.2, y=0.0] {v4}
  \Vertex[L=$v_5$, x=4.4, y=0.0] {v5}

  \Vertex[L=$f_1$, x=0.0, y=-1.0] {f1}
  \Vertex[L=$f_2$, x=1.2, y=-1.0] {f2}
  \Vertex[L=$f_3$, x=2.2, y=-1.0] {f3}
  \Vertex[L=$f_4$, x=3.2, y=-1.0] {f4}
  \Vertex[L=$f_5$, x=4.4, y=-1.0] {f5}

  \Vertex[L=$w_1$, x=-0.2, y=-2.2, style={dashed}] {w1}
  \Vertex[L=$w_2$, x=1.0, y=-2.2, style={dashed}] {w2}
  \Vertex[L=$w_3$, x=2.2, y=-2.2, style={dashed}] {w3}
  \Vertex[L=$w_4$, x=3.4, y=-2.2, style={dashed}] {w4}
  \Vertex[L=$w_5$, x=4.6, y=-2.2, style={dashed}] {w5}

  \node[draw=black, fit=(v1) (f1), inner sep=0.1cm ]{};
  \node[draw=black, fit=(v2) (f2) (v3) (f3) (v4) (f4), inner sep=0.1cm ]{};
  \node[draw=black, fit=(v5) (f5), inner sep=0.1cm ]{};

  \node[draw=black, fit=(w1), inner sep=0.1cm ]{};
  \node[draw=black, fit=(w2), inner sep=0.1cm ]{};
  \node[draw=black, fit=(w3), inner sep=0.1cm ]{};
  \node[draw=black, fit=(w4), inner sep=0.1cm ]{};
  \node[draw=black, fit=(w5), inner sep=0.1cm ]{};

  \draw[EdgeStyle, style={-stealth, very thick}](v1) to (0.7,0.0);
  \draw[EdgeStyle, style={-stealth, very thick}](v4) to (3.9,0.0);
  \draw[EdgeStyle, style={-stealth, very thick}](w1) to (0.0,-1.5);
  \draw[EdgeStyle, style={-stealth, very thick}](w2) to (1.2,-1.5);
  \draw[EdgeStyle, style={-stealth, very thick}](w3) to (2.2,-1.5);
  \draw[EdgeStyle, style={-stealth, very thick}](w4) to (3.2,-1.5);
  \draw[EdgeStyle, style={-stealth, very thick}](w5) to (4.4,-1.5);
  \end{tikzpicture}
  \caption{Causal ordering graph.}
  \label{fig:supplement causal ordering graph}
\end{subfigure}
\caption{Graphical illustration of the causal ordering algorithm that was described in Section~\ref{sec:introduction:causal ordering graph}. Figure~\ref{fig:supplement bipartite graph} shows the bipartite graph that is associated with equations \eqref{eq:f1} to \eqref{eq:f5}. Application of the first step of the causal ordering algorithm results in the directed graph in Figure~\ref{fig:supplement directed graph 1} for perfect matching $M_1$ and that in Figure~\ref{fig:supplement directed graph 2} for perfect matching $M_2$. The blue and orange edges correspond to the edges in the perfect matchings $M_1$ and $M_2$, respectively. Figures \ref{fig:supplement strongly connected components 1} and \ref{fig:supplement strongly connected components 2} show that the segmentation into strongly connected components does not depend on the choice of the perfect matching. Exogenous vertices and edges from these vertices to clusters were added to the causal ordering graph in Figure~\ref{fig:supplement causal ordering graph}.}
\label{fig:supplement causal ordering algorithm}
\end{figure}

\section{Example: signaling cascade model}\label{sec:supplement:signaling_cascade_model}

In this supplementary section we provide more details on the signaling cascade model that is discussed in Section~\ref{sec:signaling_cascade_model}.

We denote the concentrations of active (phosphorylated) RAS, RAF, MEK, and ERK proteins, respectively, by
$X_{s}(t)$, $X_{r}(t)$, $X_{m}(t)$, and $X_{e}(t)$, and denote by $I(t)$ an external stimulus or perturbation.
The system dynamics is modeled by differential equations:
\begin{align}
\label{eq:mapk s}
\dot{X}_{s}(t) &= I(t) \frac{k_{Is} \left(T_s-X_s(t)\right)}{\left(K_{Is} + (T_s-X_s(t)) \right) \left(1+\left(\frac{X_e(t)}{K_e}\right)^{\frac{3}{2}}\right) } -  F_{s} k_{F_s s} \frac{X_s(t)}{K_{F_s s} + X_s(t)} \\
\label{eq:mapk r}
\dot{X}_r(t) &= \frac{X_s(t) k_{sr} (T_r - X_r(t))}{K_{sr} + (T_r - X_r(t))} - F_r k_{F_r r} \frac{X_r(t)}{K_{F_r r} + X_r(t)} \\
\label{eq:mapk m}
\dot{X}_m(t) &= \frac{X_r(t) k_{rm} (T_m - X_m(t))}{K_{rm} + (T_m - X_m(t))} - F_m k_{F_m m} \frac{X_m(t)}{K_{F_m m} + X_m(t)} \\
\label{eq:mapk e}
\dot{X}_e(t) &= \frac{X_m(t) k_{me} (T_e - X_e(t))}{K_{me} + (T_e - X_e(t))} - F_e k_{F_e e} \frac{X_e(t)}{K_{F_e e} + X_e(t)}.
\end{align}
These dynamical equations correspond with a signaling pathway that goes from $I(t)$ to $X_s(t)$ to $X_r(t)$ to $X_m(t)$ to $X_e(t)$ with negative feedback from $X_e(t)$ on $X_s(t)$.
We will study this system in a certain saturated regime;
specifically, for $(T_e-X_e(t))\gg K_{me}$ and $X_e(t)\gg K_{F_e e}$ the following approximation of (\ref{eq:mapk e}) holds:
\begin{align}
\label{eq:mapk e approx}
\dot{X}_e(t) \approx X_m(t) k_{me} - F_e k_{F_e e}.
\end{align}

Thus, the saturated dynamical model that we consider consists of differential equations \eqref{eq:mapk s}, \eqref{eq:mapk r}, \eqref{eq:mapk m} and \eqref{eq:mapk e approx}.
The corresponding equilibrium equations of the saturated model are given by:
\begin{align}
\label{eq:mapk s eq}
0 &= I \frac{k_{Is} \left(T_s-X_s\right)}{\left(K_{Is} + (T_s-X_s) \right) \left(1+\left(\frac{X_e}{K_e}\right)^{\frac{3}{2}}\right) } -  F_{s} k_{F_s s} \frac{X_s}{K_{F_s s} + X_s} \\
\label{eq:mapk r eq}
0 &= \frac{X_s k_{sr} (T_r - X_r)}{K_{sr} + (T_r - X_r)} - F_r k_{F_r r} \frac{X_r}{K_{F_r r} + X_r} \\
\label{eq:mapk m eq}
0 &= \frac{X_r k_{rm} (T_m - X_m)}{K_{rm} + (T_m - X_m)} - F_m k_{F_m m} \frac{X_m}{K_{F_m m} + X_m} \\
\label{eq:mapk e eq approx}
0 &= X_m k_{me} - F_e k_{F_e e},
\end{align}
where we also assume the input signal $I$ to be stationary (constant in time).

Figure~\ref{fig:protein pathway} shows the results of applying the causal ordering procedure to the full model, and to the partial model that treats the equilibrium ERK concentration $X_e$ as unobserved and assumes it to be exogenous with respect to the observed concentrations $X_s$, $X_r$ and $X_m$ of RAS, RAF and MEK, respectively.

\begin{figure}[ht]
	\begin{subfigure}[b]{0.3\textwidth}
		\centering
		\vspace*{3mm}
		\begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
		\GraphInit[vstyle=Normal]
		\SetGraphUnit{1}
		\Vertex[L=$v_s$,x=0,y=0] {vs}
		\Vertex[L=$v_r$,x=1.1,y=0] {vr}
		\Vertex[L=$v_m$,x=2.2,y=0] {vm}
%		\Vertex[L=$v_e$,x=3.3,y=0] {ve}
		\Vertex[L=$f_s$,x=0,y=-1.5] {fs}
		\Vertex[L=$f_r$,x=1.1,y=-1.5] {fr}
		\Vertex[L=$f_m$,x=2.2,y=-1.5] {fm}
%		\Vertex[L=$f_e$,x=3.3,y=-1.5] {fe}
		\draw[EdgeStyle, style={-}](vs) to (fs);
		\draw[EdgeStyle, style={-}](vs) to (fr);
		\draw[EdgeStyle, style={-}](vr) to (fr);
		\draw[EdgeStyle, style={-}](vr) to (fm);
		\draw[EdgeStyle, style={-}](vm) to (fm);
%		\draw[EdgeStyle, style={-}](vm) to (fe);
%		\draw[EdgeStyle, style={-}](ve) to (fs);
		\end{tikzpicture}
    \caption{Bipartite graph $\BG$.}
		\label{fig:protein pathway:submodel:bipartite graph}
	\end{subfigure}%
	%\vspace{3mm}
	\begin{subfigure}[b]{0.4\textwidth}
		\centering
		\begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
		\GraphInit[vstyle=Normal]
		\SetGraphUnit{1}
%		\Vertex[L=$v_m$,x=3.9,y=0] {ve}
		\Vertex[L=$v_m$,x=2.6,y=0] {vm}
		\Vertex[L=$v_r$,x=1.3,y=0] {vr}
		\Vertex[L=$v_s$,x=0.0,y=0] {vs}
%		\Vertex[L=$f_e$,x=3.9,y=-1.2] {fe}
		\Vertex[L=$f_m$,x=2.6,y=-1.2] {fm}
		\Vertex[L=$f_r$,x=1.3,y=-1.2] {fr}
		\Vertex[L=$f_s$,x=0.0,y=-1.2] {fs}
		
		\begin{scope}[VertexStyle/.append style = {minimum size = 4pt, 
			inner sep = 0pt,
			color=black}]
		\Vertex[x=-1.0, y=0.0, L=$I$, Lpos=180, LabelOut]{I}
		\end{scope}

    \node[draw=black, fit=(vm) (fm), inner sep=0.1cm]{};
    \node[draw=black, fit=(vr) (fr), inner sep=0.1cm]{};
		\node[draw=black, fit=(vs) (fs), inner sep=0.1cm]{};
%		\node[draw=black, fit=(ve) (fs), inner sep=0.1cm]{};
		
		\draw[EdgeStyle, style={->}](I) to (-0.525,0.0);
		\draw[EdgeStyle, style={->}](vs) to (0.775,0.0);
		\draw[EdgeStyle, style={->}](vr) to (2.025,0.0);
%		\draw[EdgeStyle, style={->}](vm) to (3.125,0.0);
		\end{tikzpicture}
    \caption{Causal ordering graph $\mathrm{CO}(\BG)$.}
		\label{fig:protein pathway:submodel:causal ordering graph}
	\end{subfigure}%
	\begin{subfigure}[b]{0.3\textwidth}
		\centering
		\begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
		\GraphInit[vstyle=Normal]
		\SetGraphUnit{1}
		%\Vertex[L=$I$, x=0, y=1.1] {I}
%		\Vertex[L=$v_e$, x=0.0, y=0] {vE}
		\Vertex[L=$v_s$, x=1.1, y=0] {vS}
		\Vertex[L=$v_r$, x=2.2, y=0] {vR}
		\Vertex[L=$v_m$, x=3.3, y=0] {vM}
%		\Vertex[L=$w_{e}$, x=0, y=-1.1, style={dashed}] {wE}
		\Vertex[L=$w_{s}$, x=1.1, y=-1.1, style={dashed}] {wS}
		\Vertex[L=$w_{r}$, x=2.2, y=-1.1, style={dashed}] {wR}
 		\Vertex[L=$w_{m}$, x=3.3, y=-1.1, style={dashed}] {wM}
		
		\begin{scope}[VertexStyle/.append style = {minimum size = 4pt, 
			inner sep = 0pt,
			color=black}]
		\Vertex[x=0.0, y=0.0, L=$I$, Lpos=180, LabelOut]{I}
		\end{scope}
    \draw[EdgeStyle, style={->}](I) to (vS);
    \draw[EdgeStyle, style={->}](wS) to (vS);
    \draw[EdgeStyle, style={->}](wR) to (vR);
    \draw[EdgeStyle, style={->}](wM) to (vM);
    \draw[EdgeStyle, style={->}](vR) to (vM);
    \draw[EdgeStyle, style={->}](vS) to (vR);
		\end{tikzpicture}
		\caption{Markov ordering graph $\mathrm{MO}(\BG)$.}
		\label{fig:protein pathway:submodel:markov ordering graph2}
	\end{subfigure}
	\begin{subfigure}[b]{0.3\textwidth}
		\centering
		\vspace*{3mm}
		\begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
		\GraphInit[vstyle=Normal]
		\SetGraphUnit{1}
		\Vertex[L=$v_s$,x=0,y=0] {vs}
		\Vertex[L=$v_r$,x=1.1,y=0] {vr}
		\Vertex[L=$v_m$,x=2.2,y=0] {vm}
		\Vertex[L=$v_e$,x=3.3,y=0] {ve}
		\Vertex[L=$f_s$,x=0,y=-1.5] {fs}
		\Vertex[L=$f_r$,x=1.1,y=-1.5] {fr}
		\Vertex[L=$f_m$,x=2.2,y=-1.5] {fm}
		\Vertex[L=$f_e$,x=3.3,y=-1.5] {fe}
		\draw[EdgeStyle, style={-}](vs) to (fs);
		\draw[EdgeStyle, style={-}](vs) to (fr);
		\draw[EdgeStyle, style={-}](vr) to (fr);
		\draw[EdgeStyle, style={-}](vr) to (fm);
		\draw[EdgeStyle, style={-}](vm) to (fm);
		\draw[EdgeStyle, style={-}](vm) to (fe);
		\draw[EdgeStyle, style={-}](ve) to (fs);
		\end{tikzpicture}
    \caption{Bipartite graph $\BG_{\mathrm{ext}}$.}
		\label{fig:protein pathway:extended model:bipartite graph}
	\end{subfigure}%
	%\vspace{3mm}
	\begin{subfigure}[b]{0.4\textwidth}
		\centering
		\begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
		\GraphInit[vstyle=Normal]
		\SetGraphUnit{1}
		\Vertex[L=$v_m$,x=3.9,y=0] {vm}
		\Vertex[L=$v_r$,x=2.6,y=0] {vr}
		\Vertex[L=$v_s$,x=1.3,y=0] {vs}
		\Vertex[L=$v_e$,x=0.0,y=0] {ve}
		\Vertex[L=$f_e$,x=3.9,y=-1.2] {fe}
		\Vertex[L=$f_m$,x=2.6,y=-1.2] {fm}
		\Vertex[L=$f_r$,x=1.3,y=-1.2] {fr}
		\Vertex[L=$f_s$,x=0.0,y=-1.2] {fs}
		
		\begin{scope}[VertexStyle/.append style = {minimum size = 4pt, 
			inner sep = 0pt,
			color=black}]
		\Vertex[x=-1.0, y=0.0, L=$I$, Lpos=180, LabelOut]{I}
		\end{scope}

    \node[draw=black, fit=(vm) (fe), inner sep=0.1cm]{};
		\node[draw=black, fit=(vr) (fm), inner sep=0.1cm]{};
		\node[draw=black, fit=(vs) (fr), inner sep=0.1cm]{};
		\node[draw=black, fit=(ve) (fs), inner sep=0.1cm]{};
		
		\draw[EdgeStyle, style={->}](I) to (-0.525,0.0);
		\draw[EdgeStyle, style={->}](vs) to (0.525,0.0);
		\draw[EdgeStyle, style={->}](vr) to (1.825,0.0);
		\draw[EdgeStyle, style={->}](vm) to (3.125,0.0);
		\end{tikzpicture}
		\caption{Causal ordering graph $\mathrm{CO}(\BG_{\mathrm{ext}})$.}
		\label{fig:protein pathway:extended model:causal ordering graph}
	\end{subfigure}%
	\begin{subfigure}[b]{0.3\textwidth}
		\centering
		\begin{tikzpicture}[scale=0.75,every node/.style={transform shape}]
		\GraphInit[vstyle=Normal]
		\SetGraphUnit{1}
		%\Vertex[L=$I$, x=0, y=1.1] {I}
		\Vertex[L=$v_e$, x=0.0, y=0] {vE}
		\Vertex[L=$v_s$, x=1.1, y=0] {vS}
		\Vertex[L=$v_r$, x=2.2, y=0] {vR}
		\Vertex[L=$v_m$, x=3.3, y=0] {vM}
		\Vertex[L=$w_{s}$, x=0, y=-1.1, style={dashed}] {wS}
		\Vertex[L=$w_{r}$, x=1.1, y=-1.1, style={dashed}] {wR}
		\Vertex[L=$w_{m}$, x=2.2, y=-1.1, style={dashed}] {wM}
		\Vertex[L=$w_{e}$, x=3.3, y=-1.1, style={dashed}] {wE}
		
		\begin{scope}[VertexStyle/.append style = {minimum size = 4pt, 
			inner sep = 0pt,
			color=black}]
		\Vertex[x=-1.0, y=0.0, L=$I$, Lpos=180, LabelOut]{I}
		\end{scope}
		\draw[EdgeStyle, style={->}](I) to (vE);
		\draw[EdgeStyle, style={->}](wS) to (vE);
		\draw[EdgeStyle, style={->}](wR) to (vS);
		\draw[EdgeStyle, style={->}](wM) to (vR);
		\draw[EdgeStyle, style={->}](wE) to (vM);
		\draw[EdgeStyle, style={->}](vM) to (vR);
		\draw[EdgeStyle, style={->}](vR) to (vS);
		\draw[EdgeStyle, style={->}](vS) to (vE);
		\end{tikzpicture}
    \caption{Markov ordering graph $\mathrm{MO}(\BG_{\mathrm{ext}})$.}
		\label{fig:protein pathway:extended model:markov ordering graph2}
	\end{subfigure}
  \caption{Graphs associated with the saturated protein signaling pathway model, where indices $s,r,m,e$ correspond to concentrations of active RAS, RAF, MEK and ERK respectively, and $I$ is an exogenous input signal.
  Top row: submodel for RAS, RAF and MEK only.
  Bottom row: model extension with ERK.}
	\label{fig:protein pathway}
\end{figure}

\section{Proofs}
\label{sec:supplement:proofs}

%\preservedcausalpredictions*
\begin{manualtheorem}{\ref{thm:preserved causal predictions}}
  Consider model equations $F$ containing endogenous variables $V$ with bipartite graph $\BG$. Suppose $F$ is extended with equations $F_+$ containing endogenous variables in $V\cup V_+$, where $V_+$ contains endogenous variables that are added by the model extension (which may include parameters or exogenous variables that appear in $F$ and become endogenous in the extended model). Let $\BG_{\mathrm{ext}}$ be the bipartite graph associated with $F_{\mathrm{ext}}=F\cup F_+$ and $V_{\mathrm{ext}}=V\cup V_+$, and $\BG_+$ the bipartite graph associated with the extension $F_+$ and $V_+$, where variables in $V$ appearing in $F^+$ are treated as exogenous variables (i.e.\ they are not added as vertices in $\BG_+$). If $\BG$ and $\BG_+$ both have a perfect matching then:
  \begin{enumerate}
    \item $\BG_{\mathrm{ext}}$ has a perfect matching,
    \item ancestral relations in $\mathrm{CO}(\BG)$ are also present in $\mathrm{CO}(\BG_{\mathrm{ext}})$,
    \item d-connections in $\mathrm{MO}(\BG)$ are also present in $\mathrm{MO}(\BG_{\mathrm{ext}})$.
  \end{enumerate}
\end{manualtheorem}
\begin{proof}
The causal ordering graph $\mathrm{CO}(\BG)$ is constructed from a perfect matching $M$ for the bipartite graph $\BG=\tuple{V,F,E}$. Let $M_+$ be a perfect matching for $\BG_+$. Note that $M_{\mathrm{ext}}=M\cup M_+$ is a perfect matching for $\BG_{\mathrm{ext}}=\tuple{V\cup V_+, F\cup F_+, E_{\mathrm{ext}}}$. Following the causal ordering algorithm for $\BG, M$ and $\BG_{\mathrm{ext}}, M_{\mathrm{ext}}$, we note that $\G(\BG, M)$ is a subgraph of $\G(\BG_{\mathrm{ext}},M_{\mathrm{ext}})$ and hence clusters in $\mathrm{CO}(\BG)$ are fully contained in clusters in $\mathrm{CO}(\BG_{\mathrm{ext}})$. Therefore ancestral relations in $\mathrm{CO}(\BG)$ are also present in $\mathrm{CO}(\BG_{\mathrm{ext}})$.

It follows directly from the definition \citep{Forre2017} that $\sigma$-connections in a graph remain present if the graph is extended with additional vertices and edges. The directed graphs $\G(\BG, M)$ and $\G(\BG_{\mathrm{ext}},M_{\mathrm{ext}})$ can be augmented with exogenous variables by adding exogenous vertices to these graphs with directed edges towards the equations in which they appear. The $\sigma$-connections in the augmentation of $\G(\BG, M)$ must also be present in the augmentation of $\G(\BG_{\mathrm{ext}},M_{\mathrm{ext}})$. By \citep[Corollary 2.8.4, ][]{Forre2017} and \citep[Lemma~43, ][]{Blom2020} we have that d-connections in $\mathrm{MO}(\BG)$ must also be present in $\mathrm{MO}(\BG_{\mathrm{ext}})$.
\end{proof}

%\preservedcis*
\begin{manualtheorem}{\ref{thm:preserveration of conditional independence relations}}
  Let $F$, $F_+$, $F_{\mathrm{ext}}$, $V$, $V_+$, $V_{\mathrm{ext}}$, $\BG$, $\BG_+$, and $\BG_{\mathrm{ext}}$ be as in Theorem~\ref{thm:preserved causal predictions}. If $\BG$ and $\BG_+$ both have perfect matchings and no vertex in $V_+$ is adjacent to a vertex in $F$ in $\BG_{\mathrm{ext}}$ then:
  \begin{enumerate}
    \item ancestral relations absent in $\mathrm{CO}(\BG)$ are also absent in $\mathrm{CO}(\BG_{\mathrm{ext}})$,
    \item d-connections absent in $\mathrm{MO}(\BG)$ are also absent in $\mathrm{MO}(\BG_{\mathrm{ext}})$.
  \end{enumerate}
\end{manualtheorem}
\begin{proof}
Since $\BG$ and $\BG_+$ both have perfect matchings the results of Theorem~\ref{thm:preserved causal predictions} hold. Let $\G(\BG,M)$, and $\G(\BG_{\mathrm{ext}}, M_{\mathrm{ext}})$ be as in the proof of Theorem~\ref{thm:preserved causal predictions}. Note that in $M_{\mathrm{ext}}$ vertices in $F_+$ are matched to vertices in $V_+$ and therefore edges between $f_+ \in F_+$ and $v\in\adj{\BG_{\mathrm{ext}}}{F_+}\setminus V_+$ are oriented as $(f_+\leftarrow v)$ in $\G(\BG_{\mathrm{ext}}, M_{\mathrm{ext}})$. By assumption, we therefore have that vertices in $V_+$ are non-ancestors of vertices in $V\cup F$ in $\G(\BG_{\mathrm{ext}}, M_{\mathrm{ext}})$. Since $M\subseteq M_{\mathrm{ext}}$ we know that the same directed edges between vertices in $V$ and $F$ appear in both $\G(\BG,M)$ and $\G(\BG_{\mathrm{ext}}, M_{\mathrm{ext}})$. Notice that the subgraph of $\G(\BG_{\mathrm{ext}}, M_{\mathrm{ext}})$ induced by the vertices $V\cup F$ coincides with $\G(\BG,M)$. Hence $\mathrm{CO}(\BG)$ is the induced subgraph of $\mathrm{CO}(\BG_{\mathrm{ext}})$ and $\mathrm{MO}(\BG)$ is the induced subgraph of $\mathrm{MO}(\BG_{\mathrm{ext}})$.
\end{proof}

\begin{lemma}
\label{lemma:selfregulating perfect matching}
Consider a first-order dynamical model in canonical form for endogenous variables $V$ and let $F$ be the equilibrium equations of the model. If all variables in $V$ are self-regulating then $\BG$ has a perfect matching.
\end{lemma}
\begin{proof}
Recall that the equilibrium equation constructed from the derivative of a variable $i$ is labelled $f_i$ according to the natural labelling. When a variable in $v_i\in V$ is self-regulating then it can be matched to its equilibrium equation $f_i$. If this holds for all variables in $V$ then $\BG$ has a perfect matching.
\end{proof}

\begin{lemma}
\label{lemma:uniqueness of directed graph}
Let $\BG$ be a bipartite graph and let $M$ and $M'$ be two distinct perfect matchings. The associated directed graphs $\G(\BG,M)$ and $\G(\BG,M')$ that are obtained in step \ref{alg:step 1} of the causal ordering algorithm differ only in the direction of cycles.
\end{lemma}
\begin{proof}
  This follows directly from the fact that the output of the causal ordering
  algorithm does not depend on the choice of the perfect matching. This result
  is a direct consequence of Theorem 4 and Theorem 6 in \citet{Blom2020}.
\end{proof}

%\feedbackloop*
\begin{manualtheorem}{\ref{thm:feedback}}
Consider a first-order dynamical model in canonical form for endogenous variables $V$ and an extension consisting of canonical first-order differential equations for additional endogenous variables $V_+$. Let $F$ and $F_{\mathrm{ext}}= F\cup F_+$ be the equilibrium equations of the original and extended model respectively. Let $\BG=\tuple{V,F,E}$ be the bipartite graph associated with $F$ and $\BG_{\mathrm{ext}}=\tuple{V_{\mathrm{ext}}, F_{\mathrm{ext}}, E_{\mathrm{ext}}}$ the bipartite graph associated with $F_{\mathrm{ext}}$. Assume that $\BG$ and $\BG_{\mathrm{ext}}$ both have perfect matchings. If the model extension does not introduce a new feedback loop with the original dynamical model, then d-connections in $\mathrm{MO}(\BG)$ are also present in $\mathrm{MO}(\BG_{\mathrm{ext}})$.
\end{manualtheorem}
\begin{proof}
Let $E_{\mathrm{nat}}$ be the set of edges $(v_i-f_i)$ associated with the natural labelling of the equilibrium equations of the extended dynamical model. Note that the feedback loops in the dynamical model coincide with cycles in the directed graph $\G(\BG_{\mathrm{nat}}, M_{\mathrm{nat}})$ that is obtained by applying step \ref{alg:step 1} of the causal ordering algorithm to the bipartite graph $\BG_{\mathrm{nat}}=\tuple{V_{\mathrm{ext}},F_{\mathrm{ext}},E_{\mathrm{ext}}\cup E_{\mathrm{nat}}}$ using the perfect matching $M_{\mathrm{nat}} = E_{\mathrm{nat}}$.

By Theorem~\ref{thm:preserved causal predictions}, we know that if $\BG$ and $\BG_+$ (the subgraph of $\BG_{\mathrm{ext}}$ induced by $V_+\cup F_+$) both have perfect matchings then d-connections in $\mathrm{MO}(\BG)$ must also be present in $\mathrm{MO}(\BG_{\mathrm{ext}})$. Therefore, if there exists a perfect matching $M_{\mathrm{ext}}$ for $\BG_{\mathrm{ext}}$ so that each $f\in F$ is $M_{\mathrm{ext}}$-matched to a vertex $v\in V$ and each $f_+\in F_+$ is $M_{\mathrm{ext}}$-matched to a vertex $v_+\in V_+$ in $\BG_{\mathrm{ext}}$, d-connections in $\mathrm{MO}(\BG)$ are also present in $\mathrm{MO}(\BG_{\mathrm{ext}})$.

We will prove the contrapositive of the theorem, so we start with the assumption that the d-connections in $\mathrm{MO}(\BG)$ are not preserved in $\mathrm{MO}(\BG_{\mathrm{ext}})$. In that case, there must exist a perfect matching $M_{\mathrm{ext}}$ for $\BG_{\mathrm{ext}}$ so that there is an $f\in F$ that is $M_{\mathrm{ext}}$-matched to a $v_+\in V_+$ and a $v\in V$ that is $M_{\mathrm{ext}}$-matched to a $f_+\in F_+$. Note that since $\BG_{\mathrm{ext}}$ is a subgraph of $\BG_{\mathrm{nat}}$, this perfect matching $M_{\mathrm{ext}}$ is also a perfect matching for $\BG_{\mathrm{nat}}$. Lemma~\ref{lemma:uniqueness of directed graph} says that $\G(\BG_{\mathrm{nat}}, M_{\mathrm{nat}})$ and $\G(\BG_{\mathrm{nat}}, M_{\mathrm{ext}})$ only differ in the direction of cycles. We know that vertices in $V$ are only $M_{\mathrm{nat}}$-matched to vertices in $F$, while vertices in $V_+$ are only $M_{\mathrm{nat}}$-matched to vertices in $F_+$. Therefore, the vertices $v_+$ and $f$ must be on a directed cycle in both directed graphs, as well as $v$ and $f_+$. Hence the model extension $F_+$ introduced a new feedback loop that includes variables in the original model.
\end{proof}

\end{document}
