\begin{figure*}[ht]
\centering
\begin{tikzpicture}[
roundnode/.style={circle, draw=black!100, very thick, minimum size=7mm},
squarednode/.style={rectangle, draw=black!100, very thick, minimum size=7mm}
]
\tikzset{node distance = 1cm}

%Nodes of (a)
\node[roundnode] (agent1_a)                      {1};
\node[roundnode] (agent2_a)  [right=of agent1_a] {2};
\node[roundnode] (agent3_a)  [below=of agent2_a] {3};
\node[roundnode] (agent4_a)  [below=of agent1_a] {4};
\node[below right=3mm and 3mm of agent4_a] {\textbf{(a)}};

% %Lines of (a)
\draw[-] (agent1_a.east) -- (agent2_a.west);
\draw[-] (agent1_a.south east) -- (agent3_a.north west);
\draw[-] (agent1_a.south) -- (agent4_a.north);
\draw[-] (agent2_a.south) -- (agent3_a.north);
\draw[-] (agent2_a.south west) -- (agent4_a.north east);
\draw[-] (agent3_a.west) -- (agent4_a.east);

%Nodes of (b)
\node[squarednode]  (agent1_b)  [right=1cm of agent2_a] {$BR_1$};
\node[squarednode]  (agent2_b)  [right=of agent1_b] {$BR_2$};
\node[squarednode]  (agent3_b)  [below=of agent2_b] {$BR_3$};
\node[squarednode]  (agent4_b)  [below=of agent1_b] {$BR_4$};
\node[below right=1.8mm and 2mm of agent4_b] {\textbf{(b)}};

% %Lines of (b)
\draw[-] (agent1_b.east)        --node[above=-0.9mm, font=\scriptsize] {1,2,3,4}                    (agent2_b.west);
\draw[-] (agent1_b.south east)  --node[above right=-0.4mm and -0.8mm, rotate=315, font=\scriptsize] {1,2,3,4}  (agent3_b.north west);
\draw[-] (agent1_b.south)       --node[above right=-4.5mm and 0.9mm, rotate=90, font=\scriptsize] {1,2,3,4}         (agent4_b.north);
\draw[-] (agent2_b.south)       --node[above right=4.5mm and -0.9mm, rotate=270, font=\scriptsize] {1,2,3,4}        (agent3_b.north);
\draw[-] (agent2_b.south west)  --node[above right=-0.8mm and 0.4mm, rotate=45, font=\scriptsize] {1,2,3,4}   (agent4_b.north east);
\draw[-] (agent3_b.west)        --node[below=-0.8mm, font=\scriptsize] {1,2,3,4}                    (agent4_b.east);

%Nodes of (c)
\node[roundnode] (agent1_c)      [right=2.1cm of agent2_b,] {1};
\node[roundnode] (agent2_c)      [right=of agent1_c] {2};
\node[roundnode] (agent3_c)      [below=of agent2_c] {3};
\node[roundnode] (agent4_c)      [below=of agent1_c] {4};
\node[roundnode] (aggregate_c)    [below left=4mm and 10mm of agent1_c] {$Y$};
\node[below right=3mm and 0mm of agent4_c] {\textbf{(c)}};

% %Lines of (c)
\draw[-] (agent1_c.east) -- (agent2_c.west);
\draw[-] (agent1_c.south east) -- (agent3_c.north west);
\draw[-] (agent1_c.south) -- (agent4_c.north);
\draw[-] (agent2_c.south) -- (agent3_c.north);
\draw[-] (agent2_c.south west) -- (agent4_c.north east);
\draw[-] (agent3_c.west) -- (agent4_c.east);
\draw[-] (aggregate_c.east) -- (agent1_c.south west);
\draw[-] (aggregate_c.east) -- (agent2_c.south west);
\draw[-] (aggregate_c.east) -- (agent3_c.north west);
\draw[-] (aggregate_c.east) -- (agent4_c.north west);

%Nodes of (d)
\node[squarednode] (agent1_d)      [right=2.5cm of agent2_c,] {$v_{1,Y}$};
\node[squarednode] (agent2_d)      [right=of agent1_d] {$v_{2,Y}$};
\node[squarednode] (agent3_d)      [below=of agent2_d] {$v_{3,Y}$};
\node[squarednode] (agent4_d)      [below=of agent1_d] {$v_{4,Y}$};
\node[squarednode] (aggregate_d)    [below left=1.5mm and 10mm of agent1_d] {$v_{N,Y}$};
\node[below right=1.8mm and 0mm of agent4_d] {\textbf{(d)}};

% %Lines of (d)
\draw[-] (agent1_d.east)        --node[above=-0.9mm, font=\scriptsize] {$Y$}             (agent2_d.west);
\draw[-] (agent1_d.south east)  --node[near end, right, font=\scriptsize] {$Y$}   (agent3_d.north west);
\draw[-] (agent1_d.south)       --node[right=-1mm, font=\scriptsize] {$Y$}             (agent4_d.north);
\draw[-] (agent2_d.south)       --node[right=-1mm, font=\scriptsize] {$Y$}             (agent3_d.north);
\draw[-] (agent2_d.south west)  --node[near start, right, font=\scriptsize] {$Y$} (agent4_d.north east);
\draw[-] (agent3_d.west)        --node[below=-0.8mm, font=\scriptsize] {$Y$}             (agent4_d.east);
\draw[-] (aggregate_d.east)     --node[pos=0.6, above=-1mm, rotate=30, font=\scriptsize] {$1, Y$}             (agent1_d.south west);
\draw[-] (aggregate_d.east)     --node[pos=0.35, above=-1mm, rotate=12, font=\scriptsize] {$2, Y$} (agent2_d.south west);
\draw[-] (aggregate_d.east)     --node[pos=0.35, above=-1mm, rotate=-9, font=\scriptsize] {$3, Y$} (agent3_d.north west);
\draw[-] (aggregate_d.east)     --node[pos=0.6, below=-0.9mm, rotate=-30, font=\scriptsize] {$4, Y$}             (agent4_d.north west);

\end{tikzpicture}
\caption{
The four constraint networks shown here illustrate our key technical insight.\\
\textbf{(a)} A typical CSP (not used here) for $N = \{1, \cdots, 4\}$: Each node is a player with their strategy set as the domain, and each player has a best-response constraint involving all the players.\\
%
\textbf{(b)} The dual of \textbf{(a)}: Each dual node $BR_i$ represents player $i$'s best-response constraint with its domain being strategy profiles $(s_i, \mathbf{s}_{-i})$ where $s_i$ is $i$'s best response to $\mathbf{s}_{-i}$. Each edge shows that \emph{all} players are shared between its endpoints, which makes it hard to decouple the strategies of the players.\\
%
\textbf{(c)} A new CSP we present where in addition to the players, there is a node $Y$ for the configuration representing aggregated demand vectors $(\mathbf{y}_1, \mathbf{y}_2, ..., \mathbf{y}_m)$. The constraints are: (1) \emph{best-response constraint:} Each player $i$ plays its best response to $Y$, leading to the edge $(i, Y)$,  and (2) \emph{feasibility constraint:} the strategies assigned to the players are consistent with the configuration assigned to $Y$, leading to all the edges because this constraint involves all the nodes.\\
%
\textbf{(d)} The dual of \textbf{(c)}: Each $v_{i,Y}$ node (for $i = 1, \cdots, 4$) represents the best response constraint described above, and the $v_{N,Y}$ node represents the feasibility constraint described above. Each edge is labeled with the shared variables between its endpoints. Most notably, the edges show the decoupling of the players' strategies. Contrast this with \textbf{(b)}.
}
\label{fig:csp}
\end{figure*}