{
 "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, VAEGraphShared\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",
    "figure_path = '/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/figures/VBFG/simulation'\n",
    "!mkdir -p {figure_path}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c3acc9c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SimulationDataset(Dataset):\n",
    "    \"\"\"\n",
    "    A generic class for simulation data loading and extraction, as well as pre-filtering of interventions\n",
    "    NOTE: the 0-th regime should always be the observational one\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(\n",
    "        self,\n",
    "        file_path,\n",
    "        i_dataset,\n",
    "        intervention=True,\n",
    "        fraction_regimes_to_ignore=None,\n",
    "        regimes_to_ignore=None,\n",
    "        load_ignored=False,\n",
    "    ) -> None:\n",
    "        \"\"\"\n",
    "        :param str file_path: Path to the data and the DAG\n",
    "        :param int i_dataset: Exemplar to use (usually in [1,10])\n",
    "        :param boolean intervention: If True, use interventional data with interventional targets\n",
    "        :param list regimes_to_ignore: Regimes that are ignored during training\n",
    "        \"\"\"\n",
    "        super(SimulationDataset, self).__init__()\n",
    "        self.file_path = file_path\n",
    "        self.i_dataset = i_dataset\n",
    "        self.intervention = intervention\n",
    "        # load data\n",
    "        all_data, all_masks, all_regimes = self.load_data()\n",
    "        # index of all regimes, even if not used in the regimes_to_ignore case\n",
    "        self.all_regimes_list = np.unique(all_regimes)\n",
    "\n",
    "        if fraction_regimes_to_ignore is not None or regimes_to_ignore is not None:\n",
    "            if fraction_regimes_to_ignore is not None and regimes_to_ignore is not None:\n",
    "                raise ValueError(\"either fraction or list, not both\")\n",
    "            if fraction_regimes_to_ignore is not None:\n",
    "                # select fraction to ignore\n",
    "                np.random.seed(0)\n",
    "                sampling_list = self.all_regimes_list\n",
    "                self.regimes_to_ignore = np.random.choice(\n",
    "                    sampling_list,\n",
    "                    int(fraction_regimes_to_ignore * len(sampling_list)),\n",
    "                )\n",
    "            else:\n",
    "                self.regimes_to_ignore = regimes_to_ignore\n",
    "\n",
    "            to_keep = np.array(\n",
    "                [\n",
    "                    regime not in self.regimes_to_ignore\n",
    "                    for regime in np.array(all_regimes)\n",
    "                ]\n",
    "            )\n",
    "            if not load_ignored:\n",
    "                data = all_data[to_keep]\n",
    "                masks = [mask for i, mask in enumerate(all_masks) if to_keep[i]]\n",
    "                regimes = np.array(\n",
    "                    [regime for i, regime in enumerate(all_regimes) if to_keep[i]]\n",
    "                )\n",
    "            else:\n",
    "                data = all_data[~to_keep]\n",
    "                masks = [mask for i, mask in enumerate(all_masks) if ~to_keep[i]]\n",
    "                regimes = np.array(\n",
    "                    [regime for i, regime in enumerate(all_regimes) if ~to_keep[i]]\n",
    "                )\n",
    "        else:\n",
    "            data = all_data\n",
    "            masks = all_masks\n",
    "            regimes = all_regimes\n",
    "\n",
    "        self.data = data\n",
    "        self.regimes = regimes\n",
    "        self.masks = np.array(masks, dtype=object)\n",
    "\n",
    "        self.num_regimes = np.unique(self.regimes).shape[0]\n",
    "        self.num_samples = self.data.shape[0]\n",
    "        self.dim = self.data.shape[1]\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        if self.intervention:\n",
    "            # binarize mask from list\n",
    "            masks_list = self.masks[idx]\n",
    "            masks = np.ones((self.dim,))\n",
    "            for j in masks_list:\n",
    "                masks[j] = 0\n",
    "            return (\n",
    "                self.data[idx].astype(np.float32),\n",
    "                masks.astype(np.float32),\n",
    "                self.regimes[idx],\n",
    "            )\n",
    "        else:\n",
    "            # put full ones mask\n",
    "            return (\n",
    "                self.data[idx].astype(np.float32),\n",
    "                np.ones((self.dim,)).astype(np.float32),\n",
    "                self.regimes[idx],\n",
    "            )\n",
    "\n",
    "    def __len__(self):\n",
    "        return self.data.shape[0]\n",
    "\n",
    "    def load_data(self):\n",
    "        \"\"\"\n",
    "        Load the mask, regimes, and data\n",
    "        \"\"\"\n",
    "        if self.intervention:\n",
    "            name_data = f\"data_interv{self.i_dataset}.npy\"\n",
    "        else:\n",
    "            name_data = f\"data{self.i_dataset}.npy\"\n",
    "\n",
    "        # Load data\n",
    "        self.data_path = os.path.join(self.file_path, name_data)\n",
    "        data = np.load(self.data_path)\n",
    "\n",
    "        # Load intervention masks and regimes\n",
    "        masks = []\n",
    "        if self.intervention:\n",
    "            name_data = f\"data_interv{self.i_dataset}.npy\"\n",
    "            interv_path = os.path.join(\n",
    "                self.file_path, f\"intervention{self.i_dataset}.csv\"\n",
    "            )\n",
    "            regimes = np.genfromtxt(\n",
    "                os.path.join(self.file_path, f\"regime{self.i_dataset}.csv\"),\n",
    "                delimiter=\",\",\n",
    "            )\n",
    "            regimes = regimes.astype(int)\n",
    "\n",
    "            # read masks\n",
    "            with open(interv_path, \"r\") as f:\n",
    "                interventions_csv = csv.reader(f)\n",
    "                for row in interventions_csv:\n",
    "                    mask = [int(x) for x in row]\n",
    "                    masks.append(mask)\n",
    "        else:\n",
    "            regimes = np.array([0] * data.shape[0])\n",
    "\n",
    "        return data, masks, regimes\n",
    "\n",
    "    def convert_masks(self, idxs):\n",
    "        \"\"\"\n",
    "        Convert mask index to mask vectors\n",
    "        :param np.ndarray idxs: indices of mask to convert\n",
    "        :return: masks\n",
    "        Example:\n",
    "            if self.masks[i] = [1,4]\n",
    "                self.dim = 10 then\n",
    "            masks[i] = [1,0,1,1,0,1,1,1,1,1]\n",
    "        \"\"\"\n",
    "        masks_list = [self.masks[i] for i in idxs]\n",
    "\n",
    "        masks = torch.ones((idxs.shape[0], self.dim))\n",
    "        for i, m in enumerate(masks_list):\n",
    "            for j in m:\n",
    "                masks[i, j] = 0\n",
    "\n",
    "        return masks"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "07d56208",
   "metadata": {},
   "source": [
    "## 1.1 Load Training and Validation Datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b000b1bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# path='/XXXX-13/XXXX-14/XXXX-15/shared_data/dcdfg_pc/data_p100_m10_n50000_linear_uniform'\n",
    "data_path='/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/data/ABCDEFG/simulation'\n",
    "graph = np.load(f'{data_path}/DAG0.npy')\n",
    "U0 = np.load(f'{data_path}/U0.npy')\n",
    "V0 = np.load(f'{data_path}/V0.npy')\n",
    "module_causal_order = np.load(f'{data_path}/module_order0.npy')\n",
    "# intervention = pd.read_csv(f'{data_path}/intervention1.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6a1d8a94",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_samples = 100000\n",
    "np.random.seed(42)\n",
    "\n",
    "\n",
    "train_dataset = SimulationDataset(\n",
    "    data_path, 1, fraction_regimes_to_ignore=None, intervention=True\n",
    ")\n",
    "\"\"\"\n",
    "regimes_to_ignore = train_dataset.regimes_to_ignore\n",
    "test_dataset = SimulationDataset(\n",
    "    data_path, 1, regimes_to_ignore=regimes_to_ignore, load_ignored=True, intervention=True\n",
    ")\n",
    "\"\"\"\n",
    "\n",
    "train_size = int(0.8 * len(train_dataset))\n",
    "val_size = len(train_dataset) - train_size\n",
    "train_dataset, val_dataset = random_split(train_dataset, [train_size, val_size])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9c0efd79",
   "metadata": {},
   "outputs": [],
   "source": [
    "#test part\n",
    "seed=42\n",
    "batch_size=128"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2bcc08f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_loader = torch.utils.data.DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "val_loader = torch.utils.data.DataLoader(val_dataset, batch_size=batch_size, shuffle=True)\n",
    "#test_loader = torch.utils.data.DataLoader(test_dataset, batch_size=batch_size, shuffle=True)\n",
    "test_loader = val_loader\n",
    "n_train, n_val, n_test = len(train_loader), len(val_loader), len(test_loader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cd0bedb3",
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b790582f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "ax.imshow(graph)\n",
    "plt.savefig(f'{figure_path}/graph_rank1.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "804fe847",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = SimulationDataset(\n",
    "    data_path, 1, fraction_regimes_to_ignore=None, intervention=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "11507b3a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "pca = PCA(n_components=2)\n",
    "x_pca = pca.fit_transform(dataset.data)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd1780b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure()\n",
    "plt.scatter(x_pca[:, 0], x_pca[:, 1], s=5)\n",
    "plt.xlabel('PCA 1')\n",
    "plt.ylabel('PCA 2')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'{figure_path}/pca.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bdbad9c8",
   "metadata": {},
   "source": [
    "## 1.2 Define hyperparameters and train the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "6c56234f",
   "metadata": {},
   "outputs": [],
   "source": [
    "#test part genetic\n",
    "num_vars=graph.shape[0]\n",
    "num_layers=2\n",
    "num_dec_layers=1\n",
    "num_interventions=0\n",
    "num_modules=1\n",
    "hid_dim=50\n",
    "seed=42\n",
    "train_num_epochs = 300\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d4534b81",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# leaves:  2\n"
     ]
    }
   ],
   "source": [
    "model = vaeGraph(num_vars,\n",
    "                 num_interventions,\n",
    "                 num_modules,\n",
    "                 num_layers,\n",
    "                 num_dec_layers,\n",
    "                 hid_dim,\n",
    "                 batch_size,\n",
    "                 seed,\n",
    "                 device=device,\n",
    "                 spn_target='factor',\n",
    "                 z_prior={\n",
    "                     'mean': 0.0,\n",
    "                     'std': 1.0\n",
    "                 },\n",
    "                 noise_level=0.01,\n",
    "                 max_copies=8,\n",
    "                 p_conn=0.05,\n",
    "                 sparsity_temp=0.0,\n",
    "                 nonlin='linear').to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "29fc1e94",
   "metadata": {},
   "outputs": [],
   "source": [
    "nn_params = list(model.weights_n2m) + list(model.biases_n2m)\\\n",
    "    + list(model.weights_m2n) + list(model.biases_m2n)\\\n",
    "    + [model.weight_mu, model.weight_std, model.bias_mu, model.bias_std]\\\n",
    "    + [model.log_stds]\\\n",
    "    + [m.weight for m in model.bns_enc] + [m.weight for m in model.bns_dec]\\\n",
    "    + [m.bias for m in model.bns_enc] + [m.bias for m in model.bns_dec]\n",
    "optimizer = torch.optim.Adam(nn_params, lr=1e-4, weight_decay=1e-2)\n",
    "optimizer_fg = torch.optim.Adam(list(model.sample_uv.parameters()), lr=1e-2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "8aab9aa3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pred_score(pred, truth):\n",
    "    tp = np.sum((pred > 0) & (truth > 0))\n",
    "    tn = np.sum((pred == 0) & (truth == 0))\n",
    "    fp = np.sum((pred > 0) & (truth == 0))\n",
    "    fn = np.sum((pred == 0) & (truth > 0))\n",
    "    # print(tp, tn, fp, fn)\n",
    "\n",
    "    tpr = tp / (tp + fn)\n",
    "    fpr = fp / (fp + tn)\n",
    "\n",
    "    precision = tp / (tp + fp)\n",
    "    recall = tpr\n",
    "    f1 = 2 * precision * recall / (precision + recall)\n",
    "\n",
    "    return precision, recall, f1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "080e31fc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2675699/4213278239.py:11: RuntimeWarning: invalid value encountered in long_scalars\n",
      "  precision = tp / (tp + fp)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch1\tAverage Loss: 10006899.98, 1800296.66, Partition Entropy: 0.448\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch2\tAverage Loss: 1790704.90, 1256836.85, Partition Entropy: 0.376\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch3\tAverage Loss: 1123001.12, 970066.24, Partition Entropy: 0.339\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch4\tAverage Loss: 923912.17, 816460.07, Partition Entropy: 0.311\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch5\tAverage Loss: 783278.64, 708946.88, Partition Entropy: 0.291\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch6\tAverage Loss: 681302.42, 632509.27, Partition Entropy: 0.274\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch7\tAverage Loss: 615213.33, 573848.38, Partition Entropy: 0.260\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch8\tAverage Loss: 553420.73, 522333.29, Partition Entropy: 0.246\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch9\tAverage Loss: 497192.71, 475407.53, Partition Entropy: 0.236\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch10\tAverage Loss: 446233.47, 432303.94, Partition Entropy: 0.230\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch11\tAverage Loss: 404713.89, 391908.01, Partition Entropy: 0.223\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch12\tAverage Loss: 365668.31, 355192.46, Partition Entropy: 0.217\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch13\tAverage Loss: 328846.83, 321046.97, Partition Entropy: 0.215\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch14\tAverage Loss: 297047.66, 289711.18, Partition Entropy: 0.211\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch15\tAverage Loss: 266837.56, 261317.34, Partition Entropy: 0.211\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch16\tAverage Loss: 242524.50, 235654.17, Partition Entropy: 0.209\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch17\tAverage Loss: 215854.72, 212415.65, Partition Entropy: 0.214\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch18\tAverage Loss: 193952.77, 191030.41, Partition Entropy: 0.222\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch19\tAverage Loss: 174668.16, 171358.12, Partition Entropy: 0.232\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch20\tAverage Loss: 156018.13, 153393.58, Partition Entropy: 0.243\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch21\tAverage Loss: 139090.50, 137041.09, Partition Entropy: 0.258\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch22\tAverage Loss: 124156.28, 121958.10, Partition Entropy: 0.275\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch23\tAverage Loss: 110291.52, 108007.53, Partition Entropy: 0.293\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch24\tAverage Loss: 97044.63, 95272.13, Partition Entropy: 0.312\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch25\tAverage Loss: 85334.22, 83911.36, Partition Entropy: 0.330\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch26\tAverage Loss: 74892.19, 73415.80, Partition Entropy: 0.338\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch27\tAverage Loss: 65443.43, 64084.52, Partition Entropy: 0.349\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch28\tAverage Loss: 56547.88, 55571.88, Partition Entropy: 0.354\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch29\tAverage Loss: 49028.83, 47751.10, Partition Entropy: 0.362\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch30\tAverage Loss: 41819.90, 40711.27, Partition Entropy: 0.366\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch31\tAverage Loss: 35602.64, 34396.71, Partition Entropy: 0.373\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch32\tAverage Loss: 30698.14, 28820.08, Partition Entropy: 0.379\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch33\tAverage Loss: 24769.46, 23623.19, Partition Entropy: 0.398\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch34\tAverage Loss: 19931.54, 18937.97, Partition Entropy: 0.406\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch35\tAverage Loss: 15346.36, 14679.74, Partition Entropy: 0.413\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch36\tAverage Loss: 11408.34, 10606.25, Partition Entropy: 0.425\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch37\tAverage Loss: 7619.51, 7092.93, Partition Entropy: 0.431\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch38\tAverage Loss: 5351.26, 3894.11, Partition Entropy: 0.436\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch39\tAverage Loss: 1872.34, 956.75, Partition Entropy: 0.442\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch40\tAverage Loss: -667.51, -1706.37, Partition Entropy: 0.448\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch41\tAverage Loss: -3550.81, -4062.30, Partition Entropy: 0.449\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch42\tAverage Loss: -5679.29, -6082.59, Partition Entropy: 0.451\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch43\tAverage Loss: -7410.42, -7888.24, Partition Entropy: 0.451\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch44\tAverage Loss: -8568.36, -9690.02, Partition Entropy: 0.453\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch45\tAverage Loss: -10704.39, -11222.26, Partition Entropy: 0.453\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch46\tAverage Loss: -12233.33, -12644.02, Partition Entropy: 0.456\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch47\tAverage Loss: -13022.96, -13823.57, Partition Entropy: 0.452\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch48\tAverage Loss: -14441.67, -15000.59, Partition Entropy: 0.461\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch49\tAverage Loss: -15770.05, -16092.40, Partition Entropy: 0.467\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch50\tAverage Loss: -16830.38, -17137.15, Partition Entropy: 0.472\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch51\tAverage Loss: -17498.73, -17974.43, Partition Entropy: 0.477\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch52\tAverage Loss: -18378.00, -18710.95, Partition Entropy: 0.477\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch53\tAverage Loss: -18762.35, -19302.86, Partition Entropy: 0.477\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch54\tAverage Loss: -19638.51, -19859.28, Partition Entropy: 0.479\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch55\tAverage Loss: -20300.07, -20367.90, Partition Entropy: 0.480\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch56\tAverage Loss: -20672.01, -20834.73, Partition Entropy: 0.480\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch57\tAverage Loss: -21147.43, -21255.45, Partition Entropy: 0.483\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch58\tAverage Loss: -21521.67, -21635.39, Partition Entropy: 0.488\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch59\tAverage Loss: -21807.80, -21935.73, Partition Entropy: 0.488\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch60\tAverage Loss: -22114.39, -22275.80, Partition Entropy: 0.491\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch61\tAverage Loss: -22494.52, -22600.97, Partition Entropy: 0.494\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch62\tAverage Loss: -22539.63, -22798.13, Partition Entropy: 0.494\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch63\tAverage Loss: -22954.80, -23073.32, Partition Entropy: 0.498\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch64\tAverage Loss: -23124.76, -23304.43, Partition Entropy: 0.500\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch65\tAverage Loss: -23280.12, -23452.69, Partition Entropy: 0.501\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch66\tAverage Loss: -23523.44, -23604.30, Partition Entropy: 0.503\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch67\tAverage Loss: -23567.66, -23781.67, Partition Entropy: 0.504\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch68\tAverage Loss: -23716.69, -23880.03, Partition Entropy: 0.504\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch69\tAverage Loss: -23788.69, -24001.51, Partition Entropy: 0.507\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch70\tAverage Loss: -23932.24, -24137.36, Partition Entropy: 0.512\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch71\tAverage Loss: -24081.98, -24275.90, Partition Entropy: 0.515\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch72\tAverage Loss: -24209.61, -24359.34, Partition Entropy: 0.516\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch73\tAverage Loss: -24332.73, -24426.04, Partition Entropy: 0.518\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch74\tAverage Loss: -24390.06, -24476.70, Partition Entropy: 0.518\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch75\tAverage Loss: -24441.30, -24550.98, Partition Entropy: 0.518\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch76\tAverage Loss: -24514.52, -24634.26, Partition Entropy: 0.518\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch77\tAverage Loss: -24640.39, -24697.08, Partition Entropy: 0.520\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch78\tAverage Loss: -24714.82, -24767.42, Partition Entropy: 0.524\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch79\tAverage Loss: -24749.88, -24857.25, Partition Entropy: 0.531\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch80\tAverage Loss: -24849.97, -24965.52, Partition Entropy: 0.541\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch81\tAverage Loss: -24944.85, -25071.71, Partition Entropy: 0.550\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch82\tAverage Loss: -25066.86, -25172.90, Partition Entropy: 0.558\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch83\tAverage Loss: -25190.32, -25280.80, Partition Entropy: 0.560\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch84\tAverage Loss: -25282.27, -25472.98, Partition Entropy: 0.570\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch85\tAverage Loss: -25468.94, -25700.72, Partition Entropy: 0.572\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch86\tAverage Loss: -25846.36, -26165.47, Partition Entropy: 0.597\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch87\tAverage Loss: -26428.45, -26832.87, Partition Entropy: 0.639\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch88\tAverage Loss: -26964.39, -27256.63, Partition Entropy: 0.643\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch89\tAverage Loss: -27173.27, -27511.39, Partition Entropy: 0.662\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch90\tAverage Loss: -27497.22, -27744.61, Partition Entropy: 0.673\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch91\tAverage Loss: -27731.58, -27921.27, Partition Entropy: 0.676\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch92\tAverage Loss: -27761.27, -28011.51, Partition Entropy: 0.674\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch93\tAverage Loss: -27878.29, -28153.00, Partition Entropy: 0.675\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch94\tAverage Loss: -28124.61, -28226.23, Partition Entropy: 0.677\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch95\tAverage Loss: -28262.69, -28299.62, Partition Entropy: 0.678\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch96\tAverage Loss: -28178.84, -28405.58, Partition Entropy: 0.685\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch97\tAverage Loss: -28524.59, -28557.42, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch98\tAverage Loss: -28438.78, -28560.82, Partition Entropy: 0.690\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch99\tAverage Loss: -28427.84, -28577.41, Partition Entropy: 0.691\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch100\tAverage Loss: -28455.68, -28379.06, Partition Entropy: 0.685\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch101\tAverage Loss: -27749.45, -28422.42, Partition Entropy: 0.683\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch102\tAverage Loss: -28608.83, -28575.09, Partition Entropy: 0.690\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch103\tAverage Loss: -28640.40, -28632.84, Partition Entropy: 0.691\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch104\tAverage Loss: -28698.55, -28668.66, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch105\tAverage Loss: -28708.17, -28678.77, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch106\tAverage Loss: -28692.03, -28689.09, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch107\tAverage Loss: -28735.39, -28693.72, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch108\tAverage Loss: -28668.30, -28661.49, Partition Entropy: 0.691\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch109\tAverage Loss: -28723.81, -28669.36, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch110\tAverage Loss: -28802.96, -28693.24, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch111\tAverage Loss: -28782.83, -28700.10, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch112\tAverage Loss: -28713.89, -28674.23, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch113\tAverage Loss: -28465.99, -28559.77, Partition Entropy: 0.689\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch114\tAverage Loss: -28771.37, -28648.35, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch115\tAverage Loss: -28746.53, -28663.87, Partition Entropy: 0.691\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch116\tAverage Loss: -28807.06, -28693.87, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch117\tAverage Loss: -28774.25, -28622.24, Partition Entropy: 0.690\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch118\tAverage Loss: -28802.84, -28683.59, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch119\tAverage Loss: -28803.69, -28703.38, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch120\tAverage Loss: -28826.45, -28710.96, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch121\tAverage Loss: -28827.80, -28698.41, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch122\tAverage Loss: -28845.67, -28715.20, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch123\tAverage Loss: -28762.05, -28614.72, Partition Entropy: 0.690\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch124\tAverage Loss: -28822.82, -28676.91, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch125\tAverage Loss: -28859.14, -28713.75, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch126\tAverage Loss: -28850.61, -28728.16, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch127\tAverage Loss: -28848.48, -28724.83, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch128\tAverage Loss: -28550.19, -28693.35, Partition Entropy: 0.691\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch129\tAverage Loss: -28838.73, -28708.59, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch130\tAverage Loss: -28846.27, -28726.66, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch131\tAverage Loss: -28848.77, -28736.07, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch132\tAverage Loss: -28879.71, -28742.95, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch133\tAverage Loss: -28887.08, -28743.71, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch134\tAverage Loss: -28887.92, -28744.59, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch135\tAverage Loss: -28857.87, -28739.07, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch136\tAverage Loss: -28808.71, -28684.39, Partition Entropy: 0.690\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch137\tAverage Loss: -28889.42, -28738.19, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch138\tAverage Loss: -28762.67, -28744.85, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch139\tAverage Loss: -28856.81, -28732.03, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch140\tAverage Loss: -28877.13, -28729.21, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch141\tAverage Loss: -28883.18, -28752.78, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch142\tAverage Loss: -28919.60, -28763.89, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch143\tAverage Loss: -28914.12, -28770.74, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch144\tAverage Loss: -28919.93, -28772.20, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch145\tAverage Loss: -28917.87, -28774.45, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch146\tAverage Loss: -28927.11, -28780.22, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch147\tAverage Loss: -28902.89, -28783.05, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch148\tAverage Loss: -28933.40, -28787.81, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch149\tAverage Loss: -28943.79, -28793.61, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch150\tAverage Loss: -28947.71, -28796.71, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch151\tAverage Loss: -28954.24, -28801.05, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch152\tAverage Loss: -28964.00, -28781.87, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch153\tAverage Loss: -28962.92, -28807.57, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch154\tAverage Loss: -28973.56, -28817.97, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch155\tAverage Loss: -28987.97, -28826.31, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch156\tAverage Loss: -28991.63, -28834.40, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch157\tAverage Loss: -29002.71, -28841.98, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch158\tAverage Loss: -29009.56, -28847.85, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch159\tAverage Loss: -29022.72, -28855.88, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch160\tAverage Loss: -29029.45, -28867.67, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch161\tAverage Loss: -29042.06, -28875.48, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch162\tAverage Loss: -29057.01, -28888.65, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch163\tAverage Loss: -29070.10, -28900.07, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch164\tAverage Loss: -29084.69, -28916.76, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch165\tAverage Loss: -29105.20, -28932.57, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch166\tAverage Loss: -29124.07, -28953.01, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch167\tAverage Loss: -29146.29, -28975.08, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch168\tAverage Loss: -29168.21, -28994.84, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch169\tAverage Loss: -29192.64, -29015.45, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch170\tAverage Loss: -29213.10, -29035.71, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch171\tAverage Loss: -29230.05, -29047.79, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch172\tAverage Loss: -29243.87, -29061.86, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch173\tAverage Loss: -29256.92, -29072.45, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch174\tAverage Loss: -29268.16, -29086.54, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch175\tAverage Loss: -29284.53, -29099.53, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch176\tAverage Loss: -29300.82, -29115.78, Partition Entropy: 0.692\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch177\tAverage Loss: -29316.59, -29132.12, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch178\tAverage Loss: -29338.38, -29152.86, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch179\tAverage Loss: -29360.81, -29178.77, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch180\tAverage Loss: -29389.99, -29208.14, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch181\tAverage Loss: -29429.18, -29252.21, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch182\tAverage Loss: -29487.40, -29318.60, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch183\tAverage Loss: -29565.89, -29377.42, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch184\tAverage Loss: -29588.31, -29396.18, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch185\tAverage Loss: -29594.14, -29405.53, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch186\tAverage Loss: -29599.18, -29411.15, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch187\tAverage Loss: -29603.65, -29415.57, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch188\tAverage Loss: -29607.11, -29419.87, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch189\tAverage Loss: -29610.46, -29422.34, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch190\tAverage Loss: -29613.15, -29425.07, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch191\tAverage Loss: -29615.27, -29427.26, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch192\tAverage Loss: -29616.89, -29428.63, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch193\tAverage Loss: -29617.92, -29429.48, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch194\tAverage Loss: -29618.81, -29429.61, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch195\tAverage Loss: -29619.18, -29430.00, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch196\tAverage Loss: -29619.47, -29429.97, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch197\tAverage Loss: -29619.38, -29430.87, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n",
      "Epoch198\tAverage Loss: -29619.56, -29430.76, Partition Entropy: 0.693\n",
      "\tGraph prediction: precision=nan, recall=0.000, f1 score=nan\n",
      "\n"
     ]
    }
   ],
   "source": [
    "train_loss_list=[]\n",
    "eval_loss_list = []\n",
    "loss_comp = {\n",
    "    're': [],\n",
    "    'uv_kl': [],\n",
    "    'z_kl': [],\n",
    "    'l1_reg': [],\n",
    "    'precision': [],\n",
    "    'recall': [],\n",
    "    'f1': []\n",
    "}\n",
    "\n",
    "stop_counter = 0\n",
    "patience = 5\n",
    "stop_thred = 1.0\n",
    "prev_loss = 0\n",
    "memory = 0.25\n",
    "\n",
    "for epoch in range(train_num_epochs):\n",
    "    # kl_coeff = min(1.0, 0.01 * epoch)\n",
    "    kl_coeff = 1.0\n",
    "    model.train()\n",
    "    \n",
    "    train_loss = 0\n",
    "    eval_loss = 0\n",
    "    re_loss, uv_kl, z_kl, l1_reg = 0, 0, 0, 0\n",
    "    for inputs in train_loader:\n",
    "        data, masks, regimes=inputs\n",
    "        batch_size = data.shape[0]\n",
    "        data=data.to(device)\n",
    "        masks=masks.to(device)\n",
    "        regimes=regimes.to(device)\n",
    "        \n",
    "        # n2m = torch.tensor(np.tile(U0, (batch_size, 1, num_modules))).float().to(device)\n",
    "        # m2n = torch.tensor(np.tile(V0.T, (batch_size, 1, num_modules))).float().to(device)\n",
    "        _re_loss, _uv_kl, _z_kl, _l1_reg = model.losses(data, masks)\n",
    "        loss = _re_loss + kl_coeff * _uv_kl + kl_coeff * _z_kl \n",
    "\n",
    "        train_loss += loss.detach().cpu().item() * (batch_size / n_train)\n",
    "        re_loss += _re_loss.detach().cpu().item() * (batch_size / n_train)\n",
    "        uv_kl += _uv_kl.detach().cpu().item() * (batch_size / n_train)\n",
    "        z_kl += _z_kl.detach().cpu().item() * (batch_size / n_train)\n",
    "        l1_reg += _l1_reg.detach().cpu().item() * (batch_size / n_train)\n",
    "\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        optimizer_fg.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        optimizer_fg.step()\n",
    "\n",
    "    train_loss_list.append(train_loss)\n",
    "    loss_comp['re'].append(re_loss)\n",
    "    loss_comp['uv_kl'].append(uv_kl)\n",
    "    loss_comp['z_kl'].append(z_kl)\n",
    "    loss_comp['l1_reg'].append(l1_reg)\n",
    "        \n",
    "    # validation\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        for inputs in val_loader:\n",
    "            data,masks,regimes=inputs\n",
    "            batch_size = data.shape[0]\n",
    "            data = data.to(device)\n",
    "            masks = masks.to(device)\n",
    "            regimes = regimes.to(device)\n",
    "            # n2m = torch.tensor(np.tile(U0, (batch_size, 1, num_modules))).float().to(device)\n",
    "            # m2n = torch.tensor(np.tile(V0.T, (batch_size, 1, num_modules))).float().to(device)\n",
    "            _re_loss, _uv_kl, _z_kl, _l1_reg = model.losses(data, masks)\n",
    "            loss = _re_loss + kl_coeff * _uv_kl + kl_coeff * _z_kl \n",
    "            eval_loss += loss.detach().cpu().item() * (batch_size / n_val)\n",
    "\n",
    "    eval_loss_list.append(eval_loss)\n",
    "    # Smoothing\n",
    "    if epoch > 0:\n",
    "        eval_loss = prev_loss * memory + eval_loss * (1 - memory)\n",
    "    \n",
    "    # Graph evaluation\n",
    "    with torch.no_grad():\n",
    "        n2m, m2n = model.sample_uv.fg.sample_deterministic()\n",
    "        n2m = n2m.squeeze().detach().cpu().numpy()\n",
    "        m2n = m2n.squeeze().detach().cpu().numpy()\n",
    "        graph_pred = (np.matmul(n2m, m2n.T) > 0).astype(int)\n",
    "    precision, recall, f1 = pred_score(graph_pred, graph)\n",
    "    loss_comp['precision'].append(precision)\n",
    "    loss_comp['recall'].append(recall)\n",
    "    loss_comp['f1'].append(f1)\n",
    "    \n",
    "    print(f\"Epoch{epoch + 1}\\tAverage Loss: {train_loss:.2f}, {eval_loss:.2f}, Partition Entropy: {model.sample_uv.fg.entropy_y():.3f}\")\n",
    "    print(f\"\\tGraph prediction: precision={precision:.3f}, recall={recall:.3f}, f1 score={f1:.3f}\\n\")\n",
    "    # Update early stopping variables\n",
    "    if prev_loss - eval_loss < stop_thred:\n",
    "        stop_counter += 1\n",
    "    else:\n",
    "        stop_counter = 0\n",
    "    prev_loss = eval_loss\n",
    "    \n",
    "    if stop_counter > patience:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef3c41ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.927992706394196\n"
     ]
    }
   ],
   "source": [
    "mse = 0\n",
    "with torch.no_grad():\n",
    "    for inputs in train_loader:\n",
    "        data,masks,regimes=inputs\n",
    "        batch_size = data.shape[0]\n",
    "        data = data.to(device)\n",
    "        masks = masks.to(device)\n",
    "        regimes = regimes.to(device)\n",
    "        n2m = torch.tensor(np.tile(U0, (batch_size, 1, 1))).float().to(device)\n",
    "        m2n = torch.tensor(np.tile(V0.T, (batch_size, 1, 1))).float().to(device)\n",
    "        _mse = model.mse(data, masks, n2m, m2n)\n",
    "        mse += _mse.detach().cpu().item() * (batch_size/n_train)\n",
    "print(mse)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "8b264f81",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.9381099954532206\n"
     ]
    }
   ],
   "source": [
    "mse = 0\n",
    "with torch.no_grad():\n",
    "    for inputs in val_loader:\n",
    "        data,masks,regimes=inputs\n",
    "        batch_size = data.shape[0]\n",
    "        data = data.to(device)\n",
    "        masks = masks.to(device)\n",
    "        regimes = regimes.to(device)\n",
    "        n2m = torch.tensor(np.tile(U0, (batch_size, 1, 1))).float().to(device)\n",
    "        m2n = torch.tensor(np.tile(V0.T, (batch_size, 1, 1))).float().to(device)\n",
    "        _mse = model.mse(data, masks, n2m, m2n)\n",
    "        mse += _mse.detach().cpu().item() * (batch_size/n_val)\n",
    "print(mse)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6c3827d5",
   "metadata": {},
   "source": [
    "# Inspect latent space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "e05b4cf9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_z_posterior(data_loader, mask_type=None):\n",
    "    mu, std = [], []\n",
    "    with torch.no_grad():\n",
    "        for inputs in data_loader:\n",
    "            data, masks, regimes=inputs\n",
    "            batch_size = data.shape[0]\n",
    "            data = data.to(device)\n",
    "            masks = masks.to(device)\n",
    "            regimes = regimes.to(device)\n",
    "            if mask_type is None:\n",
    "                n2m, m2n = None, None\n",
    "            elif mask_type == 'random':\n",
    "                n2m = torch.bernoulli(torch.ones(batch_size, num_vars, num_modules).float()).float().to(device)\n",
    "                m2n = 1 - n2m\n",
    "                model.mse(data, masks, n2m, m2n)\n",
    "            elif mask_type == 'true':\n",
    "                n2m = torch.tensor(np.tile(U0, (batch_size, 1, num_modules))).float().to(device)\n",
    "                m2n = torch.tensor(np.tile(V0.T, (batch_size, 1, num_modules))).float().to(device)\n",
    "                model.mse(data, masks, n2m, m2n)\n",
    "            elif mask_type == 'null':\n",
    "                n2m = torch.zeros(batch_size, num_vars, num_modules).float().to(device)\n",
    "                m2n = torch.zeros(batch_size, num_vars, num_modules).float().to(device)\n",
    "                model.mse(data, masks, n2m, m2n)\n",
    "            else:\n",
    "                model.mse(data, masks)\n",
    "            mu.append(model.mu_q.detach().cpu().numpy())\n",
    "            std.append(model.std_q.detach().cpu().numpy())\n",
    "    return np.concatenate(mu, 0), np.concatenate(std, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "61c8363c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_z_true, std_z_true = get_z_posterior(train_loader, 'true')\n",
    "mu_z_null, std_z_null = get_z_posterior(train_loader, 'null')\n",
    "mu_z_rand, std_z_rand = get_z_posterior(train_loader, 'random')\n",
    "mu_z, std_z = get_z_posterior(train_loader, '')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "43e4f254",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2675699/316010641.py:4: UserWarning: Dataset has 0 variance; skipping density estimate. Pass `warn_singular=False` to disable this warning.\n",
      "  seaborn.kdeplot(df, ax=ax[0])\n",
      "/tmp/ipykernel_2675699/316010641.py:11: UserWarning: Dataset has 0 variance; skipping density estimate. Pass `warn_singular=False` to disable this warning.\n",
      "  seaborn.kdeplot(df, ax=ax[1])\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKUAAAGGCAYAAACqvTJ0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAACrAElEQVR4nOzdeXxU9b3/8deZycxkTwiQBGRVlEUBERVTl6JQQdG6YHttrUjrUluwRapY+rMu2Ip1Ba3Va1sFK7S1vWpdEQQFF0QEUUTFqiAIJKxJyDrLOb8/Zs5kBmaSSZiQZd7P+8hNcs73nPMdrOOXz3w+n69hWZaFiIiIiIiIiIjIYeRo6wmIiIiIiIiIiEjqUVBKREREREREREQOOwWlRERERERERETksFNQSkREREREREREDjsFpURERERERERE5LBTUEpERERERERERA47BaVEREREREREROSwU1BKREREREREREQOOwWlRERERERERETksFNQSkREREREREREDrs2DUo98sgjDBs2jNzcXHJzcykpKeGVV14Jn6+rq2PKlCl07dqV7OxsJk6cSFlZWdQ9tmzZwoQJE8jMzKSwsJAbb7wRv98fNeaNN97ghBNOwOPxMGDAAObNm3c4Xp6IiIiIiIiIiMTRpkGpXr16cdddd7FmzRref/99zjrrLC644AI2bNgAwPXXX88LL7zAv/71L5YvX8727du5+OKLw9cHAgEmTJiA1+vlnXfeYf78+cybN49bbrklPGbTpk1MmDCBM888k3Xr1jFt2jSuuuoqXn311cP+ekVEREREREREJMiwLMtq60lEKigo4J577uGSSy6he/fuLFy4kEsuuQSAzz77jMGDB7Ny5UpOOeUUXnnlFc477zy2b99OUVERAI8++ig33XQTu3btwu12c9NNN/HSSy/x8ccfh59x6aWXUl5ezqJFi9rkNYqIiIiIiIiIpLp201MqEAjwj3/8g+rqakpKSlizZg0+n4+xY8eGxwwaNIg+ffqwcuVKAFauXMnQoUPDASmAcePGUVlZGc62WrlyZdQ97DH2PURERERERERE5PBLa+sJrF+/npKSEurq6sjOzubZZ59lyJAhrFu3DrfbTX5+ftT4oqIiSktLASgtLY0KSNnn7XONjamsrKS2tpaMjIyD5lRfX099fX34d9M02bt3L127dsUwjEN+zSIi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0aP5xS9+wYwZMygoKKC4uJjbbrsNgM2bN2MYBuvWrQuPLy8vxzAM3njjjTaZr4iItD1lSkmq0/opvrS2noCISFtp2H0vIigVs6lUw4+Wod33pJVYFvhq2ubZrsw4/+OPbf78+UyfPp1Vq1axcuVKJk+ezKmnnsrRRx/dipMUEZGOKrKPlHpKSVJp/dThKSglIikrnCllRjQ6b6p8DwOXofI9aQW+GrizZ9s8+zfbwZ2V8PBhw4Zx6623AnD00Ufzxz/+kaVLl6b8oupwWbFiBffccw9r1qxhx44dPPvss1x44YXh85Zlceutt/LnP/+Z8vJyTj31VB555JGofz579+7luuuu44UXXsDhcDBx4kTmzp1LdnZ2eMxHH33ElClTWL16Nd27d+e6665jxowZh/OlikhnoUwpaS1aP3V4Kt8TkZQVzpSKKN9LqNF5qHxPQSlJVcOGDYv6vUePHuzcubONZpN6qqurGT58OA8//HDM83fffTcPPvggjz76KKtWrSIrK4tx48ZRV1cXHnPZZZexYcMGlixZwosvvsiKFSu45pprwucrKys5++yz6du3L2vWrOGee+7htttu47HHHmv11ycinY/iUCJaP8WjTCkRSVlRu+810ug8MlBlGUZ49z1vQD2lJIlcmcFP3Nrq2c0Z7nJF/W4YBqZp4nAEP+uyIj4G9/kUvE22c845h3POOSfmOcuymDNnDjfffDMXXHABAE8++SRFRUU899xzXHrppXz66acsWrSI1atXc+KJJwLw0EMPce6553LvvffSs2dPFixYgNfr5fHHH8ftdnPssceybt067r///qjglYhIIqKyo5QqJcmk9VOHp6CUiKQsOyhlWFbjjc4PLN/T7nvSGgyjWSng7VH37t0B2LFjByNGjACIatoprW/Tpk2UlpYyduzY8LG8vDxGjRrFypUrufTSS1m5ciX5+fnhgBTA2LFjcTgcrFq1iosuuoiVK1dyxhln4Ha7w2PGjRvHH/7wB/bt20eXLl0OenZ9fT319fXh3ysrK1vpVYpIRxPZR8pUTEqSSeunDk9BKRFJWXZQymkZjfeUighUWRDOlFJQSiRaRkYGp5xyCnfddRf9+/dn586d3HzzzW09rZRSWloKQFFRUdTxoqKi8LnS0lIKCwujzqelpVFQUBA1pn///gfdwz4XKyg1e/Zsbr/99uS8EBHpVKJ331NUSiRSqq+f1FNKRFJWQ/le5O57jWdKWYbR0FNKu++JHOTxxx/H7/czcuRIpk2bxu9+97u2npIcJjNnzqSioiL8tXXr1raekoi0E1acn0UkKJXXT8qUEpGUZTc6N0wr3FPK0cSurhaQpkwpSWFvvPHGQceee+658M+DBw/mnXfeiTof+an46NGjo36fPHkykydPTvY0U1ZxcTEAZWVl9OjRI3y8rKyM448/PjzmwMaqfr+fvXv3hq8vLi6mrKwsaoz9uz3mQB6PB4/Hk5TXISKdS+T7vhKlJBVp/RSfMqVEJGXFzJSKMe7ATCm3ekqJSDvVv39/iouLWbp0afhYZWUlq1atoqSkBICSkhLKy8tZs2ZNeMyyZcswTZNRo0aFx6xYsSKq0eqSJUsYOHBgzNI9EZHGKFNKROJRUEpEUpaJ3eiciN33YpTvRfWU0u57ItK2qqqqWLduXbgJ6qZNm1i3bh1btmzBMIxw2v/zzz/P+vXrmTRpEj179uTCCy8Egp/Gjh8/nquvvpr33nuPt99+m6lTp3LppZfSs2dPAH74wx/idru58sor2bBhA//85z+ZO3cu06dPb6NXLSIdmnpKiUgcKt8TkZRlmqFMKbNhrRSrfO/AOJULJ6BMKRFpG++//z5nnnlm+Hc7UHTFFVcwb948ZsyYQXV1Nddccw3l5eWcdtppLFq0iPT09PA1CxYsYOrUqYwZMwaHw8HEiRN58MEHw+fz8vJYvHgxU6ZMYeTIkXTr1o1bbrmFa6655vC9UBHpNCzlR4lIHApKiUjKsntKRZbvxSrgcxgHZEqpfE9E2tCBfSUOZBgGs2bNYtasWXHHFBQUsHDhwkafM2zYMN58880Wz1NExBa9+17bzUNE2p82Ld+bPXs2J510Ejk5ORQWFnLhhReycePGqDGjR4/GMIyor2uvvTZqzJYtW5gwYQKZmZkUFhZy44034vf7o8a88cYbnHDCCXg8HgYMGMC8efNa++WJSDtnf2rXVKPzyEOWgcr3RERERJrBjAxKKWtKRCK0aVBq+fLlTJkyhXfffZclS5bg8/k4++yzqa6ujhp39dVXs2PHjvDX3XffHT4XCASYMGECXq+Xd955h/nz5zNv3jxuueWW8JhNmzYxYcIEzjzzTNatW8e0adO46qqrePXVVw/baxWR9idghjKlzIhG502U71kY2n1PREREpDmUKSUicbRp+d6iRYuifp83bx6FhYWsWbOGM844I3w8MzMz7vbDixcv5pNPPuG1116jqKiI448/njvuuIObbrqJ2267DbfbzaOPPkr//v257777gGCDz7feeosHHniAcePGtd4LFJF2zf6kzmE1fGZnxCjfi25+buBWUEpEREQkYdp9T0TiaVe771VUVADBPgeRFixYQLdu3TjuuOOYOXMmNTU14XMrV65k6NChFBUVhY+NGzeOyspKNmzYEB4zduzYqHuOGzeOlStXxpxHfX09lZWVUV8i0vnYPaUMs2H3PUcT74qR5Xu+gIJSIiIiIk2JCkopKiUiEdpNo3PTNJk2bRqnnnoqxx13XPj4D3/4Q/r27UvPnj356KOPuOmmm9i4cSPPPPMMAKWlpVEBKSD8e2lpaaNjKisrqa2tJSMjI+rc7Nmzuf3225P+GkWkfbHL95wRjc5jZUpBsITPCo1zGdp9T0RERCRxVsRPikqJSIN2E5SaMmUKH3/8MW+99VbU8cith4cOHUqPHj0YM2YMX375JUcddVSrzGXmzJnh7ZUBKisr6d27d6s8S0TajtcMNip3m45wplSsnlIQbHZuEcyoUk8pkcNj8uTJlJeX89xzz7X1VERE5BBo9z2Rw6ejrZ/aRfne1KlTefHFF3n99dfp1atXo2NHjRoFwBdffAFAcXExZWVlUWPs3+0+VPHG5ObmHpQlBeDxeMjNzY36EpHOx949z2U6GnpKxYlK2cctVL4nIiIi0hyKQ4lIPG0alLIsi6lTp/Lss8+ybNky+vfv3+Q169atA6BHjx4AlJSUsH79enbu3Bkes2TJEnJzcxkyZEh4zNKlS6Pus2TJEkpKSpL0SkSkI7KDUmkRPaXiJErhCJ2ILN+zM61EUpnXq38PRESkcZHZUaZSpUS0forQpkGpKVOm8NRTT7Fw4UJycnIoLS2ltLSU2tpaAL788kvuuOMO1qxZw+bNm3n++eeZNGkSZ5xxBsOGDQPg7LPPZsiQIVx++eV8+OGHvPrqq9x8881MmTIFj8cDwLXXXstXX33FjBkz+Oyzz/jTn/7E008/zfXXX99mr11E2pbf9IcbnbsDjnBPKUfc8j3D/gEXKt+T1DV69GimTp3KtGnT6NatG+PGjeP+++9n6NChZGVl0bt3b37+859TVVUVvmbevHnk5+fz6quvMnjwYLKzsxk/fjw7duwIjwkEAkyfPp38/Hy6du3KjBkzsPQXFxGRTsGK6iklknq0foqvTYNSjzzyCBUVFYwePZoePXqEv/75z38C4Ha7ee211zj77LMZNGgQv/rVr5g4cSIvvPBC+B5Op5MXX3wRp9NJSUkJP/rRj5g0aRKzZs0Kj+nfvz8vvfQSS5YsYfjw4dx333385S9/Ydy4cYf9NYtI+2BnSQG4IjOlGmsqRTBTyq3yPWkFlmVR46tpk6/mLl7mz5+P2+3m7bff5tFHH8XhcPDggw+yYcMG5s+fz7Jly5gxY0bUNTU1Ndx777387W9/Y8WKFWzZsoUbbrghfP6+++5j3rx5PP7447z11lvs3buXZ599Nil/tiIi0rbUU0pai9ZPHX/91KaNzpv6h9i7d2+WL1/e5H369u3Lyy+/3OiY0aNH88EHHzRrfiLSeUVmOblMo2H3vcZjUlgYpKl8T1pBrb+WUQtHtcmzV/1wFZmuzITHH3300dx9993h3wcOHBj+uV+/fvzud7/j2muv5U9/+lP4uM/n49FHHw1vUjJ16tSoD5DmzJnDzJkzufjiiwF49NFHefXVV1v8mkREpP2won5WVEqSR+unjr9+aje774mIHE71gXoAnIYTp2k0NDqP01UqHKwyII1gUMpv+lt5liLt08iRI6N+f+2115g9ezafffYZlZWV+P1+6urqqKmpITMzuFjLzMyM2jW3R48e4X6QFRUV7NixI7yZCUBaWhonnnhih0tBFxGRg0W+l+ttXVKV1k+xKSglIinJLt9zO91gBiLK92KPt4NVwfI9F6DyPUmujLQMVv1wVZs9uzmysrLCP2/evJnzzjuPn/3sZ/z+97+noKCAt956iyuvvBKv1xteVLlcrqh7GIbRoRZMIiKSHHrnl2TS+qnjU1BKRFJSZFDKMq2mG52He0oR3n3Pb/kxLROH0abt+aSTMAyjWSng7cWaNWswTZP77rsPhyP478LTTz/drHvk5eXRo0cPVq1axRlnnAGA3+9nzZo1nHDCCUmfs4iIHF6mmkpJK9H6qeOvnxSUEpGUZPeDcjvcEAhghTfXi1O+F/puGUa4fA+Cvak8Tk9rTlWkXRswYAA+n4+HHnqI888/P9y8s7l++ctfctddd3H00UczaNAg7r//fsrLy5M/YREROeyiYlJtNw2RdkPrpwb6eF9EUlJUppRlNmRKxXlXdBgN5Xt2phSohE9k+PDh3H///fzhD3/guOOOY8GCBcyePbvZ9/nVr37F5ZdfzhVXXEFJSQk5OTlcdNFFrTBjERE53KzoTuciKU/rpwbKlBKRlGQ3Onc73RAwwz2liJMpRUT5XprVELmK3MVPJBW88cYbBx27/vrruf7666OOXX755eGfJ0+ezOTJk6POX3jhhVE9EdLS0pgzZw5z5sxJ5nRFRKQd0O57kuq0fopPmVIikpLsDCe3ww0RmVLxG53bPxg4cJBmBGP6dsaViIiIiMSm3fdEJB4FpUQkJdmZUh6nB8tsyJSK3+jcLt8DLAuXM7QDnzKlRERERBql6j0RiUdBKRFJSXajc5fTFSzfCx2P2+g8XL5nABYuh4JSIiIiIgnR5nsiEoeCUiKSkuyyO4/TE2x03lSmVOi7ZRjBTKlQUErleyIiIiKNi+wjpZ5SIhJJQSkRSUnh3fccoUbn4Z5S8TKlIo5HlO/5TX/rTlRERESkg7OUKSUicSgoJSIpKap8zzSb/MwunClFMFPK7XADKt8TERERaUpUTylFpUQkgoJSIpKSosr3ohqdN54pZRkGlsr3RERERBKmTCkRiUdBKRFJSeHyPac7lClll+/FHt/Q6Dz4/7T7noiIiEhiontKiYg0UFBKRFJSfaAeCPWUshqCUgk1OtfueyIiIiIJU6aUiMSjoJSIpCS7p5Tb6cYKNJTvxW90HvxuAZimglIiSdCvXz/mzJnT6s8ZPXo006ZNa/XniIhI07T7nsih6Wzrp7RWf4KISDvkCwSDSQ3le0FxEqUwwmeMqN331FNKUs3o0aM5/vjjk7IYWr16NVlZWYc+KRERadcim5srU0pSkdZP8SkoJSIpKVy+53RHNTpPJFMqstG5MqVEolmWRSAQIC2t6SVG9+7dD8OMRESkrSkQJdK4VF4/qXxPRFJSuNG5I8FG56HvlmGAFboOBaUktUyePJnly5czd+5cDMPAMAzmzZuHYRi88sorjBw5Eo/Hw1tvvcWXX37JBRdcQFFREdnZ2Zx00km89tprUfc7MP3cMAz+8pe/cNFFF5GZmcnRRx/N888/H3XNxx9/zDnnnEN2djZFRUVcfvnl7N69O3y+urqaSZMmkZ2dTY8ePbjvvvta9c9ERESaFp0ppQiVpBatnxqnoJSIpCQ7KOVxerDMAFYo6hS30XkoWmWpfE9aiWVZmDU1bfKV6F8Q5s6dS0lJCVdffTU7duxgx44d9O7dG4Bf//rX3HXXXXz66acMGzaMqqoqzj33XJYuXcoHH3zA+PHjOf/889myZUujz7j99tv5/ve/z0cffcS5557LZZddxt69ewEoLy/nrLPOYsSIEbz//vssWrSIsrIyvv/974evv/HGG1m+fDn/+c9/WLx4MW+88QZr165t4T8VERFJBivOzyKHSuunoI68flL5noikpMhG55hWQ6ZUnK5SzlC0yjQcRO6+5zf9rT9ZSQlWbS0bTxjZJs8euHYNRmZmk+Py8vJwu91kZmZSXFwMwGeffQbArFmz+M53vhMeW1BQwPDhw8O/33HHHTz77LM8//zzTJ06Ne4zJk+ezA9+8AMA7rzzTh588EHee+89xo8fzx//+EdGjBjBnXfeGR7/+OOP07t3bz7//HN69uzJX//6V5566inGjBkDwPz58+nVq1cz/jRERCTZtPuetBatn4I68vpJQSkRSUl2hpPL4QqW7xmNl+/ZQamAEcyUcjtVvicS6cQTT4z6vaqqittuu42XXnqJHTt24Pf7qa2tbfKTvmHDhoV/zsrKIjc3l507dwLw4Ycf8vrrr5OdnX3QdV9++SW1tbV4vV5GjRoVPl5QUMDAgQMP5aWJiMghis6UUlRKxKb1k4JSIpKiDirfo/FG53ZZn2k4guV7DpXvSXIZGRkMXLumzZ59qA7cBeaGG25gyZIl3HvvvQwYMICMjAwuueQSvN7G/51xuVzRczMMTNMEggu1888/nz/84Q8HXdejRw+++OKLQ3wVIiLSGrT7nrQWrZ+COvL6SUEpEUlJ8cv3Yoss39Pue9IaDMNIKAW8rbndbgKBQJPj3n77bSZPnsxFF10EBBdEmzdvPqRnn3DCCfzf//0f/fr1i7k7zVFHHYXL5WLVqlX06dMHgH379vH555/z7W9/+5CeLSIiyaGYlCST1k9Na+/rJzU6F5GUVB+oB0JBqUBko/N4mVJ2UMoAs6HRuS+goJSkln79+rFq1So2b97M7t27w5/CHejoo4/mmWeeYd26dXz44Yf88Ic/jDs2UVOmTGHv3r384Ac/YPXq1Xz55Ze8+uqr/PjHPyYQCJCdnc2VV17JjTfeyLJly/j444+ZPHkyDoeWOyIibSm6p5TCUpJ6tH6KT6s0EUlJdtmd2+nGsiIypZroKXVgo3M740okVdxwww04nU6GDBlC9+7d4/Y4uP/+++nSpQvf+ta3OP/88xk3bhwnnHDCIT27Z8+evP322wQCAc4++2yGDh3KtGnTyM/PDy+c7rnnHk4//XTOP/98xo4dy2mnncbIkW3TAFVERIIi+0gpJiWpSOun+FS+JyIpyS67czvsTKnGy/eiMqVUvicp7JhjjmHlypVRxyZPnnzQuH79+rFs2bKoY1OmTIn6/cB09FifnpeXl0f9bn+CGE92djZ/+9vf+Nvf/hY+duONN8YdLyIirU+770mq0/opPmVKiUhKssv3PE4PlmWGM6Ucjjjle5GZUpFBKZXviYiIiDTKivOziIiCUiKSkuzyPZfTFWx0Hi9FKsQZ3n3PwLKsYC8qlCklIiIi0hRlSolIPApKiUhKCveUssv37EypOE2lnPEypRSUEhEREWmUpfwoEYlDQSkRSUl2UCpYvmc19JSKkzEV7imFAyxUviciIiKSIGVKiUg8CkqJSMqxLCu8a57L6YrKlIpXxdeQKWUAKt8TERERSVRkI2ZlTYlIJAWlRCTlRAaSPE4PWGY4U6q55Xt2cEukJUzTbOspCPrnICLS2qy4v4g0n/673T4k659DWlLuIiLSgdilewBupxvLbPjMrqnyvYDhwDJNle/JIXG73TgcDrZv30737t1xu90Y8f7HJ63Gsiy8Xi+7du3C4XDgdrvbekpJEQgEuO2223jqqacoLS2lZ8+eTJ48mZtvvjn8vzPLsrj11lv585//THl5OaeeeiqPPPIIRx99dPg+e/fu5brrruOFF17A4XAwceJE5s6dS3Z2dlu9NBHpoLT7niSD1k/tQ7LXTwpKiUjKqQ/Uh392OQ4o32syU8oIZko51ehcWs7hcNC/f3927NjB9u3b23o6KS8zM5M+ffrgcHSOBPI//OEPPPLII8yfP59jjz2W999/nx//+Mfk5eXxi1/8AoC7776bBx98kPnz59O/f39++9vfMm7cOD755BPS09MBuOyyy9ixYwdLlizB5/Px4x//mGuuuYaFCxe25csTkQ4ouqeUwlLSMlo/tS/JWj8pKCUiKccOJLkcLhyGAyuifC/eZy3hRudGdKNzle9JS7ndbvr06YPf7ycQCLT1dFKW0+kkLS2tU33S+s4773DBBRcwYcIEAPr168ff//533nvvPSD4F8I5c+Zw8803c8EFFwDw5JNPUlRUxHPPPcell17Kp59+yqJFi1i9ejUnnngiAA899BDnnnsu9957Lz179mybFyciHVJkHymFpORQaP3UPiRz/aSglIikHLt8z25WTsBssnzPGfoA4MCeUirfk0NhGAYulwuXy9XWU5FO5Fvf+haPPfYYn3/+Occccwwffvghb731Fvfffz8AmzZtorS0lLFjx4avycvLY9SoUaxcuZJLL72UlStXkp+fHw5IAYwdOxaHw8GqVau46KKLDvvrEpGOS7vvSTJp/dS5KCglIinHLt/zOD3BA6aJnSPVdKPz4O57Kt8Tkfbq17/+NZWVlQwaNAin00kgEOD3v/89l112GQClpaUAFBUVRV1XVFQUPldaWkphYWHU+bS0NAoKCsJjDlRfX099fUN5dGVlZdJek4h0bOopJSLxdI7mCSIizWCX3NnZTpZphoJNTTc6tzOl3I5glpWCUiLS3jz99NMsWLCAhQsXsnbtWubPn8+9997L/PnzW/W5s2fPJi8vL/zVu3fvVn2eiHQgEelRpsJSIhJBQSkRSTkHle+ZZvMbnat8T0TaqRtvvJFf//rXXHrppQwdOpTLL7+c66+/ntmzZwNQXFwMQFlZWdR1ZWVl4XPFxcXs3Lkz6rzf72fv3r3hMQeaOXMmFRUV4a+tW7cm+6WJSAdlxf1FRFKdglIiknLsoJRdvpdIo3Nn6HzAcGBp9z0RacdqamoO2gnH6XRimiYA/fv3p7i4mKVLl4bPV1ZWsmrVKkpKSgAoKSmhvLycNWvWhMcsW7YM0zQZNWpUzOd6PB5yc3OjvkREgKhAlKWolIhEUE8pEUk5dlDKznZKpNG5nUFlYYCFyvdEpN06//zz+f3vf0+fPn049thj+eCDD7j//vv5yU9+AgTfz6ZNm8bvfvc7jj76aPr3789vf/tbevbsyYUXXgjA4MGDGT9+PFdffTWPPvooPp+PqVOncumll2rnPRFptqjd9xSTEpEIbZopNXv2bE466SRycnIoLCzkwgsvZOPGjVFj6urqmDJlCl27diU7O5uJEycelG6+ZcsWJkyYQGZmJoWFhdx44434/f6oMW+88QYnnHACHo+HAQMGMG/evNZ+eSLSTh2YKYVphqNR8Rudh4YaDrDMcKaUN+DF0upKRNqRhx56iEsuuYSf//znDB48mBtuuIGf/vSn3HHHHeExM2bM4LrrruOaa67hpJNOoqqqikWLFpGenh4es2DBAgYNGsSYMWM499xzOe2003jsscfa4iWJSAen3fdEJJ42zZRavnw5U6ZM4aSTTsLv9/Ob3/yGs88+m08++YSsrCwArr/+el566SX+9a9/kZeXx9SpU7n44ot5++23AQgEAkyYMIHi4mLeeecdduzYwaRJk3C5XNx5551AcOvjCRMmcO2117JgwQKWLl3KVVddRY8ePRg3blybvX4RaRt2o3O7p5Rlmpg0Xr5nB6ssg6ieUhYWAStAmqHEUxFpH3JycpgzZw5z5syJO8YwDGbNmsWsWbPijikoKGDhwoWtMEMRSTXRu+8pKiUiDdr0b1GLFi2K+n3evHkUFhayZs0azjjjDCoqKvjrX//KwoULOeusswB44oknGDx4MO+++y6nnHIKixcv5pNPPuG1116jqKiI448/njvuuIObbrqJ2267DbfbzaOPPkr//v257777gGBK+ltvvcUDDzygoJRICqoPBLcst7OdMBt6SsXLlIou32sISkGwhC/NoaCUiIiISCympfI9EYmtXTU6r6ioAIKfzAGsWbMGn8/H2LFjw2MGDRpEnz59WLlyJQArV65k6NChFBUVhceMGzeOyspKNmzYEB4TeQ97jH0PEUkt4fI9R6jRecTue/FSpUKb72Ee0Og88n4iIiIiEoMV80cRkfbT6Nw0TaZNm8app57KcccdB0BpaSlut5v8/PyosUVFRZSWlobHRAak7PP2ucbGVFZWUltbS0ZGRtS5+vp66uvrw79XVlYe+gsUkXbDbk5ul+9hRjQ6j3ONnUBlGcFG55Hlemp2LiIiIhJfVPmeolIiEqHdZEpNmTKFjz/+mH/84x9tPRVmz55NXl5e+Kt3795tPSURSSK7fC8yKNVUo/NwTykAy8IwjHAJn9/0x7xGRERERDhgUxhFpUSkQbsISk2dOpUXX3yR119/nV69eoWPFxcX4/V6KS8vjxpfVlZGcXFxeMyBu/HZvzc1Jjc396AsKYCZM2dSUVER/tq6deshv0YRaT/scruYjc7jlu/Zjc6N8Ed89vUq3xMRERGJT7vviUg8bRqUsiyLqVOn8uyzz7Js2TL69+8fdX7kyJG4XC6WLl0aPrZx40a2bNlCSUkJACUlJaxfv56dO3eGxyxZsoTc3FyGDBkSHhN5D3uMfY8DeTwecnNzo75EpPMIB6UcEeV7oWBU/EbnoaEY2J/w2ZlSKt8TERERiU95UiIST5v2lJoyZQoLFy7kP//5Dzk5OeEeUHl5eWRkZJCXl8eVV17J9OnTKSgoIDc3l+uuu46SkhJOOeUUAM4++2yGDBnC5Zdfzt13301paSk333wzU6ZMweMJNjG+9tpr+eMf/8iMGTP4yU9+wrJly3j66ad56aWX2uy1i0jbCTc6d3qC6eQRjc7jZUoZHJwppaCUiIiISNOiM6UUlhKRBm2aKfXII49QUVHB6NGj6dGjR/jrn//8Z3jMAw88wHnnncfEiRM544wzKC4u5plnngmfdzqdvPjiizidTkpKSvjRj37EpEmTmDVrVnhM//79eemll1iyZAnDhw/nvvvu4y9/+Qvjxo07rK9XRNoHu6eUy+kKr5KseNGoEHv3PQsjvJiyy/d8AQWlREREROKxIvKjFJISkUhtmimVSJQ8PT2dhx9+mIcffjjumL59+/Lyyy83ep/Ro0fzwQcfNHuOItL52JlNHqcHAoHQ0SYanTsiMqXM6Ewpr6meUiIiIiLxRP61z1RUSkQitItG5yIih1NkTyk7OG4aTZTvRfaUCl2T5gjG9VW+JyIiIpIgle+JSAQFpUQk5USV75km0JBKbveOOlBUTylUviciIiKSKPWREpF4FJQSkZRjl9tFlu9Z4fK92NdE9pQ6sNG5yvdERERE4ovafU/xKRGJoKCUiKSccPmes6F8zwqX78XpKWU0ZEpZ2n1PREREJGFRu++p1bmIRFBQSkRSTmRQqrmZUqZxcKaUyvdERERE4jMjolLKlBKRSApKiUjKscvt3A43VqinlN3oPN7ue3an82D5XvBQuKeUMqVERERE4lL5nojEo6CUiKScqEwpu9G5HZSK867YWE8pZUqJiIiIxKfyPRGJR0EpEUk5dlDK4/QcFJRKpKfUQUEpZUqJiIiINELleyISm4JSIpJy6gP1QDCoZJnBlZFpBN8O45XvRfeUCgayXE7tviciIiLSlOhMKRGRBgpKiUjKscvtgplSiTU6NyJ6Sh24+56deSUiIiIiB4vKjlJUSkQiKCglIikn3Og8oqdUU5lSRlSmVPDnLFcWADX+mlacrYiIiEjHFh2TUlRKRBooKCUiKccu34vcfc9y2D2lYl/TEKxq6CmV7coGoMpb1XqTFREREengosr3FJMSkQgKSolIyrHL96J23wuX7yXSUyoUlHKHglI+BaVEREREEqGYlIhEUlBKRFJKwAzgt/xAMChlBRIr34vafQ9lSomIiIgkKjI7ylSqlIhEUFBKRFJK5E55HqcnvJOeZTTe6NxmokwpERERkeaI7COlmJSIRFJQSkRSSuROeS6nq6F8z7B7SjWeKQWEd9+zG50rKCUiIiLSCCvmjyIiCkqJSGqxg1IGBmlGWrjRuV2+F7/ROaFxBgQCAOS4cgCV74mIiIg0JioQpVQpEYmgoJSIpBS7fM/j9ASzohJtdO6we0o5sHzBnlQq3xMRERFpmhURiFJISkQiKSglIimlPlAPhEr3INzovKmeUvZhEwPLF9y9z250Xu2rjlpsiYiIiEgDM7J8T0smEYmgoJSIpBRfIBhQ8jg9wQNWYplS4V5TBg1BqVCmlGmZ1PprW2vKIiIiIh2aFfWzolIi0kBBKRFJKXamlNvhDh4I95SyG53Hvs4OVkVmSqU703EaTgD2e/e31pRFREREOjTtvici8SgoJSIpxW5KnuUO7px3cPlevN33CI+zg1KGYYSzpap91a02ZxEREZGOLCpTSkEpEYmgoJSIpJRKbyUAue7c4IFQ+Z7ZZPle8LtpOMJBKWjoK7Xfp0wpERERkZismD+KiLQsKPXVV18lex4iIofFgUEpKxAIfm+q0XnovBVRvgcRzc69ypQSkcZp/SQiqSq6fE9hKRFp0KKg1IABAzjzzDN56qmnqKurS/acRERazUGZUqHtYOxMKSNu+Z4dlCI6KOVWppSIJEbrJxFJVYpDiUg8LQpKrV27lmHDhjF9+nSKi4v56U9/ynvvvZfsuYmIJF1lfSgo5bGDUollSsXqKQURmVLqKSUiTdD6SURSVWRQSgEqEYnUoqDU8ccfz9y5c9m+fTuPP/44O3bs4LTTTuO4447j/vvvZ9euXcmep4hIUhxUvhfKlLKa6CkV3n3PMLB83vDxcKaUdt8TkSZo/SQiqcqKbnXeZvMQkfbnkBqdp6WlcfHFF/Ovf/2LP/zhD3zxxRfccMMN9O7dm0mTJrFjx45kzVNEJCniNjpvYvc9+3C8nlJVvqrWmK6IdEJaP4lIqrHU6FxE4jikoNT777/Pz3/+c3r06MH999/PDTfcwJdffsmSJUvYvn07F1xwQbLmKSKSFAeW74UbnYfOx4lJNTQ6j1O+V+VVUEpEEqP1k4ikmshAlKn6PRGJkNaSi+6//36eeOIJNm7cyLnnnsuTTz7Jueeei8MRjHH179+fefPm0a9fv2TOVUTkkDXV6NzhMIj1GZ4jXqaUW5lSIpIYrZ9EJFUpU0pE4mlRUOqRRx7hJz/5CZMnT6ZHjx4xxxQWFvLXv/71kCYnIpJsBwelEm10HtlTSo3ORaT5tH4SkdSlqJSIxNaioNSSJUvo06dP+JM9m2VZbN26lT59+uB2u7niiiuSMkkRkWQJB6Xs8j0z1FMqlCllEKenVOi7hQERQaksVxagRuci0jStn0QkVSlTSkTiaVFPqaOOOordu3cfdHzv3r3079//kCclItIaTMsM935qyJQyo8bEy5SK6inlbQhK5bhzAGVKiUjTtH4SkVQV2UfKUk8pEYnQoqBUvDeSqqoq0tPTD2lCIiKtZb93f3hL4jx3XvDggZlScTqdR/WU8vvDx+3yPWVKiUhTtH4SkVRlxflZRKRZ5XvTp08Hgn9pu+WWW8jMzAyfCwQCrFq1iuOPPz6pExQRSRa7dC8jLQOX0wWAZQbDVC3uKeVWTykRaZzWTyKS6qLK9xSVEpEIzQpKffDBB0Dwk77169fjdrvD59xuN8OHD+eGG25I7gxFRJLEDkrZJXcAmIFgn6gQR5xMKfuwFafRuXbfE5F4tH4SkVQXnSmlqJSINGhWUOr1118H4Mc//jFz584lNze3VSYlItIaKusP2HmPYKNzy2g6KGUft4gdlKr11+I3/aQ5WrR/hIh0Ym2xftq2bRs33XQTr7zyCjU1NQwYMIAnnniCE088EQgGyG699Vb+/Oc/U15ezqmnnsojjzzC0UcfHb7H3r17ue6663jhhRdwOBxMnDiRuXPnkp2d3erzF5FOJqqnVBvOQ0TanRb1lHriiScUkBKRDie8815EUIqAGe4nBWDEeVeMlymV5c4K/6wSPhFpzOFaP+3bt49TTz0Vl8vFK6+8wieffMJ9991Hly5dwmPuvvtuHnzwQR599FFWrVpFVlYW48aNo66uLjzmsssuY8OGDSxZsoQXX3yRFStWcM0117T6/EWk81H5nojEk/BH+hdffDHz5s0jNzeXiy++uNGxzzzzzCFPTEQk2WIGpazmZUqZB2RKuRwu0p3p1AXqqPJVkefJa4WZi0hH1Rbrpz/84Q/07t2bJ554Inwscnc/y7KYM2cON998MxdccAEATz75JEVFRTz33HNceumlfPrppyxatIjVq1eHs6seeughzj33XO6991569uyZlLmKSGqILNnT7nsiEinhTKm8vLzwrlR5eXmNfomItEfh8j1PRPlewMSMCkrFvjYyUwrTxAoEwufsZudVXvWVEpFobbF+ev755znxxBP53ve+R2FhISNGjODPf/5z+PymTZsoLS1l7NixUfMcNWoUK1euBGDlypXk5+eHA1IAY8eOxeFwsGrVqqTNVURSQ2izY0C774lItIQzpSI/bYv8WUSko4ibKZVAo/PInlIAls+H4XQCwb5Su2t3s9+7vzWmLSIdWFusn7766iseeeQRpk+fzm9+8xtWr17NL37xC9xuN1dccQWlpaUAFBUVRV1XVFQUPldaWkphYWHU+bS0NAoKCsJjDlRfX099fX3498rKymS+LBHpwMyI7ChTmVIiEqFFPaVqa2upqakJ//71118zZ84cFi9enLSJiYgkW6yglGVGZ0rFiUlFZ0pBzGbn6iklIo05XOsn0zQ54YQTuPPOOxkxYgTXXHMNV199NY8++mhSn3Og2bNnR2V+9e7du1WfJyIdR2QYylRMSkQitCgodcEFF/Dkk08CUF5ezsknn8x9993HBRdcwCOPPJLUCYqIJEus8j0Cze8pBQcEpULle/t9ypQSkfgO1/qpR48eDBkyJOrY4MGD2bJlCwDFxcUAlJWVRY0pKysLnysuLmbnzp1R5/1+P3v37g2POdDMmTOpqKgIf23dujUpr0dEOj5Lu++JSBwtCkqtXbuW008/HYB///vfFBcX8/XXX/Pkk0/y4IMPJnyfFStWcP7559OzZ08Mw+C5556LOj958mQMw4j6Gj9+fNSYvXv3ctlll5Gbm0t+fj5XXnklVVXRfV0++ugjTj/9dNLT0+nduzd33313S162iHRwSSnfczSSKeVVppSIxJes9VNTTj31VDZu3Bh17PPPP6dv375AsOl5cXExS5cuDZ+vrKxk1apVlJSUAFBSUkJ5eTlr1qwJj1m2bBmmaTJq1KiYz/V4POTm5kZ9iYhAdHaUGp2LSKQWBaVqamrIyckBYPHixVx88cU4HA5OOeUUvv7664TvU11dzfDhw3n44Yfjjhk/fjw7duwIf/3973+POt/UdsWVlZWcffbZ9O3blzVr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Ufj6669Rv359zJgxAy4uLggODgYATJ48Gb169YK3tzdu3bqFqKgotGzZEgDg7u4OhUKB8PBwPP/881Cr1ahfvz6mTZuGt99+GxqNBk899RQyMjJw8OBBWFtbIyQkpNztmz59OkJDQ+Hp6Yl27dohLCwMx48fL/MOe+XRsmVL/P3337CwsChxfkBAAPz9/fHiiy9i4cKF8Pb2xl9//YWdO3fipZdeQocOHeDl5YUtW7agT58+UCgU+OCDD3gGFBERUR1VV/pU4eHh2LBhAwYMGABvb2+ICH766SdEREQgLCys1FysrKwwYsQITJ8+Hba2tnBwcMCsWbNQr57u+RkzZ87E5cuXsWbNmgq1i4gqh4NSRGQwYWFhmDRpEl544QXk5uaiW7duiIiI0P7srKCgAOPHj8elS5dgbW2NoKAgfPrppwAAFxcXzJkzBzNmzMCwYcPwxhtvYNWqVfjoo49gb2+PBQsWIDk5GTY2NvDz88N7771XobZNnDgRGRkZmDp1Kq5du4ZWrVphx44d8PLyqnTeD18v6kEKhQIRERGYNWsWhg0bhuvXr8PR0RHdunVD48aNAQBLly7F8OHD0aVLF9jZ2eHdd99FZmZmpdtFRERENVNd6FO1atUKFhYWmDp1Ki5evAiVSgUvLy+sXLkSQ4YMKTOXRYsWITs7G3369EH9+vUxdepUZGRk6Cz/ypUrxa7PSUT6pxAp4X6aREREREREREREesRrShERERERERERUbXjoBQREREREREREVU7DkoREREREREREVG146AUERERERERERFVOw5KERERERERERFRteOgFBERERERERERVTsOShERERERERERUbXjoBQREREREREREVU7DkoREREREREREVG146AUERERERERERFVOw5KERERERERERFRteOgFBERERERERERVbv/B5BU2hUmr6S1AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1200x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(12, 4))\n",
    "\n",
    "df = pd.DataFrame(np.concatenate([mu_z_true, mu_z_null, mu_z_rand, mu_z], 1), columns=['true', 'null', 'rand', 'trained'])\n",
    "seaborn.kdeplot(df, ax=ax[0])\n",
    "ymin, ymax = ax[0].get_ylim()\n",
    "ax[0].plot([mu_z_null.mean(), mu_z_null.mean()], [ymin, ymax], color='orange')\n",
    "ax[0].set_xlabel('Posterior Mean')\n",
    "ax[0].set_ylim(0, 3000)\n",
    "df = pd.DataFrame(np.concatenate([std_z_true, std_z_null, std_z_rand, std_z], 1), columns=['true', 'null', 'rand', 'trained'])\n",
    "\n",
    "seaborn.kdeplot(df, ax=ax[1])\n",
    "ymin, ymax = ax[1].get_ylim()\n",
    "ax[1].plot([std_z_null.mean(), std_z_null.mean()], [ymin, ymax], color='orange')\n",
    "ax[1].set_xlabel('Posterior Std.')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'{figure_path}/posterior.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "50517b0f",
   "metadata": {},
   "source": [
    "## 1.3 Training sanity check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "c2071d82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x14e8b686cd60>"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.plot(loss_comp['re'], label='reconstruction loss')\n",
    "plt.plot(loss_comp['uv_kl'], label='KL Graph')\n",
    "plt.plot(loss_comp['z_kl'], label='KL Z')\n",
    "#plt.xlim(20, 300)\n",
    "plt.ylim(0, 5e4)\n",
    "plt.legend()\n",
    "#plt.savefig(f'{figure_path}/loss_spnfactor.png')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "e221b2a2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x14e8b68b5340>"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAGdCAYAAADuR1K7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAty0lEQVR4nO3de1xVdb7/8fcGuXgDRlE2FIiapeUtMYkuo5M8QsdH5cnKHE9esswCs7AiKrXbRJcx07HRnFODnTLNLjaZx8bw0kXyglp5Y9RDUsklM0BFAeH7+6Pjnt8eEYHYbvbX1/PxWI/Y3/Vda32+fIX1bu21Fw5jjBEAAIAl/LxdAAAAQFMi3AAAAKsQbgAAgFUINwAAwCqEGwAAYBXCDQAAsArhBgAAWIVwAwAArNLC2wV4Q01NjQ4cOKC2bdvK4XB4uxwAAFAPxhgdPnxYUVFR8vM7/fWZczLcHDhwQNHR0d4uAwAANMJ3332n888//7Trz8lw07ZtW0m/fHNCQkK8XA0AAKiPsrIyRUdHu87jp3NOhpuTb0WFhIQQbgAA8DFnuqWEG4oBAIBVCDcAAMAqhBsAAGCVc/KeGwCA3YwxOnHihKqrq71dChrA399fLVq0+NWPaSHcAACsUllZqYKCApWXl3u7FDRCq1atFBkZqcDAwEbvg3ADALBGTU2N8vLy5O/vr6ioKAUGBvKwVh9hjFFlZaV+/PFH5eXlqVu3bnU+qK8uhBsAgDUqKytVU1Oj6OhotWrVytvloIFatmypgIAA7d+/X5WVlQoODm7UfrihGABgncb+Hz+8rynmjtkHAABWIdwAAHCOWrt2rRwOh0pKSpq0r7cRbgAAOEddccUVKigoUGhoaJP29TbCDQAAPqiysvJX7yMwMFBOp7NenyhrSF9vI9wAANAMDBo0SCkpKUpJSVFoaKjCw8M1bdo0GWMkSbGxsXrqqac0ZswYhYSEaOLEiZKkzz//XFdffbVatmyp6Oho3XvvvTp69KhrvxUVFUpLS1N0dLSCgoJ0wQUX6NVXX5V06ltN+/fv13XXXaff/OY3at26tS655BKtWLGi1r6S9O677+qSSy5RUFCQYmNjNXPmTLcxxcbG6plnntHtt9+utm3bKiYmRgsWLPDUt9CFcAMAsJoxRuWVJ7yynAwm9bVw4UK1aNFCGzdu1OzZs/Xiiy/qv/7rv1zr//SnP6lPnz7aunWrpk2bpn379mnIkCEaMWKEvv76ay1ZskSff/65UlJSXNuMGTNGb731lubMmaNdu3bplVdeUZs2bWo9fnJysioqKvTpp5/qm2++0XPPPXfavjk5Obrlllt066236ptvvtHjjz+uadOmKTMz063fzJkz1b9/f23dulX33HOP7r77buXm5jbo+9JQDtPQ77wFysrKFBoaqtLSUoWEhHi7HABAEzl+/Ljy8vLUuXNn1zNSyitP6OLpH3ulnp1PJqlVYP0eKTdo0CAVFxdrx44drrd+Hn74Yf3973/Xzp07FRsbq0svvVTvv/++a5s77rhD/v7+euWVV1xtn3/+uQYOHKijR48qPz9fF110kVatWqXExMRTjrl27Vr97ne/088//6ywsDD17t1bI0aM0IwZM87Yd/To0frxxx/1j3/8w9XnoYce0kcffaQdO3ZI+uXKzdVXX63//u//lvRL0HQ6nXriiSc0adKkWr8Ptc3hSfU9f3PlBgCAZuLyyy93u6clISFBe/bscf2NrP79+7v1/+qrr5SZmak2bdq4lqSkJNeTmrdt2yZ/f38NHDiwXse/99579fTTT+vKK6/UjBkz9PXXX5+2765du3TllVe6tV155ZVu9UpS7969XV87HA45nU4VFxfXq57G4gnFAACrtQzw184nk7x27KbUunVrt9dHjhzRXXfdpXvvvfeUvjExMdq7d2+D9n/HHXcoKSlJH330kf7xj38oIyNDM2fO1OTJkxtdc0BAgNtrh8OhmpqaRu+vPgg3AACrORyOer815G0bNmxwe/3ll1+qW7du8vevPST169dPO3fu1AUXXFDr+l69eqmmpkbr1q2r9W2p2kRHR2vSpEmaNGmS0tPT9de//rXWcNOjRw998cUXbm1ffPGFLrzwwtPWe7bwthQAAM1Efn6+UlNTlZubq7feekt//vOfNWXKlNP2T0tL0/r165WSkqJt27Zpz549+uCDD1w3FMfGxmrs2LG6/fbbtWzZMuXl5Wnt2rV6++23a93ffffdp48//lh5eXnasmWL1qxZox49etTad+rUqcrKytJTTz2lf/7zn1q4cKHmzp2rBx544Nd/I34l34iyAACcA8aMGaNjx45pwIAB8vf315QpU1wf+a5N7969tW7dOj366KO6+uqrZYxR165dNXLkSFefefPm6ZFHHtE999yjn376STExMXrkkUdq3V91dbWSk5P1/fffKyQkREOGDNGsWbNq7duvXz+9/fbbmj59up566ilFRkbqySef1Lhx437V96Ap8GkpPi0FANao65M2zd2gQYPUt29fvfTSS94uxav4tBQAAMC/IdwAAACrcM8NAADNwNq1a71dgjW4cgMAAKxCuAEAAFYh3AAAAKsQbgAAgFUINwAAwCqEGwAAYBXCDQAA56jHH39cffv2db0eN26chg8f7rV6mgrhBgAAWIVwAwBAM1RZWentEnwW4QYAgGZg0KBBSklJ0X333afw8HAlJSVp+/btGjp0qNq0aaOIiAjddtttOnjwoGubmpoaPf/887rgggsUFBSkmJgY/fGPf3StT0tL04UXXqhWrVqpS5cumjZtmqqqqrwxvLOKP78AALCbMVJVuXeOHdBKcjjq3X3hwoW6++679cUXX6ikpETXXHON7rjjDs2aNUvHjh1TWlqabrnlFq1evVqSlJ6err/+9a+aNWuWrrrqKhUUFGj37t2u/bVt21aZmZmKiorSN998ozvvvFNt27bVQw891ORDbU4INwAAu1WVS89EeefYjxyQAlvXu3u3bt30/PPPS5KefvppXXrppXrmmWdc61977TVFR0frn//8pyIjIzV79mzNnTtXY8eOlSR17dpVV111lav/Y4895vo6NjZWDzzwgBYvXky4AQAAZ0dcXJzr66+++kpr1qxRmzZtTum3b98+lZSUqKKiQoMHDz7t/pYsWaI5c+Zo3759OnLkiE6cOKGQkBCP1N6cEG4AAHYLaPXLFRRvHbsBWrf+11WeI0eO6LrrrtNzzz13Sr/IyEj97//+b537ys7O1ujRo/XEE08oKSlJoaGhWrx4sWbOnNmgmnwR4QYAYDeHo0FvDTUX/fr107vvvqvY2Fi1aHHq6bpbt25q2bKlsrKydMcdd5yyfv369erUqZMeffRRV9v+/fs9WnNzwaelAABohpKTk3Xo0CGNGjVKmzZt0r59+/Txxx9r/Pjxqq6uVnBwsNLS0vTQQw/p9ddf1759+/Tll1/q1VdflfRL+MnPz9fixYu1b98+zZkzR++//76XR3V2EG4AAGiGoqKi9MUXX6i6ulrXXnutevXqpfvuu09hYWHy8/vl9D1t2jRNnTpV06dPV48ePTRy5EgVFxdLkq6//nrdf//9SklJUd++fbV+/XpNmzbNm0M6axzGGOPtIs62srIyhYaGqrS09Jy4sQoAzhXHjx9XXl6eOnfurODgYG+Xg0aoaw7re/7myg0AALDKWQk3L7/8smJjYxUcHKz4+Hht3Lixzv5Lly5V9+7dFRwcrF69emnFihWn7Ttp0iQ5HA699NJLTVw1AADwRR4PN0uWLFFqaqpmzJihLVu2qE+fPkpKSnK9J/jv1q9fr1GjRmnChAnaunWrhg8fruHDh2v79u2n9H3//ff15ZdfKirKSw9nAgAAzY7Hw82LL76oO++8U+PHj9fFF1+s+fPnq1WrVnrttddq7T979mwNGTJEDz74oHr06KGnnnpK/fr109y5c936/fDDD5o8ebLefPNNBQQEeHoYAADAR3g03FRWVionJ0eJiYn/OqCfnxITE5WdnV3rNtnZ2W79JSkpKcmtf01NjW677TY9+OCDuuSSS85YR0VFhcrKytwWAABgJ4+Gm4MHD6q6uloRERFu7RERESosLKx1m8LCwjP2f+6559SiRQvde++99aojIyNDoaGhriU6OrqBIwEAAL7C5z4tlZOTo9mzZyszM1OOev6l1fT0dJWWlrqW7777zsNVAgAAb/FouAkPD5e/v7+Kiorc2ouKiuR0Omvdxul01tn/s88+U3FxsWJiYtSiRQu1aNFC+/fv19SpUxUbG1vrPoOCghQSEuK2AAAAO3k03AQGBiouLk5ZWVmutpqaGmVlZSkhIaHWbRISEtz6S9KqVatc/W+77TZ9/fXX2rZtm2uJiorSgw8+qI8//thzgwEAAD7B4384MzU1VWPHjlX//v01YMAAvfTSSzp69KjGjx8vSRozZozOO+88ZWRkSJKmTJmigQMHaubMmRo2bJgWL16szZs3a8GCBZKk9u3bq3379m7HCAgIkNPp1EUXXeTp4QAA4BHGGN11111655139PPPP2vr1q3q27evt8vySR6/52bkyJH605/+pOnTp6tv377atm2bVq5c6bppOD8/XwUFBa7+V1xxhRYtWqQFCxaoT58+euedd7Rs2TL17NnT06UCAOA1K1euVGZmppYvX66CggKVlZXpuuuuU1RUlBwOh5YtW+btEn2Gx6/cSFJKSopSUlJqXbd27dpT2m6++WbdfPPN9d7/t99+28jKAABoHvbt26fIyEhdccUVkqStW7eqT58+uv3223XjjTd6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afz48erfv78WLVokSfrhhx80ePBgvf766xowYIAk6e6779aKFSuUmZmpkJAQTZ48WdIv99ZIv7wVdc011ygpKUkvvPCC61j+/v71Cl0n8WkpAAB8T33P3x65oViS3nzzTaWkpGjw4MHy8/PTiBEjNGfOHNf6qqoq5ebmqry83NU2a9YsV9+KigolJSXpL3/5i2v9O++8ox9//FFvvPGG3njjDVd7p06d9O2333pqKAAAwId47MpNc8aVGwAAfI9Xn3MDAADgLYQbAABgFcINAACwCuEGAABYhXADAACsQrgBAABWIdwAAACrEG4AAIBVCDcAAMAqhBsAAGAVwg0AALAK4QYAAFiFcAMAAKxCuAEAAFYh3AAAAKsQbgAAgFUINwAAwCqEGwAAYBXCDQAAsArhBgAAWIVwAwAArEK4AQAAViHcAAAAqxBuAACAVQg3AADAKoQbAABgFcINAACwCuEGAABYhXADAACsQrgBAABWIdwAAACrEG4AAIBVCDcAAMAqhBsAAGAVwg0AALAK4QYAAFiFcAMAAKxCuAEAAFYh3AAAAKsQbgAAgFUINwAAwCqEGwAAYBXCDQAAsArhBgAAWIVwAwAArEK4AQAAViHcAAAAqxBuAACAVQg3AADAKoQbAABgFcINAACwCuEGAABYhXADAACsQrgBAABWIdwAAACrEG4AAIBVCDcAAMAqHgs3hw4d0ujRoxUSEqKwsDBNmDBBR44cqXOb48ePKzk5We3bt1ebNm00YsQIFRUV1dr3p59+0vnnny+Hw6GSkhIPjAAAAPgij4Wb0aNHa8eOHVq1apWWL1+uTz/9VBMnTqxzm/vvv18ffvihli5dqnXr1unAgQO68cYba+07YcIE9e7d2xOlAwAAH+Ywxpim3umuXbt08cUXa9OmTerfv78kaeXKlfr973+v77//XlFRUadsU1paqg4dOmjRokW66aabJEm7d+9Wjx49lJ2drcsvv9zVd968eVqyZImmT5+uwYMH6+eff1ZYWFi96ysrK1NoaKhKS0sVEhLy6wYLAADOivqevz1y5SY7O1thYWGuYCNJiYmJ8vPz04YNG2rdJicnR1VVVUpMTHS1de/eXTExMcrOzna17dy5U08++aRef/11+fnVr/yKigqVlZW5LQAAwE4eCTeFhYXq2LGjW1uLFi3Url07FRYWnnabwMDAU67AREREuLapqKjQqFGj9MILLygmJqbe9WRkZCg0NNS1REdHN2xAAADAZzQo3Dz88MNyOBx1Lrt37/ZUrUpPT1ePHj30n//5nw3errS01LV89913HqoQAAB4W4uGdJ46darGjRtXZ58uXbrI6XSquLjYrf3EiRM6dOiQnE5nrds5nU5VVlaqpKTE7epNUVGRa5vVq1frm2++0TvvvCNJOnm7UHh4uB599FE98cQTte47KChIQUFB9RkiAADwcQ0KNx06dFCHDh3O2C8hIUElJSXKyclRXFycpF+CSU1NjeLj42vdJi4uTgEBAcrKytKIESMkSbm5ucrPz1dCQoIk6d1339WxY8dc22zatEm33367PvvsM3Xt2rUhQwEAAJZqULiprx49emjIkCG68847NX/+fFVVVSklJUW33nqr65NSP/zwgwYPHqzXX39dAwYMUGhoqCZMmKDU1FS1a9dOISEhmjx5shISElyflPr3AHPw4EHX8RryaSkAAGAvj4QbSXrzzTeVkpKiwYMHy8/PTyNGjNCcOXNc66uqqpSbm6vy8nJX26xZs1x9KyoqlJSUpL/85S+eKhEAAFjII8+5ae54zg0AAL7Hq8+5AQAA8BbCDQAAsArhBgAAWIVwAwAArEK4AQAAViHcAAAAqxBuAACAVQg3AADAKoQbAABgFcINAACwCuEGAABYhXADAACsQrgBAABWIdwAAACrEG4AAIBVCDcAAMAqhBsAAGAVwg0AALAK4QYAAFiFcAMAAKxCuAEAAFYh3AAAAKsQbgAAgFUINwAAwCqEGwAAYBXCDQAAsArhBgAAWIVwAwAArEK4AQAAViHcAAAAqxBuAACAVQg3AADAKoQbAABgFcINAACwCuEGAABYhXADAACsQrgBAABWIdwAAACrEG4AAIBVCDcAAMAqhBsAAGAVwg0AALBKC28X4A3GGElSWVmZlysBAAD1dfK8ffI8fjrnZLg5fPiwJCk6OtrLlQAAgIY6fPiwQkNDT7veYc4UfyxUU1OjAwcOqG3btnI4HE2677KyMkVHR+u7775TSEhIk+67uWCMdmCM9jgXxskY7fBrx2iM0eHDhxUVFSU/v9PfWXNOXrnx8/PT+eef79FjhISEWPuP8yTGaAfGaI9zYZyM0Q6/Zox1XbE5iRuKAQCAVQg3AADAKoSbJhYUFKQZM2YoKCjI26V4DGO0A2O0x7kwTsZoh7M1xnPyhmIAAGAvrtwAAACrEG4AAIBVCDcAAMAqhBsAAGAVwk0TevnllxUbG6vg4GDFx8dr48aN3i6p0TIyMnTZZZepbdu26tixo4YPH67c3Fy3PoMGDZLD4XBbJk2a5KWKG+7xxx8/pf7u3bu71h8/flzJyclq37692rRpoxEjRqioqMiLFTdObGzsKeN0OBxKTk6W5Jvz+Omnn+q6665TVFSUHA6Hli1b5rbeGKPp06crMjJSLVu2VGJiovbs2ePW59ChQxo9erRCQkIUFhamCRMm6MiRI2dxFHWra4xVVVVKS0tTr1691Lp1a0VFRWnMmDE6cOCA2z5qm/tnn332LI/k9M40j+PGjTul/iFDhrj18eV5lFTrz6bD4dALL7zg6tPc57E+54v6/D7Nz8/XsGHD1KpVK3Xs2FEPPvigTpw40aiaCDdNZMmSJUpNTdWMGTO0ZcsW9enTR0lJSSouLvZ2aY2ybt06JScn68svv9SqVatUVVWla6+9VkePHnXrd+edd6qgoMC1PP/8816quHEuueQSt/o///xz17r7779fH374oZYuXap169bpwIEDuvHGG71YbeNs2rTJbYyrVq2SJN18882uPr42j0ePHlWfPn308ssv17r++eef15w5czR//nxt2LBBrVu3VlJSko4fP+7qM3r0aO3YsUOrVq3S8uXL9emnn2rixIlnawhnVNcYy8vLtWXLFk2bNk1btmzRe++9p9zcXF1//fWn9H3yySfd5nby5Mlno/x6OdM8StKQIUPc6n/rrbfc1vvyPEpyG1tBQYFee+01ORwOjRgxwq1fc57H+pwvzvT7tLq6WsOGDVNlZaXWr1+vhQsXKjMzU9OnT29cUQZNYsCAASY5Odn1urq62kRFRZmMjAwvVtV0iouLjSSzbt06V9vAgQPNlClTvFfUrzRjxgzTp0+fWteVlJSYgIAAs3TpUlfbrl27jCSTnZ19lir0jClTppiuXbuampoaY4zvz6Mk8/7777te19TUGKfTaV544QVXW0lJiQkKCjJvvfWWMcaYnTt3Gklm06ZNrj7/8z//YxwOh/nhhx/OWu319e9jrM3GjRuNJLN//35XW6dOncysWbM8W1wTqW2MY8eONTfccMNpt7FxHm+44QZzzTXXuLX50jwac+r5oj6/T1esWGH8/PxMYWGhq8+8efNMSEiIqaioaHANXLlpApWVlcrJyVFiYqKrzc/PT4mJicrOzvZiZU2ntLRUktSuXTu39jfffFPh4eHq2bOn0tPTVV5e7o3yGm3Pnj2KiopSly5dNHr0aOXn50uScnJyVFVV5Tan3bt3V0xMjE/PaWVlpd544w3dfvvtbn801tfn8f+Xl5enwsJCt7kLDQ1VfHy8a+6ys7MVFham/v37u/okJibKz89PGzZsOOs1N4XS0lI5HA6FhYW5tT/77LNq3769Lr30Ur3wwguNvszvLWvXrlXHjh110UUX6e6779ZPP/3kWmfbPBYVFemjjz7ShAkTTlnnS/P47+eL+vw+zc7OVq9evRQREeHqk5SUpLKyMu3YsaPBNZyTfzizqR08eFDV1dVukyJJERER2r17t5eqajo1NTW67777dOWVV6pnz56u9j/84Q/q1KmToqKi9PXXXystLU25ubl67733vFht/cXHxyszM1MXXXSRCgoK9MQTT+jqq6/W9u3bVVhYqMDAwFNOFBERESosLPROwU1g2bJlKikp0bhx41xtvj6P/+7k/NT283hyXWFhoTp27Oi2vkWLFmrXrp1Pzu/x48eVlpamUaNGuf0xwnvvvVf9+vVTu3bttH79eqWnp6ugoEAvvviiF6utvyFDhujGG29U586dtW/fPj3yyCMaOnSosrOz5e/vb908Lly4UG3btj3l7W9fmsfazhf1+X1aWFhY68/syXUNRbjBGSUnJ2v79u1u96NIcntfu1evXoqMjNTgwYO1b98+de3a9WyX2WBDhw51fd27d2/Fx8erU6dOevvtt9WyZUsvVuY5r776qoYOHaqoqChXm6/P47muqqpKt9xyi4wxmjdvntu61NRU19e9e/dWYGCg7rrrLmVkZPjEI/5vvfVW19e9evVS79691bVrV61du1aDBw/2YmWe8dprr2n06NEKDg52a/eleTzd+eJs422pJhAeHi5/f/9T7vwuKiqS0+n0UlVNIyUlRcuXL9eaNWt0/vnn19k3Pj5ekrR3796zUVqTCwsL04UXXqi9e/fK6XSqsrJSJSUlbn18eU7379+vTz75RHfccUed/Xx9Hk/OT10/j06n85Sb/U+cOKFDhw751PyeDDb79+/XqlWr3K7a1CY+Pl4nTpzQt99+e3YKbGJdunRReHi469+mLfMoSZ999plyc3PP+PMpNd95PN35oj6/T51OZ60/syfXNRThpgkEBgYqLi5OWVlZrraamhplZWUpISHBi5U1njFGKSkpev/997V69Wp17tz5jNts27ZNkhQZGenh6jzjyJEj2rdvnyIjIxUXF6eAgAC3Oc3NzVV+fr7Pzunf/vY3dezYUcOGDauzn6/PY+fOneV0Ot3mrqysTBs2bHDNXUJCgkpKSpSTk+Pqs3r1atXU1LjCXXN3Mtjs2bNHn3zyidq3b3/GbbZt2yY/P79T3srxFd9//71++ukn179NG+bxpFdffVVxcXHq06fPGfs2t3k80/miPr9PExIS9M0337iF1ZOB/eKLL25UUWgCixcvNkFBQSYzM9Ps3LnTTJw40YSFhbnd+e1L7r77bhMaGmrWrl1rCgoKXEt5ebkxxpi9e/eaJ5980mzevNnk5eWZDz74wHTp0sX89re/9XLl9Td16lSzdu1ak5eXZ7744guTmJhowsPDTXFxsTHGmEmTJpmYmBizevVqs3nzZpOQkGASEhK8XHXjVFdXm5iYGJOWlubW7qvzePjwYbN161azdetWI8m8+OKLZuvWra5PCj377LMmLCzMfPDBB+brr782N9xwg+ncubM5duyYax9Dhgwxl156qdmwYYP5/PPPTbdu3cyoUaO8NaRT1DXGyspKc/3115vzzz/fbNu2ze1n9OQnS9avX29mzZpltm3bZvbt22feeOMN06FDBzNmzBgvj+xf6hrj4cOHzQMPPGCys7NNXl6e+eSTT0y/fv1Mt27dzPHjx1378OV5PKm0tNS0atXKzJs375TtfWEez3S+MObMv09PnDhhevbsaa699lqzbds2s3LlStOhQweTnp7eqJoIN03oz3/+s4mJiTGBgYFmwIAB5ssvv/R2SY0mqdblb3/7mzHGmPz8fPPb3/7WtGvXzgQFBZkLLrjAPPjgg6a0tNS7hTfAyJEjTWRkpAkMDDTnnXeeGTlypNm7d69r/bFjx8w999xjfvOb35hWrVqZ//iP/zAFBQVerLjxPv74YyPJ5ObmurX76jyuWbOm1n+fY8eONcb88nHwadOmmYiICBMUFGQGDx58yth/+uknM2rUKNOmTRsTEhJixo8fbw4fPuyF0dSurjHm5eWd9md0zZo1xhhjcnJyTHx8vAkNDTXBwcGmR48e5plnnnELBt5W1xjLy8vNtddeazp06GACAgJMp06dzJ133nnK/zD68jye9Morr5iWLVuakpKSU7b3hXk80/nCmPr9Pv3222/N0KFDTcuWLU14eLiZOnWqqaqqalRNjv8rDAAAwArccwMAAKxCuAEAAFYh3AAAAKsQbgAAgFUINwAAwCqEGwAAYBXCDQAAsArhBgAAWIVwAwAArEK4AQAAViHcAAAAqxBuAACAVf4f76ED/i9b1+QAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.plot(loss_comp['precision'], label='precision')\n",
    "plt.plot(loss_comp['recall'], label='recall')\n",
    "plt.plot(loss_comp['f1'], label='f1')\n",
    "\n",
    "plt.legend()\n",
    "#plt.savefig(f'{figure_path}/graph_eval_spnfactor.png')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "37ed770e",
   "metadata": {},
   "source": [
    "## 1.4 Evaluate the factor graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "defeee7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pred_adj = model.weight_mask.detach().cpu().numpy()\n",
    "with torch.no_grad():\n",
    "    n2m, m2n = model.sample_uv.fg.sample_deterministic(hard=True)\n",
    "    n2m = n2m.detach().cpu().numpy()\n",
    "    m2n = m2n.detach().cpu().numpy()\n",
    "graph_pred = np.matmul(n2m, m2n.T)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "6071e9d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_bar(df, num_modules, partition = False):\n",
    "    column_sums = np.sum(df,axis=0)\n",
    "    print(column_sums)\n",
    "    if partition==True:\n",
    "        plt.bar(range(num_modules+1),column_sums)\n",
    "        plt.xlabel('Partition')\n",
    "    else:\n",
    "        plt.bar(range(num_modules),column_sums)\n",
    "        plt.xlabel('Factor')\n",
    "    plt.ylabel('Edge counts')\n",
    "    #plt.savefig('ori_y_sampled.png',bbox_inches='tight')\n",
    "    plt.show()\n",
    "    return True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "8a02141f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[21.]\n"
     ]
    },
    {
     "data": {
      "image/png": "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AQIAAPAGAhAAADAdAhAAADAdAhAAADAdApCXnTp1Svfcc4/CwsIUHh6uUaNGqbCwsFLXGoahpKQkWSyWCr/LrKZVpcc//elPat26terUqaNGjRpp0KBB5X69SU1zt79Tp07poYceUvv27VWnTh01b95c//u//+v8jjlfU5Wf3+uvv674+HiFhYXJYrHo9OnT1VNsJaWlpally5YKCQlRbGystm/fXuH8t956Sx06dFBISIi6dOmiDz74oJoqrRp3+tuzZ4+GDBmili1bymKxaNasWdVX6CVwp8d58+apT58+ql+/vurXr6+EhITf/JnXNHf6e+edd3TttdcqPDxc9erVU7du3fTPf/6zGqt1n7v/Bi9YtmyZLBaLBg8e7N0CJcmAV/Xv39+IiYkxtm7davznP/8x2rRpYyQnJ1fq2hdffNFISkoyJBkrV670bqGXoCo9/uMf/zA2btxo5ObmGjt37jQGDhxoREdHG+fPn6+mqivP3f52795t3Hbbbcbq1auNgwcPGhkZGUbbtm2NIUOGVGPVlVeVn99LL71kpKamGqmpqYYk44cffqieYith2bJlRlBQkLFgwQJjz549xpgxY4zw8HCjoKCgzPlbtmwxatWqZTz33HPGV199ZUyZMsWoXbu2sXv37mquvHLc7W/79u3GxIkTjX/9619GZGSk8dJLL1VvwVXgbo933323kZaWZmRlZRl79+41RowYYVitVuPo0aPVXHnluNvfhg0bjHfeecf46quvjIMHDxqzZs0yatWqZaSnp1dz5ZXjbn8X5ObmGk2bNjX69OljDBo0yOt1EoC86KuvvjIkGZ999plz7MMPPzQsFovx7bffVnhtVlaW0bRpU+P48eM+HYAupcdf+vzzzw1JxsGDB71RZpV5qr8VK1YYQUFBRnFxsTfKrLJL7W/Dhg0+F4B69OhhjBs3znleUlJiREVFGampqWXOv/POO40BAwa4jMXGxhp/+tOfvFpnVbnb3y+1aNHCLwLQpfRoGIZx/vx5IzQ01Fi8eLG3Srwkl9qfYRjGNddcY0yZMsUb5V2yqvR3/vx5o1evXsb//d//GcOHD6+WAMRLYF6UmZmp8PBwXXvttc6xhIQEBQQEaNu2beVe9+OPP+ruu+9WWlpahd9h5guq2uMvFRUVaeHChWrVqpWio6O9VWqVeKI/SbLZbAoLC1NgoG99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JMQ5lpSUpLfeestl3r///W/df//9OnHihCTp7rvvVl5enjZv3lzmuvHx8erWrZtmzZrlHHvyySf19ttva+/evbJYLJKk1157TU888YRsNpsCAgIUHx8vu92uXbt2ebhTANWFPUAA/ELfvn01Z84c53m9evX08ccfKzU1Vfv27ZPdbtf58+d19uxZ/fjjj6pbt66ys7N1xx13uPU8e/fuVVxcnDP8SNL111+vwsJCHT16VM2bN5ckde/e3TONAagRvAQGwC/Uq1dPbdq0cR4Oh0N/+MMf1LVrV7399tvauXOn0tLSJP28KVmS6tSp49V6APgvAhAAv7Rz506VlpbqhRdeUM+ePdWuXTsdO3bMZU7Xrl2VkZFR7hpBQUEqKSlxGevYsaMyMzP1y90BW7ZsUWhoqJo1a+bZJgDUGAIQAL/Upk0bFRcX65VXXtE333yjf/7znxdtRp48ebI+++wzPfjgg/riiy+0b98+zZkzx7lHqGXLltq2bZsOHTqkEydOqLS0VA8++KCOHDmihx56SPv27dO7776radOmKSUlRQEB/C8TuFzwrxmAX4qJidGLL76oZ599VldffbXefPNNpaamusxp166d1q5dq88//1w9evRQXFyc3n33XQUG/rz9ceLEiapVq5Y6deqkRo0aKS8vT02bNtUHH3yg7du3KyYmRvfff79GjRqlKVOm1ESbALyEd4EBAADT4Q4QAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwnf8HgvOHJex92zYAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plot_bar(U0[:, module_causal_order],1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "101133dc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[20]\n"
     ]
    },
    {
     "data": {
      "image/png": "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iYmJevPNN53mvfXWW7rnnnt07NgxSdJtt92mvLw8bd68udJ14+Li1KdPH82ZM8cx9uijj+rtt9/Wvn37ZLFYJEmvvvqqHnnkEdlsNvn5+SkuLk52u127du1yc6cA6gt7gAD4hKuvvlrz5s1znDdr1kwff/yxUlJStH//ftntdp05c0anTp3Szz//rKZNm2r37t26+eabXXqfffv2KTY21hF+JOmKK65QcXGxjh49qnbt2kmS+vbt657GADQIHoEB8AnNmjVT586dHUdpaan+/Oc/q3fv3nr77be1c+dOpaamSvp1U7IkNWnSxKP1APBdBCAAPmnnzp2qqKjQ888/r/79+6tr1676/vvvneb07t1b6enpVa4REBCg8vJyp7EePXooMzNTv90dsGXLFgUHB6tt27bubQJAgyEAAfBJnTt3VllZmV5++WV9++23+ve//33OZuRp06bp888/13333acvv/xS+/fv17x58xx7hDp06KBt27bp0KFDOnbsmCoqKnTffffpyJEjuv/++7V//36tWbNGM2bMUHJysvz8+L9M4HzBv2YAPik6OlovvPCCnnnmGV1yySV6/fXXlZKS4jSna9euWrdunb744gv169dPsbGxWrNmjfz9f93+OGXKFDVq1Eg9e/ZUq1atlJeXpzZt2uiDDz7Q9u3bFR0drXvuuUfjx4/XY4891hBtAvAQPgUGAABMhztAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdAhAAADAdP4/iUHI+Hc84sgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plot_bar(n2m,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed2517c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_bar(V0[module_causal_order].T,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba129db1",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_bar(m2n,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "e3771529",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.        , 0.        , 0.        , 0.02093462, 0.02290758,\n",
       "       0.95317316, 0.39094242, 0.02032896, 0.5153729 , 0.47325373],\n",
       "      dtype=float32)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n2m[3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "7dd94599",
   "metadata": {},
   "outputs": [],
   "source": [
    "def boolean_prod(n2m, m2n, thred):\n",
    "    m = n2m.shape[1]\n",
    "    b = (n2m[:, [0]] @ m2n[:, [0]].T) > thred\n",
    "    for i in range(1, m):\n",
    "        b = b | ((n2m[:, [i]] @ m2n[:, [i]].T) > thred)\n",
    "    return b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "41ee66c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "threds = np.arange(0, 1.0, 0.001)\n",
    "precision_list, recall_list, f1_list = [], [], []\n",
    "for i in range(len(threds)):\n",
    "    graph_pred = boolean_prod(n2m, m2n, threds[i]).astype(int)\n",
    "    p, r, f = pred_score(graph_pred, graph)\n",
    "    precision_list.append(p)\n",
    "    recall_list.append(r)\n",
    "    f1_list.append(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "30f1e32e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Z3r27GkmTJjgLtu1a5cJDg42PXr0MOnp6eaZZ54x6enppkePHiY4ONjs2rWrXhvTpk0zksyIESPMo48+al544QXz6KOPmri4OCPJbN682ep5fldBQYEJCAgww4cPN08//bT59a9/bQIDA80NN9zgUW/Dhg1Gklm8eLFHeU5OjpFkbrnlFvPcc8+Z5ORkI8n893//t0e9yspKM2DAANOrVy/z2GOPmSeffNJERkaaiIgIU1ZWZvs0ATQRIQuAFRMmTDCBgYGmurq60Tp33HGH6dChgzl27Ji7bPfu3SYpKcn06tXL+Pn5mV69epmpU6ea3bt3N9rOq6++am644QbTvXt34+fnZ3r37m2SkpJMXl5ei55TU2zatMlcddVVJjAw0PTs2dPMnDnT486WMY2HLGOMefbZZ833v/994+/vbwYMGGCefPLJBu/SHTp0yNxyyy0mODjYBAUFmZ/85Cdm7969tk4LQDM4jDHGS08qAQAALlksfAcAALCAkAUAAGABIQsAAMACQhYAAIAFhCwAAAALCFkAAAAW8N2FzeRyuXTkyBF16dLF/YW1AADg4maM0ddff62IiAj5+Ni910TIaqYjR44oMjLS28MAAADNcOjQIfXt29dqH4SsZjrzBayHDh1ScHCwl0cDAACaorKyUpGRka3yReqErGY684gwODiYkAUAQBvTGkt9WPgOAABggddDVk5OjpxOpwIDAxUfH69t27Y1Wnfnzp2aPHmynE6nHA6HsrOz69V57733NGHCBEVERMjhcGjdunX16lRVVWnWrFnq27evOnbsqMsvv1wrVqxowbMCAADtnVdD1po1a5SWlqbFixersLBQMTExGjdunMrKyhqsX1NTo/79+yszM1Ph4eEN1qmurlZMTIxycnIa7TctLU3r16/Xyy+/rN27dys1NVWzZs3S66+/3iLnBQAA4DDGGG91Hh8fr9jYWC1fvlzSt69FiIyM1OzZs7VgwYKzHut0OpWamqrU1NRG6zgcDq1du1YTJ070KP/BD36gpKQkLVy40F02cuRI3XjjjXrkkUeaNPbKykqFhISooqKCNVkAALQRrfn722t3smpra1VQUKDExMT/G4yPjxITE5Wfn2+176uuukqvv/66Dh8+LGOMNmzYoE8//VQ33HCD1X4BAED74bW/Ljx27Jjq6uoUFhbmUR4WFqZPPvnEat/Lli3TjBkz1LdvX/n5+cnHx0fPPfecrrvuukaPOXXqlE6dOuX+XFlZaXWMAACgbfP6wndvWLZsmbZs2aLXX39dBQUFevzxxzVz5ky98847jR6TkZGhkJAQ98aLSAEAwNl47U5WaGiofH19VVpa6lFeWlra6KL2lnDixAk9+OCDWrt2rX784x9Lkq644goVFRUpKyvL4/Hld6WnpystLc39+czLzAAAABritTtZ/v7+GjlypHJzc91lLpdLubm5Gj16tLV+T58+rdOnT9f7viJfX1+5XK5GjwsICHC/eJQXkAIAgHPx6hvf09LSlJKSolGjRikuLk7Z2dmqrq7W9OnTJUnJycnq06ePMjIyJH27WH7Xrl3unw8fPqyioiIFBQUpOjpa0rfvwNq3b5+7j+LiYhUVFal79+6KiopScHCwEhISNG/ePHXs2FH9+vXTxo0b9dJLL+mJJ55o5RkAAACXKq++wkGSli9frqVLl6qkpETDhg3TU089pfj4eEnSmDFj5HQ6tXLlSknS559/rssuu6xeGwkJCcrLy5Mk5eXlaezYsfXqpKSkuNspKSlRenq63nrrLZWXl6tfv36aMWOG7r///ia/Zp9XOAAA0Pa05u9vr4estoqQBQBA29Mu3pMFAABwKSNkAQAAWEDIAgAAsICQBQAAYAEhCwAAwAJCFgAAgAWELAAAAAsIWQAAABYQsgAAACwgZAEAAFhAyAIAALCAkAUAAGABIQsAAMACQhYAAIAFhCwAAAALCFkAAAAWELIAAAAsIGQBAABYQMgCAACwgJAFAABgASELAADAAkIWAACABYQsAAAACwhZAAAAFhCyAAAALCBkAQAAWEDIAgAAsICQBQAAYAEhCwAAwAJCFgAAgAWELAAAAAsIWQAAABYQsgAAACwgZAEAAFhAyAIAALCAkAUAAGABIQsAAMACQhYAAIAFhCwAAAALCFkAAAAWELIAAAAsIGQBAABYQMgCAACwgJAFAABgASELAADAAkIWAACABYQsAAAACwhZAAAAFhCyAAAALPB6yMrJyZHT6VRgYKDi4+O1bdu2Ruvu3LlTkydPltPplMPhUHZ2dr067733niZMmKCIiAg5HA6tW7euwbZ2796tn/70pwoJCVHnzp0VGxurgwcPttBZAQCA9s6rIWvNmjVKS0vT4sWLVVhYqJiYGI0bN05lZWUN1q+p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5ml6XWvP88GDB811111nunfvbgICAkx0dLSZN2/eeb8ny2GMMU2/7wUAAICmYE0WAACABYQsAAAACwhZAAAAFhCyAAAALCBkAQAAWEDIAgAAsICQBQAAYAEhCwD+Q15enhwOR73vh7vQugDaF15GCgD/oba2VuXl5QoLC5PD4WixugDaF0IWgEtKbW2t/P39vT0MAOBxIYCL25gxYzRr1izNmjVLISEhCg0N1cKFC3Xmvw+dTqcefvhhJScnKzg4WDNmzJAkvf/++7r22mvVsWNHRUZGas6cOaqurna3e+rUKc2fP1+RkZEKCAhQdHS0nn/+eUn1HwEeOHBAEyZMULdu3dS5c2cNGTJEf//73xusK0l//vOfNWTIEAUEBMjpdOrxxx/3OCen06lHH31Ud955p7p06aKoqCg9++yztqYQgJcQsgBc9F588UX5+flp27Zt+t3vfqcnnnhCv//97937s7KyFBMTo48++kgLFy7U/v37NX78eE2ePFk7duzQmjVr9P7772vWrFnuY5KTk/XHP/5RTz31lHbv3q1nnnlGQUFBDfY/c+ZMnTp1Su+9954+/vhjLVmypNG6BQUFmjJliqZOnaqPP/5YDz30kBYuXKiVK1d61Hv88cc1atQoffTRR7rvvvv0i1/8Qnv27LnwyQJw8Ti/78EGgNaVkJBgBg8ebFwul7ts/vz5ZvDgwcYYY/r162cmTpzocczPf/5zM2PGDI+yTZs2GR8fH3PixAmzZ88eI8m8/fbbDfa5YcMGI8n8+9//NsYYM3ToUPPQQw81qe5tt91mfvSjH3nUmTdvnrn88svdn/v162duv/1292eXy2V69eplnn766bPMBIC2hjtZAC56V155pcei8tGjR2vv3r2qq6uTJI0aNcqj/j//+U+tXLlSQUFB7m3cuHFyuVwqLi5WUVGRfH19lZCQ0KT+58yZo0ceeURXX321Fi9erB07djRad/fu3br66qs9yq6++mqP8UrSFVdc4f7Z4XAoPDxcZWVlTRoPgLaBkAWgzevcubPH56qqKt1zzz0qKipyb//85z+1d+9eDRgwQB07djyv9u+66y599tlnmjZtmj7++GONGjVKy5Ytu6Axd+jQweOzw+GQy+W6oDYBXFwIWQAuelu3bvX4vGXLFg0cOFC+vr4N1h8xYoR27dql6Ojoepu/v7+GDh0ql8uljRs3NnkMkZGRuvfee/Xaa69p7ty5eu655xqsN3jwYH3wwQceZR988IG+973vNTpeAJcmQhaAi97BgweVlpamPXv26I9//KOWLVumX/7yl43Wnz9/vjZv3qxZs2apqKhIe/fu1V/+8hf3wnen06mUlBTdeeedWrdunYqLi5WXl6dXXnmlwfZSU1P15ptvqri4WIWFhdqwYYMGDx7cYN25c+cqNzdXDz/8sD799FO9+OKLWr58uX71q19d+EQAaFP8vD0AADiX5ORknThxQnFxcfL19dUvf/lL96saGnLFFVdo48aN+vWvf61rr71WxhgNGDBASUlJ7jpPP/20HnzwQd133306fvy4oqKi9OCDDzbYXl1dnWbOnKkvvvhCwcHBGj9+vJ588skG644YMUKvvPKKFi1apIcffli9e/fWb3/7W91xxx0XNAcA2h5eRgrgojZmzBgNGzZM2dnZ3h4KAJwXHhcCAABYQMgCAACwgMeFAAAAFnAnCwAAwAJCFgAAgAWELAAAAAsIWQAAABYQsgAAACwgZAEAAFhAyAIAALCAkAUAAGABIQsAAMCC/w9PbB363rtY1AAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.metrics import auc\n",
    "plt.figure()\n",
    "plt.plot(precision_list, recall_list)\n",
    "plt.xlabel('precision')\n",
    "plt.ylabel('recall')\n",
    "idx = np.argsort(precision_list)\n",
    "plt.title(f'AUC = {auc(np.array(precision_list)[idx], np.array(recall_list)[idx]):.2f}')\n",
    "plt.savefig(f'{figure_path}/auc_spnfactor.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "58eeebeb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1660, 96, 81)"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "graph_pred = boolean_prod(n2m, m2n, 0.5).astype(int)\n",
    "np.sum(graph != graph_pred), np.sum(n2m != U0[:, module_causal_order]), np.sum(m2n != V0[module_causal_order].T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "3df96dc4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "7"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n2m.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "b55a3100",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAzYAAAGiCAYAAAA1J1M9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA550lEQVR4nO3de3hU1b3/8c+EXIHMEBASogGjgnhBURDk8itYY1NABUUtihZR6y2IoK2KFe8atdZGLGK1PahH8IKnSPWoHImiB0VAFAsqBCQqlSZgC5lUJJBk/f7IyTSTzCQzk5nZs8j79TzzPMyevdf67rVn5ss3e8/aLmOMEQAAAABYLMnpAAAAAACgvShsAAAAAFiPwgYAAACA9ShsAAAAAFiPwgYAAACA9ShsAAAAAFiPwgYAAACA9ShsAAAAAFiPwgYAAACA9ShsgBhzuVy68847nQ6jVZdeeqm6du3qdBgAcFA6/PDDdemll/qer1ixQi6XSytWrHAspuaax2irMWPG6Pjjj3c6DDiEwgYJoby8XNOnT1f//v3VuXNnde7cWccee6yKior017/+1enwYmrMmDFyuVxtPtpbHO3du1d33nlnQiVSAIi1p59+2u+7ND09Xf3799f06dNVWVnpdHhhef311xPiD2U1NTV67LHHNGrUKGVlZSk1NVW5ubk6++yz9fzzz6uurs7pENFBJTsdAPDaa6/pZz/7mZKTkzVlyhSdeOKJSkpK0qZNm/TnP/9Z8+fPV3l5ufr27et0qDHx61//WldccYXv+dq1azV37lzdeuutOuaYY3zLTzjhhHb1s3fvXt11112SGoopAOhI7r77buXn52vfvn1auXKl5s+fr9dff10bN25U586d4xrLj370I/3www9KTU0Na7vXX39d8+bNc7S42bVrl8aOHat169apsLBQt912m7p3766KigotX75cF110kbZu3ao5c+Y4FiM6LgobOOrLL7/U5MmT1bdvX5WWlqp3795+rz/44IN6/PHHlZTU+snF77//Xl26dIllqDFzxhln+D1PT0/X3LlzdcYZZ7RagNi8zwAQb2PHjtWQIUMkSVdccYV69OihRx55REuXLtWFF14YcJtYfc8mJSUpPT096u3GwyWXXKJPPvlE//Vf/6Vzzz3X77XZs2fro48+0ubNm1ttY9++fUpNTW0ztwPh4h0FRz300EP6/vvvtWDBghZFjSQlJydrxowZysvL8y1r/D3Il19+qXHjxikzM1NTpkyR1JCEbrzxRuXl5SktLU1HH320Hn74YRljfNt/9dVXcrlcevrpp1v01/ySrzvvvFMul0tbt27VpZdeqm7dusnj8WjatGnau3ev37Y1NTWaNWuWevbsqczMTJ199tn629/+1s4R8o/j888/10UXXaSsrCyNGjVKUsPZl0AF0KWXXqrDDz/ct889e/aUJN11111BL2/79ttvNXHiRHXt2lU9e/bUL3/5Sy4pAHBQ+vGPfyyp4VJoqfXcUl9fr5KSEh133HFKT09Xdna2rrrqKu3evduvTWOM7r33Xh122GHq3LmzTjvtNH322Wct+g72G5vVq1dr3LhxysrKUpcuXXTCCSfo0Ucf9cU3b948SfK7tK5RtGMMZNWqVVq2bJmuvPLKFkVNoyFDhvjGrem+vvDCC7rtttt06KGHqnPnzvJ6vfrnP/+pX/7ylxo4cKC6du0qt9utsWPH6tNPPw04Xi+++KJuvfVW5eTkqEuXLjr77LO1ffv2gHF8/vnnOu2009S5c2cdeuiheuihh0LaR9iNMzZw1GuvvaajjjpKw4YNC2u72tpaFRYWatSoUXr44YfVuXNnGWN09tln65133tHll1+uQYMGadmyZfrVr36lb7/9Vr/73e8ijvOCCy5Qfn6+iouL9fHHH+uPf/yjevXqpQcffNC3zhVXXKHnnntOF110kUaMGKG3335b48ePj7jPQM4//3z169dP999/v1+x1paePXtq/vz5uuaaa3TOOef4ElLTy9vq6upUWFioYcOG6eGHH9by5cv129/+VkceeaSuueaaqO4HADjtyy+/lCT16NHDtyxQbpGkq666Sk8//bSmTZumGTNmqLy8XL///e/1ySef6P3331dKSook6fbbb9e9996rcePGady4cfr444/1k5/8RPv3728znrfeektnnnmmevfureuvv145OTn64osv9Nprr+n666/XVVddpR07duitt97Sf/7nf7bYPh4xvvrqq5Kkiy++uM11m7vnnnuUmpqqX/7yl6qpqVFqaqo+//xzvfLKKzr//POVn5+vyspK/eEPf9Do0aP1+eefKzc316+N++67Ty6XSzfffLN27typkpISFRQUaP369crIyPCtt3v3bv30pz/VueeeqwsuuEAvv/yybr75Zg0cOFBjx44NO3ZYxAAOqaqqMpLMxIkTW7y2e/dus2vXLt9j7969vtemTp1qJJlbbrnFb5tXXnnFSDL33nuv3/LzzjvPuFwus3XrVmOMMeXl5UaSWbBgQYt+JZk77rjD9/yOO+4wksxll13mt94555xjevTo4Xu+fv16I8lce+21futddNFFLdpsy+LFi40k884777SI48ILL2yx/ujRo83o0aNbLJ86darp27ev7/muXbuCxtI4pnfffbff8pNOOskMHjw45NgBINEsWLDASDLLly83u3btMtu3bzcvvPCC6dGjh8nIyDB/+9vfjDHBc8v//u//Gklm4cKFfsvffPNNv+U7d+40qampZvz48aa+vt633q233mokmalTp/qWvfPOO37f87W1tSY/P9/07dvX7N6926+fpm0VFRWZQP91i0WMgZxzzjlGktmzZ4/f8h9++MEvZzfdh8Z9PeKII/xyuTHG7Nu3z9TV1fktKy8vN2lpaX75qLGNQw891Hi9Xt/yl156yUgyjz76qG/Z6NGjjSTz7LPP+pbV1NSYnJwcM2nSpFb3D/bjUjQ4xuv1SlLAaYbHjBmjnj17+h6Np9+ban4W4fXXX1enTp00Y8YMv+U33nijjDF64403Io716quv9nv+//7f/9M//vEP3z68/vrrktSi75kzZ0bcZyhxRFug/dy2bVtM+wSAeCgoKFDPnj2Vl5enyZMnq2vXrlqyZIkOPfRQv/Wa55bFixfL4/HojDPO0Hfffed7DB48WF27dtU777wjSVq+fLn279+v6667zu8SsVDywCeffKLy8nLNnDlT3bp183utaVvBxCNGKXjefuKJJ/xyduOl0k1NnTrV76yKJKWlpfl+Z1NXV6d//OMf6tq1q44++mh9/PHHLdr4+c9/rszMTN/z8847T7179/bl4EZdu3b1O6uUmpqqoUOHks86AC5Fg2Mav5z+9a9/tXjtD3/4g6qrq1VZWRnwlHdycrIOO+wwv2Vff/21cnNz/b70JPlmFvv6668jjrVPnz5+z7OysiQ1nO52u936+uuvlZSUpCOPPNJvvaOPPjriPgPJz8+PantNpaen+36H0ygrK6vF9dkAYKN58+apf//+Sk5OVnZ2to4++ugWP14PlFu2bNmiqqoq9erVK2C7O3fulPTvHNOvXz+/13v27OnLGcE0XhYX6f1X4hGj5J+3PR6Pb/mkSZN8sd94440Bf5sZKH/V19fr0Ucf1eOPP67y8nK/7ZpeItioedwul0tHHXWUvvrqK7/lhx12WIuCMCsr66C/fQQobOAgj8ej3r17a+PGjS1ea/zNTfMvq0ZN/8oTrmB//WrtR/KdOnUKuNyE8TuXaGj+1y6pYX8CxRHuj/6D7SMAHAyGDh3qmxUtmEC5pb6+Xr169dLChQsDbtP8D0JOiFeMAwYMkCRt3LhRI0eO9C3Py8vzTfKTlZWl7777rsW2gfLX/fffrzlz5uiyyy7TPffco+7duyspKUkzZ85UfX19xHEmSs5G/FHYwFHjx4/XH//4R61Zs0ZDhw5tV1t9+/bV8uXLVV1d7XfWZtOmTb7XpX+fbdmzZ4/f9u05o9O3b1/V19fryy+/9DtL09aUl9GQlZUV8PR68/0J5XIGAIC/I488UsuXL9fIkSMD/ue8UWOO2bJli4444gjf8l27drV55rvxbP/GjRtVUFAQdL1g3+PxiFGSzjzzTD3wwANauHChX2ETqZdfflmnnXaa/vSnP/kt37Nnjw455JAW62/ZssXvuTFGW7dubfd93nDw4Dc2cNRNN92kzp0767LLLgt4B+hw/roybtw41dXV6fe//73f8t/97ndyuVy+mVDcbrcOOeQQvffee37rPf744xHsQYPGtufOneu3vKSkJOI2Q3XkkUdq06ZN2rVrl2/Zp59+qvfff99vvcbZfZoXdACA4C644ALV1dXpnnvuafFabW2t7zu1oKBAKSkpeuyxx/xyVyh54OSTT1Z+fr5KSkpafEc3bavxnjrN14lHjJI0cuRInXHGGXryySe1dOnSgOuEk7c7derUYv3Fixfr22+/Dbj+s88+q+rqat/zl19+WX//+9+Z6Qw+nLGBo/r166dFixbpwgsv1NFHH60pU6boxBNPlDFG5eXlWrRokZKSklpc8xzIWWedpdNOO02//vWv9dVXX+nEE0/U//zP/2jp0qWaOXOm3+9frrjiCj3wwAO64oorNGTIEL333nsqKyuLeD8GDRqkCy+8UI8//riqqqo0YsQIlZaWauvWrRG3GarLLrtMjzzyiAoLC3X55Zdr586deuKJJ3Tcccf5fugpNVwGcOyxx+rFF19U//791b17dx1//PERX9MNAB3B6NGjddVVV6m4uFjr16/XT37yE6WkpGjLli1avHixHn30UZ133nm+e38VFxfrzDPP1Lhx4/TJJ5/ojTfeCHj2oamkpCTNnz9fZ511lgYNGqRp06apd+/e2rRpkz777DMtW7ZMkjR48GBJDRPVFBYWqlOnTpo8eXJcYmz03HPP6ac//akmTpyosWPHqqCgQFlZWaqoqNDy5cv13nvvhVxonHnmmbr77rs1bdo0jRgxQhs2bNDChQv9ziY11b17d40aNUrTpk1TZWWlSkpKdNRRR+kXv/hFSP2hA3BmMjbA39atW80111xjjjrqKJOenm4yMjLMgAEDzNVXX23Wr1/vt+7UqVNNly5dArZTXV1tZs2aZXJzc01KSorp16+f+c1vfuM3raUxxuzdu9dcfvnlxuPxmMzMTHPBBReYnTt3Bp3uedeuXX7bN04fWl5e7lv2ww8/mBkzZpgePXqYLl26mLPOOsts3749qtM9N4+j0XPPPWeOOOIIk5qaagYNGmSWLVvWYrpnY4z54IMPzODBg01qaqpfXMHGtLFfALBV4/f12rVrW12vtdxijDFPPvmkGTx4sMnIyDCZmZlm4MCB5qabbjI7duzwrVNXV2fuuusu07t3b5ORkWHGjBljNm7caPr27dvqdM+NVq5cac444wyTmZlpunTpYk444QTz2GOP+V6vra011113nenZs6dxuVwtvp+jGWNrfvjhB1NSUmKGDx9u3G63SU5ONjk5OebMM880CxcuNLW1tS32dfHixS3a2bdvn7nxxht9sYwcOdKsWrWqxW0MGtt4/vnnzezZs02vXr1MRkaGGT9+vPn666/92hw9erQ57rjjWvQVKCfi4OMyhl9SAQAAIDGtWLFCp512mhYvXqzzzjvP6XCQwPiNDQAAAADrUdgAAAAAsB6FDQAAAADr8RsbAAAAANbjjA0AAAAA68WssJk3b54OP/xwpaena9iwYVqzZk2sugIAoE3kJQA4uMXkUrQXX3xRP//5z/XEE09o2LBhKikp0eLFi7V582b16tWr1W3r6+u1Y8cOZWZmyuVyRTs0AEArjDGqrq5Wbm6ukpIOnpP67clLErkJAJwSVl6Kxc1xhg4daoqKinzP6+rqTG5urikuLm5z28YbGvLgwYMHD+ce27dvj0V6cEx78pIx5CYePHjwcPoRSl5KVpTt379f69at0+zZs33LkpKSVFBQoFWrVrVYv6amRjU1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cVwkaeTIkS2mXS0rK1Pfvn0lSfn5+crJyfEbG6/Xq9WrVx/UY7N3714lJfl/1XXq1En19fWSOu64IHTkpX8jNwVGbgqMvBQcuSlGnJ69IJAXXnjBpKWlmaefftp8/vnn5sorrzTdunUzFRUVTocWN9dcc43xeDxmxYoV5u9//7vvsXfvXt86V199tenTp495++23zUcffWSGDx9uhg8f7mDUzmg684wxHXdc1qxZY5KTk819991ntmzZYhYuXGg6d+5snnvuOd86DzzwgOnWrZtZunSp+etf/2omTJhw0E8dOXXqVHPooYf6ptT885//bA455BBz0003+dbpiOOC8JCXGpCbQkduIi+1htwUGwlZ2BhjzGOPPWb69OljUlNTzdChQ82HH37odEhxJSngY8GCBb51fvjhB3PttdearKws07lzZ3POOeeYv//9784F7ZDmyaMjj8urr75qjj/+eJOWlmYGDBhgnnzySb/X6+vrzZw5c0x2drZJS0szp59+utm8ebND0caH1+s1119/venTp49JT083RxxxhPn1r39tampqfOt0xHFB+Dp6XjKG3BQOclMD8lJg5KbYcBnT5BanAAAAAGChhPuNDQAAAACEi8IGAAAAgPUobAAAAABYj8IGAAAAgPUobAAAAABYj8IGAAAAgPUobAAAAABYj8IGAAAAgPUobAAAAABYj8IGAAAAgPUobAAAAABYj8IGAAAAgPX+P43gz/PG2ufaAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "ax[0].imshow(graph)\n",
    "ax[1].imshow(graph_pred)\n",
    "ax[0].set_title('Ground Truth')\n",
    "ax[1].set_title('Predicted Graph')\n",
    "plt.savefig(f'{figure_path}/graph.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "dfb5e2a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.25135135135135134, 0.11211573236889692, 0.1550646102542726)"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pred_score(graph_pred, graph)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "bd9e2058",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4\n"
     ]
    }
   ],
   "source": [
    "up_nodes_pred = np.where(n2m.squeeze() > 0)[0]\n",
    "up_nodes = np.where(U0.squeeze() > 0)[0]\n",
    "print(len(np.intersect1d(up_nodes, up_nodes_pred)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "b5ac901f",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'figure_path' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[35], line 11\u001b[0m\n\u001b[1;32m      9\u001b[0m ax[\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mset_title(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mPredicted U\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m     10\u001b[0m plt\u001b[38;5;241m.\u001b[39mtight_layout()\n\u001b[0;32m---> 11\u001b[0m plt\u001b[38;5;241m.\u001b[39msavefig(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mfigure_path\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m/U.png\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'figure_path' is not defined"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAHqCAYAAAAAtunEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAArbElEQVR4nO3deXRV5b3G8eckJCchJGFOQKbIIFTgMgkEuIA1EkW9aHHAYgVqBRWVoRWIq2AZNBdKLUIp1FoZXFiUXpHSi7owCgoNiMEBkEkJlwgkyHQiUEKG9/7B5VxfE5AkZ8o+389aZy2zz94775Hfm+fs/e53b5cxxggAgP8TEewGAABCC8EAALAQDAAAC8EAALAQDAAAC8EAALAQDAAAC8EAALAQDAAAC8EAICS1atVKI0eO9P68YcMGuVwubdiwIWht+r7vt9EpCIYAcblcV/UKdtG3atVKt99+e4Xvffzxx3K5XFq6dGlgG4WAW7p0qVWXMTExateunR5//HEVFBQEu3mVsm7dOv3mN78J2u8/ePCgXC6X5s6dW+H7c+fOlcvl0sGDBwPbsCuoFewGhItXXnnF+nn58uVav359ueUdOnQIZLOAK5oxY4ZSUlJ0/vx5bdq0SYsWLdK6deu0c+dO1a5dO6Bt6d+/v/71r38pOjq6UtutW7dOCxcuDGo41DQEQ4A88MAD1s9btmzR+vXryy3/vnPnzgW8AwKX3HrrrerRo4ck6Re/+IUaNGig559/XmvWrNH9999f4TZnz55VXFycz9sSERGhmJgYn+8X5XEqKYQMHDhQHTt2VE5Ojvr376/atWvr6aeflnTxVFRF33gqOsd5+vRpjR8/Xs2bN5fb7VabNm00e/ZslZWVBeBTwMl+/OMfS5Jyc3MlSSNHjlSdOnX01VdfafDgwYqPj9fw4cMlSWVlZZo3b56uv/56xcTEKCkpSWPGjNGpU6esfRpjNGvWLDVr1ky1a9fWjTfeqF27dpX73ZcbY9i6dasGDx6sevXqKS4uTp07d9YLL7zgbd/ChQsl2adzL/F1G52CI4YQc+LECd16660aNmyYHnjgASUlJVVq+3PnzmnAgAE6fPiwxowZoxYtWuif//ynMjIydPToUc2bN88/DUdY+OqrryRJDRo08C4rKSlRenq6+vXrp7lz53qPcMeMGaOlS5dq1KhRevLJJ5Wbm6s//OEP+uSTT7R582ZFRUVJkqZNm6ZZs2Zp8ODBGjx4sLZv365BgwbpwoULP9ie9evX6/bbb1eTJk00btw4JScna/fu3frHP/6hcePGacyYMTpy5EiFp20D1cYaySAoxo4da77/v3/AgAFGklm8eHG59SWZZ555ptzyli1bmhEjRnh/njlzpomLizP79u2z1psyZYqJjIw0hw4dumK7WrZsaW677bYK39u2bZuRZJYsWXLFfaDmW7JkiZFk3n33XfPNN9+YvLw8s3LlStOgQQMTGxtrvv76a2OMMSNGjDCSzJQpU6ztP/zwQyPJrFixwlr+9ttvW8uPHTtmoqOjzW233WbKysq86z399NNGklXb77//vpFk3n//fWOMMSUlJSYlJcW0bNnSnDp1yvo9391XRX3NX22sSG5urpFkfvvb31b4/m9/+1sjyeTm5l5xP4HEqaQQ43a7NWrUqCpvv2rVKv37v/+76tWrp+PHj3tfaWlpKi0t1QcffODD1sLp0tLS1KhRIzVv3lzDhg1TnTp1tHr1al1zzTXWeo8++qj186pVq5SYmKibb77ZqsPu3burTp06ev/99yVJ7777ri5cuKAnnnjCOsUzfvz4H2zbJ598otzcXI0fP15169a13vvuvi4nEG2sqTiVFGKuueaaSl918V379+/X559/rkaNGlX4/rFjx6q870uuptPBGRYuXKh27dqpVq1aSkpK0nXXXaeICPv7ZK1atdSsWTNr2f79++XxeNS4ceMK93upDv/nf/5HktS2bVvr/UaNGqlevXpXbNul01odO3a8+g8U4DZWRij1K4IhxMTGxlZq/dLSUuvnsrIy3XzzzZo0aVKF67dr1+6K+4uJidG//vWvCt87d+6cdx2Eh549e3qvSroct9tdLizKysrUuHFjrVixosJtLvfFJZAC1cZL/aUm9SuCoYaoV6+eTp8+bS27cOGCjh49ai1r3bq1zpw5o7S0tCr9npYtW+qLL76o8L29e/d61wGupHXr1nr33XfVt2/fK37ZuVRL+/fv17XXXutd/s0335S7Mqii3yFJO3fuvGK9X+6beCDaKF0MmNq1a3v7z/ft3btXtWvXVsOGDX9wX4HCGEMN0bp163LjAy+++GK5I4Z7771X2dnZeuedd8rt4/Tp0yopKbni7xk8eLC+/vprvfnmm9byoqIivfTSS2rcuLG6detWtQ+BsHHvvfeqtLRUM2fOLPdeSUmJ90tOWlqaoqKitGDBAhljvOtczdVz3bp1U0pKiubNm1fuS9N393VpTsX31wlEGyUpMjJSgwYN0tq1a3Xo0CHrvUOHDmnt2rUaNGiQIiMjr2p/gcARQw3xi1/8Qo888oiGDh2qm2++WZ999pneeeedct8ynnrqKf3973/X7bffrpEjR6p79+46e/asduzYob/97W86ePDgFb+ZjB49Wi+//LLuuece/fznP1fXrl114sQJvfbaa9q5c6eWL19erTEQhIcBAwZozJgxyszM1KeffqpBgwYpKipK+/fv16pVq/TCCy/o7rvvVqNGjfSrX/1KmZmZuv322zV48GB98skneuutt37wG3RERIQWLVqkO+64Q126dNGoUaPUpEkT7dmzR7t27fJ+Oerevbsk6cknn1R6eroiIyM1bNiwgLTxkueee069e/dWt27dNHr0aLVq1UoHDx7Uiy++KJfLpeeee656/8N9LchXRYWty12uev3111e4fmlpqZk8ebJp2LChqV27tklPTzdffvlluctVjTHm22+/NRkZGaZNmzYmOjraNGzY0PTp08fMnTvXXLhw4QfbdurUKTNhwgSTkpJioqKiTEJCgrnxxhvNW2+9VeXPi5rl0uWq27Ztu+J6I0aMMHFxcZd9/8UXXzTdu3c3sbGxJj4+3nTq1MlMmjTJHDlyxLtOaWmpmT59umnSpImJjY01AwcONDt37ixX29+/XPWSTZs2mZtvvtnEx8ebuLg407lzZ7NgwQLv+yUlJeaJJ54wjRo1Mi6Xq1y/82Ubr2T37t3mvvvuM40bNza1atUyjRs3NsOGDTO7d+++qu0DyWXMd46NAABhjzEGAICFYAAAWAgGAICFYAAAWAgGAIClRgTDwoUL1apVK8XExKhXr1766KOPgt0kIKDoAwikkL9c9bXXXtODDz6oxYsXq1evXpo3b55WrVqlvXv3XvbmV99VVlamI0eOKD4+PqRuUgXfMMbo22+/VdOmTcvdr8cpqtMHqH9n81v9B3MSxdXo2bOnGTt2rPfn0tJS07RpU5OZmXlV2+fl5RlJvBz+ysvL81cJBl11+gD1Hx4vX9d/SN8S48KFC8rJyVFGRoZ3WUREhNLS0pSdnV3hNkVFRSoqKvL+bP7vgKifBquWovzbYARciYq1SesUHx8f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\n",
      "text/plain": [
       "<Figure size 400x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(4, 5))\n",
    "ax[0].imshow(U0[:, module_causal_order], aspect='auto')\n",
    "ax[1].imshow(n2m, aspect='auto')\n",
    "\n",
    "for i in range(2):\n",
    "    ax[i].set_xlabel('Factor')\n",
    "    ax[i].set_ylabel('Node')\n",
    "ax[0].set_title('True U')\n",
    "ax[1].set_title('Predicted U')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'{figure_path}/U.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "016dc696",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'figure_path' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[36], line 11\u001b[0m\n\u001b[1;32m      9\u001b[0m ax[\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mset_title(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mPredicted V\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m     10\u001b[0m plt\u001b[38;5;241m.\u001b[39mtight_layout()\n\u001b[0;32m---> 11\u001b[0m plt\u001b[38;5;241m.\u001b[39msavefig(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mfigure_path\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m/V.png\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'figure_path' is not defined"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAHqCAYAAAAAtunEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAsF0lEQVR4nO3da3QUZbr28atDkk4ISTiFBOQUgYhK2CIIBhhgxmAUdBBhFAZGYKug4gHZoxC3hwF1snGpgyCCjiOCm4jiiOiIuDAiDhgQA8j5oMQhAgki0OEwQJJ+3g9u+uUxAUnS6Wo6/99avRaprqrcTe6nr66qriqXMcYIAID/E+Z0AQCA4EIwAAAsBAMAwEIwAAAsBAMAwEIwAAAsBAMAwEIwAAAsBAMAwEIwAAharVu31siRI30/f/bZZ3K5XPrss88cq+nnfl5jKCAYAsjlcp3Xw6mm379/v8LDwzV8+PCzznPkyBFFR0fr5ptvDmBlcMLrr79u9WVUVJRSUlJ07733qqioyOnyKmXx4sX605/+5Mjvfvfdd+VyufTqq6+edZ6lS5fK5XJp2rRpAazs7MKdLqA2eeONN6yf586dq6VLl5abfumllwayLJ8mTZqob9++WrRokY4fP666deuWm+fdd9/ViRMnzhkeCC2TJ09WcnKyTpw4oRUrVmjmzJlavHixNm3aVGGP1KRevXrp3//+tyIjIyu13OLFizVjxgxHwqF///6Kj49Xdna27rjjjgrnyc7OVp06dTRkyJAAV1cxgiGAfv5mumrVKi1duvQX32TP9iZdE4YNG6YlS5bo/fffr7BJs7OzFR8fr/79+wekHjjv+uuvV5cuXSRJd9xxhxo1aqTnn39eixYt0tChQytc5tixY4qJifF7LWFhYYqKivL7emuS2+3W4MGDNXv2bO3du1fNmjWznj9x4oQWLlyovn37qkmTJg5VaWNXUpDp06ePOnTooLy8PPXq1Ut169bVI488IumnXVEVfeKpaB/n4cOHNW7cOLVo0UJut1tt27bVlClT5PV6z/n7Bw4cqJiYGGVnZ5d7bv/+/crJydHgwYPldrur/BpxYfvNb34jScrPz5ckjRw5UvXq1dO3336rfv36KTY2VsOGDZMkeb1eTZ06VZdffrmioqKUmJioMWPG6NChQ9Y6jTF66qmn1Lx5c9WtW1e//vWvtXnz5nK/+2zHGFavXq1+/fqpQYMGiomJUceOHfXCCy/46psxY4Yke3fuaf6usSLDhw+X1+vV/Pnzyz334YcfyuPx+P7PggFbDEHoxx9/1PXXX68hQ4Zo+PDhSkxMrNTyx48fV+/evbVnzx6NGTNGLVu21BdffKHMzEzt27dPU6dOPeuyMTExGjBggN555x0dPHhQDRs29D331ltvqaysLKgaGIH37bffSpIaNWrkm1ZaWqqMjAz17NlTzz77rG8Ld8yYMXr99dc1atQo3X///crPz9eLL76odevWaeXKlYqIiJAkPf7443rqqafUr18/9evXT2vXrtW1116rU6dO/WI9S5cu1Q033KCmTZvqgQceUFJSkrZu3ap//OMfeuCBBzRmzBjt3bu3wt22gaqxV69eat68ubKzszV+/HjruezsbNWtW1c33XTTL64nYAwcM3bsWPPzP0Hv3r2NJDNr1qxy80syTzzxRLnprVq1MiNGjPD9/OSTT5qYmBizY8cOa76JEyeaOnXqmN27d5+zrg8//NBIMi+//LI1/eqrrzYXXXSRKSsr+4VXhlAwe/ZsI8l88skn5ocffjAFBQVm/vz5plGjRiY6Otp8//33xhhjRowYYSSZiRMnWsv/85//NJLMvHnzrOlLliyxpu/fv99ERkaa/v37G6/X65vvkUceMZKs3l62bJmRZJYtW2aMMaa0tNQkJyebVq1amUOHDlm/58x1VTTWaqrGs3nooYeMJLN9+3bfNI/HY6KioszQoUN/cflAYldSEHK73Ro1alSVl1+wYIF+9atfqUGDBjpw4IDvkZ6errKyMn3++efnXP7aa69VQkKCtTspPz9fq1at0tChQxUWRtvUJunp6UpISFCLFi00ZMgQ1atXTwsXLtRFF11kzXf33XdbPy9YsEDx8fHq27ev1YedO3dWvXr1tGzZMknSJ598olOnTum+++6zdvGMGzfuF2tbt26d8vPzNW7cONWvX9967sx1nU0gajzt9LHEM8fV3//+d504cSLotsLZlRSELrrookp/6+JMO3fu1IYNG5SQkFDh8/v37z/n8uHh4br11lv10ksvac+ePbrooot8zRxsDYyaN2PGDKWkpCg8PFyJiYm65JJLyn04CA8PV/Pmza1pO3fulMfjOesB1dN9+K9//UuS1K5dO+v5hIQENWjQ4Jy1nd6t1aFDh/N/QQGu8bSOHTuqQ4cOevPNN33HCrOzs9W4cWNlZGRUqf6aQjAEoejo6ErNX1ZWZv3s9XrVt29fPfzwwxXOn5KS8ovrHD58uF588UW9+eab+uMf/6g333xTl112ma644opK1YYLX9euXX3fSjobt9tdLiy8Xq+aNGmiefPmVbjM2T64BFKgaxw+fLgmTpyor776Ss2bN9eyZcs0ZswYhYcH11txcFWDc2rQoIEOHz5sTTt16pT27dtnTWvTpo2OHj2q9PT0Kv+ubt26qU2bNsrOzlbfvn21efNmPf3001VeH2qfNm3a6JNPPlGPHj3O+WGnVatWkn769H7xxRf7pv/www/lvhlU0e+QpE2bNp2z38+2WykQNZ5p6NChyszMVHZ2tlq1ahW0X+ZgZ/EFpE2bNuWOD7zyyivlthhuueUW5ebm6uOPPy63jsOHD6u0tPS8ft+wYcO0bt06PfHEE3K5XPr9739f9eJR69xyyy0qKyvTk08+We650tJS34ec9PR0RUREaPr06TLG+OY517fnTrvyyiuVnJysqVOnlvvQdOa6Tp9T8fN5AlHjmVq2bKlf/epXeuutt/S///u/Sk5OVvfu3Su1jkBgi+ECcscdd+iuu+7SoEGD1LdvX3399df6+OOP1bhxY2u+hx56SO+//75uuOEGjRw5Up07d9axY8e0ceNGvfPOO/ruu+/KLVOR4cOHa/LkyVq0aJF69Oih1q1b19ArQyjq3bu3xowZo6ysLK1fv17XXnutIiIitHPnTi1YsEAvvPCCBg8erISEBP3xj39UVlaWbrjhBvXr10/r1q3TRx999It9GhYWppkzZ+rGG2/UFVdcoVGjRqlp06batm2bNm/e7Ptw1LlzZ0nS/fffr4yMDN9ZxoGo8eeGDx+u0aNHa+/evfrv//7vqv3n1jSHvxVVq53t66qXX355hfOXlZWZCRMmmMaNG5u6deuajIwM880335T7uqoxxhw5csRkZmaatm3bmsjISNO4cWPTvXt38+yzz5pTp06dd41XXXWVkWReeumlSr8+XNhOf111zZo155xvxIgRJiYm5qzPv/LKK6Zz584mOjraxMbGmtTUVPPwww+bvXv3+uYpKyszkyZNMk2bNjXR0dGmT58+ZtOmTeV6++dfVz1txYoVpm/fviY2NtbExMSYjh07munTp/ueLy0tNffdd59JSEgwLper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\n",
      "text/plain": [
       "<Figure size 400x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(4, 5))\n",
    "ax[0].imshow(V0[module_causal_order].T, aspect='auto')\n",
    "ax[1].imshow(m2n, aspect='auto')\n",
    "\n",
    "for i in range(2):\n",
    "    ax[i].set_xlabel('Factor')\n",
    "    ax[i].set_ylabel('Node')\n",
    "ax[0].set_title('True V')\n",
    "ax[1].set_title('Predicted V')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'{figure_path}/V.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02765154",
   "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
}
