\spaceendsection
\section{Our framework}
\label{sec:framework}
\spacebefsection
We are concerned with describing causal models for growing networks. 
Both of these structures can be interpreted as graphs,
% \footnote{In particular, both the causal model and the growing network can be thought as directed acyclic graphs (DAGs), with the direction of the edges of the growing network given by the node ordering, but this is not necessary and to avoid confusion we think of the growing network as undirected.} 
so to avoid confusion, we refer to the data being generated as the \emphWord{growing network} 
and the causal structure describing its generation as the \emphWord{causal DAG} or \emphWord{meta-DAG}. 
%\footnote{
% % As an aside, 
% \potentiallyRemove{Notice that growing networks can also quite naturally be represented by a DAG, with the direction of the edges given by the node ordering, but this is not necessary and to avoid confusion we think of the growing network as undirected. 
% We also reserve the word ``graph(s)'' 
% to refer exclusively to the causal meta-DAG(s).}} 
%
For instance,  
in Figs.~\ref{Fig:SchemeWithLocalInfluences} and \ref{Fig:SchemeWithNonInfluences} 
the white nodes and black edges represent the growing network and the 
% (colorful) 
% (\colorHub{c}\colorTransitive{o}\colorForward{l}\colorBackward{o}\colorNonLocalExterior{r}\colorNonLocalInterface{f}\colorNonLocalInterior{u}\colorSelfArrow{l})
(\colorHub{c}\colorTransitive{o}\colorForward{l}\colorBackward{o}\colorNonLocalExterior{r}\colorNonLocalInterface{f}\colorNonLocalInterior{u}l) 
arrows between these black edges represent the meta-DAG. 
% Appendix~Figs.~\ref{Fig:ExampleGraphicalModelLocalDirect},~\ref{Fig:ExampleGraphicalModelNonLocalDirect},~and~\ref{Fig:ExampleGraphicalModelLocalDirectSeveral} display several examples of these meta-DAGs. 
\spaceendsection
\subsection{The Growing Network}
\label{sec:GrowingNetworkDescription}
\spacebefsubsection
The \emphWord{nodes} in the growing network are indexed by the natural numbers $\mathbb{N}$ with the standard $\leq$ ordering.   
Intuitively, we can think of the nodes as ``arriving'' in that order, 
and 
% subsequently 
then 
deciding with other nodes to connect to.
We refer to specific node indices with lower-case letters 
(sometimes $i$ and $j$, and sometimes $a$, $b$, $c$, $d$), 
with ordering implied lexicographically.  
Unspecified nodes are represented as open circles $\BoxNodeS{}$, 
with ordering implied by position (such as in \refTypeCausalArrows).  

The random variables in our model are indexed 
%by 2-element subsets of $\mathbb{N}$, representing 
pairs of distinct nodes \dyadpair{i}{j},  
which we refer to as \emphWord{dyad variables}, or simply \emphWord{dyads}.  
%\textit{``dyad variables''}\potentiallyRemove{ or simply as ``dyads''}. 
That is, we take the node ordering of the growing network as given and model distributions over their dyadic connections. 
%%  
While the set of nodes is infinite, 
one can equivalently think of the growing network as a random process defining an infinite 
family of probability distributions 
% (indexed by $n$) 
over the $n \choose 2$ dyad variables between the first $n$ nodes,   
for each \mbox{$n \in \mathbb{N}$}.
The dyads variables could in principle take values from any set of outcomes,  
but in  our example model in Section~\ref{sec:parttwoppa} 
they are binary (for presence or absence of an edge). 
% 
%%%
\spaceendsubsection
\subsection{The Causal Meta-DAG}
\label{ref:TheMetaDAGDescription}
\spacebefsubsection
The  meta-DAG is a directed acyclic graph (DAG) that represents 
the causal relationships between the dyad variables of the growing network 
(see Appendix~\ref{appendix:AppendixMetaDAGS} Figs.~\ref{Fig:ExampleGraphicalModelLocalDirect}, \ref{Fig:ExampleGraphicalModelNonLocalDirect}, and \ref{Fig:ExampleGraphicalModelLocalDirectSeveral} for several examples).
%show examples) 
It refers to the generative model for the growing network. 
%** , 
% which we take to be structural eq
As such, the dyad variables of the growing network
are represented as the 
vertices of the meta-DAG. 
For instance,  
in Figs.~\ref{Fig:SchemeWithLocalInfluences} and \ref{Fig:SchemeWithNonInfluences} 
the white nodes and black edges represent the growing network and the (\colorHub{c}\colorTransitive{o}\colorForward{l}\colorBackward{o}\colorNonLocalExterior{r}\colorNonLocalInterface{f}\colorNonLocalInterior{u}\colorSelfArrow{l}) directed arrows between these black 
edges represent the meta-DAG. 
To avoid confusion, 
we refer to the vertices of the meta-DAG as ``dyads'', 
using 
the word ``nodes'' only to 
refer to the nodes of the growing network. 
%***
% \potentiallyRemove{(\eg, Figs.~\ref{Fig:ExampleGraphicalModelLocalDirect},~\ref{Fig:ExampleGraphicalModelNonLocalDirect},~and~\ref{Fig:ExampleGraphicalModelLocalDirectSeveral}) 
% % Figs.~\ref{Fig:ExampleGraphicalModelLocalDirect},~\ref{Fig:ExampleGraphicalModelNonLocalDirect},~and~\ref{Fig:ExampleGraphicalModelLocalDirectSeveral}
% % %show examples)
% }. % that do not form a cycle.

We refer to these directed edges as \emphWord{causal arrows}.  
% \potentiallyRemove{(defined in \refTypeCausalArrows).}   
A causal arrow \mbox{$\dyadpair{a}{b}\hspace{2pt} \CausalArrow \hspace{2pt}\dyadpair{c}{d}$} from a parent dyad \dyadpair{a}{b} to a child dyad \dyadpair{c}{d} 
indicates that the 
outcome of the parent dyad variable \dyadpair{a}{b} 
% can \textit{affect} 
% can \textit{influence} 
\textit{can affect} 
the outcome of the child dyad \mbox{variable \dyadpair{c}{d}}, 
% but not the other way around; 
whereas the outcome of the child dyad variable \dyadpair{c}{d} \textit{cannot affect} the outcome of the parent dyad variable \dyadpair{a}{b}. 
This is typically phrased in terms of performing interventions on variables, 
such as in the do-calculus of ``hard'' interventions \citep{pearl1994probabilistic}, 
but also applies to various notions of ``soft'' interventions \citep{lorenz2023causal, bravo2024intervention}.  

%
% As an aside, notice that the growing network can also be represented by a DAG, with the direction of the edges given by the node ordering, but this is not necessary and to avoid confusion we think of the growing network as undirected. We also reserve the word ``graph(s)'' to refer exclusively to the causal meta-DAG(s). 
\spaceendsubsection
%%%
\subsection{Invariances of the Causal Meta-DAGs}
\label{ref:InvarianceCausalModel}
\spacebefsubsection
%%%%
% \potentiallyRemove{In addition to being a natural way to define growing network models, 
% another of our motivations}
% One of the motivations 
One of our reasons for defining the nodes to be countably infinite is that 
% it is more natural to state 
our notions of invariance  
and symmetries
({\refTypeCausalArrows}, 
% and 
\Cref{thm:NodeDeletionInvariantCausalModels,thm:21InvariantCausalModels}) 
are more natural to state.

Deleting a node $\BoxNodeS{}$ from the growing network leaves a set of nodes that is isomorphic to the original; 
there is a unique order-preserving map $\varphi$ from the remaining nodes to the original nodes:  
\[\quad \varphi(i) = \begin{cases} i-1 \quad & \text{if}\quad \BoxNodeS{}<i \\ i \quad & \text{if}\quad i<\BoxNodeS{} \\\end{cases} \]
Deleting a node also deletes the dyads containing that node.  
This relabeling induces a map from the remaining dyads to the original dyads:
\vspace{-1pt}
\begin{align*}
    \varphi\big(\dyadpair{i}{j}\big) = \dyadpair{\varphi(i)}{\varphi(j)} 
\end{align*}
Similarly, for each deleted dyad, any causal arrows referencing it (either as a parent or as a child) are also deleted, 
and the relabeling maps the remaining causal arrows:
\begin{align*}
    \varphi\Big(\dyadpair{i}{j}\hspace{1pt} \CausalArrow \hspace{1pt}\dyadpair{k}{l} \Big) = \Big(\varphi\big(\dyadpair{i}{j}\big)\hspace{1pt} \CausalArrow  \hspace{1.2pt} \varphi\big(\dyadpair{k}{l}\big)\Big) 
\end{align*}
A meta-DAG is a set of causal arrows between dyad variables.  We want to classify all meta-DAGs that are invariant to this action of node deletion and relabeling.  
That is, what sets of causal arrows are isomorphic to their image under the map $\varphi$: 
\vspace{-5pt}
\begin{align*}
    \varphi\Big(\big\{\text{causal arrows}\big\} \Big) \cong \big\{\text{causal arrows}\big\} 
\end{align*}
To answer this question, 
note that the only property that is preserved 
by $\varphi$ is the relative ordering of the nodes in the growing network.  
Indeed, if we define a set of causal arrows that makes reference to nodes that are any specific number of steps away 
(such as ``immediate predecessor''), 
deleting nodes changes this property, and the set of causal arrows will not be invariant.  
% **** maybe footnote here about no need of integer arriving times??
% \commentToDo{Homogeneize the use of ``classes'' and ``types'' I think for the 7 arrows we should use type and class for the 21 classes (lol) of meta DAGs.}

With this in mind, consider a generic dyad \dyadpair{i}{j} between two nodes $i<j$.  
There are five ways that an arbitrary node, which we denote by an open circle $\BoxNodeS{}$, 
can relate to the nodes $i$ and $j$:
\def\TempSpacingFirst{\kern1.25em}
\def\TempSpacingSecond{\kern-0.25em}
% \newcommand{\textNodeRelationNode}[1]{\protect{\text{#1}}}
% \newcommand{\textNodeRelationNodeType}[1]{\protect{\text{``#1''}}}
\vspace{-5pt}
\begin{align*}
\vspace{-1pt}
    \renewcommand{\arraystretch}{1.35}
    \begin{array}{crc}
    \BoxNode{} \UnBoxNode{i} \UnBoxNode{} \UnBoxNode{j} \UnBoxNode{} 
  \TempSpacingFirst  & \textNodeRelationNodeType{distant}  \textNodeRelationNode{nodes}\hphantom{\textNodeRelationNode{node}} & \TempSpacingSecond \BoxNodeS{}<i<j\\
    \UnBoxNode{} \BoxNode{i} \UnBoxNode{} \UnBoxNode{j} \UnBoxNode{}
    \TempSpacingFirst  & \textNodeRelationNodeType{past} \textNodeRelationNode{node}\hphantom{\textNodeRelationNode{nodes}} & \TempSpacingSecond \BoxNodeS{}=i<j\\ 
    \UnBoxNode{} \UnBoxNode{i} \BoxNode{} \UnBoxNode{j} \UnBoxNode{}
    \TempSpacingFirst  & \textNodeRelationNodeType{recent} \textNodeRelationNode{nodes}\hphantom{\textNodeRelationNode{node}} & \TempSpacingSecond  i<\BoxNodeS{}<j\\  
    \UnBoxNode{} \UnBoxNode{i} \UnBoxNode{} \BoxNode{j} \UnBoxNode{}
    \TempSpacingFirst  & \textNodeRelationNodeType{current} \textNodeRelationNode{node}\hphantom{\textNodeRelationNode{nodes}}  & \TempSpacingSecond  i<\BoxNodeS{}=j\\
    \UnBoxNode{} \UnBoxNode{i} \UnBoxNode{} \UnBoxNode{j} \BoxNode{}
   \TempSpacingFirst  & \textNodeRelationNodeType{future} \textNodeRelationNode{nodes}\hphantom{\textNodeRelationNode{node}}  & \TempSpacingSecond i<j<\BoxNodeS{}
   \end{array}
    \vspace{-8pt}
\end{align*}
% Notice 
Note that the set of ``future'' nodes is infinite, 
whereas the other four sets of node types are finite (with two of them having a single element). 

% % \def\DyadPairCircleNodes{(\BoxNodeS{}\kern-0.5pt,\kern-1.5pt\BoxNodeS{})}
% \def\DyadPairCircleNodes{\dyadpair{\BoxNodeS{}}{\BoxNodeS{}}}
To enumerate the relationships between \textit{dyads}, 
\ie, pairs of nodes,
consider all the ways that \textit{two} arbitrary nodes can relate to \dyadpair{i}{j}.  
These two arbitrary nodes denote the parent dyad with a causal arrow to the child dyad: \mbox{$\DyadPairCircleNodes\hspace{2pt} \CausalArrow \hspace{2pt}\dyadpair{i}{j}$}.  
% Now, to consider all possible ways that causal arrows that point to dyad \dyadpair{i}{j}, 
% we consider all the ways that \textit{two} arbitrary nodes %\dyadpair{\BoxNodeOneS{}}{\BoxNodeTwoS{}}
% relate to the nodes $i$ and $j$.  
There are 12 types of deletion-invariant causal arrows\footnote{Plus the identity arrow from a dyad to itself makes 13.} in total. 
% , which we enumerate in Appendix~\ref{appendix:enumeration}.  
However, 5 of those options contain  ``future'' node(s) in the parent dyad, 
leading to a causal meta-DAG in which child dyads have infinitely many parents.

% **** make distinction one or two nodes and explain resampling???
% However, in 
% 5 of those options the parent dyad 
% contain  ``future'' node(s) in the parent dyad, 
% leading to a causal DAG in which child dyads have infinitely many parents.  
% **** maybe footnote explaining more the resempalng 
% This makes sampling from the distribution considerably more involved,
% %\footnote{One would need to resample the entire network every time a new node is added.} 
% so here we restrict our attention to those with finite ancestral sets. 
% % \citep{peters2021causal}
To a 
avoid issues associated with infinitely many variables we require that 
% all the dyad variables on 
our 
%causal models 
causal meta-DAGs
have finite ancestral sets, 
where an ancestral set contains the parents of all variables in the set \citep{lauritzen1996graphical}.  
% Thereby, we exclude these 5 options containing ``future'' nodes in the parent dyad. 
Thereby, we exclude these 5 options in which the parent dyad has at least one ``future'' node.
% This ensures that the resulting distribution is unique \citep{peters2021causal}, and makes the model straightforward to sample from.
This ensures that the probability distribution resulting from a model following one such causal meta-DAG   
is unique \citep{peters2021causal}, 
and  also makes the model straightforward to sample from.
% **** potentially talk about the sampling of the other one more, and faithfulness and bla

The remaining 7 types of arrows (defined in \refTypeCausalArrows) constitute the choices one has for constructing deletion-invariant 
meta-DAGs with finite ancestral sets; 
including any causal arrow of a given type requires one to include \textit{all} arrows of that type. 
\vspace{-6pt}
\def\KernTemp{\kern-0.15cm}
\def\KernTempRight{\kern1em}
\def\KernTempSpaceOne{\kern-0.1cm}
\def\KernTempSpaceTwo{\kern-0.0cm}
\def\PreHorizontalLineGap{-9pt}
\def\HorizontalLineTemp{\kern-0.2cm\rule{8cm}{1pt}\kern-8cm\\[-4pt]}
\renewcommand{\arraystretch}{1.35}
\begin{table}[ht]
  \centering
  \begin{tabular}{l l l}
    % Row 1
    % \vspace{-0.2cm}
    \HorizontalLineTemp
    \KernTemp\UnBoxNode{} \UnBoxNode{} \BoxNodeOne{i} \BoxNodeTwo{} \UnBoxNode{} \UnBoxNode{j} \UnBoxNode{} \UnBoxNode{} &       \KernTempSpaceOne\colorHub{\hub} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{a}{b}}
      \mathmakebox[24pt][c]{\CausalArrowColor{HubColor}} 
      \mathmakebox[24pt][l]{\dyadpair{a}{c}}\KernTempRight$ \\
    % Row 2
    \KernTemp\BoxNodeOne{} \UnBoxNode{} \BoxNodeTwo{i} \UnBoxNode{} \UnBoxNode{} \UnBoxNode{j} \UnBoxNode{} \UnBoxNode{} &
      \KernTempSpaceOne\colorTransitive{\transitive} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{a}{b}}
      \mathmakebox[24pt][c]{\CausalArrowColor{TransitiveColor}}
      \mathmakebox[24pt][l]{\dyadpair{b}{c}}\KernTempRight$ \\
    % Row 3
    \KernTemp\BoxNodeOne{} \UnBoxNode{} \UnBoxNode{i} \UnBoxNode{} \UnBoxNode{} \BoxNodeTwo{j} \UnBoxNode{} \UnBoxNode{} & 
      \KernTempSpaceOne\colorForward{\forward} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{a}{c}} 
      \mathmakebox[24pt][c]{\CausalArrowColor{ForwardColor}}
      \mathmakebox[24pt][l]{\dyadpair{b}{c}}\KernTempRight$ \\
    % Row 4
    \KernTemp\UnBoxNode{} \UnBoxNode{} \UnBoxNode{i} \BoxNodeOne{} \UnBoxNode{} \BoxNodeTwo{j} \UnBoxNode{} \UnBoxNode{} & 
      \KernTempSpaceOne\colorBackward{\backward} & 
      \KernTempSpaceTwo\kern6pt  
      $\mathmakebox[24pt][r]{\dyadpair{b}{c}}
      \mathmakebox[24pt][c]{\CausalArrowColor{BackwardColor}}
      \mathmakebox[24pt][l]{\dyadpair{a}{c}}\KernTempRight$ \\[\PreHorizontalLineGap]
    \HorizontalLineTemp
    % Row 5
    \KernTemp\BoxNodeOne{} \BoxNodeTwo{} \UnBoxNode{i} \UnBoxNode{} \UnBoxNode{} \UnBoxNode{j} \UnBoxNode{} \UnBoxNode{} & 
      \KernTempSpaceOne\colorNonLocalExterior{\nonLocalExterior} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{a}{b}}
      \mathmakebox[24pt][c]{\CausalArrowColor{NonLocalExteriorColor}}
      \mathmakebox[24pt][l]{\dyadpair{c}{d}}\KernTempRight$ \\
    % Row 6
    \KernTemp\BoxNodeOne{} \UnBoxNode{} \UnBoxNode{i} \BoxNodeTwo{} \UnBoxNode{} \UnBoxNode{j} \UnBoxNode{} \UnBoxNode{}  & 
      \KernTempSpaceOne\colorNonLocalInterface{\nonLocalInterface} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{a}{c}}
      \mathmakebox[24pt][c]{\CausalArrowColor{NonLocalInterfaceColor}}
      \mathmakebox[24pt][l]{\dyadpair{b}{d}}\KernTempRight$ \\
    % Row 7
    \KernTemp\UnBoxNode{} \UnBoxNode{} \UnBoxNode{i} \BoxNodeOne{} \BoxNodeTwo{} \UnBoxNode{j} \UnBoxNode{} \UnBoxNode{} & 
      \KernTempSpaceOne\colorNonLocalInterior{\nonLocalInterior} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{b}{c}}
      \mathmakebox[24pt][c]{\CausalArrowColor{NonLocalInteriorColor}}
      \mathmakebox[24pt][l]{\dyadpair{a}{d}}\KernTempRight$ \\[\PreHorizontalLineGap]
    \HorizontalLineTemp
    % Row 8
    \KernTemp\UnBoxNode{} \UnBoxNode{} \BoxNodeOne{i} \UnBoxNode{} \UnBoxNode{} \BoxNodeTwo{j} \UnBoxNode{} \UnBoxNode{} & 
      \KernTempSpaceOne\colorSelfArrow{\selfArrow} & 
      \KernTempSpaceTwo\kern6pt 
      $\mathmakebox[24pt][r]{\dyadpair{a}{b}}
      \mathmakebox[24pt][c]{\CausalArrowColor{SelfArrowColor}}
      \mathmakebox[24pt][l]{\dyadpair{a}{b}}\KernTempRight$ \\[\PreHorizontalLineGap]
    \HorizontalLineTemp
  \end{tabular}
  \caption{\textbf{The seven types of deletion-invariant  causal arrows with finite ancestral sets.} %\\
  The \textit{left} column represents the relative ordering of the parent dyad 
  {\protect\DyadPairCircleNodes} 
  % {\protect\dyadpair{\protect\BoxNodeS{}}{\protect\BoxNodeS{}}}
  and the child dyad {\protect\dyadpair{i}{j}}. 
  %   \textit{Left column:} column represents the relative ordering of the parent dyad 
  % {\protect\DyadPairCircleNodes} 
  % {\protect\dyadpair{\protect\BoxNodeS{}}{\protect\BoxNodeS{}}}
  and the child dyad {\protect\dyadpair{i}{j}}. 
 % (also illustrated in Figs.~\ref{Fig:SchemeWithLocalInfluences}~and~\ref{Fig:SchemeWithNonInfluences}).  
The \textit{middle} column are the names we have given to each type of causal arrow.  
 The \textit{right} column shows the causal arrows from the parent dyad to the child dyad in terms of lexicographic node indices \mbox{$a<b<c<d$}.  
 See Figs.~\ref{Fig:SchemeWithLocalInfluences}~and~\ref{Fig:SchemeWithNonInfluences} for the  representation of the causal arrows in the growing network and Appendix~\ref{appendix:AppendixMetaDAGS}   Figs.~\ref{Fig:ExampleGraphicalModelLocalDirect}~and~\ref{Fig:ExampleGraphicalModelNonLocalDirect}
 for their representation in the causal meta-DAGs. 
  }
  \label{Def:TypesOfCausalArrows}
\end{table}
\vspace{-10pt}
\spaceendsubsection
\subsection{Seven Types of Causal Arrows}
\label{sec:typesofcausalarrows}
\spacebefsubsubsection
% \potentiallyImproveN{
% To get an intuition for these 7 classes of causal arrows, 
% we will use networks of references as examples. % a running example.  
% For instance, the nodes could represent publications, 
% and the dyads citations. 
% Recall that the variables in our growing network models are the dyads; 
% % aside from their total ordering relation,  (which we take as given),
% the nodes have no intrinsic properties other than their (relative ordering and) dyadic relationships with other nodes. % 
% % Taking it literally, 
% For a citation network, 
% this would mean that decisions about which publications to cite 
% are based solely on properties of the bibliographic network so far,  
% and not explicitly on the publications themselves. % (the nodes) 
% However, abstracting the notions of publication and citation 
% to include things like ``words/concepts/people'' and ``usage/reference/ideologies'',
% it is not unreasonable to view the content of such ``generalized publications'' as 
% essentially encoded in the structure of their relationships.}\footnote{
%     % This ``relation-centric'' viewpoint follows the spirit of category theory.  
%     % %\cite{cheng2022joy,riehl2017category}. 
%     % To wit, here is how \citet{mazur2008one} describes one of its essential tenets: 
%     % \textit{``Mathematical objects are determined by---and understood by---the network of relationships they enjoy with all the other objects of their species.''} 
%     This ``relation-centric'' perspective appears across many fields of mathematics.  
%     %\cite{cheng2022joy,riehl2017category}. 
%     % To wit, 
%     To quote \citet{mazur2008one} on an essential tenet of category theory: 
%     \textit{``Mathematical objects are determined by---and understood by---the network of relationships they enjoy with all the other objects of their species.''} 
% }
% To get an intuition for these 7 classes of causal arrows, 
% we will use networks of references as examples. % a running example.  
% For instance, the nodes could represent publications, 
% and the dyads citations. 
Recall that the variables in our growing network models are the dyads; 
% aside from their total ordering relation,  (which we take as given),
the nodes have no intrinsic properties other than their (relative ordering and) dyadic relationships with other nodes. % 
% Taking it literally, 
At face value, this might appear overly simplistic.   
For example, in a growing network of citations between publications, 
this would mean that decisions about which publications to cite 
are determined solely by their interconnected bibliographies, 
and not explicitly on their content or quality. % (the nodes) 
However, abstracting the notions of publication and citation 
to include notions like ``words/concepts/people'' and ``usage/reference/ideologies'',
it is not unreasonable to think of the content of such objects as 
encoded in the \potentiallyImproveN{structure of what they reference.}\footnote{
    % This ``relation-centric'' viewpoint follows the spirit of category theory.  
    % %\cite{cheng2022joy,riehl2017category}. 
    % To wit, here is how \citet{mazur2008one} describes one of its essential tenets: 
    % \textit{``Mathematical objects are determined by---and understood by---the network of relationships they enjoy with all the other objects of their species.''} 
    This 
    % ``relation-centric'' 
    relation-centric  
    perspective appears across many fields of mathematics.  
    %\cite{cheng2022joy,riehl2017category}. 
    % To wit, 
    To quote \citet{mazur2008one} on an essential tenet of category theory: 
    \textit{``Mathematical objects are determined by---and understood by---the network of relationships they enjoy with all the other objects of their species.''} 
}
\spaceendsection
% \subsubsection{Arrows between dyads that share a node.} 
\subsubsection{Arrows Between Dyads Sharing a Node} 
\label{sec:localcausalarrows}
\spacebefsubsection
% \paragraph{Arrows between dyads that share a node} 
The first four types of causal arrows in {\refTypeCausalArrows} are %{\hub}, {\transitive}, {\forward}, and  {\backward}.  
% These causal arrows are 
from a parent dyad to a child dyad that have a node in common. 
Fig.~\ref{Fig:SchemeWithLocalInfluences} displays these relations in the growing network, and  Appendix~\ref{appendix:AppendixMetaDAGS} Fig.~\ref{Fig:ExampleGraphicalModelLocalDirect} shows their associated causal \mbox{meta-DAGs}. 
% \vspace{-10pt}
\begin{figure}[h] %[H]
\begin{tikzpicture}
    \newcommand{\LocLength}{1.75}
    \newcommand{\LocCosAngle}{0.92387953251} 
    \newcommand{\LocSinAngle}{0.38268343236} 
    \newcommand{\LocCosAngleTwo}{0.70710678118} 
    \newcommand{\TopNodeY}{3.0}
    \newcommand{\TopNodeX}{\TopNodeY*\LocSinAngle/\LocCosAngle}
    % \newcommand{\LeftDashedLength}{2.2}
    % \newcommand{\RightDashedLength}{2.4}
    \newcommand{\LeftDashedLength}{3.0}
    \newcommand{\RightDashedLength}{5.0}
    \newcommand{\NewEdgeThickness}{2pt}
    \newcommand{\NewNodeSize}{13pt}
    \newcommand{\OtherEdgeThickness}{1pt}
    \newcommand{\DottedThickness}{1pt}
    \newcommand{\CausalThickness}{1pt}
    \newcommand{\OtherNodeSize}{12pt}
    \newcommand{\NodeBorderThickness}{1pt}
    % Draw the vertical arrow
    \draw[line width=\NewEdgeThickness] (0,0) -- (\TopNodeX,\TopNodeY);
    % Draw the horizontal dashed lines
    % \draw[line width=\DottedThickness,dotted] (-\LeftDashedLength+1.25,0) -- (\RightDashedLength+2,0); % bottom dashed line
    \draw[line width=\DottedThickness,dotted] (-\LeftDashedLength,0) -- (\RightDashedLength,0); % bottom dashed line
    % \draw[line width=\DottedThickness,dotted] (-\LeftDashedLength-1.25,\TopNodeY) -- (\RightDashedLength,\TopNodeY); % top dashed line
    \draw[line width=\DottedThickness,dotted] (-\LeftDashedLength,\TopNodeY) -- (\RightDashedLength,\TopNodeY); % top dashed line
    % Add text labels
    % \node[right] at (\RightDashedLength,0) {``current'' node}; % label for bottom node
    % \node[left] at (-\LeftDashedLength+1.25,0) {``current'' node}; % label for bottom node
    % \node[right] at (\RightDashedLength,\TopNodeY) {``past'' node}; % label for top node
    \node[right, anchor=west,fill=white,draw=none] at (-\LeftDashedLength,0) {``current'' node}; % label for bottom node
    \node[right, anchor=east,fill=white,draw=none] at (\RightDashedLength,\TopNodeY) {``past'' node}; % label for top node
    % Add tilted text labels
    \newcommand{\TiltedOffsetX}{-0.5}
    \newcommand{\TiltedOffsetY}{-0.5}
    % \node [label={[rotate=45,align=center]``recent''\\nodes}] at (-\LeftDashedLength+\TiltedOffsetX,\TopNodeY/2+\TiltedOffsetY) {};% label for recent nodes
      % \node [label={[rotate=22.5,align=center]``recent''\\nodes $<j$ and $>i$}] at 
    \node [label={[rotate=0,align=center]``recent'' nodes\\ \mbox{$i<\BoxNodeS{}<j$}}] at (\RightDashedLength-1.8,\TopNodeY/2-1.5) {};% label for recent nodes
    \node [label={[rotate=0,align=center]``distant'' nodes\\ \mbox{$\BoxNodeS{}<i<j$}}] at (-\LeftDashedLength+2.0,\TopNodeY*3/2-0.5) {};% label for distant nodes
    % Arched colored arrows
    \newcommand{\CausalRadius}{\LocLength/2}
    \draw[color=BackwardColor,line width=\CausalThickness, -latex] (\CausalRadius*\LocCosAngle,\CausalRadius*\LocSinAngle) arc (22.5:67.5:\CausalRadius);
    \node [label={[rotate=-22.5,anchor=south west]\NewName},inner sep=0] at (\CausalRadius*\LocSinAngle,\CausalRadius*\LocCosAngle) {};
    \draw[color=ForwardColor,line width=\CausalThickness, -latex] (-\CausalRadius*\LocSinAngle,\CausalRadius*\LocCosAngle) arc (90+22.5:90-22.5:\CausalRadius);
    \node [label={[rotate=-22.5,align=center,anchor=south east]\OldName},inner sep=0] at (\CausalRadius*\LocSinAngle,\CausalRadius*\LocCosAngle) {};
    \draw[color=HubColor,line width=\CausalThickness, -latex] (\TopNodeX+\CausalRadius*\LocSinAngle,\TopNodeY-\CausalRadius*\LocCosAngle) arc (-90+22.5:-90-22.5:\CausalRadius);
    \node [label={[rotate=-22.5,align=center,anchor=north west]\HubName},inner sep=0] at (\TopNodeX-\CausalRadius*\LocSinAngle,\TopNodeY-\CausalRadius*\LocCosAngle) {};
    \draw[color=TransitiveColor,line width=\CausalThickness, -latex] (\TopNodeX-\CausalRadius*\LocSinAngle,\TopNodeY+\CausalRadius*\LocCosAngle) arc (90+22.5:270-22.5:\CausalRadius);
    \node [label={[rotate=-22.5,align=center,anchor=north east]\PathName},inner sep=0] at (\TopNodeX-\CausalRadius*\LocSinAngle,\TopNodeY-\CausalRadius*\LocCosAngle) {};
    %% other black arrows
    % oldest first
    \draw[line width=\OtherEdgeThickness] (0,0) -- (-2.4*\LocLength*\LocSinAngle,2.4*\LocLength*\LocCosAngle);
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (-2.4*\LocLength*\LocSinAngle,2.4*\LocLength*\LocCosAngle) {};
    % \filldraw [black] (-2.4*\LocLength*\LocSinAngle,2.4*\LocLength*\LocCosAngle) circle (\OtherNodeSize); 
    % transitive arrow
    \draw[line width=\OtherEdgeThickness] (\TopNodeX,\TopNodeY) -- (\TopNodeX-\LocLength*\LocSinAngle,\TopNodeY+\LocLength*\LocCosAngle);
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\TopNodeX-\LocLength*\LocSinAngle,\TopNodeY+\LocLength*\LocCosAngle) {};
    % hub arrow
    \draw[line width=\OtherEdgeThickness] (\TopNodeX+\LocLength*\LocSinAngle,\TopNodeY-\LocLength*\LocCosAngle) -- (\TopNodeX,\TopNodeY);
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\TopNodeX+\LocLength*\LocSinAngle,\TopNodeY-\LocLength*\LocCosAngle) {};
    % oldest last
    \draw[line width=\OtherEdgeThickness] (0,0) -- (\LocLength*\LocCosAngle,\LocLength*\LocSinAngle);
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\LocLength*\LocCosAngle,\LocLength*\LocSinAngle) {};
    % Draw the nodes as black circles
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (0,0) {$\boldsymbol{j}$}; % bottom node
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\TopNodeX,\TopNodeY) {$\boldsymbol{i}$}; % bottom node
    % \filldraw [fill=white, draw=black] (\TopNodeX,\TopNodeY) circle (\NewNodeSize){$i$}; % top node
%
    % %FIXING HEIGHT TO BE THE SAME AS NONLOCAL
    % \newcommand{\NonLocSpacing}{0.6}
    % \newcommand{\NonLocMidX}{-0.0}%{-1.89264068712}%-\LeftDashedLength+\NonLocSpacing+0.75
    % \newcommand{\NonLocMidY}{3.0}%\TopNodeY-0.25
    % \newcommand{\NonLocLengthY}{\LocLength}
    % %FIXING HEIGHT TO BE THE SAME AS NONLOCAL
    % \node [fill=white, draw=white, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX+\NonLocSpacing,\NonLocMidY+\NonLocSpacing*\LocCosAngle/\LocSinAngle + \NonLocLengthY/2) { };
\end{tikzpicture}
\caption{
\textbf{Types of causal arrows between dyads that share a node.}
% \textit{Left:} \textbf{Schema of how dyads sharing a node with the dyad being currently added (thicker black arrow) can influence the decision.}
\potentiallyImproveN{The black edges represent the dyads of the growing network and colors represent different types of causal arrows between them.}   
%
% colors represent different classes of causal arrows between them.  
% colored arrows represent cl between them.  
%to the directed arrows of the causal meta-DAG, which has the growing network's dyads as vertices. 
% The nodes are ordered in two regions with respect to the dyad being added: 
% the ``recent'' nodes region, comprise of the nodes that are younger than the ``past'' node that the current dyad is connecting; 
% and the ``distant'' nodes region, comprised of the nodes that are older than this ``past'' node.  
% But, with respect to this dyad, the ordering of the nodes within the two regions is not important.  
}
\label{Fig:SchemeWithLocalInfluences}
\end{figure}

% The {\hub} causal arrows refer to which nodes connect to the target node, 
% {\transitive} arrows refer to which nodes the target node connected to. 
The {\hub} causal arrows 
mediate the tendency to reference a past concept 
due to how others have referenced it since then   
(\eg, citing a seminal paper).   

The {\transitive} causal arrows mediate the tendency to reference a concept 
due to the earlier concepts that it referenced  
(\eg, citing a paper due to its remarkable bibliography). 
% These arrows are closely related to the {\hub} arrows. 
% They mediate the tendency to reference a concept because of the previous things that concept itself referenced. 
% This may be a case of citing a publication due to its remarkable bibliography, 
% or talking about someone because of what they chose to talk about. 
% Thus, while {\hub} arrows consider what other nodes connected to the target node, 
% {\hub} arrows consider what nodes the target node connected to.
% Thus arrows are closely related to the {\hub} arrows: 

% Thus, while {\hub} arrows refer to which nodes connect to the target node, 
% {\transitive} arrows refer to which nodes the target node connected to. 
% If one uses the ordering of the nodes to orient the edges of the growing network, 
% {\hub} arrows refer to the \mbox{in-degree} 
% of the node $\BoxNodeS{}$ of the dyad \mbox{\dyadpair{\BoxNodeS{}}{j}} being decided 
% (\ie, dyads of the type \mbox{\dyadpair{\BoxNodeS{}}{i}}, where \mbox{$\BoxNodeS{}<i$}). 
% Whereas {\transitive} arrows refer to the \mbox{out-degree} of the node $\BoxNodeS{}$ 
% (\ie, dyads of the type \mbox{\dyadpair{i}{\BoxNodeS{}}}, where \mbox{$i<\BoxNodeS{}$}).  
% These {\hub} and {\transitive} are very natural causal arrows; 
% in fact, they are the ones we have in our example network model in 
% Section~\ref{sec:parttwoppa}. 
% (A representation of the causal meta-DAG for {\hub} and {\transitive} is shown at the top-left of Fig.~\ref{Fig:ExampleGraphicalModelLocalDirectSeveral}.)

% 
% corresponds to the decision of the arriving node 
% to connect to a given previous node being influenced by 
% the connections of this node to other nodes 
% (the publications that this publication cited). %*** maybe something like deciding to be friends/connect with someone based on who they decided to be friends with 
% Thus, {\transitive} describes the influence of older dyads on newer dyads when the newer node of the older dyad is the same as the older node of the newer dyad. % can influence each other. 
% while {\transitive} corresponds to this decision being influence by 
% the connections of this node to other nodes. 
% Note that since both the {\hub} and the {\transitive} influences have a clear direction, 
% they must correspond to directed edges in the graphical model. 
% Since both of the {\hub} and the {\transitive} influences have a clear direction, they must correspond to directed edges in the graphical model.


The {\OldName} and {\NewName} causal arrows describe 
two ways in which one could sequentially decide which previous concepts to reference.  
A publication deciding what to cite using {\OldName} would do so chronologically,
making decisions about the oldest publications first, 
and allowing those choices to modulate its decisions about which recent publications to cite as well.  
Using {\NewName} is exactly the reverse; 
a publication begins by deciding which recent references to cite, 
and allowing these choices to modulate its decisions about older publications.  

Realistically, bibliographies are assembled more holistically, 
requiring both {\OldName} and {\NewName} causal influences.  
But since these causal arrows point in opposite directions, 
they cannot both be included in a causal meta-DAG  
as they would introduce cycles.  
However, in \Cref{sec:DorPAModel}, 
we describe a way to include both {\OldName} and {\NewName} causal arrows 
%\textit{without} creating cycles, 
% by unrolling the sequence of events generating the dyad variables
by using structural equations %for the dyad variables 
that can be unrolled into an asynchronous generative process.  
 % It is however relatively straightforward to incorporate them both in a ``multi-pass'' causal meta-DAG (see Section~\ref{sec:extensions}).  
% Note that these two orderings of the previous dyads (\ie, older to younger and younger to older) are the only orderings that make reference only to the relative ordering of the nodes in growing the network (and thereby that leave the causal meta-DAG invariant to deleting nodes of the network). ***** 
\spaceendsubsection
% \subsubsection{Arrows between dyads that share a node.} 
\subsubsection{Arrows between Dyads Not Sharing a Node} 
\label{sec:nonlocalcausalarrows}
\spacebefsubsection
% \paragraph{Causal arrows between dyads that do not share nodes.} 
% The remaining three  causal influences in Def.~\ref{def:seveninfluences} --- {\nonLocalExterior}, {\nonLocalInterface}, and  {\nonLocalInterior}  (\cref{eq:nonlocalinterior,eq:nonlocalinterface,eq:nonlocalexterior}) 
The next three types of causal arrows in {\refTypeCausalArrows} %are {\nonLocalInterior}, {\nonLocalInterface}, and {\nonLocalExterior}.   
% These causal arrows  *****
are from a parent dyad to a child dyad with \textit{no} nodes in common. 
% (see schema in Fig.~\ref{Fig:SchemeWithNonInfluences}) 
% (\cref{eq:hub,eq:transitive,eq:backward,eq:forward}) 
 % refer to how dyads that do not share a node can influence each other.  
% These are causal arrows from parent dyads to child dyads that do \textit{not share a node} with the child dyad.  ****
Fig.~\ref{Fig:SchemeWithNonInfluences} displays these relations in the growing network, and  Appendix~\ref{appendix:AppendixMetaDAGS} Fig.~\ref{Fig:ExampleGraphicalModelNonLocalDirect} shows their associated meta-DAGs. 
% associated with each of these types of causal arrows. %  in a (growing) network with five nodes.  
% Fig.~\ref{Fig:ExampleGraphicalModelNonLocalDirect} shows the causal DAG induced by each of these types of causal arrows in a (growing) network with five nodes. 
% are a bit less intuitive, %/natural as in general (at least classically) things need to be connected to affect each other.
% Still, intuitively, 
% but can interpreted as a sort of ``context''. 
\begin{figure}[h]
\begin{tikzpicture}
    \newcommand{\LocLength}{1.75}
    \newcommand{\LocCosAngle}{0.92387953251} %angle=22.5deg
    \newcommand{\LocSinAngle}{0.38268343236} 
    \newcommand{\LocCosAngleTwo}{0.70710678118} 
    \newcommand{\TopNodeY}{3.0}
    \newcommand{\TopNodeX}{2.2426406871}%{1+\TopNodeY*\LocSinAngle/\LocCosAngle}
    \newcommand{\LeftDashedLength}{3.0}
    \newcommand{\RightDashedLength}{5.0}
    \newcommand{\NewEdgeThickness}{2pt}
    \newcommand{\NewNodeSize}{13pt}
    \newcommand{\OtherEdgeThickness}{1pt}
    \newcommand{\DottedThickness}{1pt}
    \newcommand{\CausalThickness}{1pt}
    \newcommand{\OtherNodeSize}{12pt}
    \newcommand{\NodeBorderThickness}{1pt}
    
    \newcommand{\BottomNodeX}{1.0}

    \newcommand{\NonLocSpacing}{0.6}
    \newcommand{\NonLocMidX}{-0.0}%{-1.89264068712}%-\LeftDashedLength+\NonLocSpacing+0.75
    \newcommand{\NonLocMidY}{3.0}%\TopNodeY-0.25
    \newcommand{\NonLocLengthY}{\LocLength}

    % Draw the vertical arrow
    \draw[line width=\NewEdgeThickness] (\BottomNodeX,0) -- (\TopNodeX,\TopNodeY);
    % Draw the horizontal dashed lines
    \draw[line width=\OtherEdgeThickness,dotted] (-\LeftDashedLength,0) -- (\RightDashedLength,0); % bottom dashed line
    \draw[line width=\OtherEdgeThickness,dotted] (-\LeftDashedLength,\TopNodeY) -- (\RightDashedLength,\TopNodeY); % top dashed line
    % Add text labels
    \node[right, anchor=east,fill=white,draw=none] at (\RightDashedLength,0) {``current'' node}; % label for bottom node
    \node[right, anchor=east,fill=white,draw=none] at (\RightDashedLength,\TopNodeY) {``past'' node}; % label for top node
    % Add tilted text labels
    \newcommand{\TiltedOffsetX}{-0.5}
    \newcommand{\TiltedOffsetY}{-0.5}
    \node [label={[rotate=0,align=center]``recent'' nodes\\ \mbox{$i<\BoxNodeS{}<j$}}] at (-\LeftDashedLength+1.1,\TopNodeY/2-0.6) {};% label for recent nodes
    \node [label={[rotate=0,align=center]``distant'' nodes\\ \mbox{$\BoxNodeS{}<i<j$}}] at (-\LeftDashedLength+1.1+\NonLocSpacing,\TopNodeY*3/2-0.6) {};% label for distant nodes
    %% other black arrows
    % nonlocal

    \draw[color=NonLocalInteriorColor,line width=\OtherEdgeThickness, -latex] (\NonLocMidX-\NonLocSpacing,\NonLocMidY-\NonLocSpacing*\LocCosAngle/\LocSinAngle) -- (\BottomNodeX*3/4+\TopNodeX/4,\NonLocMidY/4);
    \node [label={[rotate=-23.5,align=center,anchor=south,inner sep=0]\NearName}] at (\NonLocMidX/2-\NonLocSpacing/2+\TopNodeX*1/4/2+\BottomNodeX*2/4/2,\NonLocMidY/2-\NonLocSpacing*\LocCosAngle/\LocSinAngle/2 + \NonLocMidY/8) {};
    \draw[line width=\OtherEdgeThickness] (\NonLocMidX-\NonLocSpacing,\NonLocMidY-\NonLocSpacing*\LocCosAngle/\LocSinAngle - \NonLocLengthY/2) -- (\NonLocMidX-\NonLocSpacing,\NonLocMidY-\NonLocSpacing*\LocCosAngle/\LocSinAngle + \NonLocLengthY/2);% nonlocal interior
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX-\NonLocSpacing,\NonLocMidY-\NonLocSpacing*\LocCosAngle/\LocSinAngle - \NonLocLengthY/2) { };
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX-\NonLocSpacing,\NonLocMidY-\NonLocSpacing*\LocCosAngle/\LocSinAngle + \NonLocLengthY/2) { };


    \draw[color=NonLocalInterfaceColor,line width=\OtherEdgeThickness, -latex] (\NonLocMidX,\NonLocMidY) -- (\BottomNodeX*1/2+\TopNodeX/2,\NonLocMidY/2);
    \node [label={[rotate=-44.5,align=center,anchor=south,inner sep=0]\MidName}] at (\NonLocMidX/2+\TopNodeX*2/4/2+\BottomNodeX*2/4/2,\NonLocMidY/2+\NonLocMidY/4) {};
    \draw[line width=\OtherEdgeThickness] (\NonLocMidX,\NonLocMidY-\NonLocLengthY/2) -- (\NonLocMidX,\NonLocMidY+\NonLocLengthY/2); % nonlocal middle arrow
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX,\NonLocMidY-\NonLocLengthY/2) { };
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX,\NonLocMidY+\NonLocLengthY/2) { };

    \draw[color=NonLocalExteriorColor,line width=\OtherEdgeThickness, -latex] (\NonLocMidX+\NonLocSpacing,\NonLocMidY+\NonLocSpacing*\LocCosAngle/\LocSinAngle) -- (\BottomNodeX*1/4+\TopNodeX*3/4,\NonLocMidY*3/4);
    \node [label={[rotate=-58,align=center,anchor=south,inner sep=0]\FarName}] at (\NonLocMidX/2+\NonLocSpacing/2+\TopNodeX*3/4/2+\BottomNodeX*1/4/2,\NonLocMidY/2+\NonLocSpacing*\LocCosAngle/\LocSinAngle/2+\NonLocMidY*3/4/2) {};
    \draw[line width=\OtherEdgeThickness] (\NonLocMidX+\NonLocSpacing,\NonLocMidY+\NonLocSpacing*\LocCosAngle/\LocSinAngle - \NonLocLengthY/2) -- (\NonLocMidX+\NonLocSpacing,\NonLocMidY+\NonLocSpacing*\LocCosAngle/\LocSinAngle + \NonLocLengthY/2);% nonlocal exterior arrow
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX+\NonLocSpacing,\NonLocMidY+\NonLocSpacing*\LocCosAngle/\LocSinAngle - \NonLocLengthY/2) { };
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\NonLocMidX+\NonLocSpacing,\NonLocMidY+\NonLocSpacing*\LocCosAngle/\LocSinAngle + \NonLocLengthY/2) { };

    % Draw the nodes as black circles
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\BottomNodeX,0) {$\boldsymbol{j}$};
    \node [fill=white, draw=black, circle, minimum size=\NewNodeSize, inner sep=0, line width=\NodeBorderThickness] at (\TopNodeX,\TopNodeY) {$\boldsymbol{i}$};

\end{tikzpicture}
% \vspace{1pt}
\caption{\textbf{Types of causal arrows between dyads that do not share a node.}  Horizontal dashed lines indicate the relative ordering of the nodes in the parent dyad ${\protect\DyadPairCircleNodes}$ with respect to the nodes in the child dyad $\dyadpair{i}{j}$.
% \textit{Right:} 
% \textbf{Schema of how dyads that do not share any node with the dyad being currently added (thicker black arrow) can influence the decision.}
}
\label{Fig:SchemeWithNonInfluences}
\end{figure}
% \vspace{-6pt}

These types of causal arrows can be interpreted as a sort of ``context''. 
The {\nonLocalExterior} causal arrows allow current citation decisions to be influenced by the way historical documents referenced each other.  
% the influence of dyads that with both of their nodes older than the two nodes of the dyad being decided.  
% Intuitively, this can be thought as ``old wisdoms''.
% , such as, religion or true knowledge. 
The {\nonLocalInterface} causal arrows allow for influence from 
% what recent people have been saying about the ancient philosophers.  
how more recent publications have been referencing historical documents.  
% influence of dyads that have one of their nodes older than the two nodes in the dyad being decided, and the older node having age between that of these two nodes. 
% Intuitively, this can be thought as beliefs that connect between generations. 
And the {\nonLocalInterior} causal arrows allow for influence from 
% what recent people have been saying about each other.  
how recent publications have been referencing each other.  
% to the influence of dyads that have both of their nodes with ages that are between the ages of the two nodes forming the dyad being decided.  
% Intuitively, this can be thought as ``common wisdom at the time''. 
\spaceendsubsection
\subsubsection{The Arrow from a Dyad to Itself} 
\label{sec:selfarrows}
\spacebefsubsection
% \paragraph{The arrow from a dyad to itself.} 
% The {\selfArrow} arrow in {\refTypeCausalArrows} is not an arrow between different dyad variables, 
% so we do not include it \potentiallyImprove{as a causal arrow for the purpose of enumatio.} 
Technically, the {\selfArrow} arrow in {\refTypeCausalArrows} is a directed cycle, 
so we do not include it on our meta-DAGs. 
% \potentiallyImproveN{As the {\selfArrow} arrow in {\refTypeCausalArrows} is 
% not an arrow between different dyad variables, 
% we do not include it on our enumerations in \Cref{thm:NodeDeletionInvariantCausalModels,thm:21InvariantCausalModels}.}
% as a causal arrow.  
% (\cref{eq:hub,eq:transitive,eq:backward,eq:forward}) 
% While it is not an arrow between different dyad variables, 
Nevertheless, 
% the {\selfArrow} causal arrow can be reasonably interpreted in a number of ways,   
it can be reasonably interpreted in a number of ways,   
such as the intrinsic stochasticity of the dyad variable 
or as a mechanism for interventions on it.  
% In Section~\ref{sec:poset}, 
\potentiallyImproveN{For the enumeration} of \Cref{thm:21InvariantCausalModels}, 
it plays a useful role as the identity operator. 
% for the enumeration in \Cref{thm:21InvariantCausalModels}.  
% in a structural causal model (SCM), 
% s on the dyad variable, 
% or (for time-series data (see Section~\ref{sec:extensions})) the previous value of that dyad variable.  % *****
\spaceendsubsection
\subsection{Invariance to Node Deletion}
\label{sec:deletion}
\spacebefsubsection
To enumerate all the possible deletion-invariant causal meta-DAGs with finite ancestral sets, 
we consider all combinations of these 7 causal arrow types that do not result in directed cycles.   
% For the $\FarName$, $\PathName$, $\MidName$, $\HubName$, and $\NearName$ causal arrows, 
%
\potentiallyImproveN{For all 
 types of 
causal arrows except $\OldName$ and $\NewName$, 
the largest node index necessarily increases from parent dyad to child dyad, 
so any combination of those 5 causal arrow types cannot contain a cycle.}  
% result in a deletion-invariant causal DAG.  
To any of these $2^5=32$ subsets, we may add either $\OldName$ or $\NewName$ 
(but not both) to create a valid deletion-invariant causal DAG.  
% , as their causal arrows point in exactly opposite directions, 
% so cannot both be included in a causal DAG, but they are individually compatible with any of the other 5.  
% as they form cycles.  
% To any of these models, either of the $\OldName$ or $\NewName$ causal may be added without creating cycles.  
% Hence, there are \mbox{$2^5 3=96$} deletion-invariant causal DAG with finite ancestral sets.  
% \thmNameHasseAppendix
% \thmlabel{Family of causal models}

\begin{theorem}[\thmNameNodeDel]
\label{thm:NodeDeletionInvariantCausalModels}
There are \mbox{$2^5 3 = 96$} deletion-invariant causal meta-DAGs with finite ancestral sets, given by the subsets of $\{\FarName,\PathName,\MidName,\HubName,\NearName,\OldName,\NewName\}$ that do not contain both $\OldName$ and $\NewName$. 
\end{theorem}
\vspace{-5pt}
% These are the causal \mbox{meta-DAGs} given by the union of all subsets of 
% $\{\FarName,\PathName,\MidName,\HubName,\NearName,\OldName,\NewName\}$ that do not contain both $\OldName$ and $\NewName$.
By requiring invariance to node deletion, 
% we have essentially described the set of causal DAGs over dyad variables that are ``the same'' 
we have described the set of causal DAGs over dyad variables that are ``the same'' 
% regardless of which nodes actually exist.  
for any subset of nodes that are actually included in the growing network.  
\potentiallyImproveN{To illustrate this idea, consider indexing publication nodes by the precise time that the authors made their final edit, 
in terms of milliseconds since 1 Jan 1970.} 
% **cite reference here or quick footnote
One can think of the resulting citation network as being initialized with over a trillion potential nodes, 
then deleting the vast majority of those that did not contain a publication.  
In a sense, invariance to node deletion is invariance to ``that which never existed''.  
\spaceendsubsection
\subsection{Invariance to Node Marginalization}
\label{sec:poset}
\spacebefsubsection
% By requiring invariance to node deletion, 
% we have essentially described the set of causal DAGs over dyad variables that are ``the same'' 
% regardless of which nodes actually exist.  
% To illustrate this idea, consider indexing publication nodes by the 
% number of milliseconds between 1 Jan 1970 and the time the authors made their final edit.  
% One can think of the resulting citation network as being initialized with over a trillion potential nodes, 
% then deleting the vast majority of those that did not contain a publication.  
% In a sense, invariance to deletion is invariance to ``that which never existed''.  
% 
Similarly, one might be interested in invariance to ``that which was not observed''.  
% as it is often the case that one observes only subset of the variables in a causal model.  
Variables that exist but are not observed cannot simply be deleted from a causal model; 
in order to preserve the causal 
 and probabilistic 
relationships between the remaining variables, 
they must be \textit{marginalized}.  
For a causal DAG, marginalizing a variable is a two-step process: 
first add arrows from all of its parents to all of its children, 
then delete that variable \citep{richardson2002ancestral}. 
In general, one must also account for the stochastic component of this now-unobserved latent variable, 
often represented by introducing bidirected arrows between the children \citep{lauritzen1996graphical}.  
We will ignore such bidirected arrows for now, 
and address them momentarily.  %at the end of this section. 
%\potentiallyRemove{As we will see, to preserve conditional independence statements, one must also include so-called ``bidirected causal arrows'' between the children as well.}}  
% Technically, marginalizing variables in a causal DAG 
% also introduce so-called bidirected causal arrows
% If we wish to stay within the space of causal DAGs, with only directed edges, 
% we can consider statements about the effect of interventions instead of conditional independence.  
%
% This can be motivated by the fact that observations are frequently marginal distributions; 
% there are unobserved nodes, and their unobserved connections can mediate causal influences.  
% For such marginal distributions, 
% the unobserved variables can induce correlations between the observed variables, 
% even if the observed variables are not connected themselves.  
% For causal DAGs, marginalizing a variable is instantiated by 
% connecting its parents to its children before deleting it.  

% In our framework, 
% marginalizing a node in the growing network 
% involves marginalizing all dyad variables containing that node. 
%% -- answered below
In our setting, the random variables are the dyads between the nodes of the growing network.  
So marginalization of a node in the growing network means 
marginalizing all dyad variables containing that node.  
Of the 96 deletion-invariant causal meta-DAGs, 
21 are also invariant to node marginalization, 
shown in Appendix~\ref{appendixFigHasse} Fig.~\ref{fig:PosetMetaDAG}.  
They are precisely the meta-DAGs that are \textit{transitively closed}, 
\potentiallyImproveN{that is, all dyad variables have the property that 
all of its parent dyads have arrows pointing to all of its child dyads.}  

To obtain the transitive closure \potentiallyImproveN{of a causal meta-DAG,  
one can} repeatedly perform the first step of marginalizing a variable, 
adding arrows from parents to children \textit{without} deleting the variable, 
until no more arrows can be added.  
For example, if the \potentiallyImproveN{meta-DAG} contains the arrows $\dyadpair{a}{b} \CausalArrow \dyadpair{i}{j}$ and $\dyadpair{i}{j} \CausalArrow \dyadpair{r}{s}$, then it must also include the arrow $\dyadpair{a}{b} \CausalArrow \dyadpair{r}{s}$.  
\potentiallyImproveN{As this first step is the only difference between deletion and marginalization, 
taking the transitive closure renders them equivalent, 
ensuring invariance to marginalization as well as deletion.}   
% Of the 96 deletion-invariant causal meta-DAGs in Theorem~\ref{thm:NodeDeletionInvariantCausalModels}, 
% there are 21 that are also invariant to marginalization (Theorem~\ref{thm:21InvariantCausalModels}, see also Appendix~\ref{appendixFigHasse} Fig.~\ref{fig:PosetMetaDAG}).  

With the directed causal arrows accounted for, 
we return to the bidirected arrows mentioned earlier.  %between the children of marginalized variables.  
Indeed, these must be included if one wishes to 
preserve conditional independence statements between the remaining variables.  
% if one wishes to preserve conditional independence statements, 
% marginalization of a variable in a causal DAG also introduces 
% bidirected causal arrows between all its children \citep{richardson2002ancestral}.  
% For our setting, these bidirected arrows proliferate, 
% and conditional independence statements would not be sufficient to distinguish between many of the 21 causal DAGs in %\ref{thm:21InvariantCausalModels} and 
But for our setting, these statements do not distinguish 
between many of the resulting causal structures.  
For example, any causal meta-DAG with the $\FarName$ causal arrow
would require bidirected arrows between every dyad 
(marginalizing the first two nodes will suffice),  
resulting in zero conditional independence statements
for 13 of the 21 meta-DAGs in Appendix~\ref{appendixFigHasse} Fig.~\ref{fig:PosetMetaDAG}.  

% these 21 causal DAGs in %\ref{thm:21InvariantCausalModels} and 
% Appendix~\ref{appendixFigHasse} Fig.~\ref{fig:PosetMetaDAG}.  

However, causal models encode more than just conditional independence; 
% and it is possible to distinguish between them using statements involving interventions.  
% they also encode which variables might change as a result of performing interventions.  
they also encode how the distribution might change as a result of performing interventions.  
% For example, the question of which dyads $\DyadPairCircleNodes$ are not affected by an intervention on $\dyadpair{i}{j}$, i.e., $\DyadPairCircleNodes \perp \text{do}\big(\dyadpair{i}{j}\big)$.  
Consider the question of which dyad variables $\DyadPairCircleNodes$ \textit{cannot} be affected by an intervention on the outcome of $\dyadpair{i}{j}$. %, i.e., $\DyadPairCircleNodes \perp \text{do}\big(\dyadpair{i}{j}\big)$.  
% For causal DAGs, the answer is yes if there is \textit{no} arrow $\dyadpair{i}{j} \CausalArrow \DyadPairCircleNodes$ in its transitive closure.  
% Statements of this form are not affected by the presence of bidirected arrows, 
For causal DAGs, the answer is unaffected by the presence of bidirected arrows; 
\mbox{$\DyadPairCircleNodes \perp \text{do}\big(\dyadpair{i}{j}\big)$} if there is \textit{no} arrow \mbox{$\dyadpair{i}{j} \CausalArrow \DyadPairCircleNodes$} in its transitive closure.  
We therefore consider invariance (to node deletion and contraction) of this interventional structure 
to define and distinguish between the 21 meta-DAGs in Theorem~\ref{thm:21InvariantCausalModels}. 
% , shown in the Hasse diagram in .  
\begin{theorem}[\thmNameHasse]
\label{thm:21InvariantCausalModels}
% There are \mbox{$21$} causal meta-DAGs with finite ancestral sets that are 
% invariant to both node deletion and marginalization.
There are \mbox{$21$} causal meta-DAGs with finite ancestral sets whose interventional structure is 
invariant to both node deletion and marginalization. 
Their partial ordering is shown in \Cref{fig:PosetMetaDAG}.  
% Appendix~\ref{appendixFigHasse} Fig.~\ref{fig:PosetMetaDAG}.  
% \potentiallyImprove{invariant to node deletion and closed under interventions.}
\end{theorem}
\vspace{-5pt}
% To compute such equivalence classes of interventional structure, 
% we consider compositions of causal arrows.  
\def\JoinArrowSpacing{\kern-3pt}
\def\ListArrowSpacing{\kern-2pt}
% The answer to such questions is precisely encoded in the transitive closure; 
% $\DyadPairCircleNodes \perp \text{do}\big(\dyadpair{i}{j}\big)$ if there is no arrow $\dyadpair{i}{j} \CausalArrow \DyadPairCircleNodes$ in the transitive closure.
% \begin{theorem}[\thmNameHasse]
% \label{thm:21InvariantCausalModels}
% There are \mbox{$21$} causal meta-DAGs with finite ancestral sets that are 
% % invariant to both node deletion and marginalization.
% \potentiallyImprove{invariant to node deletion and closed under interventions.}
% \end{theorem}
% \vspace{-5pt}
\spaceendsubsection
\subsubsection{Computing the Transitive Closure}
\spacebefsubsubsection
% \begin{theorem}[\thmNameHasse]
% \label{thm:21InvariantCausalModels}
% % There are \mbox{$21$} causal meta-DAGs with finite ancestral sets that are 
% % invariant to both node deletion and marginalization.
% There are \mbox{$21$} causal meta-DAGs with finite ancestral sets whose interventional structure is 
% invariant to both node deletion and marginalization.
% % \potentiallyImprove{invariant to node deletion and closed under interventions.}
% \end{theorem}
% \vspace{-5pt}
% % To compute such equivalence classes of interventional structure, 
% % we consider compositions of causal arrows.  
% \def\JoinArrowSpacing{\kern-3pt}
% \def\ListArrowSpacing{\kern-2pt}
To take the transitive closure of a set of causal arrows, 
consider all the ways those arrows can compose.  
That is, for all cases in which the child dyad of the first causal arrow is the parent dyad of the next causal arrow, 
which types of causal arrows could point from the parent dyad of the first arrow to the child dyad of the second?  

For example: \mbox{$\CausalArrowColorNamePath\JoinArrowSpacing\CausalArrowColorNamePath=\{\CausalArrowColorNameFar\JoinArrowSpacing\}$}, 
since the effect of traversing two $\PathName$ causal arrows is always equivalent to
traversing a single $\FarName$ causal arrow.  
Some compositions have the potential to be equivalent to multiple arrow types: 
\mbox{$\CausalArrowColorNameHub\JoinArrowSpacing\CausalArrowColorNameOld=\{\CausalArrowColorNameMid\ListArrowSpacing,\CausalArrowColorNamePath\ListArrowSpacing,\CausalArrowColorNameFar\JoinArrowSpacing\}$}.  
% In this example, the order in which the causal arrows are composed matters: \mbox{$\CausalArrowColorNameOld\JoinArrowSpacing\CausalArrowColorNameHub=\{\CausalArrowColorNameMid\JoinArrowSpacing\}$}.    
Technically, this composition depends on the order: \mbox{$\CausalArrowColorNameOld\JoinArrowSpacing\CausalArrowColorNameHub=\{\CausalArrowColorNameMid\JoinArrowSpacing\}$}, 
but this noncommutativity will not be important for our purposes.    
% while connecting the arrows the other way around can be equivalent to several arrow types: .   

Define the composition of two \textit{sets} of arrow types as the union over all combinations of arrows from the two sets.  
Then, to take the transitive closure, 
% we 
begin with an initial set of causal arrows 
(along with the {$\SelfName$} arrow, which plays the role of the identity).  
Compose this set of arrows with itself to obtain a (possibly) larger set of causal arrow types.  
Continue this process until the set is no longer increasing to obtain the transitive closure.  

For example, \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameHub\ListArrowSpacing,\CausalArrowColorNamePath\JoinArrowSpacing\}$} composed with itself results in \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameHub\ListArrowSpacing,\CausalArrowColorNamePath\ListArrowSpacing,\CausalArrowColorNameFar\JoinArrowSpacing\}$}.  
Composing \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameHub\ListArrowSpacing,\CausalArrowColorNamePath\ListArrowSpacing,\CausalArrowColorNameFar\JoinArrowSpacing\}$} with itself results in the same set, so it is transitively closed.  
% Of the 96 possible initial subsets of arrows, the 21 that are invariant to marginalization are fixed points of this process.  
Starting with the 96 deletion-invariant subsets of arrows from Theorem~\ref{thm:NodeDeletionInvariantCausalModels}, 
one obtains the 21 fixed points of this process, 
corresponding to the meta-DAGs in Theorem~\ref{thm:21InvariantCausalModels}.  
%
% For example, \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameMid\JoinArrowSpacing\}$} composed with itself results in \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameMid,\CausalArrowColorNamePath\ListArrowSpacing,\CausalArrowColorNameFar\JoinArrowSpacing\}$}.  
% Composing this %\mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameHub\ListArrowSpacing,\CausalArrowColorNamePath\ListArrowSpacing,\CausalArrowColorNameFar\JoinArrowSpacing\}$} 
% with itself results in the same set, so it is transitively closed.  
%
% Likewise, \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameHub\ListArrowSpacing,\CausalArrowColorNameNew\JoinArrowSpacing\}$} composed with itself results in \mbox{$\{\CausalArrowColorNameSelf\ListArrowSpacing,\CausalArrowColorNameHub\ListArrowSpacing,\CausalArrowColorNameNew\ListArrowSpacing,\CausalArrowColorNameNear\JoinArrowSpacing\}$}, which is transitively closed.  

Computationally, we implemented this by representing the arrows and their composition as matrices and matrix multiplication.  
% While these 21 equivalence classes could be found by hand, 
While these 21 equivalence classes can easily be found by hand, 
this 
% would 
quickly become unwieldy for generalizations of the procedure.\footnote{
For example, 
% there are 37 causal arrows for trivalent hyperedges.
for simple hypergraphs with cardinality 3, 
% simple cardinality 3-hypergraphs (\ie, that only have only hyperedges between three distinct vertices), 
there are already 37 type of causal arrows between the triads 
(subsets of 3 nodes) with finite ancestral sets. 
% and are closed under node dele 
% For example, there are 37 types of causal arrows between triads (subsets of 3 nodes).
}
% ***** point to appendix