{
 "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 torch\n",
    "from torch.utils.data import DataLoader, random_split\n",
    "from dcdfg_extend_pc import vaeGraph\n",
    "from codebase.models.spns import construct_fg\n",
    "from make_dataset import PerturbDataset\n",
    "import networkx as nx\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "import sys\n",
    "sys.path.insert(1, '../')\n",
    "from data.simulations import DatasetLowRankGenerator\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset\n",
    "#from dcdfg.metrics import fdr, shd_metric\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ef63fb90",
   "metadata": {},
   "source": [
    "# Load existing simulation data and train VBFG"
   ]
  },
  {
   "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": "d45e90c3",
   "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/VBFG/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])\n",
    "dataset = SimulationDataset(\n",
    "    data_path, 1, fraction_regimes_to_ignore=None, intervention=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9c0efd79",
   "metadata": {},
   "outputs": [],
   "source": [
    "#test part\n",
    "seed=42\n",
    "batch_size=64"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2bcc08f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_loader = torch.utils.data.DataLoader(train_dataset, batch_size=batch_size)\n",
    "test_loader = torch.utils.data.DataLoader(test_dataset, batch_size=batch_size)"
   ]
  },
  {
   "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": 9,
   "id": "7d1537da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  1,   1,   1, ..., 100, 100, 100])"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset.regimes"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eb019bb7",
   "metadata": {},
   "source": [
    "# Fisher z-test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d3d9d78f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from causallearn.utils.cit import CIT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "01775c15",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 1,  2, 14, 20, 21, 23, 29, 37, 51, 52, 59, 60, 63, 71, 74, 82, 85,\n",
       "       86, 87, 92, 98])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.where(graph[:, 0] > 0)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d0c3dcd4",
   "metadata": {},
   "outputs": [],
   "source": [
    "pval_0, pval_1 = [], []\n",
    "S = None\n",
    "for x in range(100):\n",
    "    Y_0 = np.where(graph[:, x] == 0)[0]\n",
    "    Y_1 = np.where(graph[:, x] > 0)[0]\n",
    "    mask = (dataset.regimes != x) & (dataset.regimes != y1)\n",
    "    fisherz_obj = CIT(dataset.data[mask], \"fisherz\") # construct a CIT instance with data and method name\n",
    "    for y1 in Y_1:\n",
    "        pval_1.append(fisherz_obj(x, y1, S))\n",
    "\n",
    "    invalid = 0\n",
    "    for y0 in Y_0:\n",
    "        try:\n",
    "            pval_0.append(fisherz_obj(x, y0, S))\n",
    "        except ValueError:\n",
    "            invalid += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44083266",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure()\n",
    "plt.boxplot([pval_0, pval_1])\n",
    "plt.xticks([1, 2], ['Non-Causal', 'Causal'])\n",
    "xmin, xmax = plt.xlim()\n",
    "plt.plot([xmin, xmax], [0.05, 0.05])\n",
    "plt.savefig('/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/figures/VBFG/simulation/fisher_z.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "d1cb6fbf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.nn.init.calculate_gain('linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bdbad9c8",
   "metadata": {},
   "source": [
    "## 1.2 Define hyperparameters and train the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6c56234f",
   "metadata": {},
   "outputs": [],
   "source": [
    "#test part genetic\n",
    "num_vars=train_dataset.data[0].size\n",
    "num_layers=2\n",
    "num_interventions=0\n",
    "num_modules=10\n",
    "hid_dim=256\n",
    "seed=42\n",
    "train_num_epochs = 400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d4534b81",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# leaves:  200\n"
     ]
    }
   ],
   "source": [
    "model = vaeGraph(num_vars,\n",
    "                 num_interventions,\n",
    "                 num_modules,\n",
    "                 num_layers,\n",
    "                 num_layers,\n",
    "                 hid_dim,\n",
    "                 batch_size,\n",
    "                 seed,\n",
    "                 device=device,\n",
    "                 spn_target='node',\n",
    "                 noise_level=0.01,\n",
    "                 max_copies=8,\n",
    "                 p_conn=0.2,\n",
    "                 sparsity_temp=0.0).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1652164f",
   "metadata": {},
   "outputs": [],
   "source": [
    "m2n, n2m = model.sample_uv.fg.sample_deterministic()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "7c5432f0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 6.,  7., 12.,  5.,  8.,  8., 14.,  9., 16., 15.]),\n",
       " array([ 0.,  1.,  2.,  3.,  4.,  5.,  6.,  7.,  8.,  9., 10.]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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q3vfczOPj9NPPz369+8fhw8f7rX/8OHDMXLkyGPOz+Vykcvleu079dRTsx6rlyFDhviHnYDnOQ3Pczqe6zQ8z2kU43l+vyse78j8A6cDBgyIT33qU7F58+aefd3d3bF58+a48MILs14OACgzRXnbpbm5ORobG2PSpEkxZcqUWLlyZXR0dMSCBQuKsRwAUEaKEh9f/OIX49///nfcdNNNcejQoTjvvPNi48aNx3wINbVcLhc333zzMW/zkC3Pcxqe53Q812l4ntM4EZ7nqsIH+U4MAEBG/LYLAJCU+AAAkhIfAEBS4gMASOqkio9Vq1bFmDFjYuDAgTF16tR45plnSj1SRWltbY3JkydHTU1NDB8+PObNmxf79u0r9VgVb/ny5VFVVRWLFy8u9SgV56WXXoovf/nLMWzYsBg0aFBMmDAhdu3aVeqxKkpXV1csXbo0GhoaYtCgQfHxj388br311g/0+yC8t61bt8bcuXOjrq4uqqqqYsOGDb2OFwqFuOmmm2LUqFExaNCgmDlzZjz33HNJZjtp4uPRRx+N5ubmuPnmm2PPnj0xceLEmDVrVhw5cqTUo1WMp556KpqammL79u2xadOmePvtt+PSSy+Njo6OUo9WsXbu3Bk/+clP4pOf/GSpR6k4r776akybNi1OOeWU+O1vfxt/+9vf4kc/+lGcdtpppR6toqxYsSJWr14d9957b/z973+PFStWxJ133hn33HNPqUcrex0dHTFx4sRYtWrVcY/feeedcffdd8eaNWtix44dMXjw4Jg1a1a8+eabxR+ucJKYMmVKoampqed2V1dXoa6urtDa2lrCqSrbkSNHChFReOqpp0o9SkV6/fXXC2eddVZh06ZNhc985jOFa6+9ttQjVZQbbrihcPHFF5d6jIo3Z86cwsKFC3vt+9znPleYP39+iSaqTBFRWL9+fc/t7u7uwsiRIws/+MEPeva99tprhVwuV3j44YeLPs9JceXjrbfeit27d8fMmTN79vXr1y9mzpwZTz/9dAknq2zt7e0RETF06NAST1KZmpqaYs6cOb3+XZOdxx57LCZNmhRXXnllDB8+PM4///y4//77Sz1Wxbnoooti8+bNsX///oiI+POf/xzbtm2L2bNnl3iyynbw4ME4dOhQr/8/amtrY+rUqUleF0v+q7YpvPLKK9HV1XXMX1gdMWJE/OMf/yjRVJWtu7s7Fi9eHNOmTYvx48eXepyK88gjj8SePXti586dpR6lYv3rX/+K1atXR3Nzc9x4442xc+fOWLRoUQwYMCAaGxtLPV7FWLJkSeTz+Rg7dmz0798/urq64vbbb4/58+eXerSKdujQoYiI474uvnOsmE6K+CC9pqamePbZZ2Pbtm2lHqXitLW1xbXXXhubNm2KgQMHlnqcitXd3R2TJk2KO+64IyIizj///Hj22WdjzZo14iNDv/jFL+Khhx6KdevWxbhx42Lv3r2xePHiqKur8zxXsJPibZfTTz89+vfvH4cPH+61//DhwzFy5MgSTVW5rrnmmnj88cdjy5YtccYZZ5R6nIqze/fuOHLkSFxwwQVRXV0d1dXV8dRTT8Xdd98d1dXV0dXVVeoRK8KoUaPi3HPP7bXvnHPOiRdffLFEE1Wm66+/PpYsWRJXXXVVTJgwIa6++uq47rrrorW1tdSjVbR3XvtK9bp4UsTHgAED4lOf+lRs3ry5Z193d3ds3rw5LrzwwhJOVlkKhUJcc801sX79+vj9738fDQ0NpR6pIl1yySXx17/+Nfbu3duzTZo0KebPnx979+6N/v37l3rEijBt2rRjviq+f//+OPPMM0s0UWV64403ol+/3i9F/fv3j+7u7hJNdHJoaGiIkSNH9npdzOfzsWPHjiSviyfN2y7Nzc3R2NgYkyZNiilTpsTKlSujo6MjFixYUOrRKkZTU1OsW7cufv3rX0dNTU3P+4a1tbUxaNCgEk9XOWpqao75HM3gwYNj2LBhPl+Toeuuuy4uuuiiuOOOO+ILX/hCPPPMM3HffffFfffdV+rRKsrcuXPj9ttvj/r6+hg3blz86U9/irvuuisWLlxY6tHK3tGjR+PAgQM9tw8ePBh79+6NoUOHRn19fSxevDhuu+22OOuss6KhoSGWLl0adXV1MW/evOIPV/Tv05xA7rnnnkJ9fX1hwIABhSlTphS2b99e6pEqSkQcd3vggQdKPVrF81Xb4vjNb35TGD9+fCGXyxXGjh1buO+++0o9UsXJ5/OFa6+9tlBfX18YOHBg4WMf+1jhu9/9bqGzs7PUo5W9LVu2HPf/5MbGxkKh8H9ft126dGlhxIgRhVwuV7jkkksK+/btSzJbVaHgz8gBAOmcFJ/5AABOHOIDAEhKfAAASYkPACAp8QEAJCU+AICkxAcAkJT4AACSEh8AQFLiAwBISnwAAEmJDwAgqf8Hgr7ESH+IzoYAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "y = torch.argmax(model.sample_uv.fg.logpy, 1).detach().cpu().numpy()\n",
    "plt.hist(y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "20964597",
   "metadata": {},
   "outputs": [],
   "source": [
    "nn_params = list(model.weights_n2m) + list(model.biases_n2m)\\\n",
    "    + list(model.weights_m2n) + list(model.biases_m2n)\\\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",
    "    + [model.weight_mu, model.weight_std, model.bias_mu, model.bias_std]\\\n",
    "    + [model.weight_dec_out, model.bias_dec_out]\n",
    "optimizer = torch.optim.Adam(nn_params, lr=1e-3)\n",
    "optimizer_fg = torch.optim.Adam([v for u,v in model.sample_uv.named_parameters()], lr=1e-3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9fa8f296",
   "metadata": {},
   "source": [
    "## 1.3 Train the factor graph using the ground truth"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "c0e648b6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.57525\n",
      "0.5547500000000001\n",
      "0.538\n",
      "0.512\n",
      "0.5065\n",
      "0.49275\n",
      "0.457\n",
      "0.47900000000000004\n",
      "0.455\n",
      "0.44700000000000006\n",
      "0.4375\n",
      "0.40700000000000003\n",
      "0.40900000000000003\n",
      "0.40349999999999997\n",
      "0.37925\n",
      "0.36875\n",
      "0.3715\n",
      "0.36075\n",
      "0.34775\n",
      "0.35\n",
      "0.3435\n",
      "0.331\n",
      "0.321\n",
      "0.3245\n",
      "0.29725\n",
      "0.29100000000000004\n",
      "0.2895\n",
      "0.2905\n",
      "0.27375\n",
      "0.27025\n",
      "0.267\n",
      "0.262\n",
      "0.2525\n",
      "0.2345\n",
      "0.248\n",
      "0.2375\n",
      "0.22175\n",
      "0.2395\n",
      "0.21250000000000002\n",
      "0.21500000000000002\n",
      "0.21650000000000003\n",
      "0.202\n",
      "0.20425\n",
      "0.185\n",
      "0.19874999999999998\n",
      "0.1825\n",
      "0.1765\n",
      "0.18475000000000003\n",
      "0.172\n",
      "0.17275000000000001\n",
      "0.1775\n",
      "0.1655\n",
      "0.1665\n",
      "0.16975\n",
      "0.1565\n",
      "0.15075\n",
      "0.14475\n",
      "0.14300000000000002\n",
      "0.14400000000000002\n",
      "0.12425\n",
      "0.13675\n",
      "0.12825\n",
      "0.12125\n",
      "0.12075\n",
      "0.1245\n",
      "0.124\n",
      "0.11574999999999999\n",
      "0.11825\n",
      "0.10675000000000001\n",
      "0.10900000000000001\n",
      "0.10850000000000001\n",
      "0.10375000000000001\n",
      "0.0935\n",
      "0.0965\n",
      "0.10300000000000001\n",
      "0.0915\n",
      "0.08825\n",
      "0.08225\n",
      "0.07875\n",
      "0.08925\n",
      "0.09275\n",
      "0.08125\n",
      "0.08175\n",
      "0.07700000000000001\n",
      "0.06575\n",
      "0.07050000000000001\n",
      "0.08075\n",
      "0.06825\n",
      "0.08249999999999999\n",
      "0.07250000000000001\n",
      "0.0645\n",
      "0.0635\n",
      "0.06025\n",
      "0.05925\n",
      "0.061\n",
      "0.058249999999999996\n",
      "0.06125\n",
      "0.0465\n",
      "0.056\n",
      "0.0545\n",
      "0.05575\n",
      "0.05025\n",
      "0.052000000000000005\n",
      "0.04725\n",
      "0.0445\n",
      "0.0415\n",
      "0.045\n",
      "0.0445\n",
      "0.0405\n",
      "0.04075\n",
      "0.04025\n",
      "0.045\n",
      "0.037000000000000005\n",
      "0.04025\n",
      "0.0375\n",
      "0.03375\n",
      "0.03175\n",
      "0.039\n",
      "0.0315\n",
      "0.038250000000000006\n",
      "0.028999999999999998\n",
      "0.033\n",
      "0.03075\n",
      "0.034\n",
      "0.032\n",
      "0.02875\n",
      "0.02975\n",
      "0.03475\n",
      "0.029\n",
      "0.026500000000000003\n",
      "0.0275\n",
      "0.026750000000000003\n",
      "0.0305\n",
      "0.0305\n",
      "0.025\n",
      "0.026500000000000003\n",
      "0.029249999999999998\n",
      "0.02825\n",
      "0.0295\n",
      "0.0285\n",
      "0.027\n",
      "0.025750000000000002\n",
      "0.022\n",
      "0.0275\n",
      "0.02325\n",
      "0.026250000000000002\n",
      "0.026750000000000003\n",
      "0.02525\n",
      "0.02325\n",
      "0.025500000000000002\n",
      "0.026500000000000003\n",
      "0.02425\n",
      "0.02325\n",
      "0.02275\n",
      "0.02425\n",
      "0.02475\n",
      "0.023\n",
      "0.02425\n",
      "0.023\n",
      "0.023\n",
      "0.02225\n",
      "0.02325\n",
      "0.025750000000000002\n",
      "0.023\n",
      "0.02325\n",
      "0.026000000000000002\n",
      "0.02325\n",
      "0.02325\n",
      "0.022\n",
      "0.021\n",
      "0.02175\n",
      "0.02225\n",
      "0.02375\n",
      "0.025500000000000002\n",
      "0.02325\n",
      "0.01975\n",
      "0.02175\n",
      "0.02475\n",
      "0.02425\n",
      "0.023\n",
      "0.0225\n",
      "0.0215\n",
      "0.02375\n",
      "0.02\n",
      "0.02225\n",
      "0.0205\n",
      "0.02275\n",
      "0.02225\n",
      "0.021500000000000002\n",
      "0.021249999999999998\n",
      "0.021\n",
      "0.02\n",
      "0.02175\n",
      "0.0225\n",
      "0.02075\n",
      "0.021\n",
      "0.021\n",
      "0.0205\n",
      "0.02025\n",
      "0.0195\n"
     ]
    }
   ],
   "source": [
    "u_file = f'{file}/U0.npy'\n",
    "v_file = f'{file}/V0.npy'\n",
    "order_file = f'{file}/module_order0.npy'\n",
    "U = np.load(u_file)\n",
    "V = np.load(v_file)\n",
    "module_causal_order = np.load(order_file)\n",
    "U_ts = torch.tensor(U[:, module_causal_order]).to(device)\n",
    "V_ts = torch.tensor(V[module_causal_order].T).to(device)\n",
    "\n",
    "loss_fn = torch.nn.L1Loss()\n",
    "batch_size_fg = 4\n",
    "n_total = len(U)\n",
    "train_loss = []\n",
    "for epoch in range(40000):\n",
    "    node2factor, factor2node = model.sample_uv(batch_size_fg)\n",
    "    loss = loss_fn(node2factor, U_ts.repeat(batch_size_fg, 1, 1)) \\\n",
    "        + loss_fn(factor2node, V_ts.repeat(batch_size_fg, 1, 1))\n",
    "    optimizer_fg.zero_grad()\n",
    "    loss.backward()\n",
    "    optimizer_fg.step()\n",
    "    train_loss.append(loss.item())\n",
    "    if epoch % 200 == 199:\n",
    "        print(loss.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "14e5cf0d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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IiIiItvFOTdERETkUBhuiIiIyKEw3BAREZFDYbghIiIih8JwQ0RERA6F4YaIiIgcCsMNERERORSGGyIiInIoDDdE5HTCw8OxePFiqcsgIgthuCEii3r44YcxceJEAMDIkSMxe/Zsq+175cqV8PHxuWb53r17MX36dKvVQUTW5SJ1AURE5qqvr4dSqWzz9v7+/iJWQ0S2hkduiMgqHn74YWzfvh3vvPMOZDIZZDIZzp49CwDIycnBuHHj4OnpicDAQEyePBmlpaXGbUeOHInHHnsMs2fPhp+fH8aMGQMAWLRoEfr164cOHTogLCwMjz76KCorKwEA27ZtQ1JSErRarXF/L730EoBrT0vl5eVhwoQJ8PT0hLe3N+6//34UFRUZ17/00kuIjo7GF198gfDwcKjVajzwwAOoqKiw7D8aEbUJww0RWcU777yD+Ph4TJs2DYWFhSgsLERYWBjKy8tx6623YsCAAdi3bx82bNiAoqIi3H///Sbbf/bZZ1Aqldi1axeWLVsGAJDL5Xj33Xdx+PBhfPbZZ9iyZQueeeYZAMCQIUOwePFieHt7G/f31FNPXVOXwWDAhAkTUFZWhu3bt2PTpk04ffo0EhMTTdqdOnUKa9aswdq1a7F27Vps374dCxYssNC/FhG1B09LEZFVqNVqKJVKeHh4ICgoyLh8yZIlGDBgAF5//XXjsuXLlyMsLAzHjx9Hz549AQA9evTAm2++adLn1fN3wsPD8eqrr2LGjBl4//33oVQqoVarIZPJTPb3d2lpaTh06BDOnDmDsLAwAMDnn3+OPn36YO/evRg8eDCAyyFo5cqV8PLyAgBMnjwZaWlpeO2119r3D0NEouORGyKS1IEDB7B161Z4enoaX5GRkQAuHy25IiYm5pptN2/ejFGjRiE0NBReXl6YPHkyLl68iOrq6lbv/+jRowgLCzMGGwDo3bs3fHx8cPToUeOy8PBwY7ABgODgYBQXF5s1ViKyDh65ISJJVVZW4s4778Qbb7xxzbrg4GDjzx06dDBZd/bsWdxxxx2YOXMmXnvtNXTs2BE7d+7EI488gvr6enh4eIhap6urq8l7mUwGg8Eg6j6ISBwMN0RkNUqlEnq93mTZwIED8cMPPyA8PBwuLq3/T1JmZiYMBgPefvttyOWXD0J/++23193f3914443Iz89Hfn6+8ejNkSNHUF5ejt69e7e6HiKyHTwtRURWEx4ejj///BNnz55FaWkpDAYDZs2ahbKyMkyaNAl79+7FqVOn8PvvvyMpKanFYBIREYGGhga89957OH36NL744gvjROOr91dZWYm0tDSUlpY2eboqISEB/fr1w0MPPYSsrCxkZGRgypQpGDFiBAYNGiT6vwERWR7DDRFZzVNPPQWFQoHevXvD398feXl5CAkJwa5du6DX6zF69Gj069cPs2fPho+Pj/GITFOioqKwaNEivPHGG+jbty+++uorpKammrQZMmQIZsyYgcTERPj7+18zIRm4fHrp559/hq+vL4YPH46EhAR069YNq1evFn38RGQdMkEQBKmLICIiIhILj9wQERGRQ2G4ISIiIofCcENEREQOheGGiIiIHArDDRERETkUhhsiIiJyKAw3RERE5FAYboiIiMihMNwQERGRQ2G4ISIiIofCcENEREQO5f8DbqHSSGK/iVMAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.plot(range(40000), train_loss)\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('L1 Loss')\n",
    "#plt.savefig('fg_training_loss.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7053e4e2",
   "metadata": {},
   "source": [
    "## 1.4 Train the VAE with a fixed FG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "080e31fc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tEpoch 1 \tAverage Loss:  12884318.679999998 3173228.666015625\n",
      "\tEpoch 2 \tAverage Loss:  4588134.696000001 2347813.333984375\n",
      "\tEpoch 3 \tAverage Loss:  3048333.9219999993 2029168.7998046875\n",
      "\tEpoch 4 \tAverage Loss:  2585254.6439999994 1993662.8193359375\n",
      "\tEpoch 5 \tAverage Loss:  2401182.157000001 1976703.654296875\n",
      "\tEpoch 6 \tAverage Loss:  2298992.724999999 1951794.83203125\n",
      "\tEpoch 7 \tAverage Loss:  2242338.7390000005 1952024.3740234375\n",
      "\tEpoch 8 \tAverage Loss:  2202559.7010000004 1932482.384765625\n",
      "\tEpoch 9 \tAverage Loss:  2158938.27 1941156.16796875\n",
      "\tEpoch 10 \tAverage Loss:  2154239.3639999996 1948224.7880859375\n",
      "\tEpoch 11 \tAverage Loss:  2132279.2499999995 1920575.626953125\n",
      "\tEpoch 12 \tAverage Loss:  2117454.8209999995 1917553.701171875\n",
      "\tEpoch 13 \tAverage Loss:  2093450.3760000004 1927790.54296875\n",
      "\tEpoch 14 \tAverage Loss:  2083376.1100000013 1904989.3017578125\n",
      "\tEpoch 15 \tAverage Loss:  2071297.0020000003 1905981.765625\n",
      "\tEpoch 16 \tAverage Loss:  2063556.0029999993 1914733.84375\n",
      "\tEpoch 17 \tAverage Loss:  2045607.4970000004 1922978.96484375\n",
      "\tEpoch 18 \tAverage Loss:  2037704.517 1914494.099609375\n",
      "\tEpoch 19 \tAverage Loss:  2029117.7849999995 1903598.349609375\n",
      "\tEpoch 20 \tAverage Loss:  2029284.2179999999 1913989.4765625\n",
      "\tEpoch 21 \tAverage Loss:  2010710.6629999992 1909827.4296875\n",
      "\tEpoch 22 \tAverage Loss:  2004341.767 1911059.6962890625\n",
      "\tEpoch 23 \tAverage Loss:  2006703.0439999998 1899532.6591796875\n",
      "\tEpoch 24 \tAverage Loss:  1998667.942 1891020.57421875\n",
      "\tEpoch 25 \tAverage Loss:  1988134.1360000002 1896716.33984375\n",
      "\tEpoch 26 \tAverage Loss:  1981842.3290000001 1890768.20703125\n",
      "\tEpoch 27 \tAverage Loss:  1993128.1020000007 1890241.796875\n",
      "\tEpoch 28 \tAverage Loss:  1977505.7829999994 1888699.63671875\n",
      "\tEpoch 29 \tAverage Loss:  1964755.037 1898092.384765625\n",
      "\tEpoch 30 \tAverage Loss:  1960032.703000001 1887158.7919921875\n",
      "\tEpoch 31 \tAverage Loss:  1960333.0850000004 1903921.6396484375\n",
      "\tEpoch 32 \tAverage Loss:  1952216.1840000001 1887303.8408203125\n",
      "\tEpoch 33 \tAverage Loss:  1959818.7649999992 1885690.1142578125\n",
      "\tEpoch 34 \tAverage Loss:  1954371.9339999997 1880477.7001953125\n",
      "\tEpoch 35 \tAverage Loss:  1944748.6630000002 1886072.11328125\n",
      "\tEpoch 36 \tAverage Loss:  1944758.233 1882803.76171875\n",
      "\tEpoch 37 \tAverage Loss:  1937654.505 1885954.6201171875\n",
      "\tEpoch 38 \tAverage Loss:  1941729.325 1890123.1884765625\n",
      "\tEpoch 39 \tAverage Loss:  1941353.0249999997 1884651.783203125\n",
      "\tEpoch 40 \tAverage Loss:  1928450.949 1888450.57421875\n",
      "\tEpoch 41 \tAverage Loss:  1937528.8450000002 1884190.921875\n",
      "\tEpoch 42 \tAverage Loss:  1935808.1479999996 1882414.67578125\n",
      "\tEpoch 43 \tAverage Loss:  1931969.1240000003 1878430.5859375\n",
      "\tEpoch 44 \tAverage Loss:  1928136.4680000003 1875648.9658203125\n",
      "\tEpoch 45 \tAverage Loss:  1924951.975 1871007.41796875\n",
      "\tEpoch 46 \tAverage Loss:  1924044.0549999992 1886293.908203125\n",
      "\tEpoch 47 \tAverage Loss:  1923335.724 1878321.8544921875\n",
      "\tEpoch 48 \tAverage Loss:  1916382.7459999993 1881875.6142578125\n",
      "\tEpoch 49 \tAverage Loss:  1912699.9859999993 1877036.802734375\n",
      "\tEpoch 50 \tAverage Loss:  1911976.6469999999 1886380.83984375\n",
      "\tEpoch 51 \tAverage Loss:  1907525.429 1870175.77734375\n",
      "\tEpoch 52 \tAverage Loss:  1915878.9650000005 1870943.2197265625\n",
      "\tEpoch 53 \tAverage Loss:  1910782.6460000009 1884190.2763671875\n",
      "\tEpoch 54 \tAverage Loss:  1912081.6820000005 1888217.345703125\n",
      "\tEpoch 55 \tAverage Loss:  1904924.7630000005 1866723.322265625\n",
      "\tEpoch 56 \tAverage Loss:  1904012.8199999996 1884294.3681640625\n",
      "\tEpoch 57 \tAverage Loss:  1912658.931 1875279.9873046875\n",
      "\tEpoch 58 \tAverage Loss:  1901498.2470000007 1873583.53125\n",
      "\tEpoch 59 \tAverage Loss:  1900465.974 1889347.322265625\n",
      "\tEpoch 60 \tAverage Loss:  1902158.9959999998 1882389.78125\n",
      "\tEpoch 61 \tAverage Loss:  1895430.734999999 1876582.220703125\n",
      "\tEpoch 62 \tAverage Loss:  1907178.7530000003 1883831.7685546875\n",
      "\tEpoch 63 \tAverage Loss:  1889195.1840000001 1877843.5986328125\n",
      "\tEpoch 64 \tAverage Loss:  1890201.854999999 1877543.4541015625\n",
      "\tEpoch 65 \tAverage Loss:  1887553.129 1879110.9580078125\n",
      "\tEpoch 66 \tAverage Loss:  1888746.76 1877241.3154296875\n",
      "\tEpoch 67 \tAverage Loss:  1887478.2689999999 1874416.166015625\n",
      "\tEpoch 68 \tAverage Loss:  1885056.5520000004 1882235.4755859375\n",
      "\tEpoch 69 \tAverage Loss:  1886261.2260000003 1884244.8671875\n",
      "\tEpoch 70 \tAverage Loss:  1892906.706 1880494.6396484375\n",
      "\tEpoch 71 \tAverage Loss:  1883191.6330000015 1864707.2060546875\n",
      "\tEpoch 72 \tAverage Loss:  1889351.005999999 1882598.5517578125\n",
      "\tEpoch 73 \tAverage Loss:  1882662.4360000002 1876651.912109375\n",
      "\tEpoch 74 \tAverage Loss:  1878463.5299999989 1886722.3369140625\n",
      "\tEpoch 75 \tAverage Loss:  1880740.867 1868948.29296875\n",
      "\tEpoch 76 \tAverage Loss:  1890310.3509999986 1872619.484375\n",
      "\tEpoch 77 \tAverage Loss:  1880728.327000001 1883596.7080078125\n",
      "\tEpoch 78 \tAverage Loss:  1882832.1659999997 1877844.916015625\n",
      "\tEpoch 79 \tAverage Loss:  1883291.2750000001 1875941.708984375\n",
      "\tEpoch 80 \tAverage Loss:  1875082.3069999996 1882913.494140625\n",
      "\tEpoch 81 \tAverage Loss:  1878345.5820000004 1884354.6943359375\n",
      "\tEpoch 82 \tAverage Loss:  1874006.6500000001 1872483.5673828125\n",
      "\tEpoch 83 \tAverage Loss:  1874863.128 1870628.4345703125\n",
      "\tEpoch 84 \tAverage Loss:  1884728.6090000004 1876743.9833984375\n",
      "\tEpoch 85 \tAverage Loss:  1880257.835 1877984.6943359375\n",
      "\tEpoch 86 \tAverage Loss:  1875266.4450000003 1879614.89453125\n",
      "\tEpoch 87 \tAverage Loss:  1877562.2910000002 1876266.880859375\n",
      "\tEpoch 88 \tAverage Loss:  1872792.2650000001 1872214.6396484375\n",
      "\tEpoch 89 \tAverage Loss:  1872787.9889999994 1877994.685546875\n",
      "\tEpoch 90 \tAverage Loss:  1870346.4110000005 1882964.2373046875\n",
      "\tEpoch 91 \tAverage Loss:  1866167.7200000007 1885473.935546875\n",
      "\tEpoch 92 \tAverage Loss:  1872559.253000001 1868234.3095703125\n",
      "\tEpoch 93 \tAverage Loss:  1874690.0859999997 1868886.21484375\n",
      "\tEpoch 94 \tAverage Loss:  1867492.7640000002 1872068.283203125\n",
      "\tEpoch 95 \tAverage Loss:  1861960.386999999 1869200.76171875\n",
      "\tEpoch 96 \tAverage Loss:  1862160.7049999991 1881009.5322265625\n",
      "\tEpoch 97 \tAverage Loss:  1862947.1209999998 1877028.3515625\n",
      "\tEpoch 98 \tAverage Loss:  1874052.7929999994 1869396.2158203125\n",
      "\tEpoch 99 \tAverage Loss:  1863175.8010000004 1882071.021484375\n",
      "\tEpoch 100 \tAverage Loss:  1866110.723 1877940.8232421875\n",
      "\tEpoch 101 \tAverage Loss:  1867108.785999999 1881030.7744140625\n",
      "\tEpoch 102 \tAverage Loss:  1863390.0099999993 1883315.3486328125\n",
      "\tEpoch 103 \tAverage Loss:  1857862.4799999997 1881675.84765625\n",
      "\tEpoch 104 \tAverage Loss:  1867920.944000001 1873550.9326171875\n",
      "\tEpoch 105 \tAverage Loss:  1866196.8889999995 1876857.4248046875\n",
      "\tEpoch 106 \tAverage Loss:  1858147.585999999 1878579.6279296875\n",
      "\tEpoch 107 \tAverage Loss:  1860822.4199999997 1880959.3515625\n",
      "\tEpoch 108 \tAverage Loss:  1859132.416000001 1884243.5\n",
      "\tEpoch 109 \tAverage Loss:  1855953.2750000015 1861481.0703125\n",
      "\tEpoch 110 \tAverage Loss:  1872556.5159999994 1867245.76171875\n",
      "\tEpoch 111 \tAverage Loss:  1854109.0930000003 1872629.9970703125\n",
      "\tEpoch 112 \tAverage Loss:  1859474.2890000006 1884115.9814453125\n",
      "\tEpoch 113 \tAverage Loss:  1851944.2900000003 1867304.4296875\n",
      "\tEpoch 114 \tAverage Loss:  1863264.1209999998 1872004.4130859375\n",
      "\tEpoch 115 \tAverage Loss:  1855317.9640000002 1873824.4951171875\n",
      "\tEpoch 116 \tAverage Loss:  1855460.1100000003 1870533.9169921875\n",
      "\tEpoch 117 \tAverage Loss:  1863472.725 1875728.4384765625\n",
      "\tEpoch 118 \tAverage Loss:  1857568.6679999991 1873115.943359375\n",
      "\tEpoch 119 \tAverage Loss:  1862048.533 1879077.8828125\n",
      "\tEpoch 120 \tAverage Loss:  1859927.9180000005 1876152.396484375\n",
      "\tEpoch 121 \tAverage Loss:  1851984.5250000001 1881127.0927734375\n",
      "\tEpoch 122 \tAverage Loss:  1863169.9000000004 1881355.37109375\n",
      "\tEpoch 123 \tAverage Loss:  1854212.178 1883778.8076171875\n",
      "\tEpoch 124 \tAverage Loss:  1852863.957 1875651.591796875\n",
      "\tEpoch 125 \tAverage Loss:  1854282.0879999993 1872311.6396484375\n",
      "\tEpoch 126 \tAverage Loss:  1856573.5890000009 1881689.1240234375\n",
      "\tEpoch 127 \tAverage Loss:  1858337.9000000001 1883403.4814453125\n",
      "\tEpoch 128 \tAverage Loss:  1852625.3250000004 1882413.20703125\n",
      "\tEpoch 129 \tAverage Loss:  1848210.7839999995 1874521.4521484375\n",
      "\tEpoch 130 \tAverage Loss:  1848726.0670000003 1884102.453125\n",
      "\tEpoch 131 \tAverage Loss:  1852032.2929999998 1883298.5341796875\n",
      "\tEpoch 132 \tAverage Loss:  1845762.3280000011 1875298.2890625\n",
      "\tEpoch 133 \tAverage Loss:  1855027.8250000004 1872313.904296875\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tEpoch 134 \tAverage Loss:  1852255.4179999998 1879999.21875\n",
      "\tEpoch 135 \tAverage Loss:  1845126.8639999994 1879029.798828125\n",
      "\tEpoch 136 \tAverage Loss:  1851422.9240000008 1865040.9716796875\n",
      "\tEpoch 137 \tAverage Loss:  1849179.2319999998 1885026.6904296875\n",
      "\tEpoch 138 \tAverage Loss:  1857242.6879999998 1886002.8955078125\n",
      "\tEpoch 139 \tAverage Loss:  1848791.2949999992 1865435.87890625\n",
      "\tEpoch 140 \tAverage Loss:  1842277.7630000012 1873210.3486328125\n",
      "\tEpoch 141 \tAverage Loss:  1848810.4070000008 1883333.8681640625\n",
      "\tEpoch 142 \tAverage Loss:  1847561.7090000003 1871880.8017578125\n",
      "\tEpoch 143 \tAverage Loss:  1849507.5719999992 1876361.5908203125\n",
      "\tEpoch 144 \tAverage Loss:  1845293.3289999997 1872223.4921875\n",
      "\tEpoch 145 \tAverage Loss:  1850690.9930000005 1880710.537109375\n",
      "\tEpoch 146 \tAverage Loss:  1843428.5409999993 1872969.46484375\n",
      "\tEpoch 147 \tAverage Loss:  1849499.7510000004 1874966.8330078125\n",
      "\tEpoch 148 \tAverage Loss:  1849403.8850000002 1882163.5849609375\n",
      "\tEpoch 149 \tAverage Loss:  1842338.3150000006 1878135.755859375\n",
      "\tEpoch 150 \tAverage Loss:  1851260.5219999999 1885878.0859375\n",
      "\tEpoch 151 \tAverage Loss:  1853937.8940000003 1865620.8232421875\n",
      "\tEpoch 152 \tAverage Loss:  1848370.8650000005 1876592.6748046875\n",
      "\tEpoch 153 \tAverage Loss:  1842886.966 1886466.2412109375\n",
      "\tEpoch 154 \tAverage Loss:  1841103.1240000005 1885423.8037109375\n",
      "\tEpoch 155 \tAverage Loss:  1837618.334999999 1885780.8310546875\n",
      "\tEpoch 156 \tAverage Loss:  1842883.7309999992 1889796.861328125\n",
      "\tEpoch 157 \tAverage Loss:  1846630.178 1872422.416015625\n",
      "\tEpoch 158 \tAverage Loss:  1841836.2310000004 1886851.203125\n",
      "\tEpoch 159 \tAverage Loss:  1840005.6430000016 1869485.759765625\n",
      "\tEpoch 160 \tAverage Loss:  1844776.402 1882674.09765625\n",
      "\tEpoch 161 \tAverage Loss:  1840545.7079999992 1863420.775390625\n",
      "\tEpoch 162 \tAverage Loss:  1843819.1169999992 1871162.9208984375\n",
      "\tEpoch 163 \tAverage Loss:  1837847.7330000007 1886925.9755859375\n",
      "\tEpoch 164 \tAverage Loss:  1847164.3759999997 1884399.0673828125\n",
      "\tEpoch 165 \tAverage Loss:  1848016.293 1862913.947265625\n",
      "\tEpoch 166 \tAverage Loss:  1840716.941 1875500.720703125\n",
      "\tEpoch 167 \tAverage Loss:  1832975.7830000005 1873730.697265625\n",
      "\tEpoch 168 \tAverage Loss:  1841420.7589999991 1869425.23046875\n",
      "\tEpoch 169 \tAverage Loss:  1841992.4319999998 1876703.78515625\n",
      "\tEpoch 170 \tAverage Loss:  1846746.5799999994 1882185.0556640625\n",
      "\tEpoch 171 \tAverage Loss:  1840560.9710000008 1889231.857421875\n",
      "\tEpoch 172 \tAverage Loss:  1845901.0879999998 1880031.5146484375\n",
      "\tEpoch 173 \tAverage Loss:  1839455.2659999998 1887899.4775390625\n",
      "\tEpoch 174 \tAverage Loss:  1844466.6579999994 1881734.6611328125\n",
      "\tEpoch 175 \tAverage Loss:  1838074.5130000007 1887055.630859375\n",
      "\tEpoch 176 \tAverage Loss:  1849073.082000001 1878710.857421875\n",
      "\tEpoch 177 \tAverage Loss:  1842736.512 1868010.43359375\n",
      "\tEpoch 178 \tAverage Loss:  1841615.8050000006 1887051.9345703125\n",
      "\tEpoch 179 \tAverage Loss:  1834112.4430000004 1891415.05859375\n",
      "\tEpoch 180 \tAverage Loss:  1835077.1860000002 1882481.5517578125\n",
      "\tEpoch 181 \tAverage Loss:  1840176.0880000005 1873877.9287109375\n",
      "\tEpoch 182 \tAverage Loss:  1844723.8560000008 1866993.6416015625\n",
      "\tEpoch 183 \tAverage Loss:  1836364.2130000005 1882741.44921875\n",
      "\tEpoch 184 \tAverage Loss:  1836241.3030000003 1871752.3662109375\n",
      "\tEpoch 185 \tAverage Loss:  1843084.0620000002 1881885.697265625\n",
      "\tEpoch 186 \tAverage Loss:  1834770.5960000006 1887016.7119140625\n",
      "\tEpoch 187 \tAverage Loss:  1844923.0190000006 1869739.2802734375\n",
      "\tEpoch 188 \tAverage Loss:  1834101.4230000002 1872291.6240234375\n",
      "\tEpoch 189 \tAverage Loss:  1837016.2989999999 1877381.255859375\n",
      "\tEpoch 190 \tAverage Loss:  1832395.8290000004 1872520.9541015625\n",
      "\tEpoch 191 \tAverage Loss:  1835970.7449999996 1872748.8681640625\n",
      "\tEpoch 192 \tAverage Loss:  1834632.2680000004 1870088.7783203125\n",
      "\tEpoch 193 \tAverage Loss:  1840684.295 1881534.38671875\n",
      "\tEpoch 194 \tAverage Loss:  1833146.3539999996 1872460.08984375\n",
      "\tEpoch 195 \tAverage Loss:  1838272.38 1876144.69921875\n",
      "\tEpoch 196 \tAverage Loss:  1836875.2079999994 1876818.07421875\n",
      "\tEpoch 197 \tAverage Loss:  1843532.0329999996 1865312.55859375\n",
      "\tEpoch 198 \tAverage Loss:  1833524.2729999998 1881600.1357421875\n",
      "\tEpoch 199 \tAverage Loss:  1828863.148 1865527.9814453125\n",
      "\tEpoch 200 \tAverage Loss:  1829312.6770000001 1876530.65625\n",
      "\tEpoch 201 \tAverage Loss:  1835047.5349999988 1870836.4638671875\n",
      "\tEpoch 202 \tAverage Loss:  1833624.0569999996 1882405.150390625\n",
      "\tEpoch 203 \tAverage Loss:  1838395.0330000005 1877377.6181640625\n",
      "\tEpoch 204 \tAverage Loss:  1829521.8310000002 1873916.8447265625\n",
      "\tEpoch 205 \tAverage Loss:  1832592.024 1870334.4013671875\n",
      "\tEpoch 206 \tAverage Loss:  1829146.1880000005 1887453.8603515625\n",
      "\tEpoch 207 \tAverage Loss:  1827909.957 1881918.25\n",
      "\tEpoch 208 \tAverage Loss:  1834599.1979999992 1873181.576171875\n",
      "\tEpoch 209 \tAverage Loss:  1829907.658 1878517.8955078125\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[30], line 35\u001b[0m\n\u001b[1;32m     31\u001b[0m     z_kl \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m _z_kl\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mcpu()\u001b[38;5;241m.\u001b[39mitem() \u001b[38;5;241m*\u001b[39m (batch_size \u001b[38;5;241m/\u001b[39m n_train)\n\u001b[1;32m     34\u001b[0m     optimizer\u001b[38;5;241m.\u001b[39mzero_grad()\n\u001b[0;32m---> 35\u001b[0m     \u001b[43mloss\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     36\u001b[0m     optimizer\u001b[38;5;241m.\u001b[39mstep()\n\u001b[1;32m     37\u001b[0m train_loss_list\u001b[38;5;241m.\u001b[39mappend(train_loss)\n",
      "File \u001b[0;32m/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/envs/velo_env/lib/python3.9/site-packages/torch/_tensor.py:488\u001b[0m, in \u001b[0;36mTensor.backward\u001b[0;34m(self, gradient, retain_graph, create_graph, inputs)\u001b[0m\n\u001b[1;32m    478\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m has_torch_function_unary(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    479\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m handle_torch_function(\n\u001b[1;32m    480\u001b[0m         Tensor\u001b[38;5;241m.\u001b[39mbackward,\n\u001b[1;32m    481\u001b[0m         (\u001b[38;5;28mself\u001b[39m,),\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    486\u001b[0m         inputs\u001b[38;5;241m=\u001b[39minputs,\n\u001b[1;32m    487\u001b[0m     )\n\u001b[0;32m--> 488\u001b[0m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mautograd\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    489\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgradient\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minputs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minputs\u001b[49m\n\u001b[1;32m    490\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/XXXX-11/XXXX-12/XXXX-10-XXXX-9/XXXX-6/envs/velo_env/lib/python3.9/site-packages/torch/autograd/__init__.py:197\u001b[0m, in \u001b[0;36mbackward\u001b[0;34m(tensors, grad_tensors, retain_graph, create_graph, grad_variables, inputs)\u001b[0m\n\u001b[1;32m    192\u001b[0m     retain_graph \u001b[38;5;241m=\u001b[39m create_graph\n\u001b[1;32m    194\u001b[0m \u001b[38;5;66;03m# The reason we repeat same the comment below is that\u001b[39;00m\n\u001b[1;32m    195\u001b[0m \u001b[38;5;66;03m# some Python versions print out the first line of a multi-line function\u001b[39;00m\n\u001b[1;32m    196\u001b[0m \u001b[38;5;66;03m# calls in the traceback and some print out the last line\u001b[39;00m\n\u001b[0;32m--> 197\u001b[0m \u001b[43mVariable\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_execution_engine\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrun_backward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m  \u001b[49m\u001b[38;5;66;43;03m# Calls into the C++ engine to run the backward pass\u001b[39;49;00m\n\u001b[1;32m    198\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtensors\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgrad_tensors_\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minputs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    199\u001b[0m \u001b[43m    \u001b[49m\u001b[43mallow_unreachable\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43maccumulate_grad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "train_loss_list=[]\n",
    "eval_loss_list = []\n",
    "loss_comp = {\n",
    "    're': [],\n",
    "    'uv_kl': [],\n",
    "    'z_kl': []\n",
    "}\n",
    "n_train = len(train_loader)\n",
    "n_test = len(test_loader)\n",
    "for epoch in range(train_num_epochs):\n",
    "    num=1\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    eval_loss = 0\n",
    "    re_loss, uv_kl, z_kl = 0, 0, 0\n",
    "    \n",
    "    for inputs in train_loader:\n",
    "        data,masks,regimes=inputs\n",
    "        batch_size = data.shape[0]\n",
    "        #print(data.shape)\n",
    "        data=data.to(device)\n",
    "        masks=masks.to(device)\n",
    "        regimes=regimes.to(device)\n",
    "\n",
    "        _re_loss, _uv_kl, _z_kl, _l1_reg = model.losses(data, masks)\n",
    "        loss = _re_loss + _uv_kl + _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",
    "\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\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",
    "\n",
    "    # validation\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        for inputs in test_loader:\n",
    "            data,masks,regimes=inputs\n",
    "            batch_size = data.shape[0]\n",
    "            #print(data.shape)\n",
    "            data = data.to(device)\n",
    "            masks = masks.to(device)\n",
    "            regimes = regimes.to(device)\n",
    "            re_loss, uv_kl, z_kl, l1_reg = model.losses(data, masks)\n",
    "            loss = re_loss + uv_kl + z_kl\n",
    "            eval_loss += loss.detach().cpu().item() * (batch_size / n_test)\n",
    "    eval_loss_list.append(eval_loss) \n",
    "    print(\"\\tEpoch\", epoch + 1, \"\\tAverage Loss: \", train_loss, eval_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a18cd89",
   "metadata": {},
   "outputs": [],
   "source": [
    "train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "1940d71b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "97540.41108630945"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_comp['uv_kl'][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "249edeb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "28.038843025328614"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_comp['re'][-1] / 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "c2071d82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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s33Lvinxnr6/5Xk3X6vm8z5WTqdTK1as0GuvvaZBgwbpT3/6k0499VRt3rxZkvTkk0+qvLxcZ599tpYtW6ZTTjlF7777boccuy0JHUacDsIIAByt7373u/r000/Vr18/fec732n1SElJ0cCBA5WUlKTS0tI2tz/99NP1z3/+M9ppUpLefvttORwOnXrqqe0uh8vlUlFRkebNm6ePPvpIW7ZsifZZ8Xg8CofD7dpPz549tWPHjlbLWg7TPdL5NPcROdzxBgwYII/H06rvRzAY1Pvvv69Bgwa1q5ztcfrpp6u8vLxVuHr77beVlpamPn36SIoEnNGjR2vOnDn68MMP5fF49MILL0TXHz58uGbOnKl33nlHgwcP1pIlSzqsfAdK6DBi0GcEAI7a9OnTtWfPHk2aNEnvv/++Nm3apNdff11Tp05VOByWz+fTbbfdpltvvVVPP/20Nm3apHfffVePP/64JOnyyy+Xz+fTlClT9Mknn2jlypW6/vrrdcUVV0SbaI7k5Zdf1h//+EetW7dOX331lZ5++mmZphkNM/369dN7772nLVu2aNeuXYetWbjgggu0Zs0aPf300/ryyy81e/ZsffLJJ9HXj3Q+2dnZSkpK0vLly1VZWanq6uqDjpGSkqLrrrtOt9xyi5YvX67PPvtM06ZNU0NDg6666qp2v/dH8stf/lLbtm3T9ddfr/Xr1+ull17S7NmzVVJSIofDoffee0/33Xef1qxZo61bt+r555/Xzp07dfrpp2vz5s2aOXOmysvL9dVXX+n//u//9OWXX3Zqv5GE7jPibKqhpGYEAGLXq1cvvf3227rtttt08cUXy+/3q2/fvhozZkz05ml33nmnXC6XZs2ape3btysvL0/XXnutJCk5OVmvv/66brjhBp111llKTk7WZZddpgcffLDdZcjMzNTzzz+vu+66S42NjRo4cKCeeeYZnXHGGZKkm2++WVOmTNGgQYO0b9++aDNEW4qLi3XnnXfq1ltvVWNjo37xi19o8uTJ0f4pRzofl8ulP/7xj7r77rs1a9YsnXvuuSorKzvoOPfff79M09QVV1yh2tpajRw5Uq+//nq7R/S0R+/evfXqq6/qlltu0dChQ9W9e3ddddVVuuOOOyRJ6enpWrVqlRYsWKCamhr17dtX8+fP19ixY1VZWan169frqaee0u7du5WXl6fp06fr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Yqmvr9fQoUO1cOHCNl+fN2+e/vjHP2rRokV67733lJKSouLiYjU2NkbXufzyy/Xpp59qxYoVevnll7Vq1Spdc8018TqFhHOkayZJY8aMafU798wzz7R6nWsWP2+++aamT5+ud999VytWrFAwGNTFF1+s+vr66DpH+hwMh8MaN26cAoGA3nnnHT311FNavHixZs2aZccpHZmVoEaNGmVNnz49+jwcDlu9evWy5s6da2OpYFmWNXv2bGvo0KFtvrZ3717L7XZbzz77bHTZ559/bkmyysvL41RCNJNkvfDCC9Hnpmlaubm51n/9139Fl+3du9fyer3WM888Y1mWZX322WeWJOv999+PrvPaa69ZhmFY33zzTdzKnqgOvGaWZVlTpkyxfvjDHx5yG66ZvaqqqixJ1ptvvmlZVvs+B1999VXL4XBYFRUV0XUeeeQRKz093fL7/fE9gXZIyJqRQCCgtWvXqqioKLrM4XCoqKhI5eXlNpYMzb788kv16tVLJ598si6//HJt3bpVkrR27VoFg8FW1+60007TSSedxLU7DmzevFkVFRWtrk9GRoYKCgqi16e8vFyZmZkaOXJkdJ2ioiI5HA699957cS8zIsrKypSdna1TTz1V1113nXbv3h19jWtmr+rqaklS9+7dJbXvc7C8vFxDhgxRTk5OdJ3i4mLV1NTo008/jWPp2ychw8iuXbsUDodbXSRJysnJUUVFhU2lQrOCggItXrxYy5cv1yOPPKLNmzfr3HPPVW1trSoqKuTxeJSZmdlqG67d8aH5Ghzud6uiokLZ2dmtXne5XOrevTvX0CZjxozR008/rdLSUv3ud7/Tm2++qbFjxyocDkvimtnJNE3deOONGj16tAYPHixJ7focrKioaPP3sPm1402XuGsvEsvYsWOj/z7zzDNVUFCgvn376i9/+YuSkpJsLBlwYvrZz34W/feQIUN05plnasCAASorK9OFF15oY8kwffp0ffLJJ636zZ2IErJmJCsrS06n86Cex5WVlcrNzbWpVDiUzMxMnXLKKdq4caNyc3MVCAS0d+/eVutw7Y4PzdfgcL9bubm5B3UUD4VC2rNnD9fwOHHyyScrKytLGzdulMQ1s8uMGTP08ssva+XKlerTp090eXs+B3Nzc9v8PWx+7XiTkGHE4/FoxIgRKi0tjS4zTVOlpaUqLCy0sWRoS11dnTZt2qS8vDyNGDFCbre71bXbsGGDtm7dyrU7DvTv31+5ubmtrk9NTY3ee++96PUpLCzU3r17tXbt2ug6b7zxhkzTVEFBQdzLjIN9/fXX2r17t/Ly8iRxzeLNsizNmDFDL7zwgt544w3179+/1evt+RwsLCzUxx9/3CpErlixQunp6Ro0aFB8TiQWdvegtcvSpUstr9drLV682Prss8+sa665xsrMzGzV8xj2+PWvf22VlZVZmzdvtt5++22rqKjIysrKsqqqqizLsqxrr73WOumkk6w33njDWrNmjVVYWGgVFhbaXOrEUVtba3344YfWhx9+aEmyHnzwQevDDz+0vvrqK8uyLOv++++3MjMzrZdeesn66KOPrB/+8IdW//79rX379kX3MWbMGGv48OHWe++9Z7311lvWwIEDrUmTJtl1Sie8w12z2tpa6+abb7bKy8utzZs3W3//+9+t7373u9bAgQOtxsbG6D64ZvFz3XXXWRkZGVZZWZm1Y8eO6KOhoSG6zpE+B0OhkDV48GDr4osvttatW2ctX77c6tmzpzVz5kw7TumIEjaMWJZl/elPf7JOOukky+PxWKNGjbLeffddu4sEy7ImTpxo5eXlWR6Px+rdu7c1ceJEa+PGjdHX9+3bZ/3yl7+0unXrZiUnJ1uXXnqptWPHDhtLnFhWrlxpSTroMWXKFMuyIsN777zzTisnJ8fyer3WhRdeaG3YsKHVPnbv3m1NmjTJSk1NtdLT062pU6datbW1NpxNYjjcNWtoaLAuvvhiq2fPnpbb7bb69u1rTZs27aA/zLhm8dPWtZJkPfnkk9F12vM5uGXLFmvs2LFWUlKSlZWVZf3617+2gsFgnM+mfQzLsqx418YAAAA0S8g+IwAA4PhBGAEAALYijAAAAFsRRgAAgK0IIwAAwFaEEQAAYCvCCAAAsBVhBAAA2IowAgAAbEUYAQAAtiKMAAAAWxFGAACArf4/6nzHSoTkglsAAAAASUVORK5CYII=\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.legend()\n",
    "#plt.savefig('vae_loss.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "e985834b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "threshold term-wise:0.5\n",
      "numel:278\n",
      "Freeze threshold:cuda:0\n"
     ]
    }
   ],
   "source": [
    "model.model_val(0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "b6ac16f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "y = np.argmax(model.sample_uv.fg.logpy.detach().cpu().numpy(), 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "f35fe01c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 4,  2,  7,  2,  6,  0, 10,  0,  5,  3,  9,  0,  0,  0, 10,  0,  3,\n",
       "        7,  0,  1,  4,  1, 10,  0,  9,  1,  2,  0,  7,  0,  4,  0,  0,  0,\n",
       "        0,  0,  0,  0,  2,  2,  9,  0,  0,  1,  0,  6,  3,  0,  6,  4,  1,\n",
       "       10,  0,  5,  5,  3,  0,  2,  0,  0,  0,  5,  0,  3,  9,  0, 10,  0,\n",
       "        0,  0,  3, 10, 10,  0,  2,  5,  0,  9,  0,  3,  0,  0,  9,  0,  0,\n",
       "        0,  0,  3,  0,  1,  3,  2,  1,  0,  4,  0,  3,  4,  0,  0])"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "defeee7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "3ef95295",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import spearmanr\n",
    "corr = np.zeros((100, 100))\n",
    "for i in range(100):\n",
    "    for j in range(100):\n",
    "        corr[i, j] = spearmanr(train_dataset.data[:, i], train_dataset.data[:, j])[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "5396d6ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.imshow(corr)\n",
    "plt.colorbar()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "a6394686",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XKwRI0Zo0aJFikQiRiX2hrVr1yonJ0cNDQ3xY9TTCR9//LFuuOEGFRcXq7CwUFVVVdqzZ0/8eeecVq1apTFjxqiwsFA1NTU6ePCgYYmHXnd3t1auXKmKigoVFhZq3LhxeuCBB3otsEk9DZDzoC1btrj8/Hz3+9//3v397393P//5z93IkSNdJBKxLpqJuXPnug0bNrj9+/e7vXv3uh/84AeuvLzcffHFF/FzbrvtNldWVuaamprcnj173FVXXeVmzJhhWGpbu3fvdmPHjnXf+c533LJly+LHqSfn/vOf/7iLL77Y3XjjjW7Xrl3uo48+cq+99pr75z//GT9n7dq1LhAIuJdeesl98MEH7kc/+pGrqKhwX3/9tWHJh9bq1atdcXGxe+WVV9yhQ4fciy++6EaMGOF+97vfxc+hngbGkwE0bdo0V1dXF/+5u7vblZaWulAoZFgq7zhy5IiT5N566y3nnHMdHR1u+PDh7sUXX4yf849//MNJcs3NzVbFNHP06FE3fvx49/rrr7vvfe978QCink6499573axZs876fE9PjyspKXG//e1v48c6Ojqcz+dzzz///FAU0RPmzZvnbr755l7HfvzjH7slS5Y456inVPBcF9yxY8fU0tKimpqa+LHc3FzV1NSoubnZsGTeEY1GJUmjRo2SJLW0tKirq6tXnVVWVqq8vDwr66yurk7z5s3rVR8S9fRfL7/8sqZMmaLrrrtOo0eP1qRJk/T000/Hnz906JDC4XCvegoEApo+fXpW1dOMGTPU1NSktrY2SdIHH3ygnTt36tprr5VEPaWC51bD/uyzz9Td3a1gMNjreDAY1IcffmhUKu/o6elRQ0ODZs6cqYkTJ0qSwuGw8vPzNXLkyF7nBoNBhcNhg1La2bJli95//3299957pz1HPZ3w0Ucf6YknntDy5ct133336b333tOdd96p/Px81dbWxuviTP8Hs6meVqxYoVgspsrKSg0bNkzd3d1avXq1lixZIknUUwp4LoDQt7q6Ou3fv187d+60LorntLe3a9myZXr99ddVUFBgXRzP6unp0ZQpU7RmzRpJ0qRJk7R//349+eSTqq2tNS6dd7zwwgt67rnntHnzZk2YMEF79+5VQ0ODSktLqacU8VwX3IUXXqhhw4adNjMpEomopKTEqFTeUF9fr1deeUVvvvmmLrroovjxkpISHTt2TB0dHb3Oz7Y6a2lp0ZEjR3TllVcqLy9PeXl5euutt/Too48qLy9PwWCQepI0ZswYXX755b2OXXbZZTp8+LAkxesi2/8P3n333VqxYoUWL16sqqoq/fSnP9Vdd92lUCgkiXpKBc8FUH5+viZPnqympqb4sZ6eHjU1Nam6utqwZHacc6qvr9fWrVv1xhtvqKKiotfzkydP1vDhw3vVWWtrqw4fPpxVdTZnzhzt27dPe/fujT+mTJmiJUuWxP9NPUkzZ848bRp/W1ubLr74YklSRUWFSkpKetVTLBbTrl27sqqevvrqq9N28xw2bJh6enokUU8pYT0L4ky2bNnifD6f27hxoztw4IC79dZb3ciRI104HLYumomlS5e6QCDgduzY4T799NP446uvvoqfc9ttt7ny8nL3xhtvuD179rjq6mpXXV1tWGpvOHkWnHPUk3Mnpqjn5eW51atXu4MHD7rnnnvOnXfeee4Pf/hD/Jy1a9e6kSNHum3btrm//e1vbv78+Vk3vbi2ttZ9+9vfjk/D/tOf/uQuvPBCd88998TPoZ4GxpMB5Jxzjz32mCsvL3f5+flu2rRp7t1337UukhlJZ3xs2LAhfs7XX3/tbr/9dnfBBRe48847zy1cuNB9+umndoX2iFMDiHo64c9//rObOHGi8/l8rrKy0j311FO9nu/p6XErV650wWDQ+Xw+N2fOHNfa2mpUWhuxWMwtW7bMlZeXu4KCAnfJJZe4X/7yl66zszN+DvU0MOwHBAAw4bkxIABAdiCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACAif8D3GhzcprCnlIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "graph = np.load(f'{file}/DAG0.npy')\n",
    "plt.figure()\n",
    "plt.imshow(graph)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "a82fe965",
   "metadata": {},
   "outputs": [],
   "source": [
    "node2factor, factor2node = model.sample_uv(1)\n",
    "node2factor = node2factor.squeeze().detach().cpu().numpy()\n",
    "factor2node = factor2node.squeeze().detach().cpu().numpy()\n",
    "graph_pred = (np.matmul(node2factor, factor2node.T) > 0).astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "4f85f0e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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JDQN+84779SmTZu0detWfec734kd9/v9KiwslHRqGvZrr72m9evXq7i4WHfddZckaefOnX26huU0bABA/6VlGvZTTz0lSbr66qvjjq9bt0633HKLJOmxxx5Tbm6u5s+fr66uLs2ePVtPPvlkYqUHAAx6CbWABgItIADIbH1tAbEWHADABAEEADBBAAEATBBAAAATBBAAwAQBBAAwQQABAEwQQAAAE0mvhp1uFqthY3Bil0pb2bQaNhJDCwgAYIIAAgCYIIAAACZYjPQcvNBvPZDXBeAtmfxdwGKkAABPI4AAACYIIACACc/eB2TNqr81k/p5AaRPNnwX0AICAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmWIrnNGzh2zfU08DywtYg/J37JpO3ULBACwgAYIIAAgCYIIAAACbYkhsAkFJsyQ0A8DQCCABgggACAJgggAAAJgggAIAJAggAYMKzS/FsaW9VcdGpfGQ5C/QHy6MA3kQLCABgggACAJgggAAAJjw7BnTDpRNYigcpwZgP4E20gAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAAgAnPLsUDWGDrhuScXm/UGfqKFhAAwAQBBAAwQQABAEwwBnQOVmMBjEHYor6TQ72lXjZ8F9ACAgCYIIAAACbogjvN15u86XjfwdCVx5TbgeWF7uBvumZv52ZDV9J/ZdPvmgq0gAAAJgggAICJfgXQqlWrlJOTo4aGhtixr776SnV1dSopKdGwYcM0f/58hcPh/pYTADDI5DjnXDIv3Lt3r2666SYVFxfrmmuu0erVqyVJixYt0quvvqr169fL7/ervr5eubm5euedd/r0vtFoVH6/X1drrvJyhiZTNACAoZPuhLZrqyKRiIqLi895XlItoM8++0wLFy7U2rVrdcEFF8SORyIRPfvss3r00Ud17bXXatKkSVq3bp127typXbt2nfW9urq6FI1G4x4AgMEvqQCqq6vTnDlzVFNTE3e8paVFJ06ciDteVVWliooKNTc3n/W9gsGg/H5/7FFeXp5MkQAAGSbhANq8ebPeffddBYPBM54LhULKz8/X8OHD444HAgGFQqGzvl9jY6MikUjs0dHRkWiRAAAZKKH7gDo6OrR48WK98cYbKigoSEkBfD6f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/ec//3EXX3yxu+WWW9zu3bvdBx984F5//XX3z3/+M3bOqlWrnN/vdy+99JJ777333I9+9CNXWVnpvvzyS8OSD6wVK1a4kpIS98orr7jDhw+7F1980Q0bNsz9/ve/j51DPfWPJwNo6tSprq6uLvZzd3e3Kysrc8Fg0LBU3nH06FEnyb399tvOOec6Ozvd0KFD3Ysvvhg75x//+IeT5Jqbm62KaebYsWNu7Nix7o033nDf//73YwFEPZ1y//33u5kzZ57z+Z6eHldaWup+97vfxY51dnY6n8/nnn/++YEooifMmTPH3XbbbXHHfvzjH7uFCxc656inVPBcF9zx48fV0tKimpqa2LHc3FzV1NSoubnZsGTeEYlEJEkXXnihJKmlpUUnTpyIq7OqqipVVFRkZZ3V1dVpzpw5cfUhUU//9fLLL2vy5Mm68cYbNXLkSE2cOFFr166NPX/48GGFQqG4evL7/Zo2bVpW1dP06dPV1NSk9vZ2SdJ7772nHTt26LrrrpNEPaWC51bD/uSTT9Td3a1AIBB3PBAI6P333zcqlXf09PSooaFBM2bM0Pjx4yVJoVBI+fn5Gj58eNy5gUBAoVDIoJR2Nm/erHfffVd79+494znq6ZQPPvhATz31lJYsWaIHHnhAe/fu1d133638/HzV1tbG6uJs/wezqZ6WLl2qaDSqqqoqDRkyRN3d3VqxYoUWLlwoSdRTCngugNC7uro6HThwQDt27LAuiud0dHRo8eLFeuONN1RQUGBdHM/q6enR5MmTtXLlSknSxIkTdeDAAT399NOqra01Lp13vPDCC9q4caM2bdqkcePGaf/+/WpoaFBZWRn1lCKe64IbMWKEhgwZcsbMpHA4rNLSUqNSeUN9fb1eeeUVvfXWW7roootix0tLS3X8+HF1dnbGnZ9tddbS0qKjR4/qyiuvVF5envLy8vT222/r8ccfV15engKBAPUkadSoUbr88svjjl122WU6cuSIJMXqItv/D957771aunSpFixYoAkTJuinP/2p7rnnHgWDQUnUUyp4LoDy8/M1adIkNTU1xY719PSoqalJ1dXVhiWz45xTfX29tmzZojfffFOVlZVxz0+aNElDhw6Nq7O2tjYdOXIkq+ps1qxZam1t1f79+2OPyZMna+HChbF/U0/SjBkzzpjG397erosvvliSVFlZqdLS0rh6ikaj2r17d1bV0xdffHHGbp5DhgxRT0+PJOopJaxnQZzN5s2bnc/nc+vXr3cHDx50t99+uxs+fLgLhULWRTOxaNEi5/f73fbt293HH38ce3zxxRexc+644w5XUVHh3nzzTbdv3z5XXV3tqqurDUvtDafPgnOOenLu1BT1vLw8t2LFCnfo0CG3ceNGd95557k//vGPsXNWrVrlhg8f7rZu3er+9re/ublz52bd9OLa2lr37W9/OzYN+89//rMbMWKEu++++2LnUE/948kAcs65J554wlVUVLj8/Hw3depUt2vXLusimZF01se6deti53z55ZfuzjvvdBdccIE777zz3A033OA+/vhju0J7xNcDiHo65S9/+YsbP3688/l8rqqqyj3zzDNxz/f09Lhly5a5QCDgfD6fmzVrlmtrazMqrY1oNOoWL17sKioqXEFBgbvkkkvcr371K9fV1RU7h3rqH/YDAgCY8NwYEAAgOxBAAAATBBAAwAQBBAAwQQABAEwQQAAAEwQQAMAEAQQAMEEAAQBMEEAAABMEEADAxP8BHv0beFvlFeAAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.imshow(graph_pred)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "22436707",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'graph' 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[38], line 5\u001b[0m\n\u001b[1;32m      3\u001b[0m f1s \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m      4\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m1000\u001b[39m):\n\u001b[0;32m----> 5\u001b[0m     tp \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msum((graph_pred \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m) \u001b[38;5;241m&\u001b[39m (\u001b[43mgraph\u001b[49m \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m))\n\u001b[1;32m      6\u001b[0m     tn \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msum((graph_pred \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m) \u001b[38;5;241m&\u001b[39m (graph \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m))\n\u001b[1;32m      7\u001b[0m     fp \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msum((graph_pred \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m) \u001b[38;5;241m&\u001b[39m (graph \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m))\n",
      "\u001b[0;31mNameError\u001b[0m: name 'graph' is not defined"
     ]
    }
   ],
   "source": [
    "precisions = []\n",
    "recalls = []\n",
    "f1s = []\n",
    "for i in range(1000):\n",
    "    tp = np.sum((graph_pred > 0) & (graph > 0))\n",
    "    tn = np.sum((graph_pred == 0) & (graph == 0))\n",
    "    fp = np.sum((graph_pred > 0) & (graph == 0))\n",
    "    fn = np.sum((graph_pred == 0) & (graph > 0))\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",
    "    precisions.append(precision)\n",
    "    recalls.append(recall)\n",
    "    f1s.append(f1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "00f7e213",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ZTh16hQuX76Mo0ePQq1Ww+l0QqlU4vnnn8f69evxf//v/8Xly5fxzjvvCH/Jdv/996OtrQ2///3vcfnyZfz617/GoUOHbvGs6E5y/fp14ckgAHz44Yc4d+4c2trabu3Axjk+YZG43NxcfPnll0hISIBcLseaNWuEP1/25qGHHsKxY8ewYcMGPPLII3C73VCpVMjKyhJidu3aheLiYjzzzDO4evUqpk2bhuLiYq/3czqdWL16NT755BMEBgbi+9///pB/jfHwww/jtddeQ0lJCTZv3oypU6di06ZNWL58+ajWgMaXsLAw/PnPf8bzzz+PtLQ02O12TJ8+Hd///vfh4/PVf4fS6/W46667UFJSgk8//RRTp05FQUEBAOB//a//hXXr1qGwsBB2ux2PP/449Ho9Nm7ceAtnRXeS06dP47HHHhOuNRoNACAvL2/QX0XS2JG53f/zpR4kOY8++ihiY2NRXl5+q4dCRER0S3FLiIiIiCSPBQsRERFJHreEiIiISPL4hIWIiIgkjwULERERSR4LFiIiIpI8FixEREQkeSxYiIiISPJYsBAREZHksWAhIiIiyWPBQkRERJLHgoWIiIgk7/8DAFqbOtXoCcEAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.boxplot([precisions, recalls, f1s])\n",
    "plt.xticks([1, 2, 3], ['precision', 'recall', 'f1'])\n",
    "plt.yticks(np.linspace(0, 1.0, 101))\n",
    "plt.ylim(0.8, 1.01)\n",
    "plt.grid('on')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "1d6ddbe3",
   "metadata": {},
   "outputs": [],
   "source": [
    "indices = np.where(graph.sum(1) > 0)[0]\n",
    "mean_corr_causal = []\n",
    "mean_corr_noncausal = []\n",
    "for idx in indices:\n",
    "    mean_corr_causal.extend(list(corr[idx, np.where(graph[idx] > 0)[0]]))\n",
    "    mean_corr_noncausal.extend(list(corr[idx, np.where(graph[idx] == 0)[0]]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "cc994fab",
   "metadata": {},
   "outputs": [
    {
     "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.boxplot([mean_corr_causal, mean_corr_noncausal])\n",
    "plt.xticks([1, 2], ['Causal Pair', 'Non-Causal Pair'])\n",
    "plt.yticks(np.linspace(-1, 1, 21))\n",
    "plt.grid('on')\n",
    "plt.ylabel('Correlation')\n",
    "plt.savefig('corr_boxplot.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "c52314dc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Help on function construct_fg in module codebase.models.spns.spn_utils:\n",
      "\n",
      "construct_fg(num_nodes, num_factors, max_copies, device, normalize=True, p_conn=0.5, sparsity_temp=1.0)\n",
      "    Constructs a factor graph using spn\n",
      "    \n",
      "    Args:\n",
      "        num_nodes (int): Number of graph nodes\n",
      "        num_factors (int): Number of factors\n",
      "        max_copies (int): Maximum network width, should be a power of 2.\n",
      "        device (:class:`torch.cuda.device`): Device info, {cpu, cuda}\n",
      "        normalize (bool, optional): Whether to use normalized probability. Defaults to True.\n",
      "        p_conn (float, optional): Node-to-factor density parameter. Defaults to 0.2.\n",
      "        sparsity_temp (float, optional): Weight for sparsity control. Defaults to 1.0.\n",
      "    \n",
      "    Returns:\n",
      "        :class:`SPNFG`: Factor Graph\n",
      "\n"
     ]
    }
   ],
   "source": [
    "help(construct_fg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "aa29fbc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "fg = construct_fg(100, 10, 8, device, sparsity_temp=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32ccf8da",
   "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
}
