\begin{algorithm}[t]

  \SetAlgoLined%
  \KwIn{%
    Concrete Observational Dataset $\dset_{\scm{L}}$,\\
    \hspace{3em}Joint Observational Dataset $\dset_J$.
  }
  \KwResult{%
    Abstraction function $\hat{\mat{T}}\in\real^{d \times b}$,\\
    \hspace{3.3em}Abstract adjacency matrix $\hat{\mat{M}}\in\real^{b \times b}$,\\
    \hspace{3.3em}Concrete adjacency matrix $\hat{\mat{W}}\in\real^{d \times d}$.
  }
  \SetCommentSty{small}
  \SetKwComment{Comment}{$\triangleright$ }{}
  $\hat{\mat{T}} \gets
  \argmin_{\mat{T}\in\real^{b \times d}}
  \sum_{(\vec{x}, \vec{y}) \in \dset_J} {
    {\| \vec{x}^\tr \mat{T} - \vec{y}^\tr \|}^2_2
  }$\;
  \For(\Comment*[f]{Select Relevant Variables}){$Y_i \in \set{Y}$}{
    $\hat{\Pi}_R(Y_i) \gets \{ X_k \in \set{X}\mid {[\hat{\vec{t}_i}]}_k \neq 0 \}$
  }
  $\dset_{\hat{\scm{H}}} \gets \{\hat{\mat{T}}^\tr \vec{x}  \mid \vec{x} \in \dset_{\scm{L}} \}$
  \Comment*[f]{Create Abstract Dataset}\\
  $\hat{\mat{M}} \gets \text{DirectLiNGAM}(\dset_{\hat{\scm{H}}}, \emptyset)$
  \Comment*[f]{Abstract Discovery}\\
  $\set{K} \gets \emptyset$\\
  \For(\Comment*[f]{Collect Prior Knowledge}){$Y_i, Y_j \in \set{Y}$}{
    \If(\Comment*[f]{Check Ancestorship in $\hat{\mat{M}}$}){$Y_i \centernot\anc Y_j$}{
      \For{$X_k \in \hat\Pi_R(Y_i)$, $X_h \in \hat\Pi_R(Y_j)$}{
          $\set{K} \gets \set{K}
          \cup \{ X_k \centernot\anc X_h \}$
      }
    }
  }
  $\hat{\mat{W}} \gets \text{DirectLiNGAM}(\dset_{\scm{L}}, \set{K})$
  \Comment*[f]{Concrete Discovery}\\
  \caption{Abs-LiNGAM}%
  \label{alg:abslingam}
\end{algorithm}
