\documentclass[tikz, border=4mm]{standalone}

\usepackage{xstring}
\usepackage{amssymb}
\usetikzlibrary{fit,positioning}


\newcommand\drawNodes[2]{
  % #1 (str): namespace
  % #2 (list[list[str]]): list of labels to print in the node of each neuron
  \foreach \neurons [count=\lyrIdx] in #2 {
    \StrCount{\neurons}{,}[\lyrLength] % use xstring package to save each layer size into \lyrLength macro
    \foreach \n [count=\nIdx] in \neurons
      \node[neuron] (#1-\lyrIdx-\nIdx) at (2*\lyrIdx, \lyrLength/2-1.4*\nIdx) {\n};
  }
}

\newcommand\denselyConnectNodes[2]{
  % #1 (str): namespace
  % #2 (list[int]): number of nodes in each layer
  \foreach \n [count=\lyrIdx, remember=\lyrIdx as \previdx, remember=\n as \prevn] in #2 {
    \foreach \y in {1,...,\n} {
      \ifnum \lyrIdx > 1
        \foreach \x in {1,...,\prevn}
          \draw[->] (#1-\previdx-\x) -- (#1-\lyrIdx-\y);
      \fi
    }
  }
}

\begin{document}
\begin{tikzpicture}[
    shorten >=1pt, shorten <=1pt,
    neuron/.style={circle, draw, minimum size=4ex, thick},
    legend/.style={font=\large\bfseries},
  ]

  % encoder
  \drawNodes{encoder}{{{,,}, {,,}}}
  \denselyConnectNodes{encoder}{{3, 3}}

  % dots
  \foreach \n in {1, 2}{
    \node at (2*\n, -1) {\vdots};
  }
  \node at (6.65, 0.9) {\vdots};
  \node at (6.65, -1.3) {\vdots};
\node at (6.65, -3.5) {\vdots};

  % mu, sigma, sample nodes
\coordinate[neuron, right=2 of encoder-2-2, yshift=1 cm + 1cm, fill=white, fill opacity=0.1] (mu-1);
      \coordinate[neuron, right=2 of encoder-2-2, yshift=1 cm-1.2cm, fill=white, fill opacity=0.1] (sigma-1);
      \coordinate[neuron, right=2 of encoder-2-2, yshift=-1 cm-0.2cm, fill=white, fill opacity=0.1] (sample-1);

      \coordinate[neuron, right=2 of encoder-2-2, yshift=2.2 cm + 1cm, fill=white, fill opacity=0.1] (mu-3);
      \coordinate[neuron, right=2 of encoder-2-2, yshift=2.2 cm-1.2cm, fill=white, fill opacity=0.1] (sigma-3);
      \coordinate[neuron, right=2 of encoder-2-2, yshift=-2.2 cm-0.2cm, fill=white, fill opacity=0.1] (sample-3);

      
  \coordinate[neuron, right=2 of encoder-2-2, yshift=-3.5cm, fill=white, fill opacity=0.1] (R);
  
%input and hidden layer boxes
\node [label=input,fit=(encoder-1-1) (encoder-1-3), draw, fill=white, opacity=0.45] (input) {};
\node [label=hidden,fit=(encoder-2-1) (encoder-2-3), draw, fill=white, opacity=0.45] (hidden) {};
  % mu, sigma, sample boxes
  \node [label=right:$\mu\in\mathbb{R}^m$, fit=(mu-1) (mu-3), draw, fill=gray, opacity=0.3] (mu) {};
  \node [label=right:$l\_d\in\mathbb{R}^m$, fit=(sigma-1) (sigma-3), draw, fill=gray, opacity=0.3] (sigma) {};
  \node [label=right:$l\_tl\in\mathbb{R}^{\frac{m(m-1)}{2}}$, fit=(sample-1) (sample-3), draw, fill=gray, opacity=0.3] (sample) {};
  \node [label=right:$r\in\mathbb{R}^1$, fit=(R), draw, fill=gray, opacity=0.3] (R) {};

  % mu, sigma, sample connections
  \foreach \a in {1,2,3}
  \foreach \b in {1,3} {
      \draw[->] (encoder-2-\a) -- (mu-\b);
      \draw[->] (encoder-2-\a) -- (sigma-\b);
      \draw[->] (encoder-2-\a) -- (sample-\b);
    }
  \foreach \a in {1,2,3}{
    \draw[->] (encoder-2-\a) -- (R);
  }

  % input + output labels
  % \foreach \idx in {1,...,4} {
  %     \node[left=0 of encoder-1-\idx] {$x_\idx$};
  %     % \node[right=0 of encoder-2-\idx] {$\hat x_\idx$};
  %   }
  % \node[above=0.1 of encoder-1-1] {input};
  % \node[above=0.1 of encoder-2-1] {output};

\end{tikzpicture}
\end{document}
