\pgfkeys{
  /nodeListX/.initial={ }, % initial list
  /nodeListX/append/.code args={#1}{%
    \pgfkeysgetvalue{/nodeListX}\currentlist%
    % If the list is empty, set it to the new value;
    % otherwise, append a comma and the new element.
    \ifx\currentlist\empty
      \pgfkeyssetvalue{/nodeListX}{#1}%
    \else
      \pgfkeyssetvalue{/nodeListX}{\currentlist,#1}%
    \fi
  }
}
\pgfkeys{
  /nodeListY/.initial={ }, % initial list
  /nodeListY/append/.code args={#1}{%
    \pgfkeysgetvalue{/nodeListY}\currentlist%
    % If the list is empty, set it to the new value;
    % otherwise, append a comma and the new element.
    \ifx\currentlist\empty
      \pgfkeyssetvalue{/nodeListY}{#1}%
    \else
      \pgfkeyssetvalue{/nodeListY}{\currentlist,#1}%
    \fi
  }
}


\begin{figure*}[ht]
  \centering
  \begin{tikzpicture}[remember picture]
    \draw[draw=white, fill=none] (0,-0.25) rectangle (16.5,8.5);
    \def\NewNodeSize{12pt}
    \def\NodeBorderThickness{1pt}
    \tikzmath{\NodeRowDelta=0.75;}
    \tikzmath{\NodeColDelta=0.75;}
    \def\TitleFontSize{12}
    \draw[draw=black, line width=\NodeBorderThickness] (5.25,-0.25) -- (5.25,8.5);
    \draw[draw=black, line width=\NodeBorderThickness] (11.25,-0.25) -- (11.25,8.5);

    \def\HandSize{0.7cm}
    
    \tikzmath{\xStart=1.5;\yStart=7.5;}
    \tikzmath{\TitleYTop=\yStart+0.5;\TitleYMiddle=\yStart-4.0;}
    \tikzmath{\TitleXLeft=\xStart-1.1;\TitleXMiddle=\xStart+5.0;\TitleXRight=\xStart+11.0;}
    \tikzmath{\TitleLineSpace=0.4;}
    
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXLeft,\TitleYTop) {For growing networks...};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXLeft,\TitleYMiddle) {with a node ordering,};
    \node (TitleTopLeft) [anchor=base east,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXLeft,\TitleYMiddle) {...};
    
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXMiddle,\TitleYTop) {the set of all};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXMiddle,\TitleYTop-\TitleLineSpace) {causal influences};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXMiddle,\TitleYTop-2*\TitleLineSpace) {between the dyads...};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXMiddle,\TitleYMiddle) {are partitioned into};
    \node (TitleTopLeft) [anchor=base east,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXMiddle,\TitleYMiddle) {...};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXMiddle,\TitleYMiddle-\TitleLineSpace) {equivalence classes,};
    
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXRight,\TitleYTop) {offering streamlined};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXRight,\TitleYTop-\TitleLineSpace) {generative models...};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXRight,\TitleYMiddle) {with notably diverse};
    \node (TitleTopLeft) [anchor=base east,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXRight,\TitleYMiddle) {...};
    \node (TitleTopLeft) [anchor=base west,inner sep=0cm,font=\fontsize{\TitleFontSize}{\TitleFontSize}\selectfont] at (\TitleXRight,\TitleYMiddle-\TitleLineSpace) {emergent behavior.};
    \pgfkeys{/nodeListX/.initial={0,2,-1,3,0}}
    \edef\nodeListXList{\pgfkeysvalueof{/nodeListX}}
    \foreach [count=\i from 1] \nodeX in \nodeListXList {
        \node (node\i) [draw=white,fill=none,inner sep=0pt, circle, minimum size=\NewNodeSize, line width=\NodeBorderThickness] at (\xStart+\NodeColDelta*\nodeX,\yStart-\NodeRowDelta*\i+\NodeRowDelta) { };
    };
    
    \pgfkeys{/nodeOneEdges/.initial={2,3,4,5}}
    \pgfkeys{/nodeTwoEdges/.initial={3,4}}
    \edef\nodeOneEdgesList{\pgfkeysvalueof{/nodeOneEdges}}
    \foreach \j in \nodeOneEdgesList {
        \draw[draw=black, line width=\NodeBorderThickness] (node1) -- (node\j);
    }
    \edef\nodeTwoEdgesList{\pgfkeysvalueof{/nodeTwoEdges}}
    \foreach \j in \nodeTwoEdgesList {
        \draw[draw=black, line width=\NodeBorderThickness] (node2) -- (node\j);
    }
    
    \foreach [count=\i from 1] \nodeX in \nodeListXList {
        \node [draw=black,fill=white,inner sep=0pt, circle, minimum size=\NewNodeSize, line width=\NodeBorderThickness,font=\fontsize{10}{10}\selectfont] at (node\i) {$\mathbf{\i}$};
    };

    \def\DyadBoxSize{10pt}
    \def\DyadBoxBorderThickness{0.75pt}
    \tikzmath{\xStart=6.0+1;\yStart=\yStart;}
    \foreach [count=\j from 2] \dyadY in {2,...,5} {
        \tikzmath{\iMax=\j-1;}
        \foreach [count=\i from 1] \dyadX in {1,...,\iMax} {
            \node (dyad\i\j) [draw=white,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSize, line width=\DyadBoxBorderThickness] at (\xStart+\NodeColDelta*\i-\NodeColDelta,\yStart-\NodeRowDelta*\j+\NodeRowDelta) { };
            \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSize*0.75, line width=\DyadBoxBorderThickness,font=\fontsize{4pt}{4pt}\selectfont] at ($(node\i)!0.5!(node\j)$) {\i\j};
        };
    };

    \newcommand{\arrowlength}{1mm}
    \newcommand{\arrowwidth}{1mm}
    \def\ArrowLineWidth{0.5pt}

    \tikzmath{\AngleDiagOffset=45;}
    \tikzmath{\NearOutAngle=180+\AngleDiagOffset;\NearInAngle=\AngleDiagOffset;}
    \foreach \i in {2,...,3} {
        \tikzmath{\jMin=int(\i+1);\jMax=int(4);};
        \foreach \j in {\jMin,...,\jMax} {
            \tikzmath{\kMin=int(1);\kMax=int(\i-1);};
            \foreach \k in {\kMin,...,\kMax} {
                \tikzmath{\lMin=int(\j+1);\lMax=int(5);};
                \foreach \l in {\lMin,...,\lMax} {
                    \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=NonLocalInteriorColor, shorten <= -0.25mm] (dyad\i\j)  to[out=\NearOutAngle, in=\NearInAngle] (dyad\k\l); 
                };
            };
        };
    };

    \tikzmath{\AngleDiagOffset=0;}
    \tikzmath{\FarOutAngle=0-\AngleDiagOffset;\FarInAngle=90+\AngleDiagOffset;}
    \foreach \i in {1,...,2} {
        \tikzmath{\jMin=int(\i+1);\jMax=int(3);};
        \foreach \j in {\jMin,...,\jMax} {
            \tikzmath{\kMin=int(\j+1);\kMax=int(5-1);};
            \foreach \k in {\kMin,...,\kMax} {
                \tikzmath{\lMin=int(\k+1);\lMax=int(5);};
                \foreach \l in {\lMin,...,\lMax} {
                    \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=NonLocalExteriorColor, shorten <= -0.25mm] (dyad\i\j)  to[out=\FarOutAngle, in=\FarInAngle] (dyad\k\l); 
                };
            };
        };
    };
    \tikzmath{\AngleDiagOffset=30;}
    \tikzmath{\HubOutAngle=270-\AngleDiagOffset;\HubInAngle=90+\AngleDiagOffset;}
    \foreach \i in {1,...,3} {
        \tikzmath{\jMin=int(\i+1);\jMax=4;};
        \foreach \j in {\jMin,...,\jMax} {
            \tikzmath{\kMin=int(\j+1);\kMax=5;};
            \foreach \k in {\kMin,...,\kMax} {
                \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=HubColor, shorten <= -0.25mm] (dyad\i\j)  to[out=\HubOutAngle, in=\HubInAngle] (dyad\i\k); 
            };
        };
    };
    \tikzmath{\AngleDiagOffset=30;}
    \tikzmath{\ForwardOutAngle=-\AngleDiagOffset;\ForwardInAngle=180+\AngleDiagOffset;}
    \foreach \i in {3,...,5} {
        \tikzmath{\jMin=int(1);\jMax=int(\i-2);};
        \foreach \j in {\jMin,...,\jMax} {
            \tikzmath{\kMin=int(\j+1);\kMax=int(\i-1);};
            \foreach \k in {\kMin,...,\kMax} {
                \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=ForwardColor, shorten <= -0.25mm] (dyad\j\i)  to[out=\ForwardOutAngle, in=\ForwardInAngle] (dyad\k\i); 
            };
        };
    };
    \tikzmath{\AngleDiagOffset=30;}
    \tikzmath{\PathOutAngle=270+\AngleDiagOffset;\PathInAngle=180-\AngleDiagOffset;}
    \foreach \i in {1,...,3} {
        \tikzmath{\jMin=int(\i+1);\jMax=int(4);};
        \foreach \j in {\jMin,...,\jMax} {
            \tikzmath{\kMin=int(\j+1);\kMax=int(5);};
            \foreach \k in {\kMin,...,\kMax} {
                \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=TransitiveColor, shorten <= -0.25mm] (dyad\i\j)  to[out=\PathOutAngle, in=\PathInAngle] (dyad\j\k); 
            };
        };
    };

    \tikzmath{\AngleDiagOffset=60;}
    \tikzmath{\MidOutAngle=0-\AngleDiagOffset;\MidInAngle=90+\AngleDiagOffset;}
    % \foreach \i in {1,...,2} {
    %     \tikzmath{\jMin=int(\i+2);\jMax=int(4);};
    %     \foreach \j in {\jMin,...,\jMax} {
    %         \tikzmath{\kMin=int(\i+1);\kMax=int(\j-1);};
    %         \foreach \k in {\kMin,...,\kMax} {
    %             \tikzmath{\lMin=int(\j+1);\lMax=int(5);};
    %             \foreach \l in {\lMin,...,\lMax} {
    %                 \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=NonLocalInterfaceColor, shorten <= -0.25mm] (dyad\i\j)  to[out=\MidOutAngle, in=\MidInAngle] (dyad\k\l); 
    %             };
    %         };
    %     };
    % };



    \foreach [count=\j from 2] \dyadY in {2,...,5} {
        \tikzmath{\iMax=\j-1;}
        \foreach [count=\i from 1] \dyadX in {1,...,\iMax} {
            \node (dyad\i\j) [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSize, line width=\DyadBoxBorderThickness,font=\fontsize{6}{6}\selectfont] at (\xStart+\NodeColDelta*\i-\NodeColDelta,\yStart-\NodeRowDelta*\j+\NodeRowDelta) {$\i\j$};
        };
    };






    \def\NewNodeSizeSmaller{4pt}
    \def\NodeBorderThicknessSmaller{1pt}
    \def\DyadBoxSizeSmaller{6pt}
    \def\NodeBorderThicknessSmallerBox{0.5pt}
    \tikzmath{\NodeRowDeltaSmaller=0.4;}
    \tikzmath{\NodeColDeltaSmaller=0.4;}
    \tikzmath{\xStart=1.5;\yStartSmaller=3.0;}
    % \pgfkeys{/nodeListX/.initial={0,2,-1,3,0,2,4,-2}}
    % \pgfkeys{/nodeListX/.initial={0,2,-1,3,0,-3,4,8,-2}}
    \pgfkeys{/nodeListX/.initial={0,2,-1,3,0,-2,2,6}}
    \edef\nodeListXList{\pgfkeysvalueof{/nodeListX}}
    \foreach [count=\i from 1] \nodeX in \nodeListXList {
        \node (nodeSmaller\i) [draw=white,fill=none,inner sep=0pt, circle, minimum size=\NewNodeSizeSmaller, line width=\NodeBorderThicknessSmaller] at (\xStart+\NodeColDeltaSmaller*\nodeX,\yStartSmaller-\NodeRowDeltaSmaller*\i+\NodeRowDeltaSmaller) { };
    };
    
    \pgfkeys{/nodeOneEdges/.initial={2,3,4,5,7}}
    \pgfkeys{/nodeTwoEdges/.initial={3,4,6}}
    \pgfkeys{/nodeThreeEdges/.initial={6}}
    \pgfkeys{/nodeFourEdges/.initial={7}}
    \edef\nodeOneEdgesList{\pgfkeysvalueof{/nodeOneEdges}}
    \foreach \j in \nodeOneEdgesList {
        \draw[draw=black, line width=\NodeBorderThicknessSmaller] (nodeSmaller1) -- (nodeSmaller\j);
    }
    \edef\nodeTwoEdgesList{\pgfkeysvalueof{/nodeTwoEdges}}
    \foreach \j in \nodeTwoEdgesList {
        \draw[draw=black, line width=\NodeBorderThicknessSmaller] (nodeSmaller2) -- (nodeSmaller\j);
    }
    \edef\nodeThreeEdgesList{\pgfkeysvalueof{/nodeThreeEdges}}
    \foreach \j in \nodeThreeEdgesList {
        \draw[draw=black, line width=\NodeBorderThicknessSmaller] (nodeSmaller3) -- (nodeSmaller\j);
    }
    \edef\nodeFourEdgesList{\pgfkeysvalueof{/nodeFourEdges}}
    \foreach \j in \nodeFourEdgesList {
        \draw[draw=black, line width=\NodeBorderThicknessSmaller] (nodeSmaller4) -- (nodeSmaller\j);
    }
    
    \draw[draw=black, line width=\NodeBorderThicknessSmaller, densely dashed] (nodeSmaller4) -- (nodeSmaller8);
    \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at ($(nodeSmaller4)!0.5!(nodeSmaller8)$) {\textbf{?}};
    \node[draw=none,fill=none] at ($(nodeSmaller4)!0.5!(nodeSmaller8)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};
    

    
    \foreach [count=\i from 1] \nodeX in \nodeListXList {
        \node [draw=black,fill=white,inner sep=0pt, circle, minimum size=\NewNodeSizeSmaller, line width=\NodeBorderThicknessSmaller] at (nodeSmaller\i) { };
    };



    \tikzmath{\xStart=5.925+1;\yStartSmaller=\yStartSmaller;}
    \tikzmath{\iCurrent=4;\jCurrent=8;}
    \foreach [count=\j from 2] \dyadY in {2,...,\jCurrent} {
        \tikzmath{\iMax=int(\j-1);}
        \foreach [count=\i from 1] \dyadX in {1,...,\iMax} {
            \node (dyadSmaller\i\j) [draw=white,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (\xStart+\NodeColDeltaSmaller*\i-\NodeColDeltaSmaller,\yStartSmaller-\NodeRowDeltaSmaller*\j+\NodeRowDeltaSmaller) { };
        };
    };
    \tikzmath{\jMin=int(2);\jMax=int(\iCurrent-1);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(1);\iMax=int(\j-1);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=NonLocalExteriorColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=NonLocalExteriorColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=\FarOutAngle, in=\FarInAngle] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \tikzmath{\jMin=int(\iCurrent);\jMax=int(\iCurrent);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(1);\iMax=int(\j-1);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=TransitiveColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=TransitiveColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=270+30, in=\PathInAngle] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \tikzmath{\jMin=int(\iCurrent+1);\jMax=int(\jCurrent-1);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(1);\iMax=int(\iCurrent-1);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=NonLocalInterfaceColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            % \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=NonLocalInterfaceColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=300, in=150] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \tikzmath{\jMin=int(\iCurrent+1);\jMax=int(\jCurrent-1);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(\iCurrent);\iMax=int(\iCurrent);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=HubColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=HubColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=\HubOutAngle, in=\HubInAngle] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \tikzmath{\jMin=int(\iCurrent+2);\jMax=int(\jCurrent-1);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(\iCurrent+1);\iMax=int(\j-1);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=NonLocalInteriorColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=NonLocalInteriorColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=\NearOutAngle, in=\NearInAngle] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \tikzmath{\jMin=int(\jCurrent);\jMax=int(\jCurrent);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(1);\iMax=int(\iCurrent-1);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=ForwardColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=ForwardColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=\ForwardOutAngle, in=\ForwardInAngle] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \tikzmath{\jMin=int(\jCurrent);\jMax=int(\jCurrent);}
    \foreach \j in {\jMin,...,\jMax} {
        \tikzmath{\iMin=int(\iCurrent+1);\iMax=int(\j-1);}
        \foreach \i in {\iMin,...,\iMax} {
            \node [draw=none,fill=BackwardColor,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
            % \draw[->,line width=\ArrowLineWidth, >={Stealth[length=\arrowlength, width=\arrowwidth]}, color=BackwardColor, shorten <= -0.25mm] (dyadSmaller\i\j)  to[out=\ForwardInAngle, in=\ForwardOutAngle] (dyadSmaller\iCurrent\jCurrent); 
        };
    };
    \foreach [count=\j from 2] \dyadY in {2,...,\jCurrent} {
        \tikzmath{\iMax=int(\j-1);}
        \foreach [count=\i from 1] \dyadX in {1,...,\iMax} {
            \node [draw=black,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (dyadSmaller\i\j) { };
        };
    };

    \node [draw=black,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadSmaller\iCurrent\jCurrent) {\textbf{?}};
    \node[draw=none,fill=none] at ($(dyadSmaller\iCurrent\jCurrent)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};




    \tikzmath{\xStart=13.0;\yStart=\yStart-0.25;}
    \tikzmath{\iCurrent=4;\jCurrent=8;}
    \foreach [count=\j from 2] \dyadY in {2,...,\jCurrent} {
        \tikzmath{\iMax=int(\j-1);}
        \foreach [count=\i from 1] \dyadX in {1,...,\iMax} {
            \node (dyadStream\i\j) [draw=black,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox] at (\xStart+\NodeColDeltaSmaller*\i-\NodeColDeltaSmaller,\yStart-\NodeRowDeltaSmaller*\j+\NodeRowDeltaSmaller) { };
        };
    };

    \def\ZeroOneFontSize{6pt}
    
    \pgfkeys{/nodeOneEdges/.initial={2,3,4,5,7}}
    % \pgfkeys{/nodeOneEdges/.initial={2,3,4,5}}
    \edef\nodeOneEdgesList{\pgfkeysvalueof{/nodeOneEdges}}
    \pgfkeys{/nodeOneNonEdges/.initial={6}}
    \edef\nodeOneNonEdgesList{\pgfkeysvalueof{/nodeOneNonEdges}}
    \tikzmath{\i=1;}
    \foreach \j in \nodeOneEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=black,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=white] at (dyadStream\iTemp\jTemp) {$1$};
    }
    \foreach \j in \nodeOneNonEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=black] at (dyadStream\iTemp\jTemp) {$0$};
    }
    
    \pgfkeys{/nodeEdges/.initial={3,4,6}}
    \edef\nodeEdgesList{\pgfkeysvalueof{/nodeEdges}}
    \pgfkeys{/nodeNonEdges/.initial={5,7}}
    \edef\nodeNonEdgesList{\pgfkeysvalueof{/nodeNonEdges}}
    \tikzmath{\i=2;}
    \foreach \j in \nodeEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=black,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=white] at (dyadStream\iTemp\jTemp) {$1$};
    }
    \foreach \j in \nodeNonEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=black] at (dyadStream\iTemp\jTemp) {$0$};
    }

    \pgfkeys{/nodeEdges/.initial={6}}
    \edef\nodeEdgesList{\pgfkeysvalueof{/nodeEdges}}
    \pgfkeys{/nodeNonEdges/.initial={4,5,7,8}}
    \edef\nodeNonEdgesList{\pgfkeysvalueof{/nodeNonEdges}}
    \tikzmath{\i=3;}
    \foreach \j in \nodeEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=black,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=white] at (dyadStream\iTemp\jTemp) {$1$};
    }
    \foreach \j in \nodeNonEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=black] at (dyadStream\iTemp\jTemp) {$0$};
    }

    \pgfkeys{/nodeEdges/.initial={7}}
    \edef\nodeEdgesList{\pgfkeysvalueof{/nodeEdges}}
    \pgfkeys{/nodeNonEdges/.initial={5,6}}
    \edef\nodeNonEdgesList{\pgfkeysvalueof{/nodeNonEdges}}
    \tikzmath{\i=4;}
    \foreach \j in \nodeEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=black,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=white] at (dyadStream\iTemp\jTemp) {$1$};
    }
    \foreach \j in \nodeNonEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=black] at (dyadStream\iTemp\jTemp) {$0$};
    }

    % \pgfkeys{/nodeEdges/.initial={7}}
    % \edef\nodeEdgesList{\pgfkeysvalueof{/nodeEdges}}
    \pgfkeys{/nodeNonEdges/.initial={6}}
    \edef\nodeNonEdgesList{\pgfkeysvalueof{/nodeNonEdges}}
    \tikzmath{\i=5;}
    % \foreach \j in \nodeEdgesList {
    %     \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
    %     \node [draw=black,fill=black,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=white] at (dyadStream\iTemp\jTemp) {$1$};
    % }
    \foreach \j in \nodeNonEdgesList {
        \tikzmath{\iTemp=int(\i);\jTemp=int(\j);}
        \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\ZeroOneFontSize}{\ZeroOneFontSize}\selectfont,text=black] at (dyadStream\iTemp\jTemp) {$0$};
    }


    \tikzmath{\iCurrent=1;\jCurrent=8;}
    \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadStream\iCurrent\jCurrent) {\textbf{?}};
    \node[draw=none,fill=none] at ($(dyadStream\iCurrent\jCurrent)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};
    % \tikzmath{\iCurrent=2;\jCurrent=7;}
    % \tikzmath{\iCurrent=2;\jCurrent=8;}
    % \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadStream\iCurrent\jCurrent) {\textbf{?}};
    % \node[draw=none,fill=none] at ($(dyadStream\iCurrent\jCurrent)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};
    \tikzmath{\iCurrent=3;\jCurrent=7;}
    \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadStream\iCurrent\jCurrent) {\textbf{?}};
    \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadStream\iCurrent8) { };
    \node[draw=none,fill=none] at ($(dyadStream\iCurrent\jCurrent)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};
    % \tikzmath{\iCurrent=4;\jCurrent=8;}
    % \node [draw=black,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadStream\iCurrent\jCurrent) {\textbf{?}};
    % \node[draw=none,fill=none] at ($(dyadStream\iCurrent\jCurrent)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};
    \tikzmath{\iCurrent=5;\jCurrent=6;}
    \node [draw=black,fill=white,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{6pt}{6pt}\selectfont] at (dyadStream\iCurrent\jCurrent) {\textbf{?}};
    \node[draw=none,fill=none] at ($(dyadStream\iCurrent\jCurrent)+(0.4,-0.1)$) {\includegraphics[trim={0 0 0 0},clip,width=\HandSize,angle=320]{WritingHandFilled.png}};

    % \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=0,anchor=base] at (\PowerLawOriginX+\PowerLawWidth/2-0.05,\PowerLawOriginY-0.2) {$p_{ij}^{ } &= \frac{\alphaP + \thetain d_i^{\text{in}} + \thetaout d_i^{\text{out}}}{j-2+\alphaP +\betaP}$};



    \tikzmath{\SparsityOriginX=\xStart+1.5;\SparsityOriginY=1.25;}
    \tikzmath{\SparsityWidth=1.75;\SparsityHeight=1.5;}
    \def\AxisThickness{1pt}
    \def\AxisArrowLength{5pt}
    \def\AxisArrowWidth{4pt}
    \draw[->,line width=\AxisThickness, >={Stealth[length=\AxisArrowLength, width=\AxisArrowWidth]}, color=black, shorten <= -0.5pt] (\SparsityOriginX,\SparsityOriginY)  -- (\SparsityOriginX+\SparsityWidth,\SparsityOriginY); 
    \draw[->,line width=\AxisThickness, >={Stealth[length=\AxisArrowLength, width=\AxisArrowWidth]}, color=black, shorten <= -0.5pt] (\SparsityOriginX,\SparsityOriginY)  -- (\SparsityOriginX,\SparsityOriginY+\SparsityHeight); 
    \draw[domain=0.1:\SparsityWidth, smooth, variable=\x, black, thick] plot ({\x+\SparsityOriginX-0.05}, {\SparsityOriginY+0.4*(1-0.1/\x)});
    \draw[domain=0.1:\SparsityWidth, smooth, variable=\x, black, thick] plot ({\x+\SparsityOriginX-0.05}, {ln(\x/0.1)*0.3+\SparsityOriginY});
    \draw[domain=0.1:\SparsityWidth, smooth, variable=\x, black, thick] plot ({\x+\SparsityOriginX-0.05}, {\SparsityOriginY+1.1*sqrt(\x-0.1)});

    \def\AxisTextSize{5pt}
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=90,anchor=base] at (\SparsityOriginX-0.1,\SparsityOriginY+\SparsityHeight/2-0.05) {average degree};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=0,anchor=base] at (\SparsityOriginX+\SparsityWidth/2-0.05,\SparsityOriginY-0.2) {number of nodes};

    \tikzmath{\PowerLawOriginX=\xStart-1.0;\PowerLawOriginY=-0.0;}
    \tikzmath{\PowerLawWidth=1.75;\PowerLawHeight=1.5;}
    \draw[->,line width=\AxisThickness, >={Stealth[length=\AxisArrowLength, width=\AxisArrowWidth]}, color=black, shorten <= -0.5pt] (\PowerLawOriginX,\PowerLawOriginY)  -- (\PowerLawOriginX+\PowerLawWidth,\PowerLawOriginY); 
    \draw[->,line width=\AxisThickness, >={Stealth[length=\AxisArrowLength, width=\AxisArrowWidth]}, color=black, shorten <= -0.5pt] (\PowerLawOriginX,\PowerLawOriginY)  -- (\PowerLawOriginX,\PowerLawOriginY+\PowerLawHeight); 
    \draw[domain=0.1:\PowerLawWidth, smooth, variable=\x, black, thick] plot ({\x+\PowerLawOriginX-0.05}, {\PowerLawOriginY+0.4*(1-0.1/\x)+\PowerLawHeight-0.4-\x*0.8});
    \draw[domain=0.1:\PowerLawWidth*0.65, smooth, variable=\x, black, thick] plot ({\x+\PowerLawOriginX-0.05}, {\PowerLawOriginY+0.4*(1-0.1/\x)+\PowerLawHeight-0.45-\x*1.2});
    \draw[domain=0.1:\PowerLawWidth*1.0, smooth, variable=\x, black, thick] plot ({\x+\PowerLawOriginX-0.05}, {\PowerLawOriginY+0.4*(1-0.1/\x)+\PowerLawHeight-0.35-\x*0.5});
    
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=90,anchor=base] at (\PowerLawOriginX-0.1,\PowerLawOriginY+\PowerLawHeight/2-0.05) {log probability};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=0,anchor=base] at (\PowerLawOriginX+\PowerLawWidth/2-0.05,\PowerLawOriginY-0.2) {log degree};

    \def\DiversityTextSize{8pt}
    \tikzmath{\SparsityTextX=\SparsityOriginX-0.5;\SparsityTextY=\SparsityOriginY+1.15;}
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base east] at (\SparsityTextX,\SparsityTextY) {Phase transitions};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base east] at (\SparsityTextX,\SparsityTextY-0.3) {between sparse};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base east] at (\SparsityTextX,\SparsityTextY-0.6) {growth rates};
    % \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base west] at (\SparsityTextX,\SparsityTextY-0.6) {...};

    \tikzmath{\PowerLawTextX=\PowerLawOriginX+2.0;\PowerLawTextY=\PowerLawOriginY+0.35;}
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base west] at (\PowerLawTextX,\PowerLawTextY) {and a flexible};
    % \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base east] at (\PowerLawTextX,\PowerLawTextY) {...};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\DiversityTextSize}{\DiversityTextSize}\selectfont,rotate=0,anchor=base west] at (\PowerLawTextX,\PowerLawTextY-0.3) {power-law!}; % $p(d) \propto d^{\gamma}$

    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=-27,anchor=base] at (\PowerLawOriginX+1.2,\PowerLawOriginY+1.0) {$p\kern-0.5pt(\kern-1pt d \kern-0.5pt) \propto d^{\scalebox{0.7}[1]{\mbox{$-$}}\raisebox{0.5pt}{\scalebox{0.8}[0.8]{\mbox{$\gamma$}}}_{ }}$};

    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=25,anchor=base west] at (\SparsityOriginX+0.8,\SparsityOriginY+1.1) {$\langle d \rangle \sim n^\rho_{ }$};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=15,anchor=base west] at (\SparsityOriginX+0.8,\SparsityOriginY+0.75) {$\langle d \rangle \sim \text{log}(\kern-0.5pt n \kern-0.5pt)$};
    \node [draw=none,fill=none,inner sep=0cm, regular polygon sides=4, minimum size=\DyadBoxSizeSmaller, line width=\NodeBorderThicknessSmallerBox,font=\fontsize{\AxisTextSize}{\AxisTextSize}\selectfont,rotate=0,anchor=base west] at (\SparsityOriginX+0.8,\SparsityOriginY+0.45) {$\langle d \rangle \sim \text{const}$};


  \end{tikzpicture}
  \vspace{-8pt}
\caption{\textbf{The narrative arc of our paper at a glance.} \\ 
    \textit{Left column:} 
        The nodes of the growing network, represented as circles, have a total ordering.  
        The variables in the model are indexed by the dyads (pairs of nodes), represented as squares (\Cref{sec:GrowingNetworkDescription,ref:TheMetaDAGDescription}).   %\\
    \textit{Middle column:} 
        Causal relationships between these dyad variables are represented as 
        arrows in a causal DAG describing the generative process of the growing network.  
        We classify the relevant equivalence classes of such causal arrows, 
        represented by colors (\Cref{ref:InvarianceCausalModel,sec:typesofcausalarrows,sec:deletion,sec:poset}). %\\ 
    \textit{Right column:} 
        Some combinations of these causal arrows are remarkably parallelizable, 
        such as the model we call {\ppaName} ({\ppaAcron}).  
        In addition to a flexible power law, it naturally contains 
        a phase transition between several well-studied sparse growth rates: 
        from constant average degree, to logarithmic, to polynomial (\Cref{sec:ourppamodel}).   
}
  \label{fig:FirstNatureFigure}
\end{figure*}
