{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# External imports \n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "import random\n",
    "import numpy as np\n",
    "from tqdm import trange\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython.display import display, clear_output\n",
    "\n",
    "# Internal imports\n",
    "import sys; sys.path.insert(0, '..')\n",
    "from src import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_DIMS = 1\n",
    "NUM_SAMPLES = 20000\n",
    "BS = 500\n",
    "NUM_EPOCHS = 500\n",
    "SEED = 10\n",
    "LR = 1e-2\n",
    "DROPOUT = 0.20\n",
    "DEVICE = 'cuda:0' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "\n",
    "# Break by changing num datapoints, scales, means, or to 2D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting seed for reproducibility\n",
    "random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "np.random.seed(SEED)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define model\n",
    "model_tre1 = RatioCritic1D(dim_input=N_DIMS, dim_output=1, dropout=DROPOUT, tre=True) # CHANGE 1D MODEL FOR TRE\n",
    "model_tre2 = RatioCritic1D(dim_input=N_DIMS, dim_output=1, dropout=DROPOUT, tre=True)\n",
    "model_tre3 = RatioCritic1D(dim_input=N_DIMS, dim_output=1, dropout=DROPOUT, tre=True)\n",
    "model_tre4 = RatioCritic1D(dim_input=N_DIMS, dim_output=1, dropout=DROPOUT, tre=True)\n",
    "\n",
    "\n",
    "# model.apply(weights_init)\n",
    "\n",
    "# Define optimizer\n",
    "optim_tre1 = torch.optim.Adam(model_tre1.parameters(), lr=LR)\n",
    "optim_tre2 = torch.optim.Adam(model_tre2.parameters(), lr=LR)\n",
    "optim_tre3 = torch.optim.Adam(model_tre3.parameters(), lr=LR)\n",
    "optim_tre4 = torch.optim.Adam(model_tre4.parameters(), lr=LR)\n",
    "\n",
    "# Define distributions\n",
    "p, q, m = get_dists_1d_tre(mu1=-1., mu2=1., mu3=0, scale_p=0.1, scale_q=0.2, alphas=[0.25, 0.50, 0.75])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "m1, m2, m3 = m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[Normal(loc: -0.7182458639144897, scale: 0.1089724749326706),\n",
       " Normal(loc: -0.3660254180431366, scale: 0.13228756189346313),\n",
       " Normal(loc: 0.08856217563152313, scale: 0.16393595933914185)]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAD4CAYAAAD8Zh1EAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAWLUlEQVR4nO3df3BV5Z3H8fcnkjV2xF+QVhbQ0FEELaViaq0wjiPbGX8N1tZWXW3F6rAqTttdnS3W0VpmrLXrdK0VZRhwBH+7WhGrTEdXW2VGsYFBQBLb1GU1jNYYW5T6o6b97h85uDEkuecmJ/cmD5/XzB3OuefJOd+TwIeT5z7nOYoIzMxs5KupdgFmZlYMB7qZWSIc6GZmiXCgm5klwoFuZpaIUdU68NixY6OhoaFahzczG5HWrVv3ZkTU97ataoHe0NBAU1NTtQ5vZjYiSfrfvra5y8XMLBEOdDOzRDjQzcwSkbsPXdIeQBOwLSJO7bFtT2AFcBTQAZwZEVsLrNPMrKQPP/yQtrY23n///WqXMmh1dXVMmDCB2tra3F9Tzoei3wGagX162XYB8KeIOETSWcD1wJll7NvMbNDa2toYPXo0DQ0NSKp2OQMWEXR0dNDW1sakSZNyf12uLhdJE4BTgKV9NDkNWJ4tPwDM1kj+bprZiPT+++8zZsyYER3mAJIYM2ZM2b9p5O1DvxH4d+DvfWwfD7wKEBGdwHZgTFmVmJkVYKSH+U4DOY+SgS7pVOCNiFg3kKJ67GuepCZJTe3t7YPdnZmZdZOnD30mMEfSyUAdsI+kOyPi3G5ttgETgTZJo4B96fpw9GMiYgmwBKCxsdETsZvZkGpY8Gih+9v641MK3V/RSgZ6RFwBXAEg6Xjg8h5hDrAKOA94FjgDeDISeXJGf38hhvsP18x2LwMehy5poaQ52eoyYIykVuDfgAVFFGdmNtJs3bqVKVOmcM455zB16lTOOOMM3n333Yocu6xAj4hf7xyDHhFXR8SqbPn9iPhaRBwSEUdHxMtDUayZ2Ujw0ksvcckll9Dc3Mw+++zDLbfcUpHj+k5RM7OCTZw4kZkzZwJw7rnnsmbNmooc14FuZlawnkMOKzWU0oFuZlawV155hWeffRaAu+++m1mzZlXkuFWbD93MbKhVayTaYYcdxqJFi/jWt77F4YcfzsUXX1yR4zrQzcwKNmrUKO68886KH9ddLmZmiXCgm5kVqKGhgc2bN1fl2A50M7NEONDNzBLhQDczS4QD3cwsER62aGbpumbfgve3vdj9FcxX6GZmiXCgm5kV6Nprr2Xy5MnMmjWLs88+mxtuuKFix3aXi5lZQdatW8e9997Lhg0b6OzsZMaMGRx11FEVO74D3cysIM888wynn346n/jEJwCYM2dOia8olrtczMwS4UA3MyvIcccdx8qVK3nvvfd45513eOSRRyp6/JJdLpLqgKeBPbP2D0TED3q0mQv8B7Ate+vmiFhabKm7j2nLp5Vss+m8TRWoxGyEq/AwwxkzZnDmmWcyffp0PvnJT/L5z3++osfP04f+AXBCROyQVAuskbQ6Ip7r0e6+iLi0+BKHr4YFj/a5rVrzMJtZdV155ZVceeWVAFxzzTUVPXbJQI+IAHZkq7XZK4ayKDMzK1+uUS6S9gDWAYcAiyJibS/NvirpOOB3wL9GxKu97GceMA/goIMOGnDRZmYjQaWv0HN9KBoRf4uIzwETgKMlfaZHk0eAhoj4LPA4sLyP/SyJiMaIaKyvrx9E2WZm1lNZo1wi4s/AU8CJPd7viIgPstWlQOVG0puZGZAj0CXVS9ovW94L+BLQ0qPNuG6rc4DmAms0M7Mc8vShjwOWZ/3oNcD9EfFLSQuBpohYBXxb0hygE3gLmDtUBZuZWe/yjHLZCBzZy/tXd1u+Arii2NLMzAYnzz0d5Sjq/o+WlhbOP/981q9fz7XXXsvll19eyH49l4uZWYUdcMAB3HTTTaxcubLQ/frWfzOzAm3dupUpU6Ywd+5cJk+ezDnnnMMTTzzBzJkzOfTQQ3n++ec/uou0tra20GM70M3MCtba2spll11GS0sLLS0t3H333axZs4YbbriBH/3oR0N2XHe5mJkVbNKkSUyb1tV/f8QRRzB79mwkMW3aNLZu3Tpkx/UVuplZwfbcc8+Plmtqaj5ar6mpobOzc8iO60A3M0uEu1zMLFnDdZrp119/ncbGRt5++21qamq48cYb2bJlC/vss8+g9utANzMrUENDA5s3b/5o/fbbb+91W1tbW+HHdpeLmVkiHOhmZolwoJuZJcKBbmaWCAe6mVkiHOhmZonwsEUzS1bzlKmF7m9qSzHP7rnrrru4/vrriQhGjx7NrbfeyvTp0we9Xwe6mVmFTZo0id/85jfsv//+rF69mnnz5rF27dpB79ddLmZmBcozfe6xxx7L/vvvD8AxxxxT2E1GeZ4pWifpeUkvSHpR0g97abOnpPsktUpaK6mhkOrMzEagcqbPXbZsGSeddFIhx83T5fIBcEJE7JBUC6yRtDoinuvW5gLgTxFxiKSzgOuBMwup0HpV6tFaw3UOC7PdQd7pc5966imWLVvGmjVrCjluySv06LIjW63NXtGj2WnA8mz5AWC2JBVSoZnZCJNn+tyNGzdy4YUX8vDDDzNmzJhCjpurD13SHpI2AG8Aj0dEz9778cCrABHRCWwHdqlQ0jxJTZKa2tvbB1W4mdlI9corr/CVr3yFO+64g8mTJxe231yjXCLib8DnJO0HPCTpMxGxucSX9bafJcASgMbGxp5X+WZmhSpqmGHRFi5cSEdHB5dccgkAo0aNoqmpadD7LWvYYkT8WdJTwIlA90DfBkwE2iSNAvYFOgZdnZnZCJN3+tylS5cWfuw8o1zqsytzJO0FfAlo6dFsFXBetnwG8GRE+ArczKyC8lyhjwOWS9qDrv8A7o+IX0paCDRFxCpgGXCHpFbgLeCsIavYzMx6VTLQI2IjcGQv71/dbfl94GvFlmZmZuXwnaJmZolwoJuZJcKTc9mg5ZnRbrgOHzNLiQMdaFjwaLVLMLMhsOiiJwvd3/zFJxSyn4cffpirrrqKmpoaRo0axY033sisWbMGvV8HupVU9JzSZru72bNnM2fOHCSxceNGvv71r9PS0nM0ePnch25mVqA80+fuvffe7Jzu6i9/+QtFTX3lQDczK1ie6XMfeughpkyZwimnnMJtt91WyHEd6GZmBds5fW5NTU2f0+eefvrptLS0sHLlSq666qpCjutANzMrWJ7pc3c67rjjePnll3nzzTcHfVwHuplZhbW2trJzuqv169fzwQcfFDInuke5mFmyihpmWLQHH3yQFStWUFtby1577cV9991XyAejDnQzswLlnT73e9/7XuHHdpeLmVkiHOhmZolwoJtZUlJ5ts5AzsN96FUwbfm0apdglqS6ujo6OjoYM2ZMYXdfVkNE0NHRQV1dXVlf50A3s2RMmDCBtrY22tvbq13KoNXV1TFhwoSyvqZkoEuaCKwAPgUEsCQiftajzfHAw8D/ZG/9IiIWllWJmdkg1dbWMmnSpGqXUTV5rtA7gcsiYr2k0cA6SY9HxJYe7Z6JiFOLL9HMzPIo+aFoRLwWEeuz5XeAZmD8UBdmZmblKWuUi6QGuh4YvbaXzV+U9IKk1ZKO6OPr50lqktSUQh+XmdlwkjvQJe0NPAh8NyLe7rF5PXBwREwHfg6s7G0fEbEkIhojorG+vn6AJZuZWW9yBbqkWrrC/K6I+EXP7RHxdkTsyJYfA2oljS20UjMz61fJQFfXYM5lQHNE/LSPNgdm7ZB0dLbfjiILNTOz/uUZ5TIT+AawSdKG7L3vAwcBRMRi4AzgYkmdwHvAWZHK7Vo2YuV9QPBwnZHPrFwlAz0i1gD93nIVETcDNxdVlJmZlc9zuZiZJcKBbmaWCAe6mVkiHOhmZonwbItG85Sp1S7BzArgK3Qzs0Q40M3MEuFANzNLhAPdzCwRDnQzs0R4lMsQaVjwaK/vb/3xKRWuxMx2F75CNzNLhAPdzCwRDnQzs0Q40M3MEuFANzNLhAPdzCwReZ4pOlHSU5K2SHpR0nd6aSNJN0lqlbRR0oyhKdfMzPqSZxx6J3BZRKyXNBpYJ+nxiNjSrc1JwKHZ6wvArdmfZrY7uGbfAXzN9uLr2M2VvEKPiNciYn22/A7QDIzv0ew0YEV0eQ7YT9K4wqs1M7M+ldWHLqkBOBJY22PTeODVbutt7Br6SJonqUlSU3t7e5mlmplZf3IHuqS9gQeB70bE2wM5WEQsiYjGiGisr68fyC7MzKwPuQJdUi1dYX5XRPyilybbgInd1idk75mZWYXkGeUiYBnQHBE/7aPZKuCb2WiXY4DtEfFagXWamVkJeUa5zAS+AWyStCF77/vAQQARsRh4DDgZaAXeBc4vvFIzM+tXyUCPiDWASrQJYH5RRZlV0qKLnszVbv7iE4a4ErPB8Z2iZmaJcKCbmSXCgW5mlggHuplZIvxM0URNWz6t3+2bzttUoUqKl/dDTLPdja/QzcwS4UA3M0uEA93MLBEOdDOzRDjQzcwS4UA3M0uEA93MLBEeh25m1VHuc0j9DNKSHOhWEc1Tpva7fWpLc4UqMUuXu1zMzBLhQDczS4QD3cwsEXmeKXqbpDckbe5j+/GStkvakL2uLr5MMzMrJc+HorcDNwMr+mnzTEScWkhFZmY2ICWv0CPiaeCtCtRiZmaDUFQf+hclvSBptaQj+mokaZ6kJklN7e3tBR3azMygmEBfDxwcEdOBnwMr+2oYEUsiojEiGuvr6ws4tJmZ7TToQI+ItyNiR7b8GFAraeygKzMzs7IMOtAlHShJ2fLR2T47BrtfMzMrT8lRLpLuAY4HxkpqA34A1AJExGLgDOBiSZ3Ae8BZERFDVvEgNCx4tNolmJkNmZKBHhFnl9h+M13DGs2Slvfh1PMXnzDElZj1zpNzmdnIUO7sjLDbzdDoW//NzBLhQDczS4QD3cwsEQ50M7NEONDNzBLhQDczS4SHLe4G7r+uc5f3mq/r/xmfthsbyPBAGxZ8hW5mlggHuplZItzlYsNG3lvrzax3vkI3M0uEA93MLBEOdDOzRDjQzcwS4UA3M0uEA93MLBElA13SbZLekLS5j+2SdJOkVkkbJc0ovkwzMyslzxX67cCJ/Ww/CTg0e80Dbh18WWZmVq6SgR4RTwNv9dPkNGBFdHkO2E/SuKIKNDOzfIroQx8PvNptvS17z8zMKqiiH4pKmiepSVJTe3t7JQ9tZpa8IgJ9GzCx2/qE7L1dRMSSiGiMiMb6+voCDm1mZjsVEeirgG9mo12OAbZHxGsF7NfMzMpQcrZFSfcAxwNjJbUBPwBqASJiMfAYcDLQCrwLnD9UxY4Uo6cu6HPbtOV9bzMzG4ySgR4RZ5fYHsD8wioyM7MB8Z2iNiw0T/Ej8cwGy4FuZpYIB7qZWSIc6GZmifAzRc0KlvfZqPMXnzDEldjuxlfoZmaJcKCbmSXCXS5mqbtm32pXYBXiK3Qzs0Q40M3MEuEuFzNLV7ndTddsH5o6KsRX6GZmiXCgm5klwoFuZpYIB7qZWSIc6GZmiXCgm5klIlegSzpR0kuSWiXt8gw1SXMltUvakL0uLL5UMzPrT55niu4BLAK+BLQBv5W0KiK29Gh6X0RcOgQ1mplZDnmu0I8GWiPi5Yj4K3AvcNrQlmVmZuXKE+jjgVe7rbdl7/X0VUkbJT0gaWIh1ZmZWW5FfSj6CNAQEZ8FHgeW99ZI0jxJTZKa2tvbCzq0mZlBvrlctgHdr7gnZO99JCI6uq0uBX7S244iYgmwBKCxsTHKqjSnhgWPDsVuzcyGvTyB/lvgUEmT6Arys4B/7t5A0riIeC1bnQM0F1qljWhPHr+o2iWY7RZKBnpEdEq6FPgVsAdwW0S8KGkh0BQRq4BvS5oDdAJvAXOHsGYzM+tFrulzI+Ix4LEe713dbfkK4IpiS7M87r+us9olmNkw4TtFzcwS4UA3M0uEA93MLBEOdDOzRDjQzcwS4YdEm1XJoouezNVu/uIThrgSS4Wv0M3MEuFANzNLhLtcBmD01F2e8WFmVnW+QjczS4Sv0M3Mdrpm3wF8zfbi6xggX6GbmSXCgW5mlogR2eWyOz3EwrMp2scMpEvAdhu+QjczS4QD3cwsEQ50M7NEjMg+9KHmG4fMbCTKFeiSTgR+RtczRZdGxI97bN8TWAEcBXQAZ0bE1mJLteHGD3+ujI9P4vVQn+3mH3j60BdjuxpGY9dLdrlI2gNYBJwEHA6cLenwHs0uAP4UEYcA/wlcX3ShZmbWvzx96EcDrRHxckT8FbgXOK1Hm9OA5dnyA8BsSSquTDMzKyVPl8t44NVu623AF/pqExGdkrYDY4A3uzeSNA+Yl63ukPTSQIoeBsbS49yGSs9fhYZQ+ef00uyhqaQYFfsZVVC/53RpBQspSGo/o/zn88NBXe8e3NeGin4oGhFLgCWVPOZQkNQUEY3VrqNIqZ1TaucD6Z2Tz6d4ebpctgETu61PyN7rtY2kUcC+dH04amZmFZIn0H8LHCppkqR/AM4CVvVoswo4L1s+A3gyIqK4Ms3MrJSSXS5Zn/ilwK/oGrZ4W0S8KGkh0BQRq4BlwB2SWoG36Ar9lI34bqNepHZOqZ0PpHdOPp+CyRfSZmZp8K3/ZmaJcKCbmSXCgZ6DpK9JelHS3yX1OSxJ0omSXpLUKmlYTwgj6QBJj0v6ffbn/n20+5ukDdmr54fhVVfqey5pT0n3ZdvXSmqoQpm55TifuZLau/1MLqxGnXlJuk3SG5I297Fdkm7KznejpBmVrrEcOc7neEnbu/18rq5ogRHhV4kXMBU4DPg10NhHmz2APwCfBv4BeAE4vNq193NOPwEWZMsLgOv7aLej2rX2cw4lv+fAJcDibPks4L5q1z3I85kL3FztWss4p+OAGcDmPrafDKwGBBwDrK12zYM8n+OBX1arPl+h5xARzRFR6q7WPFMkDCfdp2tYDny5eqUMWGrTUoy0v0MlRcTTdI1868tpwIro8hywn6RxlamufDnOp6oc6MXpbYqE8VWqJY9PRcRr2fLrwKf6aFcnqUnSc5K+XJnScsvzPf/YtBTAzmkphqO8f4e+mnVPPCBpYi/bR5KR9u8mjy9KekHSaklHVPLAng89I+kJ4MBeNl0ZEQ9Xup4i9HdO3VciIiT1NX714IjYJunTwJOSNkXEH4qu1XJ7BLgnIj6Q9C90/fZxQpVrsv+3nq5/MzsknQysBA6t1MEd6JmI+KdB7iLPFAkV1d85SfqjpHER8Vr2K+4bfexjW/bny5J+DRxJVz/vcFDOtBRtI2BaipLnExHda19K12chI9mw+3czGBHxdrflxyTdImlsRFRkEjJ3uRQnzxQJw0n36RrOA3b5LUTS/tnDS5A0FpgJbKlYhaWlNi1FyfPp0b88B2iuYH1DYRXwzWy0yzHA9m5dgSOOpAN3fkYj6Wi6MrZyFxDV/tR4JLyA0+nq2/sA+CPwq+z9fwQe69buZOB3dF3BXlntukuc0xjgv4HfA08AB2TvN9L1VCqAY4FNdI222ARcUO26ezmPXb7nwEJgTrZcB/wX0Ao8D3y62jUP8nyuA17MfiZPAVOqXXOJ87kHeA34MPs3dAFwEXBRtl10PUDnD9nfsV5HkQ2XV47zubTbz+c54NhK1udb/83MEuEuFzOzRDjQzcwS4UA3M0uEA93MLBEOdDOzRDjQzcwS4UA3M0vE/wEaht6UCl2UHQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_samples = p.sample([1000])\n",
    "q_samples = q.sample([1000])\n",
    "m1_samples = m1.sample([1000])\n",
    "m2_samples = m2.sample([1000])\n",
    "m3_samples = m3.sample([1000])\n",
    "\n",
    "plt.hist(p_samples.numpy(), label='p', density=True, histtype='stepfilled')\n",
    "plt.hist(q_samples.numpy(), label='q', density=True, histtype='stepfilled')\n",
    "plt.hist(m1_samples.numpy(), label='m1', density=True, histtype='stepfilled')\n",
    "plt.hist(m2_samples.numpy(), label='m2', density=True, histtype='stepfilled')\n",
    "plt.hist(m3_samples.numpy(), label='m3', density=True, histtype='stepfilled')\n",
    "plt.legend()\n",
    "# plt.savefig('1D_demo_hist.png')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling p\n",
      "Sampling q\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "Sampling p\n",
      "Sampling q\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n"
     ]
    }
   ],
   "source": [
    "# Define dataset & dataloader\n",
    "train_ds = DistDataset3Waymark(p, q, m, num_samples=NUM_SAMPLES)\n",
    "test_ds = DistDataset3Waymark(p, q, m, num_samples=NUM_SAMPLES) # Test dataset is only of size batch "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define dataloader\n",
    "train_dl = DataLoader(train_ds, batch_size=BS, shuffle=True)\n",
    "test_dl = DataLoader(test_ds, batch_size=BS, shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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1au5++67ufTSS2uu89BDDzFv3jzuuusuli1bxoABA7j66qu7XXennXbi/vvvZ+bMmZxzzjkAbNy4kRUrVjBu3DhuuOEGVqxYwfLly5kzZw533313PXZLktSCvIREkiSphG65BaZPh5dfhm9/G+bOhXoMIfH+97+fAQMGbHad2267jSVLlnDooYcC8OKLL7Lrrrt2u+60adM6n88991wAFi1axKRJkwC48847mTZtGgMGDGDPPffkmGOO6atdkSS1OBMYkiRJJbRwYSV5MXQovPBCZb4eCYyhQ4d2Tg8cOJBNmzZ1zr/00ksAZCYzZszgC1/4wha3V337047pm266ialTp/ZVyJKkNuUlJJIkSSV09NEweHAleTF4cGW+3saMGcPSpUsBWLp0KY899hgAxx57LPPnz+epp54C4Omnn+bxxx/vdhvz5s3rfD788MOBSg+OyZMnA3DUUUcxb948Nm7cyNq1a7njjjvquk+SpNZhDwxJkqQSmjKlctnIwoWV5EUj7kD6vve9jzlz5rD//vszadIk3vKWtwAwbtw4Lr74YqZMmcKmTZsYNGgQl112GW9605tet41nnnmGgw46iMGDB3PNNdewbt06hgwZwvDhwwE4+eSTuf322xk3bhx77713Z5JDkqQtMYEhSZJUUlOm1CdxMWvWrG7Lt99+e26pMWLoqaeeyqmnnrrFbZ9//vlccsklnfNz585lStVORATf/OY3O+dPP/30ngUtSWp7JjAkSZJUN9OnT292CJKkFmECQ5IkSX1i1apVW/2aK6+8ss/jkCS1JgfxlCRJkiRJpWcCQ5IkSZIklZ4JDEmSJEmSVHomMCRJkiRJUumZwJAkSWoD69evZ/z48YwfP57dd9+dUaNGdc5HBOPHj+eAAw7gL/7iL3j22WeByqCc22+/fed648ePZ86cOVtV79q1a19zG1VJkraVdyGRJElqAyNGjGDZsmUAzJo1i2HDhnHeeecBMGzYsM5lM2bM4LLLLuMzn/kMAPvss0/nsm2xYMECjjvuuN6ELkkSYA8MSZIkVTn88MNZs2bNVr1mzJgxXHDBBRx44IFMnDiRlStXdi5bsGABxx9/PJnJzJkz2W+//Zg8eTInnHAC8+fP7+vwJUktzASGJElSWd1yC3z605XnBti4cSO33XYbJ554YmfZI4888ppLSH760592+9qddtqJ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\n",
      "text/plain": [
       "<Figure size 1080x864 with 9 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [[ax1,ax2,ax3], [ax4, ax5, ax6], [ax7, ax8, ax9]] = plt.subplots(3, 3,figsize=(15,12))\n",
    "\n",
    "line, = ax1.plot([0,1],[0,1])\n",
    "x, y = np.random.random((2, 500))\n",
    "scat1 = ax2.scatter(x,y,label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "scat2 = ax2.scatter(x,y,label='CoB p/q',alpha=0.9,s=10.,c='r')\n",
    "test_line, = ax3.plot([0,1],[0,1])\n",
    "\n",
    "ax1.set_xlabel(\"Iteration\")\n",
    "ax1.set_ylabel(\"Train Loss\")\n",
    "ax1.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax1.set_ylim([0,10])\n",
    "\n",
    "ax2.set_xlabel(\"Samples\")\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim([-6,10])\n",
    "ax2.set_ylim([-1500,5000])\n",
    "\n",
    "ax3.set_xlabel(\"Iteration\")\n",
    "ax3.set_ylabel(\"Test Loss\")\n",
    "ax3.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax3.set_ylim([0,10])\n",
    "\n",
    "line2, = ax4.plot([0,1],[0,1])\n",
    "x, y = np.random.random((2, 500))\n",
    "scat3 = ax5.scatter(x,y,label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "scat4 = ax5.scatter(x,y,label='TRE p/q',alpha=0.9,s=10.,c='r')\n",
    "test_line2, = ax6.plot([0,1],[0,1])\n",
    "\n",
    "ax4.set_xlabel(\"Iteration\")\n",
    "ax4.set_ylabel(\"Train Loss\")\n",
    "ax4.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax4.set_ylim([0,10])\n",
    "\n",
    "ax5.set_xlabel(\"Samples\")\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='best')\n",
    "ax5.set_xlim([-6,10])\n",
    "ax5.set_ylim([-1500,5000])\n",
    "\n",
    "ax6.set_xlabel(\"Iteration\")\n",
    "ax6.set_ylabel(\"Test Loss\")\n",
    "ax6.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax6.set_ylim([0,10])\n",
    "\n",
    "\n",
    "line3, = ax7.plot([0,1],[0,1])\n",
    "scat5 = ax8.scatter(x,y,label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "scat6 = ax8.scatter(x,y,label='TRE p/q',alpha=0.9,s=10.,c='r')\n",
    "test_line3, = ax9.plot([0,1],[0,1])\n",
    "\n",
    "ax7.set_xlabel(\"Iteration\")\n",
    "ax7.set_ylabel(\"Train Loss\")\n",
    "ax7.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax7.set_ylim([0,10])\n",
    "\n",
    "ax8.set_xlabel(\"Samples\")\n",
    "ax8.set_ylabel(\"Log Ratio\")\n",
    "ax8.legend(loc='best')\n",
    "ax8.set_xlim([-6,10])\n",
    "ax8.set_ylim([-1500,5000])\n",
    "\n",
    "ax9.set_xlabel(\"Iteration\")\n",
    "ax9.set_ylabel(\"Test Loss\")\n",
    "ax9.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax9.set_ylim([0,10])\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "loss_store = []\n",
    "test_loss_store = []\n",
    "\n",
    "loss_store_cob_sep = []\n",
    "test_loss_store_cob_sep = []\n",
    "\n",
    "loss_store_tre = []\n",
    "test_loss_store_tre = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8stceOGFXHzxxQDU1NQwadIkBg8ezD333MOkSZOYMGECN998M08//XQ+TkuS1ALZhUSSJKkEjRoFK1dCp06wdGluPh9DSHzsYx+joqJig+s8+uijjB07lgMPPBCA5cuXs+222za47siRI+vev/SlLwHw3HPPcdBBBwHwxBNPMHLkSCoqKth+++056qijmutUJEktnAkMSZKkEjR8OPzpT7nkRYcOufl86NSpU91027Ztqa2trZtfsWIFACklzjrrLH7wgx9sdH/1H3+6Zvrf//43xx13XHOFLElqpexCIkmSVIJGjIBbboELLsi9F+IBHv3792fcuHEAjBs3jjfffBOAo48+mrvuuos5c+YAMG/ePKZPn97gPu64446690MOOQTIteA45phjADjyyCO54447qKmpYdasWTz22GN5PSdJUsthCwxJkqQSNWJEYRIXa5x22mncfPPN7Lnnnhx00EHsuuuuAAwePJjvfve7jBgxgtraWtq1a8c111zDTjvttN4+5s+fzz777EOHDh247bbbqKqqorKyki5dugBw6qmn8p///IfBgwez44471iU5JEnaGBMYkiRJrcxVV13VYHnHjh15qJHRQk8//XROP/30je77kksu4Uc/+lHd/C233MKIelmYiOA3v/lN3fzZZ5/dtKAlSa2eCQxJkiTlzZlnnlnsECRJLYQJDEmSJDWLadOmbfI2N954Y7PHIUlqmRzEU5IkSZIklTwTGJIkSZIkqeSZwJAkSZIkSSXPBIYkSZIkSSp5JjAkSZJagblz5zJkyBCGDBlCnz596Nu3b918RDBkyBD22msvPvzhD7NgwQIgNyhnx44d69YbMmQIN9988yYdd9asWWs9RlWSpM3lU0gkSZJagZ49ezJ+/HgArrrqKjp37sxXv/pVADp37ly37KyzzuKaa67h61//OgADBw6sW7Y5HnjgAY499tgtCV2SJMAWGJIkSaXroYfgiity7wVyyCGHMHPmzE3apn///lx66aXsvffeDBs2jMmTJ9cte+CBBzj++ONJKXHhhRey2267ccwxx3DCCSdw1113NXf4kqQWzASGJElSKXroITjzTLjmmtx7AZIYNTU1PProo5x00kl1ZVOmTFmrC8l///vfBrft1q0bL7/8MhdeeCEXX3xx3f4mTZrE4MGDueeee5g0aRITJkzg5ptv5umnn877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2MG9VSRJj2IBQ5IkaUgsXkye60qSNJ4FDEmSJEmS1HkWMCRJkmaBu+66i4ULF7Jw4UJ+8zd/k5133nnN+EMPPTTw5a9cuZLFixcPfDmSpJnLk3hKkiTNAjvssANLliwB4IQTTmDrrbfmne9855rHH374YebOHVzX8IILLuCggw4a2PwlSTOfe2BIkiTNUkcffTRvetOb2HvvvXn3u9/NCSecwEc/+tE1jz/72c/m1ltvBeD0009nr732YuHChfzpn/4pq1evfsz85s+fz7vf/W6e85znsNdee7Fs2bI1j11wwQUccsghVBXHHnssu+++OwceeCCHHnoo55577sBfqyRp+rOAIUmS1FEXXgjve19zPyjLly/nO9/5Dh//+Mf7TnPjjTdy9tlnc+mll7JkyRLmzJnDGWecMeG02267Lddeey3HHnssxx13HACrV69m6dKlLFiwgPPOO4+lS5dyww03cNppp/Gd73xnEC9LkjQDeQiJJElSB114IRx5JDz4IHzmM3D66TCIU0i8+tWvZs6cOWud5uKLL+aqq67i+c9/PgAPPPAAT3ziEyec9ogjjlhz//a3vx2Ayy67jL333huAb33rWxxxxBHMmTOHJz/5yey///5T9VIkSTOcBQxJkqQOuuSSpnix1Vbw858344MoYGy11VZrhufOncsjjzyyZvyXv/wlAFXFUUcdxV//9V+vc369lz8dG/7KV77CwQcfPFWRJUmzlIeQSJIkddB++8FmmzXFi802a8YHbf78+Vx99dUAXH311dxyyy0AHHDAAZx77rnceeedANx9993cdtttE87j7LPPXnO/7777As0eHAceeCAAL37xizn77LNZvXo1K1eu5Bvf+MZAX5MkaeZwDwxJkqQOWry4OWzkkkua4sUwrkD6yle+ktNOO41nPetZ7L333jzjGc8AYMGCBXzoQx9i8eLFPPLII2yyySaceOKJPPWpT33MPO655x722GMPNttsM84880xWrVrF5ptvzjbbbAPAK17xCr7+9a+zYMECnvKUp6wpckiStC4WMCRJkjpq8eLBFC5OOOGECdu32GILLuxzxtDXvva1vPa1r13nvN/1rnfxkY98ZM346aefzuKeF5GET33qU2vGjz766MmFliTNehYwJEmSNDBHHnnkqCNIkmYICxiSJEmaErfeeut6P+fUU0+d8hySpJnJ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\n",
      "text/plain": [
       "<Figure size 1080x864 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [14:13<00:00,  1.71s/it]\n"
     ]
    }
   ],
   "source": [
    "## CONFIRM q_list_test in validation/visualization in Akash's code\n",
    "\n",
    "model_tre1.train()\n",
    "model_tre2.train()\n",
    "model_tre3.train()\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    model_tre1 = model_tre1.to(DEVICE)\n",
    "    model_tre2 = model_tre2.to(DEVICE)\n",
    "    model_tre3 = model_tre3.to(DEVICE)\n",
    "    model_tre4 = model_tre4.to(DEVICE)\n",
    "    \n",
    "i = 0\n",
    "loss_crit_tre = torch.nn.functional.binary_cross_entropy_with_logits\n",
    "\n",
    "\n",
    "for epoch in trange(NUM_EPOCHS):\n",
    "    for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(train_dl):\n",
    "        model_tre1.train()\n",
    "        model_tre2.train()\n",
    "        model_tre3.train()\n",
    "        model_tre4.train()\n",
    "        \n",
    "        i += 1\n",
    "        optim_tre1.zero_grad()\n",
    "        optim_tre2.zero_grad()\n",
    "        optim_tre3.zero_grad()\n",
    "        optim_tre4.zero_grad()\n",
    "        \n",
    "        # CUDA\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "        \n",
    "        # TRE\n",
    "        logP1 = model_tre1(p_batch).squeeze()\n",
    "        logM1_1 = model_tre1(m_batch1).squeeze()\n",
    "        \n",
    "        logM1_2 = model_tre2(m_batch1).squeeze()\n",
    "        logM2_1 = model_tre2(m_batch2).squeeze()\n",
    "        \n",
    "        logM2_2 = model_tre3(m_batch2).squeeze()\n",
    "        logM3_1 = model_tre3(m_batch3).squeeze()\n",
    "        \n",
    "        logM3_2 = model_tre4(m_batch3).squeeze()\n",
    "        logQ1 = model_tre4(q_batch).squeeze()\n",
    "        \n",
    "        zero_labels = torch.empty(p_batch.shape[0], device=DEVICE).fill_(1)\n",
    "        one_labels = torch.empty(p_batch.shape[0], device=DEVICE).fill_(0)\n",
    "        \n",
    "        loss_tre1 = loss_crit_tre(logP1, zero_labels.clone()) + loss_crit_tre(logM1_1, one_labels.clone())\n",
    "        loss_tre2 = loss_crit_tre(logM1_2, zero_labels.clone()) + loss_crit_tre(logM2_1, one_labels.clone())\n",
    "        loss_tre3 = loss_crit_tre(logM2_2, zero_labels.clone()) + loss_crit_tre(logM3_1, one_labels.clone())\n",
    "        loss_tre4 = loss_crit_tre(logM3_2, zero_labels.clone()) + loss_crit_tre(logQ1, one_labels.clone())\n",
    "        \n",
    "        loss_tre1.backward()\n",
    "        loss_tre2.backward()\n",
    "        loss_tre3.backward()\n",
    "        loss_tre4.backward()\n",
    "        optim_tre1.step()\n",
    "        optim_tre2.step()\n",
    "        optim_tre3.step()\n",
    "        optim_tre4.step()\n",
    "        loss_store.append(loss_tre1.item() + loss_tre2.item() + loss_tre3.item() + loss_tre4.item())\n",
    "        \n",
    "\n",
    "        # Validation/Test\n",
    "        if i % 50 == 0:\n",
    "            model_tre1.eval()\n",
    "            model_tre2.eval()\n",
    "            model_tre3.eval()\n",
    "            model_tre4.eval()\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(test_dl):\n",
    "                    gt_log_ratio_p_q, _, true_kl_p_q = get_gt_ratio_kl(p, q, p_batch, calc_true_kl=True)\n",
    "\n",
    "                    if torch.cuda.is_available():\n",
    "                        p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "                    \n",
    "                    # TRE \n",
    "                    logP1 = model_tre1(p_batch).squeeze()\n",
    "                    logM1_1 = model_tre1(m_batch1).squeeze()\n",
    "\n",
    "                    logM1_2 = model_tre2(m_batch1).squeeze()\n",
    "                    logM2_1 = model_tre2(m_batch2).squeeze()\n",
    "                    logP2 = model_tre2(p_batch).squeeze()\n",
    "\n",
    "                    logM2_2 = model_tre3(m_batch2).squeeze()\n",
    "                    logM3_1 = model_tre3(m_batch3).squeeze()\n",
    "                    logP3 = model_tre3(p_batch).squeeze()\n",
    "\n",
    "                    logM3_2 = model_tre4(m_batch3).squeeze()\n",
    "                    logQ1 = model_tre4(q_batch).squeeze()\n",
    "                    logP4 = model_tre4(p_batch).squeeze()\n",
    "\n",
    "                    zero_labels = torch.empty(p_batch.shape[0], device=DEVICE).fill_(1)\n",
    "                    one_labels = torch.empty(p_batch.shape[0], device=DEVICE).fill_(0)\n",
    "\n",
    "                    test_loss_tre = loss_crit_tre(logP1, zero_labels.clone()) + loss_crit_tre(logM1_1, one_labels.clone()) + \\\n",
    "                                    loss_crit_tre(logM1_2, zero_labels.clone()) + loss_crit_tre(logM2_1, one_labels.clone()) + \\\n",
    "                                    loss_crit_tre(logM2_2, zero_labels.clone()) + loss_crit_tre(logM3_1, one_labels.clone()) + \\\n",
    "                                    loss_crit_tre(logM3_2, zero_labels.clone()) + loss_crit_tre(logQ1, one_labels.clone())\n",
    "                    \n",
    "                    log_ratio_p_q_from_tre = logP1 + logP2 + logP3 + logP4\n",
    "                    \n",
    "                    # Visualize\n",
    "                    line.set_data(range(len(loss_store)), loss_store)\n",
    "                    ax1.set_xlim( 0, len(loss_store) )\n",
    "                    \n",
    "                    scat1.set_offsets(np.vstack([p_batch.cpu().squeeze(), gt_log_ratio_p_q.cpu().detach()]).T)\n",
    "                    scat2.set_offsets(np.vstack([p_batch.cpu().squeeze(), log_ratio_p_q_from_tre.cpu().detach()]).T)\n",
    "\n",
    "                    ax2.set_xlim( -5., 5. )\n",
    "                    ax2.set_ylim( -50, 200)\n",
    "            \n",
    "                    test_loss_store.append(test_loss_tre.item())\n",
    "                    test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "                    ax3.set_xlim( 0, len(test_loss_store) )\n",
    "                    \n",
    "                    clear_output(wait=True)\n",
    "                    display(fig)\n",
    "                    break\n",
    "\n",
    "            model_tre1.train()\n",
    "            model_tre2.train()\n",
    "            model_tre3.train()\n",
    "            model_tre4.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save({\n",
    "    'model1': model_tre1.state_dict(),\n",
    "    'model2': model_tre2.state_dict(),\n",
    "    'model3': model_tre3.state_dict(),\n",
    "    'model4': model_tre4.state_dict(),\n",
    "}, 'models_tre_wm_best.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fig, ax2 = plt.subplots(1, 1,figsize=(6,4))\n",
    "\n",
    "# x, y = np.random.random((2, 500))\n",
    "# scat1 = ax2.scatter(x,y,label='True Log p/q, KL = '+str(np.around(true_kl_p_q.item(),2)),alpha=0.9,s=10.,c='b')\n",
    "# scat2 = ax2.scatter(x,y,label='CoB Log p/q, KL = '+str(np.around(kl_from_cob.item(),2)),alpha=0.9,s=10.,c='r')\n",
    "\n",
    "# scat1.set_offsets(np.vstack([m_batch.cpu().squeeze(), log_ratio_p_q.cpu().detach()]).T)\n",
    "# scat2.set_offsets(np.vstack([m_batch.cpu().squeeze(), log_ratio_p_q_from_cob.cpu().detach()]).T)                    \n",
    "\n",
    "# ax2.set_xlabel(\"Samples\")\n",
    "# ax2.set_ylabel(\"Log Ratio\")\n",
    "# ax2.legend(loc='best')\n",
    "# ax2.set_xlim([-25,25])\n",
    "# ax2.set_ylim([-100000,100000])\n",
    "\n",
    "# plt.tight_layout()\n",
    "# plt.savefig('../plots/cob_mu20.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m1, m2, m3, samples):\n",
    "    p_lp = p.log_prob(samples.cpu())\n",
    "    q_lp = q.log_prob(samples.cpu())\n",
    "    m1_lp = m1.log_prob(samples.cpu())\n",
    "    m2_lp = m2.log_prob(samples.cpu())\n",
    "    m3_lp = m3.log_prob(samples.cpu())\n",
    "    \n",
    "    return p_lp - q_lp, p_lp - m1_lp, m1_lp - m2_lp, m2_lp - m3_lp, m3_lp - q_lp # log p/q, log p/m1, log m1/m2, log m2/m3, logm3/q\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "#######\n",
    "with torch.no_grad():\n",
    "    model_tre1.eval()\n",
    "    model_tre2.eval()\n",
    "    model_tre3.eval()\n",
    "    model_tre4.eval()\n",
    "    for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(test_dl):\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "\n",
    "\n",
    "#         p_batch = torch.from_numpy(np.linspace(-1.5, 1.5, 1000)).unsqueeze(1).to(DEVICE)\n",
    "\n",
    "        logP_M1 = model_tre1(p_batch).cpu()\n",
    "        logM1_M2 = model_tre2(p_batch).cpu()\n",
    "        logM2_M3 = model_tre3(p_batch).cpu()\n",
    "        logM3_Q = model_tre4(p_batch).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_p= logP_M1 + logM1_M2 + logM2_M3 + logM3_Q\n",
    "#         log_ratio_p_m1_from_p = logP_M1\n",
    "        \n",
    "        logP_M1 = model_tre1(m_batch1).cpu()\n",
    "        logM1_M2 = model_tre2(m_batch1).cpu()\n",
    "        logM2_M3 = model_tre3(m_batch1).cpu()\n",
    "        logM3_Q = model_tre4(m_batch1).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_m1 = logP_M1 + logM1_M2 + logM2_M3 + logM3_Q\n",
    "        log_ratio_p_m1_from_m1 = logP_M1\n",
    "        \n",
    "        logP_M1 = model_tre1(m_batch2).cpu()\n",
    "        logM1_M2 = model_tre2(m_batch2).cpu()\n",
    "        logM2_M3 = model_tre3(m_batch2).cpu()\n",
    "        logM3_Q = model_tre4(m_batch2).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_m2 = logP_M1 + logM1_M2 + logM2_M3 + logM3_Q\n",
    "        log_ratio_m1_m2_from_m2 = logM1_M2\n",
    "        \n",
    "        logP_M1 = model_tre1(m_batch3).cpu()\n",
    "        logM1_M2 = model_tre2(m_batch3).cpu()\n",
    "        logM2_M3 = model_tre3(m_batch3).cpu()\n",
    "        logM3_Q = model_tre4(m_batch3).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_m3 = logP_M1 + logM1_M2 + logM2_M3 + logM3_Q\n",
    "        log_ratio_m2_m3_from_m3 = logM2_M3\n",
    "        \n",
    "        logP_M1 = model_tre1(q_batch).cpu()\n",
    "        logM1_M2 = model_tre2(q_batch).cpu()\n",
    "        logM2_M3 = model_tre3(q_batch).cpu()\n",
    "        logM3_Q = model_tre4(q_batch).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_q = logP_M1 + logM1_M2 + logM2_M3 + logM3_Q\n",
    "        log_ratio_m3_q_from_q = logM3_Q\n",
    "        \n",
    "        true_log_ratio_p_q_from_p, _, _, _, _ = get_gt_log_ratios(p, q, m[0], m[1], m[2], p_batch)\n",
    "        true_log_ratio_p_q_from_m1, true_log_ratio_p_m1_from_m1, _, _, _ = get_gt_log_ratios(p, q, m[0], m[1], m[2], m_batch1)\n",
    "        true_log_ratio_p_q_from_m2, _, true_log_ratio_m1_m2_from_m2, _, _ = get_gt_log_ratios(p, q, m[0], m[1], m[2], m_batch2)\n",
    "        true_log_ratio_p_q_from_m3, _, _, true_log_ratio_m2_m3_from_m3, _ = get_gt_log_ratios(p, q, m[0], m[1], m[2], m_batch3)\n",
    "        true_log_ratio_p_q_from_q, _, _, _, true_log_ratio_m3_q_from_q = get_gt_log_ratios(p, q, m[0], m[1], m[2], q_batch)\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1gAAAFgCAYAAACmKdhBAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAABX2ElEQVR4nO3deZxU5ZX/8c8BGpuoLA0uLCKkQYUAInRwAaSHRYiERccFFxaXnyIwmrgnTgSdIa5xxIyCjBjBJCJZIARXFhsFFQHZomjCpiIoSCMIitBwfn/c6u4qeqG7qa2rvu/Xq15973PvU/dUeSzq1L33eczdERERERERkaNXI9EBiIiIiIiIpAoVWCIiIiIiIlGiAktERERERCRKVGCJiIiIiIhEiQosERERERGRKFGBJSIiIiIiEiUqsEREREREJKmZ2Slm9oaZfWhmH5jZLaH2LDOba2b/Cv1tEGo3M3vCzNaZ2Woz6xSvWFVgiYiIiIhIsisAbnP3tsA5wGgzawvcDcx399bA/NA6wE+A1qHHDcDEeAWqAktERERERJKau2919/dDy98Aa4GmwCBgami3qcDg0PIgYJoH3gXqm1njeMRaKxZP2qhRI2/RokUsnlqkVJs2bUI5J/GifJN4U85JvCnnJN6WL1++B/g4rGmyu08ubV8zawGcBSwBTnL3raFNXwAnhZabAp+FddscattKjMWkwGrRogXLli2LxVOLlConJ0c5J3GjfJN4U85JvCnnJN7M7GN3z6nAfscBfwF+5u67zaxom7u7mXkMw6wQXSIoIiIiIiJJz8wyCIqrP7j7X0PNXxZe+hf6uy3U/jlwSlj3ZqG2mKtwgWVmNc1shZnNiWVAIiIiIiIi4Sw4VTUFWOvuj4Vtmg0MDy0PB/4W1j4sNJrgOcCusEsJY6oylwjeQnAzWd0YxSJJ4Ouvv2br1rjkXpVlZmbSrFkzMjIyEh2KiIiIiMRHV2AosMbMVobafgk8CMwws+uAT4DLQtteBi4E1gHfAtfEK9AKFVhm1gzoD4wHbo1pRJJQX331FS1atKBOnTqJDqVU7s6OHTvYvHkzLVu2THQ4IiIiIhIH7r4IsDI29yplfwdGxzSoMlT0EsHHgTuBQ2XtYGY3mNkyM1u2ffv2aMQmCXDgwAEyMzMTHUaZzIyGDRuyb9++RIciIiIiIlLCEQssM/spsM3dl5e3n7tPdvccd8854YQTohagxF/4aCzJKNnjExEREZH0VZFLBLsCA83sQiATqGtmv3f3q2MbWqDF3S8VLW96sH88DikiIiIiIlIlRyyw3P0XwC8AzCwXuD1exZUkVnhxWxUqiEVEREQk3WgeLEmIvLw8LrjgAn7yk5/Qs2dP8vPzEx2SiIiIiMhRq1SB5e557v7TWAUj6cXdeeWVV7jxxhuZPHlyosMRERERETlqOoMlCXPWWWcB0LFjR9atW5fgaEREREREjp4KLEmYVatWFf3Nzs5OcDQiIiIiIkevQhMNi8RCRkYG/fr1Y9++ffzlL39JdDgiIiIiIkdNBZaUKdajAHbs2JH//u//jukxRERERETiSZcIioiIiIiIRInOYElC5Obmkpubm+gwRERERESiSmewREREREREokQFloiIiIiISJSowBIREREREYkSFVgiIiIiIiJRkrKDXLSf2j5ifc3wNQmKpBobV+8o+++KThwiIiIiItVEtSqwWtz9UsR6rOdpktjZv38/l156Kd9//z0/+MEPGDhwICNGjEh0WCIiIiIiR0WXCEpCzJo1iy5duvDqq6/SqFGjRIcjIiIiIhIVKrAkITZs2MBZZ50FQOfOnRMcjYiIiIhIdKjAkoRo2bIlq1atAmDFihUJjkZEREREJDpUYElCDB48mLfffpu+ffvy9ddfJzocEREREZGoqFaDXEicxXAUwGOOOYa///3vADz33HMxO46IiIiIVH9m9izwU2Cbu7cLtWUBLwItgE3AZe6+08wMmABcCHwLjHD39+MVq85giYiIiIhIsnsO6HdY293AfHdvDcwPrQP8BGgdetwATIxTjIDOYEkS0PDsIiIiIlIed3/TzFoc1jwIyA0tTwXygLtC7dPc3YF3zay+mTV2963xiFVnsEREREREJNEamdmysMcNFehzUljR9AVwUmi5KfBZ2H6bQ21xoTNYIiIiIiKSaF+5e05VO7u7m5lHM6Cq0hksERERERGpjr40s8YAob/bQu2fA6eE7dcs1BYXKrAk6WzZsoVOnTqRmZlJQUFBosMRERERkeQ0GxgeWh4O/C2sfZgFzgF2xev+K9AlglKO9lPbH1X/NcPXVKlfVlYW8+fP56KLLjqq44uIiIhIajCzFwgGtGhkZpuBscCDwAwzuw74BLgstPvLBEO0ryMYpv2aeMaqAksS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ffv2XH311bRv354XXniB/v3707lz56JfeRs3bhyLt0RiLNE5d+ONN3LmmWfyu9/9josvvpgOHTqwatUqoPSceuutt+jevTubNm2ie/fuXHLJJXTs2JEXXniBCy64gG7durF3714aNGhAvXrBZ0RGRka63ouQlJI551q2bAlE5kxlPgczMjIA+O677/jRj34UxXdNjkYy51xhzuzZs4cOHToAxZ9zANdeey29e/fm6quvZty4cdF+ayTS/wLHA3PNbKWZTQJw9w+AGQSDV7wKjHb3g+5eAIwBXgPWAjNC+0aFCixJa/n58NRTwd9o6Nq1K6+//nqp2+bMmUPz5s1ZsGABY8aMYdKkSaXu99BDD3HfffexePFi3njjDbZs2cKjjz7KhAkT+Otf/1rqpSvbt2/n/vvvZ+HChTzwwAMAvP766/Tp0weAbdu28cwzz/D000/zyCOP8Pe//53bbruNGTNmROeFS4WlSs7l5+dz//3388orr/CLX/yCP/7xj0yaNIkpU6aUGevcuXOLcnLPnj3MmDGDO++8k+nTp/P6669z4YUX8tprrxXtv2XLFubOncsFF1xQmbdEDpNOOXfw4EH++7//mxtvvBGo3Ofgp59+yrnnnsv//u//0r59+6N6j9JduuTc/v376datG//xH//BOeecAxR/zr333nvUrFmTefPm0bZt2+i8EVImd2/l7qe4e8fQY2TYtvHunu3up7v7K2HtL7v7aaFt46MZjwosSWvTp8OttwZ/o6Fz584AEUPYFl4GvHbtWqZPn05ubi7jx48vc56u9evX06lTJwA6duzIxo0b2bhxIx06dKBmzZq0a9euRJ+GDRvSvHlzjj322KJfbt9++226du0KQKtWrcjMzKRJkya0adOGGjVq0KRJkzJ/6ZPYSZWcO+GEEzjppJNo0qQJ2dnZRflVXk5t2LCh6CxD27Zti/Kw8PnD+3///fcMHz6c//u//6NWLV3NfjTSKeduu+02hg0bRnZ2NlC5z8HmzZvzzjvvcN999/Hoo48e7duU1tIl52rXrs2iRYv405/+xL333gsUf85t2LCBs846KyJ+SR8qsCStDRkCjz0W/I2Gwmuu69Wrx9atWwFYs2YNAKeffjrDhg0jLy+PRYsW8etf/7rU58jOzmb58uUArFixghYtWtCyZUvWrFnDwYMH+eCDkmew8/Pz2bx5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6d27N7169eLDDz8s2q9z584ANG/enPz8fHbs2MHXX39Ns2bNSj3uzp07adGiBRkZGbRs2ZJt27axe/dumjVrxrHHHlvqL6utWrXiuOOOo2nTpuzatQsIJlks/JLQtm1batSoQZMmTSLi3rlzZ5XeGylDmuVcZmYmTZo0oU2bNkX5VVZOHTp0iO+//546deqUeC2l5WR+fj5jxoxhypQpFXrv0pZyrihn3J1rr72W8ePHU79+faByn4NdunRh2bJlXHTRRTz77LNVeTvTg3KuKGeaN2/OO++8w3333cejjz4a8Tm3YcMGzjrrrIhYJTVoFEFJb0OGRP6touOPP57du3eXaDezomV35+GHH+aZZ56hadOmnHbaaUXbwq/9HzhwICNHjmTAgAFlHq9+/fps2rSJpk2bsmHDBk488UTq1q3Lli1bqF+/fqkDUaxbt469e/eya9cu6taty7Zt2yIu+wuP9fC4JYrSKOcqm1PLly+P+JJRXv+CggKuvvpqHn30UU4++eQy4xaUcxTn3L333kvXrl3p2bMnQKU+B/fv30/t2rUBqFu3bswGXEgJyjncnQMHDlCrVi3MjLp161KnTp2Iz7mWLVuyatUqLrzwQlasWME555xTwXdGkl21KbCOb3N3okOQVJSVBaNGVbn7888/z6JFi9i3bx//+Z//ecT9L7roIgYNGkTHjh2Lfj093KWXXsqtt97KxIkTy3ye+++/nyuvvJKDBw8yevRoMjIy+NWvfsWAAQNo1aoVp5xySok+p5xyCtdeey3r1q3jqaeeYu7cufTu3bvCr/Wyyy5j0aJF/Otf/+LOO+9k0KBBFe4rYdIo547k5ptvZs6cOcyePZuRI0eyfft2Lrzwwgr1/dOf/sTSpUu58847AXjggQc499xzKx1DWlDOAcFl0g899BDnnXceM2fO5PLLL6du3boV/hxcuXIld9xxBzVq1CArK4vnn3++UsdPK8o5ALZu3crQoUOpUaMGxxxzDM899xxTpkwp+pwbPHgwl1xyCX379qVBgwaVem5JbhaLX6dzcnJ82bJlR9yvMhMNR6PAiubQ7Mk6D9boST3L3jiuXvwCqapxu6rULScnh/CcW7t2LW3atIlWVHG1c+dOrr/+ev7yl79Uql9BQQG1atVi7969XHDBBSxevDhie7du3Vi0aFHR+muvvca5555bdAPx0ajO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\n",
      "text/plain": [
       "<Figure size 864x360 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [[ax1,ax2,ax3, ax4,ax5], [ax6,ax7,ax8, ax9,ax10]] = plt.subplots(2, 5,figsize=(12,5))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "scat1 = ax6.scatter(p_batch,true_log_ratio_p_q_from_p,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat2 = ax6.scatter(p_batch,log_ratio_p_q_from_p,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat3 = ax7.scatter(m_batch1.cpu(),true_log_ratio_p_q_from_m1,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat4 = ax7.scatter(m_batch1.cpu(),log_ratio_p_q_from_m1,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax8.scatter(m_batch2.cpu(),true_log_ratio_p_q_from_m2,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax8.scatter(m_batch2.cpu(),log_ratio_p_q_from_m2,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat7 = ax9.scatter(m_batch3.cpu(),true_log_ratio_p_q_from_m3,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat8 = ax9.scatter(m_batch3.cpu(),log_ratio_p_q_from_m3,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat9 = ax10.scatter(q_batch.cpu(),true_log_ratio_p_q_from_q,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat10 = ax10.scatter(q_batch.cpu(),log_ratio_p_q_from_q,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "# scat1 = ax1.scatter(p_batch,true_log_ratio_p_q_from_p,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "# scat2 = ax1.scatter(p_batch,log_ratio_p_q_from_p,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "# p_samples = p.sample([1000])\n",
    "# q_samples = q.sample([1000])\n",
    "# m1_samples = m1.sample([1000])\n",
    "# m2_samples = m2.sample([1000])\n",
    "# m3_samples = m3.sample([1000])\n",
    "all_samples = torch.stack([p_samples, q_samples, m1_samples, m2_samples, m3_samples], dim=0)\n",
    "ax1.hist(p_samples.numpy(), label='p', density=True, histtype='stepfilled')\n",
    "ax1.hist(q_samples.numpy(), label='q', density=True, histtype='stepfilled')\n",
    "ax1.hist(m1_samples.numpy(), label='m1', density=True, histtype='stepfilled')\n",
    "ax1.hist(m2_samples.numpy(), label='m2', density=True, histtype='stepfilled')\n",
    "ax1.hist(m3_samples.numpy(), label='m3', density=True, histtype='stepfilled')\n",
    "# ax1.hist(all_samples.numpy(), label='m3', density=True, histtype='stepfilled')\n",
    "# ax1.legend()\n",
    "\n",
    "scat11 = ax2.scatter(m_batch1.cpu(),true_log_ratio_p_m1_from_m1,label='True log p/m1',alpha=0.9,s=1.,c='b')\n",
    "scat12 = ax2.scatter(m_batch1.cpu(),log_ratio_p_m1_from_m1,label='Binary log p/m1',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat13 = ax3.scatter(m_batch2.cpu(),true_log_ratio_m1_m2_from_m2,label='True log m1/m2',alpha=0.9,s=1.,c='b')\n",
    "scat14 = ax3.scatter(m_batch2.cpu(),log_ratio_m1_m2_from_m2,label='Binary log m1/m2',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat15 = ax4.scatter(m_batch3.cpu(),true_log_ratio_m2_m3_from_m3,label='True log m2/m3',alpha=0.9,s=1.,c='b')\n",
    "scat16 = ax4.scatter(m_batch3.cpu(),log_ratio_m2_m3_from_m3,label='Binary log m2/m3',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat17 = ax5.scatter(q_batch.cpu(),true_log_ratio_m3_q_from_q,label='True log m3/q',alpha=0.9,s=1.,c='b')\n",
    "scat18 = ax5.scatter(q_batch.cpu(),log_ratio_m3_q_from_q,label='Binary log m3/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "ylim = [-300, 200]\n",
    "xlim = [-3, 3]\n",
    "# ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='upper right', prop={'size': 8})\n",
    "# ax1.set_xlim(xlim)\n",
    "# ax1.set_ylim(ylim)\n",
    "# ax1.set_title('p')\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\", size=7)\n",
    "ax2.tick_params(axis='y', labelsize=7)\n",
    "ax2.legend(loc='lower left', prop={'size': 8})\n",
    "ax2.set_xlim(xlim)\n",
    "ax2.set_ylim(ylim)\n",
    "# ax2.set_title('m1')\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='lower left', prop={'size': 8})\n",
    "ax3.set_xlim(xlim)\n",
    "ax3.set_ylim(ylim)\n",
    "# ax3.set_title('m2')\n",
    "\n",
    "ax4.set_ylabel(\"Log Ratio\")\n",
    "ax4.legend(loc='lower left', prop={'size': 8})\n",
    "ax4.set_xlim(xlim)\n",
    "ax4.set_ylim(ylim)\n",
    "# ax4.set_title('m3')\n",
    "\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='lower left', prop={'size': 8})\n",
    "ax5.set_xlim(xlim)\n",
    "ax5.set_ylim(ylim)\n",
    "ax5.set_ylabel(\"Log Ratio\", rotation=270, labelpad=10)\n",
    "ax5.yaxis.tick_right()\n",
    "ax5.yaxis.set_label_position(\"right\")\n",
    "# ax5.set_title('q')\n",
    "\n",
    "# ax6.tick_params(axis='y', labelsize=7)\n",
    "ax6.set_xlim(xlim)\n",
    "ax6.set_ylim(ylim)\n",
    "ax6.legend(loc='lower left', prop={'size': 8})\n",
    "ax6.set_xlabel('p')\n",
    "\n",
    "\n",
    "ax7.set_ylabel(\"Log Ratio\")\n",
    "ax7.legend(loc='lower left', prop={'size': 8})\n",
    "ax7.set_xlim(xlim)\n",
    "ax7.set_ylim(ylim)\n",
    "ax7.set_xlabel('p1')\n",
    "\n",
    "ax8.set_ylabel(\"Log Ratio\")\n",
    "ax8.legend(loc='lower left', prop={'size': 8})\n",
    "ax8.set_xlim(xlim)\n",
    "ax8.set_ylim(ylim)\n",
    "ax8.set_xlabel('p2')\n",
    "\n",
    "ax9.set_ylabel(\"Log Ratio\")\n",
    "ax9.legend(loc='lower left', prop={'size': 8})\n",
    "ax9.set_xlim(xlim)\n",
    "ax9.set_ylim(ylim)\n",
    "ax9.set_xlabel('p3')\n",
    "\n",
    "ax10.set_ylabel(\"Log Ratio\")\n",
    "ax10.legend(loc='lower left', prop={'size': 8})\n",
    "ax10.set_xlim(xlim)\n",
    "ax10.set_ylim(ylim)\n",
    "ax10.set_xlabel('q')\n",
    "ax10.set_ylabel(\"Log Ratio\", rotation=270, labelpad=10)\n",
    "ax10.yaxis.tick_right()\n",
    "ax10.yaxis.set_label_position(\"right\")\n",
    "# ax10.set_yticklabels(ax10.get_xticks(), rotation = 45)\n",
    "\n",
    "# ax1.get_xaxis().set_visible(False)\n",
    "# ax2.get_xaxis().set_visible(False)\n",
    "# ax3.get_xaxis().set_visible(False)\n",
    "# ax4.get_xaxis().set_visible(False)\n",
    "# ax2.get_yaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "ax4.get_yaxis().set_visible(False)\n",
    "ax6.get_yaxis().set_visible(False)\n",
    "ax7.get_yaxis().set_visible(False)\n",
    "ax8.get_yaxis().set_visible(False)\n",
    "ax9.get_yaxis().set_visible(False)\n",
    "# ax10.get_yaxis().set_visible(False)\n",
    "\n",
    "# fig.delaxes(ax1)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('1D_demo_tre_K=3_from_logpq.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set up viz\n",
    "fig, ax1 = plt.subplots(1, 1,figsize=(5,5))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "scat1 = ax1.scatter(p_batch,true_log_ratio_p_q,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat2 = ax1.scatter(p_batch,log_ratio_p_q_from_tre,label='Binary log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat3 = ax2.scatter(p_batch,true_log_ratio_p_m1,label='True log p/m1',alpha=0.9,s=1.,c='b')\n",
    "scat4 = ax2.scatter(p_batch,log_ratio_p_m1_from_tre,label='Binary log p/m1',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax3.scatter(p_batch,true_log_ratio_m1_m2,label='True log m1/m2',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax3.scatter(p_batch,log_ratio_m1_m2_from_tre,label='Binary log m1/m2',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat7 = ax4.scatter(p_batch,true_log_ratio_m2_m3,label='True log m2/m3',alpha=0.9,s=1.,c='b')\n",
    "scat8 = ax4.scatter(p_batch,log_ratio_m2_m3_from_tre,label='Binary log m2/m3',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat9 = ax5.scatter(p_batch,true_log_ratio_m3_q,label='True log m3/q',alpha=0.9,s=1.,c='b')\n",
    "scat10 = ax5.scatter(p_batch,log_ratio_m3_q_from_tre,label='Binary log m3/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "ylim = [-100, 100]\n",
    "xlim = [-5, 5]\n",
    "ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='best')\n",
    "ax1.set_xlim(xlim)\n",
    "ax1.set_ylim(ylim)\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim(xlim)\n",
    "ax2.set_ylim(ylim)\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='best')\n",
    "ax3.set_xlim(xlim)\n",
    "ax3.set_ylim(ylim)\n",
    "\n",
    "ax4.set_ylabel(\"Log Ratio\")\n",
    "ax4.legend(loc='upper right')\n",
    "ax4.set_xlim(xlim)\n",
    "ax4.set_ylim(ylim)\n",
    "\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='upper right')\n",
    "ax5.set_xlim(xlim)\n",
    "ax5.set_ylim(ylim)\n",
    "\n",
    "\n",
    "# ax1.get_xaxis().set_visible(False)\n",
    "# ax2.get_xaxis().set_visible(False)\n",
    "# ax3.get_xaxis().set_visible(False)\n",
    "# ax4.get_xaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "ax4.get_yaxis().set_visible(False)\n",
    "ax5.get_yaxis().set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('cob_vs_tre_3waymark_from_m1.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sr",
   "language": "python",
   "name": "sr"
  },
  "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.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
