{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "099b95a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "import os\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn\n",
    "import torch\n",
    "from torch.utils.data import DataLoader, random_split\n",
    "from dcdfg_extend_pc import vaeGraph\n",
    "from codebase.models.spns import construct_fg\n",
    "from make_dataset import PerturbDataset\n",
    "import networkx as nx\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "import sys\n",
    "sys.path.insert(1, '../')\n",
    "from data.simulations import DatasetLowRankGenerator\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset\n",
    "#from dcdfg.metrics import fdr, shd_metric\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "figure_path = '/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/figures/VBFG/simulation'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e9565a93",
   "metadata": {},
   "source": [
    "# Toy Dataset: 1 factor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f8c38079",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_features = 100\n",
    "n_modules = 1\n",
    "p_vertex = 1.0\n",
    "p_module = 1.0\n",
    "n_samples = 100000\n",
    "nb_interventions = 100\n",
    "np.random.seed(42)\n",
    "sim_data = DatasetLowRankGenerator(n_features,\n",
    "                                   n_modules,\n",
    "                                   p_vertex,\n",
    "                                   p_module,\n",
    "                                   n_samples,\n",
    "                                   n_hidden=0,\n",
    "                                   rescale=False,\n",
    "                                   obs_data=False,\n",
    "                                   nb_interventions=nb_interventions,\n",
    "                                   min_nb_target=1,\n",
    "                                   max_nb_target=1,\n",
    "                                   noise_level=0.01,\n",
    "                                   factor_noise_level=1.0,\n",
    "                                   min_corr=0.25,\n",
    "                                   conservative=False,\n",
    "                                   uniform=False,\n",
    "                                   cover=True,\n",
    "                                   verbose=True,)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9d94e438",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "../data/sems_vectorized.py:17: FutureWarning: adjacency_matrix will return a scipy.sparse array instead of a matrix in Networkx 3.0.\n",
      "  weights *= nx.adjacency_matrix(graph).A\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling the DAG\n",
      "Init sem\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "interventions: 100%|██████████| 100/100 [00:00<00:00, 120.80it/s]\n"
     ]
    }
   ],
   "source": [
    "sim_data.generate(intervention=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a07bfd0e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:ylabel='Density'>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "z = sim_data.data_factor\n",
    "plt.figure()\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "\n",
    "df = pd.DataFrame(z, columns=['true factor'])\n",
    "seaborn.kdeplot(df, ax=ax)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7854bb35",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.1185588745909547"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "z.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d32abb30",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KstestResult(statistic=0.0342198028246856, pvalue=3.577137777470996e-102, statistic_location=-2.442142201085676, statistic_sign=1)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import scipy.stats as stats\n",
    "stats.kstest(z.flatten(), stats.norm.cdf)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "18839033",
   "metadata": {},
   "source": [
    "## Node and Factor Degree"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "f7533141",
   "metadata": {},
   "outputs": [],
   "source": [
    "idx_module = np.argsort(sim_data.module_list_ordered)\n",
    "idx_module = np.array([np.where(idx_module == i)[0][0] for i in range(n_modules)])\n",
    "idx_feature = np.argsort(sim_data.feature_list_ordered)\n",
    "idx_feature = np.array([np.where(idx_feature == i)[0][0] for i in range(n_features)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "d784ac7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([79.])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sim_data.generator.V.sum(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "6511ba25",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([21.])"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sim_data.generator.U.sum(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "aa1c68f2",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxQAAAJOCAYAAAAu4UG0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAABwAUlEQVR4nO3deVwV9f7H8TfrARfAJTYDsVLRcjcJzTYp9Hq9Wl4z8+aSaYuUSouSKakp1i2zhTQtl+5PL2aledPsZ7iUSpooaoW4YVIJ5jXBJUHh+/ujh+fXEVQYdnw9H495PDzf+c7M5zvRzHmfOTPHyRhjBAAAAAAWOFd2AQAAAACqLwIFAAAAAMsIFAAAAAAsI1AAAAAAsIxAAQAAAMAyAgUAAAAAywgUAAAAACwjUAAAAACwzLWyC7hYQUGBfvnlF9WtW1dOTk6VXQ4A1EjGGJ08eVKBgYFydq5eny1xngCA8leS80SVCxS//PKLgoKCKrsMALgqZGRk6Nprr63sMkqE8wQAVJzinCeqXKCoW7eupD+K9/LyquRqAKBmysnJUVBQkP2YW51wngCA8leS80SVCxQXLl97eXlxogCAclYdvzLEeQIAKk5xzhPV64uzAAAAAKoUAgUAAAAAywgUAAAAACwjUAAAAACwjEABALDsq6++Uq9evRQYGCgnJyctX778isusX79e7du3l81m0w033KAFCxaUe50AgPJDoAAAWHb69Gm1adNG8fHxxeqfnp6unj176s4771RKSopGjx6tRx55RF988UU5VwoAKC9V7rGxAIDqo0ePHurRo0ex+8+ePVtNmjTRa6+9Jklq0aKFNm7cqNdff12RkZHlVSYAoBxxhQIAUGGSkpIUERHh0BYZGamkpKRLLpObm6ucnByHCQBQddTIKxQh41ZWdgkAUCEOTe9Z2SWUSGZmpvz8/Bza/Pz8lJOTo99//12enp6FlomLi9OkSZMqqkQANcSF94OHpve84r8vpzjLF3ddJV1vWayrInCFAgBQpcXExCg7O9s+ZWRkVHZJAIA/qZFXKAAAVZO/v7+ysrIc2rKysuTl5VXk1QlJstlsstlsFVEeAMACrlAAACpMeHi4EhMTHdrWrFmj8PDwSqoIAFBaBAoAgGWnTp1SSkqKUlJSJP3xWNiUlBQdPnxY0h9fVxo0aJC9/2OPPaaDBw/queee0549e/TOO+/oww8/1JgxYyqjfABAGSBQAAAs27Ztm9q1a6d27dpJkqKjo9WuXTtNnDhRknTkyBF7uJCkJk2aaOXKlVqzZo3atGmj1157Te+99x6PjAWAaqxEgSIuLk4333yz6tatK19fX/Xp00dpaWkOfc6ePauRI0eqQYMGqlOnjvr27Vvo+7IAgJrhjjvukDGm0HTh168XLFig9evXF1pmx44dys3N1YEDBzRkyJAKrxsAUHZKFCg2bNigkSNH6ptvvtGaNWt07tw53XPPPTp9+rS9z5gxY/Sf//xHS5cu1YYNG/TLL7/ovvvuK/PCAQAAAFS+Ej3lafXq1Q6vFyxYIF9fXyUnJ+u2225Tdna23n//fS1evFh33XWXJGn+/Plq0aKFvvnmG91yyy1lVzkAAACASleqeyiys7MlSfXr15ckJScn69y5cw6/ghoaGqrg4ODL/goqAAAAgOrJ8u9QFBQUaPTo0erSpYtuuukmSX/8Aqq7u7t8fHwc+vr5+SkzM7PI9eTm5io3N9f+Oicnx2pJAAAAACqY5SsUI0eO1HfffaeEhIRSFRAXFydvb2/7FBQUVKr1AQAAAKg4lgJFVFSUPvvsM61bt07XXnutvd3f3195eXk6ceKEQ/+srCz5+/sXua6YmBhlZ2fbp4yMDCslAQAAAKgEJQoUxhhFRUVp2bJlWrt2rZo0aeIwv0OHDnJzc3P4FdS0tDQdPnz4kr+CarPZ5OXl5TABAAAAqB5KdA/FyJEjtXjxYn366aeqW7eu/b4Ib29veXp6ytvbW8OGDVN0dLTq168vLy8vPfnkkwoPD+cJTwAAAEANVKJAMWvWLEl//CjRn82fP9/+w0Svv/66nJ2d1bdvX+Xm5ioyMlLvvPNOmRQLAAAAoGopUaAwxlyxj4eHh+Lj4xUfH2+5KAAAAADVQ6l+hwIAAADA1Y1AAQAAAMAyAgUAAAAAywgUAAAAACwjUAAAAACwjEABAAAAwDICBQAAAADLCBQAAAAALCNQAAAAALCMQAEAAADAMgIFAAAAAMsIFAAAAAAsI1AAAAAAsIxAAQAAAMAyAgUAAAAAywgUAAAAACwjUAAAAACwjEABAAAAwDICBQAAAADLCBQAAAAALCNQAAAAALCMQAEAAADAMgIFAAAAAMsIFACAUomPj1dISIg8PDwUFhamrVu3Xrb/zJkz1bx5c3l6eiooKEhjxozR2bNnK6haAEBZI1AAACxbsmSJoqOjFRsbq+3bt6tNmzaKjIzU0aNHi+y/ePFijRs3TrGxsUpNTdX777+vJUuW6Pnnn6/gygEAZYVAAQCwbMaMGRo+fLiGDh2qli1bavbs2apVq5bmzZtXZP/NmzerS5cuevDBBxUSEqJ77rlHAwYMuOJVDQBA1UWgAABYkpeXp+TkZEVERNjbnJ2dFRERoaSkpCKX6dy5s5KTk+0B4uDBg1q1apX+8pe/VEjNAICy51rZBQAAqqdjx44pPz9ffn5+Du1+fn7as2dPkcs8+OCDOnbsmG699VYZY3T+/Hk99thjl/3KU25urnJzc+2vc3JyymYAAIAywRUKAECFWb9+vaZNm6Z33nlH27dv1yeffKKVK1dqypQpl1wmLi5O3t7e9ikoKKgCKwYAXAlXKAAAljRs2FAuLi7KyspyaM/KypK/v3+Ry0yYMEEPPfSQHnnkEUlSq1atdPr0aY0YMULjx4+Xs3Phz7liYmIUHR1tf52Tk0OoAIAqhCsUAABL3N3d1aFDByUmJtrbCgoKlJiYqPDw8CKXOXPmTKHQ4OLiIkkyxhS5jM1mk5eXl8MEAKg6uEIBALAsOjpagwcPVseOHdWpUyfNnDlTp0+f1tChQyVJgwYNUqNGjRQXFydJ6tWrl2bMmKF27dopLCxM+/fv14QJE9SrVy97sAAAVC8ECgCAZf3799evv/6qiRMnKjMzU23bttXq1avtN2ofPnzY4YrECy+8ICcnJ73wwgv6+eefdc0116hXr16aOnVqZQ0BAFBKBAoAQKlERUUpKiqqyHnr1693eO3q6qrY2FjFxsZWQGUAgIrAPRQAAAAALCNQAAAAALCMQAEAAADAMgIFAAAAAMsIFAAAAAAsI1AAAAAAsIxAAQAAAMAyAgUAAAAAy0ocKL766iv16tVLgYGBcnJy0vLlyx3mDxkyRE5OTg5T9+7dy6peAAAAAFVIiQPF6dOn1aZNG8XHx1+yT/fu3XXkyBH79O9//7tURQIAAAComlxLukCPHj3Uo0ePy/ax2Wzy9/e3XBQAAACA6qFc7qFYv369fH191bx5cz3++OP673//Wx6bAQAAAFDJSnyF4kq6d++u++67T02aNNGBAwf0/PPPq0ePHkpKSpKLi0uh/rm5ucrNzbW/zsnJKeuSAAAAAJSTMg8UDzzwgP3frVq1UuvWrXX99ddr/fr16tatW6H+cXFxmjRpUlmXAQAAAKAClPtjY6+77jo1bNhQ+/fvL3J+TEyMsrOz7VNGRkZ5lwQAAACgjJT5FYqL/fTTT/rvf/+rgICAIufbbDbZbLbyLgMAAABAOShxoDh16pTD1Yb09HSlpKSofv36ql+/viZNmqS+ffvK399fBw4c0HPPPacbbrhBkZGRZVo4AAAAgMpX4kCxbds23XnnnfbX0dHRkqTBgwdr1qxZ2rVrlxYuXKgTJ04oMDBQ99xzj6ZMmcJVCAAAAKAGKnGguOOOO2SMueT8L774olQFAQAAAKg+yv2mbAAAAAA1F4ECAAAAgGUECgAAAACWESgAAAAAWEagAAAAAGAZgQIAAACAZQQKAAAAAJYRKAAAAABYRqAAAAAAYBmBAgAAAIBlBAoAAAAAlhEoAAAAAFhGoAAAAABgGYECAAAAgGUECgAAAACWESgAAKUSHx+vkJAQeXh4KCwsTFu3br1s/xMnTmjkyJEKCAiQzWZTs2bNtGrVqgqqFgBQ1lwruwAAQPW1ZMkSRUdHa/bs2QoLC9PMmTMVGRmptLQ0+fr6Fuqfl5enu+++W76+vvroo4/UqFEj/fjjj/Lx8an44gEAZYJAAQCwbMaMGRo+fLiGDh0qSZo9e7ZWrlypefPmady4cYX6z5s3T8ePH9fmzZvl5uYmSQoJCanIkgEAZYyvPAEALMnLy1NycrIiIiLsbc7OzoqIiFBSUlKRy6xYsULh4eEaOXKk/Pz8dNNNN2natGnKz8+/5HZyc3OVk5PjMAEAqg4CBQDAkmPHjik/P19+fn4O7X5+fsrMzCxymYMHD+qjjz5Sfn6+Vq1apQkTJui1117TSy+9dMntxMXFydvb2z4FBQWV6TgAAKVDoAAAVJiCggL5+vpqzpw56tChg/r376/x48dr9uzZl1wmJiZG2dnZ9ikjI6MCKwYAXAn3UAAALGnYsKFcXFyUlZXl0J6VlSV/f/8ilwkICJCbm5tcXFzsbS1atFBmZqby8vLk7u5eaBmbzSabzVa2xQMAygxXKAAAlri7u6tDhw5KTEy0txUUFCgxMVHh4eFFLtOlSxft379fBQUF9ra9e/cqICCgyDABAKj6CBQAAMuio6M1d+5cLVy4UKmpqXr88cd1+vRp+1OfBg0apJiYGHv/xx9/XMePH9eoUaO0d+9erVy5UtOmTdPIkSMrawgAgFLiK08AAMv69++vX3/9VRMnTlRmZqbatm2r1atX22/UPnz4sJyd//+zq6CgIH3xxRcaM2aMWrdurUaNGmnUqFEaO3ZsZQ0BAFBKBAoAQKlERUUpKiqqyHnr168v1BYeHq5vvvmmnKsCAFQUvvIEAAAAwDICBQAAAADLCBQAAAAALCNQAAAAALCMQAEAAADAMgIFAAAAAMsIFAAAAAAsI1AAAAAAsIxAAQAAAMAyAgUAAAAAywgUAAAAACwjUAAAAACwjEABAAAAwDICBQAAAADLCBQAAAAALCNQAAAAALCsxIHiq6++Uq9evRQYGCgnJyctX77cYb4xRhMnTlRAQIA8PT0VERGhffv2lVW9AAAAAKqQEgeK06dPq02bNoqPjy9y/iuvvKI333xTs2fP1pYtW1S7dm1FRkbq7NmzpS4WAAAAQNXiWtIFevTooR49ehQ5zxijmTNn6oUXXlDv3r0lSR988IH8/Py0fPlyPfDAA6WrFgAAAECVUqb3UKSnpyszM1MRERH2Nm9vb4WFhSkpKaksNwUAAACgCijxFYrLyczMlCT5+fk5tPv5+dnnXSw3N1e5ubn21zk5OWVZEgAAAIByVOlPeYqLi5O3t7d9CgoKquySAAAAABRTmQYKf39/SVJWVpZDe1ZWln3exWJiYpSdnW2fMjIyyrIkAAAAAOWoTANFkyZN5O/vr8TERHtbTk6OtmzZovDw8CKXsdls8vLycpgAAAAAVA8lvofi1KlT2r9/v/11enq6UlJSVL9+fQUHB2v06NF66aWX1LRpUzVp0kQTJkxQYGCg+vTpU5Z1AwAAAKgCShwotm3bpjvvvNP+Ojo6WpI0ePBgLViwQM8995xOnz6tESNG6MSJE7r11lu1evVqeXh4lF3VAAAAAKqEEgeKO+64Q8aYS853cnLS5MmTNXny5FIVBgAAAKDqq/SnPAEAAACovggUAAAAACwjUAAAAACwjEABAAAAwDICBQAAAADLCBQAAAAALCNQAABKJT4+XiEhIfLw8FBYWJi2bt1arOUSEhLk5OTED58CQDVHoAAAWLZkyRJFR0crNjZW27dvV5s2bRQZGamjR49edrlDhw7pmWeeUdeuXSuoUgBAeSFQAAAsmzFjhoYPH66hQ4eqZcuWmj17tmrVqqV58+Zdcpn8/HwNHDhQkyZN0nXXXVeB1QIAygOBAgBgSV5enpKTkxUREWFvc3Z2VkREhJKSki653OTJk+Xr66thw4ZVRJkAgHLmWtkFAACqp2PHjik/P19+fn4O7X5+ftqzZ0+Ry2zcuFHvv/++UlJSir2d3Nxc5ebm2l/n5ORYqhcAUD64QgEAqBAnT57UQw89pLlz56phw4bFXi4uLk7e3t72KSgoqByrBACUFFcoAACWNGzYUC4uLsrKynJoz8rKkr+/f6H+Bw4c0KFDh9SrVy97W0FBgSTJ1dVVaWlpuv766wstFxMTo+joaPvrnJwcQgUAVCEECgCAJe7u7urQoYMSExPtj34tKChQYmKioqKiCvUPDQ3V7t27HdpeeOEFnTx5Um+88cYlQ4LNZpPNZivz+gEAZYNAAQCwLDo6WoMHD1bHjh3VqVMnzZw5U6dPn9bQoUMlSYMGDVKjRo0UFxcnDw8P3XTTTQ7L+/j4SFKhdgBA9UGgAABY1r9/f/3666+aOHGiMjMz1bZtW61evdp+o/bhw4fl7MztegBQkxEoAAClEhUVVeRXnCRp/fr1l112wYIFZV8QAKBC8bERAAAAAMsIFAAAAAAsI1AAAAAAsIxAAQAAAMAyAgUAAAAAywgUAAAAACwjUAAAAACwjEABAAAAwDICBQAAAADLCBQAAAAALCNQAAAAALCMQAEAAADAMgIFAAAAAMsIFAAAAAAsI1AAAAAAsIxAAQAAAMAyAgUAAAAAywgUAAAAACwjUAAAAACwjEABAAAAwDICBQAAAADLCBQAAAAALCNQAAAAALCMQAEAAADAMgIFAAAAAMsIFAAAAAAsK/NA8eKLL8rJyclhCg0NLevNAAAAAKgCXMtjpTfeeKO+/PLL/9+Ia7lsBgAAAEAlK5d3+q6urvL39y+PVQMAAACoQsrlHop9+/YpMDBQ1113nQYOHKjDhw9fsm9ubq5ycnIcJgAAAADVQ5kHirCwMC1YsECrV6/WrFmzlJ6erq5du+rkyZNF9o+Li5O3t7d9CgoKKuuSAAAAAJSTMg8UPXr0UL9+/dS6dWtFRkZq1apVOnHihD788MMi+8fExCg7O9s+ZWRklHVJAAAAAMpJud8t7ePjo2bNmmn//v1FzrfZbLLZbOVdBgAAAIByUO6/Q3Hq1CkdOHBAAQEB5b0pAAAAABWszAPFM888ow0bNujQoUPavHmz7r33Xrm4uGjAgAFlvSkAQBUQHx+vkJAQeXh4KCwsTFu3br1k37lz56pr166qV6+e6tWrp4iIiMv2BwBUfWUeKH766ScNGDBAzZs31/33368GDRrom2++0TXXXFPWmwIAVLIlS5YoOjpasbGx2r59u9q0aaPIyEgdPXq0yP7r16/XgAEDtG7dOiUlJSkoKEj33HOPfv755wquHABQVsr8HoqEhISyXiUAoIqaMWOGhg8frqFDh0qSZs+erZUrV2revHkaN25cof6LFi1yeP3ee+/p448/VmJiogYNGlQhNQMAyla530MBAKiZ8vLylJycrIiICHubs7OzIiIilJSUVKx1nDlzRufOnVP9+vXLq0wAQDkr96c8AQBqpmPHjik/P19+fn4O7X5+ftqzZ0+x1jF27FgFBgY6hJKL5ebmKjc31/6aH0AFgKqFKxQAgEoxffp0JSQkaNmyZfLw8LhkP34AFQCqNgIFAMCShg0bysXFRVlZWQ7tWVlZ8vf3v+yyr776qqZPn67//d//VevWrS/blx9ABYCqjUABALDE3d1dHTp0UGJior2toKBAiYmJCg8Pv+Ryr7zyiqZMmaLVq1erY8eOV9yOzWaTl5eXwwQAqDq4hwIAYFl0dLQGDx6sjh07qlOnTpo5c6ZOnz5tf+rToEGD1KhRI8XFxUmSXn75ZU2cOFGLFy9WSEiIMjMzJUl16tRRnTp1Km0cAADrCBQAAMv69++vX3/9VRMnTlRmZqbatm2r1atX22/UPnz4sJyd//9i+KxZs5SXl6e///3vDuuJjY3Viy++WJGlAwDKCIECAFAqUVFRioqKKnLe+vXrHV4fOnSo/AsCAFQo7qEAAAAAYBmBAgAAAIBlBAoAAAAAlhEoAAAAAFhGoAAAAABgGYECAAAAgGUECgAAAACWESgAAAAAWEagAAAAAGAZgQIAAACAZQQKAAAAAJYRKAAAAABYRqAAAAAAYBmBAgAAAIBlBAoAAAAAlhEoAAAAAFhGoAAAAABgGYECAAAAgGUECgAAAACWESgAAAAAWEagAAAAAGAZgQIAAACAZQQKAAAAAJYRKAAAAABYRqAAAAAAYBmBAgAAAIBlBAoAAAAAlhEoAAAAAFhGoAAAAABgGYECAAAAgGUECgAAAACWESgAAAAAWEagAAAAAGAZgQIAAACAZeUWKOLj4xUSEiIPDw+FhYVp69at5bUpAEAlKunxfunSpQoNDZWHh4datWqlVatWVVClAIDyUC6BYsmSJYqOjlZsbKy2b9+uNm3aKDIyUkePHi2PzQEAKklJj/ebN2/WgAEDNGzYMO3YsUN9+vRRnz599N1331Vw5QCAslIugWLGjBkaPny4hg4dqpYtW2r27NmqVauW5s2bVx6bAwBUkpIe79944w11795dzz77rFq0aKEpU6aoffv2evvttyu4cgBAWXEt6xXm5eUpOTlZMTEx9jZnZ2dFREQoKSmpUP/c3Fzl5ubaX2dnZ0uScnJyLNdQkHvG8rIAUJ1YPVZeWM4YY3nbJT3eS1JSUpKio6Md2iIjI7V8+fJLbqc8zhMAar4L7wdzcnKu+O/LKc7yxV1XSddbFuuyqkTnCVPGfv75ZyPJbN682aH92WefNZ06dSrUPzY21khiYmJiYqqEKSMjo8KO98YY4+bmZhYvXuzQFh8fb3x9fS+5Hc4TTExMTJU3Fec8UeZXKEoqJibG4dOqgoICHT9+XA0aNJCTk1OJ15eTk6OgoCBlZGTIy8urLEut8dh31rHvrGPfWVeafWeM0cmTJxUYGFhO1ZWdsj5PSFf3393VPHbp6h4/Y2fsJRl7Sc4TZR4oGjZsKBcXF2VlZTm0Z2Vlyd/fv1B/m80mm83m0Obj41PqOry8vK66P5iywr6zjn1nHfvOOqv7ztvbu1TbLenxXpL8/f1L1F8qv/OEdHX/3V3NY5eu7vEzdsZeXMU9T5T5Tdnu7u7q0KGDEhMT7W0FBQVKTExUeHh4WW8OAFBJrBzvw8PDHfpL0po1azg/AEA1Vi5feYqOjtbgwYPVsWNHderUSTNnztTp06c1dOjQ8tgcAKCSXOl4P2jQIDVq1EhxcXGSpFGjRun222/Xa6+9pp49eyohIUHbtm3TnDlzKnMYAIBSKJdA0b9/f/3666+aOHGiMjMz1bZtW61evVp+fn7lsTkHNptNsbGxhS6P48rYd9ax76xj31lXFfbdlY73hw8flrPz/18M79y5sxYvXqwXXnhBzz//vJo2barly5frpptuqtC6q8K+qyxX89ilq3v8jJ2xlxcnY0rxzEAAAAAAV7Vy+WE7AAAAAFcHAgUAAAAAywgUAAAAACwjUAAAAACwrEYEiuPHj2vgwIHy8vKSj4+Phg0bplOnThVrWWOMevToIScnJy1fvrx8C62CSrrvjh8/rieffFLNmzeXp6engoOD9dRTTyk7O7sCq64c8fHxCgkJkYeHh8LCwrR169bL9l+6dKlCQ0Pl4eGhVq1aadWqVRVUadVTkn03d+5cde3aVfXq1VO9evUUERFxxX1dk5X07+6ChIQEOTk5qU+fPuVbYDVldb9WJ3Fxcbr55ptVt25d+fr6qk+fPkpLS3Poc/bsWY0cOVINGjRQnTp11Ldv30I/PFjdTZ8+XU5OTho9erS9raaP++eff9Y//vEPNWjQQJ6enmrVqpW2bdtmn2+M0cSJExUQECBPT09FRERo3759lVhx2cjPz9eECRPUpEkTeXp66vrrr9eUKVP05+cP1aSxf/XVV+rVq5cCAwOLfB9bnLGW5j30xRur9rp3727atGljvvnmG/P111+bG264wQwYMKBYy86YMcP06NHDSDLLli0r30KroJLuu927d5v77rvPrFixwuzfv98kJiaapk2bmr59+1Zg1RUvISHBuLu7m3nz5pnvv//eDB8+3Pj4+JisrKwi+2/atMm4uLiYV155xfzwww/mhRdeMG5ubmb37t0VXHnlK+m+e/DBB018fLzZsWOHSU1NNUOGDDHe3t7mp59+quDKK19J990F6enpplGjRqZr166md+/eFVNsNWJ1v1Y3kZGRZv78+ea7774zKSkp5i9/+YsJDg42p06dsvd57LHHTFBQkElMTDTbtm0zt9xyi+ncuXMlVl22tm7dakJCQkzr1q3NqFGj7O01edzHjx83jRs3NkOGDDFbtmwxBw8eNF988YXZv3+/vc/06dONt7e3Wb58udm5c6f529/+Zpo0aWJ+//33Sqy89KZOnWoaNGhgPvvsM5Oenm6WLl1q6tSpY9544w17n5o09lWrVpnx48ebTz75pMj3scUZa2neQ/9ZtQ8UP/zwg5Fkvv32W3vb559/bpycnMzPP/982WV37NhhGjVqZI4cOXJVBorS7Ls/+/DDD427u7s5d+5ceZRZJXTq1MmMHDnS/jo/P98EBgaauLi4Ivvff//9pmfPng5tYWFh5tFHHy3XOquiku67i50/f97UrVvXLFy4sLxKrLKs7Lvz58+bzp07m/fee88MHjyYQFGE0v5NVldHjx41ksyGDRuMMcacOHHCuLm5maVLl9r7pKamGkkmKSmpssosMydPnjRNmzY1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JddxtQaKku67devWGUlFTunp6ZUziAry1ltvmeDgYOPu7m46depkvvnmG/u822+/3QwePNih/4cffmiaNWtm3N3dzY033mhWrlxZwRVXHSXZd40bNy7y7ys2NrbiC68CSvp392cEiku73H6tKS51rJ4/f769z++//26eeOIJU69ePVOrVi1z7733miNHjlRe0eXk4kBR08f9n//8x9x0003GZrOZ0NBQM2fOHIf5BQUFZsKECcbPz8/YbDbTrVs3k5aWVknVlp2cnBwzatQoExwcbDw8PMx1111nxo8fb3Jzc+19atLYL/We7MJ5oThjvdL7wOJyMuZPPx8IAAAAACVQZe+hAAAAAFD1ESgAAAAAWEagAAAAAGAZgQIAAACAZQQKAAAAAJYRKAAAAABYRqAAAAAAYBmBAgAAAIBlBAoAAFAjhYSEaObMmZVdBlDjEShQIYYMGSInJ6dC0/79+0u97jvuuEOjR48ufZGX8OKLL6pt27alXk9ISIh93J6engoJCdH999+vtWvXlr5IAKiGLpwbpk+f7tC+fPlyOTk5VVJVhX322We6/fbbVbduXdWqVUs333yzFixYUOL1lOR88udzZe3atdW0aVMNGTJEycnJJd4uUN4IFKgw3bt315EjRxymJk2aVHZZdnl5eeW+jcmTJ+vIkSNKS0vTBx98IB8fH0VERGjq1Knlvu2KGB8AlJSHh4defvll/fbbb5VdSpHeeust9e7dW126dNGWLVu0a9cuPfDAA3rsscf0zDPPlOu258+fryNHjuj7779XfHy8Tp06pbCwMH3wwQflul1JOnfuXLlvAzUHgQIVxmazyd/f32FycXHRjBkz1KpVK9WuXVtBQUF64okndOrUKYdlN23apDvuuEO1atVSvXr1FBkZqd9++01DhgzRhg0b9MYbb9g/yTl06JAkacOGDerUqZNsNpsCAgI0btw4nT9/3r7OO+64Q1FRURo9erQaNmyoyMjIYo1jyJAh6tOnj1599VUFBASoQYMGGjlyZLEOvnXr1pW/v7+Cg4N12223ac6cOZowYYImTpyotLQ0e7/vvvtOPXr0UJ06deTn56eHHnpIx44ds88/efKkBg4cqNq1aysgIECvv/56oSs1ISEhmjJligYNGiQvLy+NGDFCkrRx40Z17dpVnp6eCgoK0lNPPaXTp0/bl8vNzdUzzzyjRo0aqXbt2goLC9P69euLtW8AoKQiIiLk7++vuLi4y/b7+OOPdeONN8pmsykkJESvvfaaw/yjR4+qV69e8vT0VJMmTbRo0aJC6zhx4oQeeeQRXXPNNfLy8tJdd92lnTt3XnKbGRkZevrppzV69GhNmzZNLVu21A033KCnn35a//znP/Xaa69py5YtkqQFCxbIx8fHYfk/X2lZsGCBJk2apJ07d9rPV1e6yuHj4yN/f3+FhITonnvu0UcffaSBAwcqKirKIYBd6bh+5MgR9ezZ075vFi9eXOjrYE5OTpo1a5b+9re/qXbt2vYPuj799FO1b99eHh4euu666zRp0iSHc2lJ9ylqJgIFKp2zs7PefPNNff/991q4cKHWrl2r5557zj4/JSVF3bp1U8uWLZWUlKSNGzeqV69eys/P1xtvvKHw8HANHz7cftUjKChIP//8s/7yl7/o5ptv1s6dOzVr1iy9//77eumllxy2vXDhQrm7u2vTpk2aPXt2sWtet26dDhw4oHXr1mnhwoVasGCBpcvfkjRq1CgZY/Tpp59K+uPgfNddd6ldu3batm2bVq9eraysLN1///32ZaKjo7Vp0yatWLFCa9as0ddff63t27cXWverr76qNm3aaMeOHZowYYIOHDig7t27q2/fvtq1a5eWLFmijRs3Kioqyr5MVFSUkpKSlJCQoF27dqlfv37q3r279u3bZ2l8AHA5Li4umjZtmt566y399NNPRfZJTk7W/fffrwceeEC7d+/Wiy++qAkTJjgcd4cMGaKMjAytW7dOH330kd555x0dPXrUYT39+vXT0aNH9fnnnys5OVnt27dXt27ddPz48SK3+9FHH+ncuXNFXol49NFHVadOHf373/8u1jj79++vp59+WjfeeKP9fNW/f/9iLftnY8aM0cmTJ7VmzRpJKtZxfdCgQfrll1+0fv16ffzxx5ozZ06hfSP98ZWse++9V7t379bDDz+sr7/+WoMGDdKoUaP0ww8/6N1339WCBQscrqqXdJ+ihjJABRg8eLBxcXExtWvXtk9///vfi+y7dOlS06BBA/vrAQMGmC5dulxy3bfffrsZNWqUQ9vzzz9vmjdvbgoKCuxt8fHxpk6dOiY/P9++XLt27a5Ye2xsrGnTpo3DWBo3bmzOnz9vb+vXr5/p37//ZdfTuHFj8/rrrxc5z8/Pzzz++OPGGGOmTJli7rnnHof5GRkZRpJJS0szOTk5xs3NzSxdutQ+/8SJE6ZWrVoO+6Fx48amT58+DusZNmyYGTFihEPb119/bZydnc3vv/9ufvzxR+Pi4mJ+/vlnhz7dunUzMTExlx0fAJTU4MGDTe/evY0xxtxyyy3m4YcfNsYYs2zZMvPntygPPvigufvuux2WffbZZ03Lli2NMcakpaUZSWbr1q32+ampqUaS/bj79ddfGy8vL3P27FmH9Vx//fXm3XffLbK+xx57zHh7e1+y/tatW5sePXoYY4yZP39+ob4Xj+Pi88nlSDLLli0r1P77778bSebll182xlz5uH5hP3z77bf2+fv27XPYNxe2N3r0aIf1dOvWzUybNs2h7V//+pcJCAiwb6ek+xQ1k2tlBRlcfe68807NmjXL/rp27dqSpC+//FJxcXHas2ePcnJydP78eZ09e1ZnzpxRrVq1lJKSon79+pVoW6mpqQoPD3e4qa9Lly46deqUfvrpJwUHB0uSOnToYGksN954o1xcXOyvAwICtHv3bknStGnTNG3aNPu8H374wb69SzHG2GvduXOn1q1bpzp16hTqd+DAAf3+++86d+6cOnXqZG/39vZW8+bNC/Xv2LGjw+udO3dq165dDl8FMMaooKBA6enpOnjwoPLz89WsWTOH5XJzc9WgQYPLjgEASuPll1/WXXfdVeTVgNTUVPXu3duhrUuXLpo5c6by8/OVmpoqV1dXh2N6aGiow1eQdu7cqVOnThU6lv3+++86cOBA2Q6mBB577DH9z//8j/31xV/5vZgxRpIczhmXO67v3btXrq6uat++vX3+DTfcoHr16hVad1HnjE2bNjlckcjPz7efo6vqPkXFI1CgwtSuXVs33HCDQ9uhQ4f017/+VY8//rimTp2q+vXra+PGjRo2bJjy8vJUq1YteXp6lmtNVri5uTm8dnJyUkFBgaQ/Tg5//npSYGDgZdf13//+V7/++qv9BvVTp06pV69eevnllwv1DQgIKNGTsS4e36lTp/Too4/qqaeeKtQ3ODhYu3btkouLi5KTkx0Ck6QiAw4AlJXbbrtNkZGRiomJ0ZAhQ8p8/adOnVJAQECR94RdfO/DBc2aNVN2drZ++eWXQsfyvLw8HThwQHfeeaekP76+e+HN/gXFubdu8uTJJbq5OzU1VZIczhmXO67v3bu32Osu6pwxadIk3XfffYX6enh4WNqnqJkIFKhUycnJKigo0GuvvSZn5z9u6fnwww8d+rRu3VqJiYmaNGlSketwd3dXfn6+Q1uLFi308ccfO3zyv2nTJtWtW1fXXnttOYzk/9WvX1/169cvdv833nhDzs7O6tOnjySpffv2+vjjjxUSEiJX18L/i1533XVyc3PTt99+a7/ykZ2drb179+q222677Lbat2+vH374oVCwu6Bdu3bKz8/X0aNH1bVr12KPAQDKwvTp09W2bdtCV1xbtGihTZs2ObRt2rRJzZo1k4uLi0JDQ3X+/HklJyfr5ptvliSlpaXpxIkT9v7t27dXZmamXF1dFRISUqx6+vbtq7Fjx+q1114rdBP47Nmzdfr0aQ0YMECSdM011+jkyZM6ffq0/Y15SkqKwzJFna98fX3l6+tbrHokaebMmfLy8lJERIR9XJc7rjdv3lznz5/Xjh077Fdw9u/fX6ynarVv315paWmXXLeVfYqaiZuyUaluuOEGnTt3Tm+99ZYOHjyof/3rX4Vujo6JidG3336rJ554Qrt27dKePXs0a9Ys+1OPQkJCtGXLFh06dEjHjh1TQUGBnnjiCWVkZOjJJ5/Unj179Omnnyo2NlbR0dH24FIZTp48qczMTGVkZOirr77SiBEj9NJLL2nq1Kn2A/bIkSN1/PhxDRgwQN9++60OHDigL774QkOHDlV+fr7q1q2rwYMH69lnn9W6dev0/fffa9iwYXJ2dr7ic9vHjh2rzZs3KyoqSikpKdq3b58+/fRT+817zZo108CBAzVo0CB98sknSk9P19atWxUXF6eVK1eW+/4BcHVr1aqVBg4cqDfffNOh/emnn1ZiYqKmTJmivXv3auHChXr77bftn+w3b95c3bt316OPPqotW7YoOTlZjzzyiMMV7oiICIWHh6tPnz763//9Xx06dEibN2/W+PHjtW3btiLrCQ4O1iuvvKKZM2dq/Pjx2rNnjw4cOKAZM2boueee09NPP62wsDBJUlhYmGrVqqXnn39eBw4c0OLFiws9rCMkJETp6elKSUnRsWPHlJube9n9ceLECWVmZurHH3/UmjVr9Pe//12LFy/WrFmz7FcArnRcDw0NVUREhEaMGKGtW7dqx44dGjFihDw9Pa94zpg4caI++OADTZo0Sd9//71SU1OVkJCgF154wfI+RQ1VmTdw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0ujRo9WwYUNFRkYWWff48eP1yy+/6Msvv1SPHj0UHBys2267TV988YXc3Nw0cuRIe9+iLpe3bdtWL774on2+JN17771ycnKyv74UV1dX+fv7KzAwUK1atdKTTz6pDRs26LvvvtPLL79s75ebm6tnnnlGjRo1Uu3atRUWFqb169c7rGvu3LkKCgpSrVq1dO+992rGjBny8fGxz3/xxRfVtm1bvffee2rSpIk8PDwkSSdOnNAjjzyia665Rl5eXrrrrru0c+dOh3V/+umnat++vTw8PHTddddp0qRJDvsaAMpKRESE/P39FRcXd9l+H3/8sW688UbZbDaFhITotddec5h/9OhR9erVS56enmrSpIkWLVpUaB3FOf5dzqFDh+Tk5KRPPvlEd955p2rVqqU2bdooKSnpiss6OTnJ399fAQEBatGihYYNG6bNmzfr1KlTeu655+z9CgoKFBcXpyZNmsjT01Nt2rTRRx995LCuFStWqGnTpvLw8NCdd96phQsXysnJSSdOnJD0xxURHx8frVixQi1btpTNZtPhw4eLdW7ZuHGjunbtKk9PTwUFBempp57S6dOni72PULMRKFBhnJ2d9eabb+r777/XwoULtXbtWoeDZUpKirp166aWLVsqKSlJGzduVK9evZSfn6833nhD4eHhGj58uP2qR1BQkH7++Wf95S9/0c0336ydO3dq1qxZev/99/XSSy85bHvhwoVyd3fXpk2bNHv27EK1FRQUKCEhQQMHDpS/v7/DPE9PTz3xxBP64osvdPz48WKN9dtvv5UkzZ8/X0eOHLG/LonQ0FD16NFDn3zyib0tKipKSUlJSkhI0K5du9SvXz91795d+/btk/RHIHvsscc0atQopaSk6O6779bUqVMLrXv//v36+OOP9cknnyglJUWS1K9fPx09elSff/65kpOT1b59e3Xr1s0+5q+//lqDBg3SqFGj9MMPP+jdd9/VggULilw/AJSWi4uLpk2bprfeeks//fRTkX2Sk5N1//3364EHHtDu3bv14osvasKECVqwYIG9z5AhQ5SRkaF169bpo48+0jvvvKOjR486rOdKx7/iGj9+vJ555hmlpKSoWbNmGjBggKUPXXx9fTVw4ECtWLFC+fn5kqS4uDh98MEHmj17tr7//nuNGTNG//jHP7RhwwZJUnp6uv7+97+rT58+2rlzpx599FGNHz++0LrPnDmjl19+We+9956+//57+fr6XvHccuDAAXXv3l19+/bVrl27tGTJEm3cuFFRUVElHhtqKAOUocGDBxsXFxdTu3Zt+/T3v/+9yL5Lly41DRo0sL8eMGCA6dKlyyXXffvtt5tRo0Y5tD3//POmefPmpqCgwN4WHx9v6tSpY/Lz8+3LtWvX7rJ1Z2ZmGknm9ddfL3L+J598YiSZLVu2GGOMady4caG+bdq0MbGxsfbXksyyZcsuu11jjImNjTVt2rQpct7YsWONp6enMcaYH3/80bi4uJiff/7ZoU+3bt1MTEyMMcaY/v37m549ezrMHzhwoPH29nbYnpubmzl69Ki97euvvzZeXl7m7NmzDstef/315t1337VvZ9q0aQ7z//Wvf5mAgIArjhEASmLw4MGmd+/exhhjbrnlFvPwww8bY4xZtmyZ+fNblwcffNDcfffdDss+++yzpmXLlsYYY9LS0owks3XrVvv81NRUh+N9cY5/RfnzMT49Pd1IMu+99559/vfff28kmdTU1EuuY/78+Q7H5z+bNWuWkWSysrLM2bNnTa1atczmzZsd+gwbNswMGDDAGPPH+eKmm25ymD9+/Hgjyfz222/27UkyKSkp9j7FObcMGzbMjBgxwmH+119/bZydnc3vv/9+yfHh6uFaOTEGNdmdd96pWbNm2V/Xrl1bkvTll18qLi5Oe/bsUU5Ojs6fP6+zZ8/qzJkzqlWrllJSUtSvX78SbSs1NVXh4eEON+l16dJFp06d0k8//aTg4GBJUocOHYq1PmNMibZfEocPH1bLli3tr59//nk9//zzV6znwth2796t/Px8NWvWzKFPbm6uGjRoIElKS0vTvffe6zC/U6dO+uyzzxzaGjdurGuuucb+eufOnTp16pR9PRf8/vvvOnDggL3Ppk2bHK5I5OfnO/w3BICy9vLLL+uuu+7SM888U2heamqqevfu7dDWpUsXzZw5U/n5+UpNTZWrq6vDOSA0NNTha6DFOf4VV+vWre3/DggIkPTHV65CQ0NVp04d+7x//OMfRV4t/7ML56MLDzY5c+aM7r77boc+eXl5ateunaQ/jv8333yzw/xOnToVWq+7u7tDncU5t+zcuVO7du1y+LqYMUYFBQVKT09XixYtLjsW1HwECpS52rVr64YbbnBoO3TokP7617/q8ccf19SpU1W/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\n",
      "text/plain": [
       "<Figure size 800x600 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(2, 2, figsize=(8, 6))\n",
    "ax[0, 0].bar(range(n_modules), sim_data.generator.U.sum(0)[sim_data.module_causal_order])\n",
    "ax[0, 1].bar(range(n_features), sim_data.generator.U.sum(1)[sim_data.feature_causal_order])\n",
    "ax[1, 0].bar(range(n_modules), sim_data.generator.V.sum(1)[sim_data.module_causal_order])\n",
    "ax[1, 1].bar(range(n_features), sim_data.generator.V.sum(0)[sim_data.feature_causal_order])\n",
    "ax[0, 0].set_xlabel('Factor In-Degree')\n",
    "ax[1, 0].set_xlabel('Factor Out-Degree')\n",
    "ax[0, 1].set_xlabel('Node Out-Degree')\n",
    "ax[1, 1].set_xlabel('Node In-Degree')\n",
    "plt.tight_layout()\n",
    "plt.savefig('sim_degree.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7293152d",
   "metadata": {},
   "source": [
    "## Correlation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "2354a9cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "adj_mtx = (np.matmul(sim_data.generator.U, sim_data.generator.V) > 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "dffecbbb",
   "metadata": {},
   "outputs": [],
   "source": [
    "corr = np.zeros((n_features, n_features))\n",
    "for i in range(n_features):\n",
    "    for j in range(n_features):\n",
    "        corr[i, j] = np.corrcoef(sim_data.data[:, i], sim_data.data[:, j])[0][1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "ff02bc32",
   "metadata": {},
   "outputs": [],
   "source": [
    "indices = np.where(adj_mtx.sum(1) > 0)[0]\n",
    "mean_corr_causal = []\n",
    "mean_corr_noncausal = []\n",
    "for idx in indices:\n",
    "    mean_corr_causal.extend(list(corr[idx, np.where(adj_mtx[idx] > 0)[0]]))\n",
    "    mean_corr_noncausal.extend(list(corr[idx, np.where(adj_mtx[idx] == 0)[0]]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "691f899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure()\n",
    "plt.violinplot([mean_corr_causal, mean_corr_noncausal])\n",
    "plt.xticks([1, 2], ['Causal Pair', 'Non-Causal Pair'])\n",
    "plt.yticks(np.linspace(-1, 1, 21))\n",
    "plt.grid('on')\n",
    "plt.ylabel('Correlation')\n",
    "plt.savefig('corr_violinplot.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d2c034e",
   "metadata": {},
   "source": [
    "# Fisher Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "739f2642",
   "metadata": {},
   "outputs": [],
   "source": [
    "from causallearn.utils.cit import CIT\n",
    "adj_mtx = (np.matmul(sim_data.generator.U, sim_data.generator.V) > 0)\n",
    "pval_0, pval_1 = [], []\n",
    "fisherz_obj = CIT(sim_data.data, \"fisherz\") # construct a CIT instance with data and method name\n",
    "# All upstream genes\n",
    "X = np.where(sim_data.generator.U[:, 0] > 0)[0]\n",
    "\n",
    "for x in range(100):\n",
    "    Y_0 = np.where(adj_mtx[x] == 0)[0]\n",
    "    Y_1 = np.where(adj_mtx[x] > 0)[0] # down stream genes\n",
    "    \n",
    "    for y1 in Y_1:\n",
    "        S = np.setdiff1d(X, np.array([x, y1]))\n",
    "        pval_1.append(fisherz_obj(x, y1, S))\n",
    "\n",
    "    invalid = 0\n",
    "    for y0 in Y_0:\n",
    "        S = np.setdiff1d(X, np.array([x, y0]))\n",
    "        try:\n",
    "            pval_0.append(fisherz_obj(x, y0, S))\n",
    "        except ValueError:\n",
    "            invalid += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "391995c3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ZA0bNkwbN27Url27tHbtWkkKOQZwufnMZz4jh8OhvXv3nrOmI+8fp9N53venJD377LPasWOHxo0bp/Xr12vw4MHBOSkd+QxA+COMIOjxxx/Xf/zHf2jHjh3BtmuvvVZvvvlmSN2bb76pwYMHKyIiokOvm56erquvvlpXX321Bg4cKEm6/fbb1djYqJKSknb3OXnyZPBYs2bN0je/+U0NHTpUaWlpOnToUEjtlVdeGfIvqffff7/Nv8oSEhI0ffp0lZWVaf369dq4caNOnDihXbt2KRAIaOXKlfr85z+vwYMHq6qqqkO/F2Bnffv21aRJk7R27Vp5vd4220+ePNmh98+VV16pmpqakECye/fuNq83YsQIFRQU6K233tKQIUP04osvSurYZwDCH2EEQUOHDtV3v/tdrV69Otj2wAMPqLy8XI8++qj279+v559/XmvWrNHChQs/1bFycnLkdrv1wAMPyO12a8eOHTp8+LDKy8t122236fnnn5d05l9nr7zyinbv3q2//vWvuv3224MjLq2+/OUva82aNXr33Xf19ttv6wc/+EHISM2qVav07//+79q7d6/279+vDRs2KC0tTb1799bVV1+tjz/+WE899ZQOHDigF154QevWrftUvxtgF2vXrlVLS4vGjBmjjRs36v3339eePXu0evVqjR07tkPvnwkTJuj48eNasWKFKioqtHbtWv3ud78Lbj948KAKCgqCnwG///3v9f777+vaa6+V1LHPANiA0RkrMOrsCaytDh48aLlcLuvsP43f/OY31nXXXWddccUV1oABA6zCwsKQfdqbPHbDDTdYixcvvmAf1q9fb33pS1+y4uPjrdjYWGvYsGHWkiVLrI8++ijYn5tuusnq1auXlZmZaa1Zs8a68cYbrfvuuy/4Gh9++KF18803W7GxsdZnPvMZa+vWrSETWEtLS63hw4dbsbGxVkJCgvWVr3zFeuedd4L7r1q1yurXr5/Vq1cva9KkSdavfvUrS1KwD0xgxeWsqqrKmjdvnjVw4EDL5XJZ6enp1je+8Q3rD3/4g2VZF37/WJZlPf3001ZmZqYVGxtrzZw503rssceCE1hramqsadOmWf369bNcLpc1cOBAa9GiRVZLS4tlWR37DGACa/hzWFYHZykBAAB0A07TAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjPp/mNOi4bS6ncgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.boxplot([pval_0, pval_1])\n",
    "plt.xticks([1, 2], ['Non-Causal', 'Causal'])\n",
    "xmin, xmax = plt.xlim()\n",
    "plt.plot([xmin, xmax], [0.05, 0.05])\n",
    "plt.savefig(f'{figure_path}/fisher_z_random_cond.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6f8cc543",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving\n"
     ]
    }
   ],
   "source": [
    "folder = '/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/data/VBFG/simulation'\n",
    "sim_data.save_data(folder, 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f736f5c",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "f8f82bf5",
   "metadata": {},
   "source": [
    "# UMAP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "ece03c26",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "pca = PCA(n_components=3)\n",
    "x_pca = pca.fit_transform(sim_data.data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "4c87be2a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0eDSqrq62sjIyDD+/u//3ti3b5+xevVqo3v37sbLL79sYeX2UF5ebuzdu9d45plnjJ49exp79+419u7da9TW1hqGYRjNzc3GNddcY0yePNkoLi421q9fb/Tr189YuHChxZVba/Xq1YbL5TJWrVplfPbZZ8aPf/xjo3fv3iFXU8Ewamtrg/+mJBn/9m//Zuzdu9coLy83DMMwFi9ebPTu3dt46623jI8//tiYNm2aMXToUOP06dMWV2692bNnGx6Px3jvvfdCPte+/vrr4DY//elPjUGDBhnvvvuusWvXLiM3N9fIzc21sGrrLViwwNi8ebNRWlpqfPzxx8aCBQsMh8Nh/OlPfzIMo3MfMwJLJ7dy5UpDUrvL2T766CPjxhtvNFwul3HppZcaixcvtqhie8nPz2/32G3atCm4TVlZmTF16lSjW7duRt++fY1HHnnEaGpqsq5om1i6dKkxaNAgIzU11Rg/fryxfft2q0uynU2bNrX77ys/P98wjJZLm5988kkjIyPDcLlcxqRJk4z9+/dbW7RNdPS5tnLlyuA2p0+fNv7hH/7BSE9PN7p3727ceeedIT/WuqL77rvPGDx4sJGammr069fPmDRpUjCsGEbnPmYOwzCMi9ihAwAAEDGuEgIAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALZHYAEAALb3/wHJwLZeivlzYgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.scatter(x_pca[:, 1], x_pca[:, 2], s=5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2cc7e32",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
