{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import random\n",
    "from scipy.stats import norm\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from plot_functions import *\n",
    "from utilities import * \n",
    "\n",
    "# For autoreloading the imported moduls\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "device = 'cpu'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the original data\n",
    "ihdp_train = np.load(\"data/IHDP/ihdp_npci_1-1000.train.npz\")\n",
    "device = 'cpu'\n",
    "\n",
    "#Preprocessing so that the fourth variable in the data set is transformed to categorical\n",
    "import copy\n",
    "def transform_x_data(x_data):\n",
    "    new_x_data = copy.deepcopy(x_data)\n",
    "    #Transform the 4th variable into a categorical variable\n",
    "    vals_4th_var = np.unique(x_data[:,3,:])\n",
    "    val_to_idx = dict(zip(vals_4th_var, range(len(vals_4th_var))))\n",
    "    vfunc = np.vectorize(lambda x: val_to_idx[x])\n",
    "    new_x_data[:,3,:] = vfunc(new_x_data[:,3,:])\n",
    "    \n",
    "    #Transform 14th variable to regular {0,1} representation\n",
    "    new_x_data[:,13,:] = new_x_data[:,13,:]-1\n",
    "    \n",
    "    return new_x_data\n",
    "    \n",
    "ihdp_x_train = transform_x_data(ihdp_train['x'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# check the distribution of the variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Check what are the variable distributions like\n",
    "ycf = ihdp_train['ycf'][:,0]\n",
    "yf = ihdp_train['yf'][:,0]\n",
    "x = ihdp_train['x'][:,:,0]\n",
    "t = ihdp_train['t'][:,0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XEVGRio3N1cxMTE6ePCgVq5cqYMHDyomJkY5OTmKjIys1OM5AAAAAACo7Zwy0ZmUlCRJatiwoVq0aFFqmfbt2xcrW1WFhYWaOXOmcnNzdcMNN6hly5ZW1QfAedlypri7u7v27dungQMHlvgHSdu2bTV37lxJ0sqVK0vcwr506VL98ssvuu666/T8888X2/f888/ruuuuU0pKipYvX175iwQAAAAAoJZyykRncnKyJKlZs2ZllgkODi5WtqJOnDihqKgoRUVF6b777lNISIief/55tWzZUu+//75lZmdZ8vLylJmZWewFwPlV90zx0NBQSdK5c+eUmppabF98fLwk6aGHHirR5ri5uenBBx+UJK1Zs8bqOAAAAAAAqC3cHR1AabKysiRJXl5eZZbx9vaWpEonGs+ePatly5YV2xYWFqa33npLN95442WPnzNnjmbOnFmpcwJwvIrOFE9JSVFSUpIGDRpk1fmOHDki6dJzgBs2bFhqLEUz00uL48/lAAAAAADA5Vk1o/PHH3+0VRzV5uabb5ZhGLp48aJOnjyp999/X7m5ubrllls0b968yx4fExOjjIwMyyslJaUaogZqD3u1K/acKf5XhmFYbl2/5557it3anpWVpbS0tHJjKYrjzJkzysnJsSoWAAAAwB5cMR8AoOazKtF544036q677tJHH30kwzBsFZN8fHwkqdw/8LOzsyVJvr6+VTqHyWRS06ZNNXDgQO3Zs0eBgYGaMGGCvv7663KP8/DwkK+vb7EXANuxV7tiz5nifzVz5kzt2bNH3t7eio2NLTWO8mIpiuNysfAoDQAAADiKvcbtAGANqxKdfn5+2rp1q/r3768WLVrohRdesMxUskZISIgklTtbsmhfUVlr+Pn5qV+/frp48aI+/vhjq+sDUHX2aleqy/Lly/Xcc8/Jzc1Nb731lq699lq7nWvOnDkym82WV9FMUAAAAMDeXH3cDqBmsirR+csvv2jJkiUKDQ3ViRMnNGXKFAUHB2v48OHat29flestWsQjLS2tzFtIi+r/88rJ1iiaWXX69Gmb1AegauzVrlTHTPHVq1fr0UcflSS9+eabGjhwYJlxlBdLURyXi4VHaQAAAMBR7DVuBwBrWJXo9PDwsDRie/bs0eDBg2UYhpYtW6Zbb71VnTp10nvvvaf8/PxK1RsUFKQOHTpIklasWFFif0JC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5jxo8+xr06ZNWrx4sR566CH17dvX0eHUeGlpaZIuzWh44YUXNHr0aB06dEgZGRnavHmzrrvuOiUlJalPnz7FZh7COq1atdKePXt0991369SpU/roo4+0Zs0aJScnq2XLlurWrZt8fX0dHWaNR9+K6mTrn7ei+sqrk5/f0tnjd79x48Z69tlntXfvXp05c0aZmZlKTEzU0KFDlZeXp+joaM2ePdv64HFZ9mzbmdFZjmeeeUYff/xxpY/7z3/+o86dO5e5/+TJk7r33nuVnZ2t++67T9HR0daECVTIqFGjtHXrVl1xxRX64IMPVK9ePUeHBCvQPgHlo82zn4yMDD322GO68sor9dprrzk6nFqhaPZmfn6+Bg0aVGwWYY8ePbR582a1atVKBw8e1MqVKzVkyBBHhVqj7Nq1S/3795e7u7tWrFih7t27q169etq1a5cmTpyoxx57TLt27dKSJUscHSoAoAJ69uypnj17FtvWvn17LVu2TO3atdOkSZP03HPP6bHHHmOyhwsj0VmOX375RYcOHar0cdnZ2WXu++233xQREaGff/5Zf/vb3/T+++/LZDJZE2aNUDRVOScnp8wyRZ8r/zmvvHHjxmnJkiXy9/e3zPyAa6N9ck60Zc6BNs++xo8fr5MnT2rVqlUswlJN/nxLV2mzk5s1a6Y+ffroww8/1JYtW0h02kB6err69eun1NRU7dmzR7feeqtl3z333KMbbrhBbdu21VtvvaVHHnlEd955pwOjrdnoW1GdbP3z9uf2OycnR2az2ar6apPq/t0fN26c5syZo9TUVG3atIm+1M7s+f3l1vVyvPvuuzIMo9Kvv/6HoMjp06fVvXt3HT58WD169NDatWsrtaJjTRYSEiKp/FVxi/YVlUXFTJo0SfPmzZOfn582bdpkWYEYro32yTnRljkebZ79xcfHy93dXQsWLFC3bt2KvT799FNJl57z261bNz300EMOjrZmuPrqq0v9urQyv/76a7XEVNOtX79eZ86c0dVXX10syVnkz9u3bNlS3eHVKkX9ZXp6erHbgP+MvhW2YuuxXPPmzS1fnzhxwur6apPqHlfXqVNH1157raRLd7nBvuzZtpPorCZnzpxR9+7d9cMPPygiIkIff/yx6tev7+iwnEbRH6JpaWllPmh23759kqSwsLBqi8vVPfPMM3rllVdkNpu1adOmMlczQ+1G+2Q7tGWORZtXfQoKCrRjx44Sr99//13SpcUXduzYoS+++MLBkdYMYWFhlhn2Za0KW7S96HlWsE5RQqK8WSRFM7POnj1bLTHVVq1atVKDBg0k/a8P/Sv6VtiKrcdyvr6+atmyZbHjrKmvNnHEuLromdhlLY4D27Fn206isxqkpqaqe/fu+u677xQREaF169bJ09PT0WE5laCgIHXo0EGStGLFihL7ExISlJKSIg8PD/Xu3bu6w3NJ0dHRevHFF2U2m7V582bL5wv8Ge2TbdGWOQ5tXvVJT08vc9b4sGHDJEmzZs2SYRjFVptF1TVu3NjyfOXSZg/m5+drx44dkqSOHTtWa2w1VdOmTSVJP/74ozIyMkrsz8/P14EDByRJLVq0qNbYapt69eqpT58+kkrvW3/++Wft3r1bktSvX79qjQ01jz3GckU/l6XVl52drXXr1kmS+vfvX9Wwa6TqHlcfOHBAhw8flkRfWh3s2rYbsKu0tDTjpptuMiQZPXr0MHJzcx0dktOKj483JBne3t7G/v37LdtTU1ONtm3bGpKMSZMmOTBC1/Hss88akgw/Pz/jyy+/dHQ4cFK0T/ZBW1b9aPOcx7BhwwxJxqxZsxwdSo2zZcsWQ5Lh7+9v7Nmzx7I9Pz/feOqppwxJho+Pj/Hbb785MMqa4/Tp04aXl5chyRg4cKCRlZVl2ZeXl2c8+eSThiSjbt26xk8//eTASF1fRdqN/fv3GyaTyahTp47xySefWLbn5OQYERERhiRjwIAB1REuaoGqjOXWrFljtGrVyujevXuJ+k6dOmU0aNDAkGS88cYblu0FBQXGkCFDDElGhw4djIsXL9rvolyULb8XOTk5xvz5843MzMwS59mxY4cREhJiSDI6d+5sn4upgSrSfr/22mtGq1atjCFDhpTYZ6+23WQY/38ZR9hF//79FR8fL5PJpIEDB5Y5U6pv377q27dv9QbnhMaNG6d58+apbt26ioiIkJeXl7Zu3ar09HSFh4dr8+bNzDa7jI8//lj333+/pEsryN14442llgsICNBLL71UnaHBydA+2Q9tWfWhzXMuUVFRWrZsmWbNmqWpU6c6Opwa5/nnn9e0adPk7u6ujh07qnHjxjpw4ICOHz8uT09PrV692jI7AtZ79913NXz4cBUUFOjKK69Uhw4dVLduXe3bt0+nTp2Sm5ubXn/9dY0aNcrRobqUAwcOaPTo0Zb3P/30k1JTUxUUFGSZSStdeh5wkyZNLO9fffVVTZw4USaTSV27dlWjRo20c+dO/frrr2rVqpUSEhJYIA02U9mx3NKlSzV8+HA1b9681LsZVq9erUGDBqmwsFC33nqrQkJClJiYqGPHjikwMFAJCQmWW9xRnK2+F+np6fL395eHh4dCQ0PVrFkzFRQU6PDhwzp48KAkqW3bttq4cWOxtgf/U5X2e8aMGZo5c6a6du2q7du3l6jTLm17pVOjqJSuXbsaki77mj59uqNDdRqrVq0y7rjjDsPX19fw9PQ02rRpY8TGxhp5eXmODs0lvP322xX6mWvevLmjQ4WD0T7ZF21Z9aDNcy7M6LS/jRs3Gr169TIaNmxo1K1b1wgODjaioqKMH374wdGh1UhfffWVERUVZVx99dWGh4eHUa9ePaN58+bGww8/bOzdu9fR4bmkzz77rELtdnJycoljN2/ebPTs2dNo2LCh4eHhYVx77bVGTExMqTO0AGtVZixXNB4pb7yxb98+o3///saVV15paUuefPJJZuJXgC2+F3l5eca0adOMXr16GS1atDB8fHwMd3d348orrzR69OhhLF68mHH6ZVSl/Z4+fbohyejatWuZ9dq6bWdGJwAAAAAAAACXx2JEAAAAAAAAAFweiU4AAAAAAAAALo9EJwAAAAAAAACXR6ITAAAAAAAAgMsj0QkAAAAAAADA5ZHoBAAAAAAAAODySHQCAAAAAAAAcHkkOgEAAAAAAAC4PBKdAAAAAAAAAFweiU4AAAAAAAAALo9EJwAAAAAAAGqE7Oxsubu7y8fHR4WFhY4OB9WMRCcAAABqjE8++UQmk0k33nhjmWXOnj2rRo0aydPTU0ePHq3G6AAAgL19+eWXKiwsVMeOHVWnTh1Hh4NqRqITAAAANUZ4eLjq1KmjH374Qenp6aWW+cc//qEzZ87o2WefVcuWLas3QAAAYFd79uyRJHXq1MnBkcARSHSiVvjnP/8pk8lU7qtBgwZMawcAwMX5+vqqXbt2MgzD8ofOn23fvl1vv/22rr/+ej3zzDMOiBAAANjDO++8I5PJpKlTp0qS/vWvfxX7m3/t2rWODRDVwt3RAQDVITAwUMOGDSt138aNG/Xbb7+pffv2TGsHAKAGuOOOO3TgwAHt3r1bvXr1smzPy8vTyJEjZTKZtHjxYtWrV8+BUQIAAFtq0KCBhg0bplWrVun8+fN68MEHVb9+fcv+jh07OjA6VBeTYRiGo4MAHOVf//qXpk6dquuuu06bN29Ws2bNHB0SAACwUnx8vPr376/u3btr69atlu3//Oc/NWvWLD366KNasmSJAyMEAAD2kJmZKT8/P/n4+Cg9PV0mk8nRIaGakehErfXMM8/oxRdf1M0336yNGzeqUaNGjg4JAADYQGpqqho1aiQvLy+lp6erTp06+v777xUaGiqz2awff/xRDRs2dHSYAADAxj777DN1795d3bp102effebocOAAPKMTtc7Fixc1cuRIvfjiiwoPD9f27dtJcgIAUIMEBATo+uuvV3Z2tr755hsZhqGRI0fqwoULevnll0lyAgBQQ+3fv1+SdMsttzg4EjgKz+hErZKfn6+hQ4dq5cqVuvvuuxUfH68GDRo4OiwAAGBjd9xxh77//nvt3r1biYmJSkhIUEREhIYMGeLo0AAAgJ3s27dPktS+fXsHRwJHYUYnao1z586pb9++WrlypQYMGKB169aR5AQAoIa64447JF16XufkyZPl4eGhhQsXOjgqAABgT8zoBM/oRK2QlZWle++9Vzt27NDw4cP15ptvssI6AAA12KlTpxQUFGR5P3PmTP3zn/90YEQAAMCeMjIy5O/vL19fX/3xxx8sRFRLMaMTNV5aWpq6d++uHTt2aMKECVqyZAlJTgAAarimTZvq6quvliS1atVK0dHRDo4IAADY03fffSfDMHTTTTeR5KzFSHSiRvvll190xx13aN++fZoxY4ZeeeUVGjwAAGqBvLw8FRQUSJIWL16sevXqOTgiAABgT/n5+ZKk3NxcB0cCR2IxItRoQ4YM0ffff69GjRopOTlZUVFRpZZbsGABz+sEAKAGeeGFF3TixAkNHz5cXbt2dXQ4AADAztq1ayd/f3/t379fHTt2VOvWreXm5qaoqCh169bN0eGhmvCMTtRYFy9elNlsVnZ2drnlAgMD9dtvv1VTVAAAwN4+//xz3XXXXQoICNDBgwfl7+/v6JAAAEA12L17t/75z3/qq6++UlpamqRL44IuXbo4ODJUFxKdAAAAcHkHDx7Uv//9b/3+++/69NNP5ebmpi1btvCHDQAAQC3CMzoBAADg8j755BMtWbJEO3bsUHh4uDZu3EiSEwAAoJZhRicAAAAAAAAAl8eMTgAAAAAAAAAuj0QnAAAAAAAAAJdHohMAAAAAAACAyyPRCQAAAAAAAMDlkegEAAAAAAAA4PJIdAIAAAAAAABweSQ6AQAAAAAAALg8Ep0AAAAAAAAAXB6JTgAAAAAAAAAuj0QnAAAAAAAAAJf3/wDPeh2B67vmqAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1600x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,3, figsize=(16,4),gridspec_kw={\"width_ratios\":[1,3,1]})\n",
    "\n",
    "\n",
    "\n",
    "ax[0].hist(x[:, 5], bins=30, density=True)\n",
    "ax[0].set_title(\"$z$ distribution\", fontsize=18)\n",
    "ax[0].set_xlabel('$z$', fontsize=16)\n",
    "ax[0].set_ylabel(\"probability\", fontsize=16)\n",
    "ax[0].tick_params(which='major', axis='both', labelsize=16)\n",
    "\n",
    "ax[1].hist(yf, bins=30, density=True)\n",
    "ax[1].set_title(\"$y$ distribution\", fontsize=18)\n",
    "ax[1].set_xlabel('$y$', fontsize=16)\n",
    "ax[1].set_ylabel(\"probability\", fontsize=16)\n",
    "ax[1].tick_params(which='major', axis='both', labelsize=16)\n",
    "\n",
    "ax[2].hist(t, bins=30, density=True)\n",
    "ax[2].set_title(\"$t$ distribution\", fontsize=18)\n",
    "ax[2].set_xlabel('$t$', fontsize=16)\n",
    "ax[2].set_ylabel(\"probability\", fontsize=16)\n",
    "ax[2].tick_params(which='major', axis='both', labelsize=16)\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines['right'].set_visible(False)\n",
    "    ax[i].spines['top'].set_visible(False)\n",
    "\n",
    "#plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Train a VAE to generate samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0:\n",
      "Epoch loss: 586.9543050130209\n",
      "x: 585.5528855096726, kld: 1.4014200695923396\n",
      "Epoch 1:\n",
      "Epoch loss: 553.4265427362351\n",
      "x: 553.0916195824033, kld: 0.3349244906788781\n",
      "Epoch 2:\n",
      "Epoch loss: 551.9572172619048\n",
      "x: 550.9763474237351, kld: 0.9808772717203412\n",
      "Epoch 3:\n",
      "Epoch loss: 542.2511887323288\n",
      "x: 526.7992437453497, kld: 15.451940564882188\n",
      "Epoch 4:\n",
      "Epoch loss: 551.6707298642114\n",
      "x: 529.8229704357329, kld: 21.84775888352167\n",
      "Epoch 5:\n",
      "Epoch loss: 543.3697655087426\n",
      "x: 523.3331967308408, kld: 20.03657563527425\n",
      "Epoch 6:\n",
      "Epoch loss: 531.1751534598214\n",
      "x: 502.1331496465774, kld: 29.042007991245814\n",
      "Epoch 7:\n",
      "Epoch loss: 528.6631731305804\n",
      "x: 497.8653855096726, kld: 30.79778525942848\n",
      "Epoch 8:\n",
      "Epoch loss: 520.9789530436198\n",
      "x: 489.2783610026042, kld: 31.700591314406623\n",
      "Epoch 9:\n",
      "Epoch loss: 524.398659842355\n",
      "x: 491.8984534853981, kld: 32.500206356956845\n",
      "Epoch 10:\n",
      "Epoch loss: 524.7040071033296\n",
      "x: 491.80199032738096, kld: 32.9020144144694\n",
      "Epoch 11:\n",
      "Epoch loss: 519.7561892554874\n",
      "x: 487.52025059291293, kld: 32.235936664399645\n",
      "Epoch 12:\n",
      "Epoch loss: 521.6578499930246\n",
      "x: 486.77090744745163, kld: 34.88694590613956\n",
      "Epoch 13:\n",
      "Epoch loss: 520.1658862885974\n",
      "x: 483.92764863513764, kld: 36.23823783511207\n",
      "Epoch 14:\n",
      "Epoch loss: 519.8448442731585\n",
      "x: 484.048334030878, kld: 35.79650960649763\n",
      "Epoch 15:\n",
      "Epoch loss: 525.7452189127604\n",
      "x: 493.4406302315848, kld: 32.30458886282785\n",
      "Epoch 16:\n",
      "Epoch loss: 522.3184422084263\n",
      "x: 490.5910339355469, kld: 31.7274109068371\n",
      "Epoch 17:\n",
      "Epoch loss: 519.3574814569382\n",
      "x: 488.6664385114397, kld: 30.69103949410575\n",
      "Epoch 18:\n",
      "Epoch loss: 517.8285551525298\n",
      "x: 481.0421404157366, kld: 36.78641855149042\n",
      "Epoch 19:\n",
      "Epoch loss: 514.757822672526\n",
      "x: 476.95794968377976, kld: 37.79987108139765\n",
      "Epoch 20:\n",
      "Epoch loss: 510.88138979957216\n",
      "x: 474.3274579729353, kld: 36.55393028259277\n",
      "Epoch 21:\n",
      "Epoch loss: 518.1676417759487\n",
      "x: 479.619137718564, kld: 38.54850968860445\n",
      "Epoch 22:\n",
      "Epoch loss: 516.4047284807477\n",
      "x: 480.9108450753348, kld: 35.49388031732468\n",
      "Epoch 23:\n",
      "Epoch loss: 519.8165472121466\n",
      "x: 482.78331356956846, kld: 37.033230372837615\n",
      "Epoch 24:\n",
      "Epoch loss: 517.1657918294271\n",
      "x: 482.2622724260603, kld: 34.903514498756046\n",
      "Epoch 25:\n",
      "Epoch loss: 513.9527922130767\n",
      "x: 477.3576500302269, kld: 36.595137459891184\n",
      "Epoch 26:\n",
      "Epoch loss: 514.9241173153832\n",
      "x: 478.7142116001674, kld: 36.20990753173828\n",
      "Epoch 27:\n",
      "Epoch loss: 515.17626226516\n",
      "x: 476.73275611514134, kld: 38.443505514235724\n",
      "Epoch 28:\n",
      "Epoch loss: 516.6520138695126\n",
      "x: 479.32286435081846, kld: 37.32915424165272\n",
      "Epoch 29:\n",
      "Epoch loss: 513.5104733421689\n",
      "x: 476.95958164760043, kld: 36.55089914231073\n",
      "Epoch 30:\n",
      "Epoch loss: 515.6177062988281\n",
      "x: 476.15977696010043, kld: 39.45792734055292\n",
      "Epoch 31:\n",
      "Epoch loss: 516.2986115955171\n",
      "x: 478.3730977376302, kld: 37.92551730927967\n",
      "Epoch 32:\n",
      "Epoch loss: 517.5870550246466\n",
      "x: 483.3342503138951, kld: 34.252802076793856\n",
      "Epoch 33:\n",
      "Epoch loss: 517.4763895670573\n",
      "x: 478.8628307524182, kld: 38.61355935959589\n",
      "Epoch 34:\n",
      "Epoch loss: 515.0536804199219\n",
      "x: 475.5367591494606, kld: 39.51692018054781\n",
      "Epoch 35:\n",
      "Epoch loss: 520.1346304757254\n",
      "x: 483.6206330798921, kld: 36.513998304094585\n",
      "Epoch 36:\n",
      "Epoch loss: 514.5048319498698\n",
      "x: 479.5572102864583, kld: 34.94762148175921\n",
      "Epoch 37:\n",
      "Epoch loss: 511.1632995605469\n",
      "x: 473.14576503208707, kld: 38.01753525506882\n",
      "Epoch 38:\n",
      "Epoch loss: 516.7539876302084\n",
      "x: 478.41491553896947, kld: 38.33907499767485\n",
      "Epoch 39:\n",
      "Epoch loss: 514.0271591913132\n",
      "x: 477.0034615652902, kld: 37.02369617280506\n",
      "Epoch 40:\n",
      "Epoch loss: 514.5547892252604\n",
      "x: 476.130868094308, kld: 38.42392312912714\n",
      "Epoch 41:\n",
      "Epoch loss: 512.1286097935268\n",
      "x: 473.5849144345238, kld: 38.54369844709124\n",
      "Epoch 42:\n",
      "Epoch loss: 513.8304036458334\n",
      "x: 473.59532383510043, kld: 40.235080900646395\n",
      "Epoch 43:\n",
      "Epoch loss: 510.63384719122024\n",
      "x: 472.00804937453495, kld: 38.62579618181501\n",
      "Epoch 44:\n",
      "Epoch loss: 511.0146222795759\n",
      "x: 471.885733468192, kld: 39.12889008294968\n",
      "Epoch 45:\n",
      "Epoch loss: 513.8940778459821\n",
      "x: 474.60230800083707, kld: 39.2917731148856\n",
      "Epoch 46:\n",
      "Epoch loss: 510.8676016671317\n",
      "x: 472.16591099330356, kld: 38.701690310523624\n",
      "Epoch 47:\n",
      "Epoch loss: 511.43031819661456\n",
      "x: 471.20670718238466, kld: 40.223616827101935\n",
      "Epoch 48:\n",
      "Epoch loss: 511.6305876232329\n",
      "x: 470.8384166899182, kld: 40.79216875348772\n",
      "Epoch 49:\n",
      "Epoch loss: 513.2704395112537\n",
      "x: 473.1114966982887, kld: 40.15894898914156\n",
      "Epoch 50:\n",
      "Epoch loss: 511.74672154017856\n",
      "x: 472.5472673688616, kld: 39.1994514465332\n",
      "Epoch 51:\n",
      "Epoch loss: 512.7675548735119\n",
      "x: 471.9872770763579, kld: 40.780276888892764\n",
      "Epoch 52:\n",
      "Epoch loss: 508.4305129278274\n",
      "x: 470.7874988374256, kld: 37.64301454453241\n",
      "Epoch 53:\n",
      "Epoch loss: 511.5748232886905\n",
      "x: 471.86629667736236, kld: 39.70852770124163\n",
      "Epoch 54:\n",
      "Epoch loss: 511.9514625186012\n",
      "x: 472.50743902297245, kld: 39.44402385893322\n",
      "Epoch 55:\n",
      "Epoch loss: 512.5331144787017\n",
      "x: 472.04549298967635, kld: 40.48762003580729\n",
      "Epoch 56:\n",
      "Epoch loss: 510.3919648670015\n",
      "x: 470.7090366908482, kld: 39.68292981102353\n",
      "Epoch 57:\n",
      "Epoch loss: 510.5883527483259\n",
      "x: 470.52867344447543, kld: 40.05967512584868\n",
      "Epoch 58:\n",
      "Epoch loss: 512.7031860351562\n",
      "x: 473.3756161644345, kld: 39.32756878080822\n",
      "Epoch 59:\n",
      "Epoch loss: 513.8345918201264\n",
      "x: 475.0413600376674, kld: 38.793229239327566\n",
      "Epoch 60:\n",
      "Epoch loss: 510.24012393043154\n",
      "x: 470.5310247512091, kld: 39.70909763517834\n",
      "Epoch 61:\n",
      "Epoch loss: 510.9610973539807\n",
      "x: 472.35690162295384, kld: 38.60419718424479\n",
      "Epoch 62:\n",
      "Epoch loss: 511.15236409505206\n",
      "x: 470.35020810081846, kld: 40.80215563092913\n",
      "Epoch 63:\n",
      "Epoch loss: 514.0726550874256\n",
      "x: 474.2556370326451, kld: 39.81702096121652\n",
      "Epoch 64:\n",
      "Epoch loss: 510.17691911969865\n",
      "x: 473.1361578078497, kld: 37.040758768717446\n",
      "Epoch 65:\n",
      "Epoch loss: 510.32886468796505\n",
      "x: 470.5382763090588, kld: 39.79058474586124\n",
      "Epoch 66:\n",
      "Epoch loss: 512.8657546270462\n",
      "x: 470.7330017089844, kld: 42.13275982084728\n",
      "Epoch 67:\n",
      "Epoch loss: 513.0985746837798\n",
      "x: 471.79601905459447, kld: 41.30255490257626\n",
      "Epoch 68:\n",
      "Epoch loss: 509.7219456263951\n",
      "x: 468.02239699590774, kld: 41.699548812139604\n",
      "Epoch 69:\n",
      "Epoch loss: 510.27168927873885\n",
      "x: 469.18880063011534, kld: 41.08289028349377\n",
      "Epoch 70:\n",
      "Epoch loss: 510.5250302269345\n",
      "x: 469.11034429640995, kld: 41.41469555809384\n",
      "Epoch 71:\n",
      "Epoch loss: 509.87562052408856\n",
      "x: 470.8037298293341, kld: 39.07189632597424\n",
      "Epoch 72:\n",
      "Epoch loss: 508.66976056780135\n",
      "x: 468.9806402297247, kld: 39.6891241527739\n",
      "Epoch 73:\n",
      "Epoch loss: 510.32560657319567\n",
      "x: 468.80436052594865, kld: 41.521249316987536\n",
      "Epoch 74:\n",
      "Epoch loss: 510.01388113839283\n",
      "x: 468.99399820963544, kld: 41.01988510858445\n",
      "Epoch 75:\n",
      "Epoch loss: 512.7009088425409\n",
      "x: 470.51359194800966, kld: 42.18732107253302\n",
      "Epoch 76:\n",
      "Epoch loss: 510.3580801827567\n",
      "x: 470.36765834263394, kld: 39.99041620890299\n",
      "Epoch 77:\n",
      "Epoch loss: 520.0406959170386\n",
      "x: 483.1009986514137, kld: 36.9396976289295\n",
      "Epoch 78:\n",
      "Epoch loss: 516.0761253720239\n",
      "x: 480.2488040015811, kld: 35.8273191906157\n",
      "Epoch 79:\n",
      "Epoch loss: 511.3074471609933\n",
      "x: 474.9203854515439, kld: 36.38705834888277\n",
      "Epoch 80:\n",
      "Epoch loss: 514.8223353794643\n",
      "x: 476.7175452822731, kld: 38.104794729323615\n",
      "Epoch 81:\n",
      "Epoch loss: 513.3003525506882\n",
      "x: 471.73920259021577, kld: 41.56115395682199\n",
      "Epoch 82:\n",
      "Epoch loss: 512.553726922898\n",
      "x: 472.541745140439, kld: 40.01198014758882\n",
      "Epoch 83:\n",
      "Epoch loss: 510.9049551827567\n",
      "x: 471.3772205171131, kld: 39.52773684547061\n",
      "Epoch 84:\n",
      "Epoch loss: 510.37800670805433\n",
      "x: 472.75912039620533, kld: 37.6188903990246\n",
      "Epoch 85:\n",
      "Epoch loss: 511.3700663248698\n",
      "x: 470.15946306501115, kld: 41.21060453142439\n",
      "Epoch 86:\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[26], line 15\u001b[0m\n\u001b[1;32m     13\u001b[0m x_mode\u001b[38;5;241m=\u001b[39m[\u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m3\u001b[39m\u001b[38;5;241m+\u001b[39m[\u001b[38;5;241m4\u001b[39m]\u001b[38;5;241m+\u001b[39m[\u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m2\u001b[39m\u001b[38;5;241m+\u001b[39m[\u001b[38;5;241m2\u001b[39m]\u001b[38;5;241m*\u001b[39m(x_dim\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m6\u001b[39m)\n\u001b[1;32m     14\u001b[0m \u001b[38;5;66;03m#Remove the following comments to run\u001b[39;00m\n\u001b[0;32m---> 15\u001b[0m proxymodel, losses \u001b[38;5;241m=\u001b[39m \u001b[43mtrain_datagenerator\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdevice\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mplot_curves\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mprint_logs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     16\u001b[0m \u001b[43m              \u001b[49m\u001b[43mdataloader\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnum_epochs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlr_start\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlr_end\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_dim\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mz_dim\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     17\u001b[0m \u001b[43m              \u001b[49m\u001b[43mp_x_z_nn_layers\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m3\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mp_x_z_nn_width\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m30\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m     18\u001b[0m \u001b[43m              \u001b[49m\u001b[43mq_z_nn_layers\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m3\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mq_z_nn_width\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m30\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_mode\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mx_mode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     19\u001b[0m savemodel(proxymodel, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mproxygenerator(zdim=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;241m+\u001b[39m\u001b[38;5;28mstr\u001b[39m(z_dim)\u001b[38;5;241m+\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m)\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "File \u001b[0;32m~/Desktop/PhD/TL/Application of Transportability on Bandit with Unobservable Confounder/code/transportability-bandit/CEVAE_transfer/datagenVAE.py:279\u001b[0m, in \u001b[0;36mtrain_datagenerator\u001b[0;34m(device, plot_curves, print_logs, train_loader, num_epochs, lr_start, lr_end, x_dim, z_dim, p_x_z_nn_layers, p_x_z_nn_width, q_z_nn_layers, q_z_nn_width, x_mode)\u001b[0m\n\u001b[1;32m    277\u001b[0m x \u001b[38;5;241m=\u001b[39m data\u001b[38;5;241m.\u001b[39mto(device)\n\u001b[1;32m    278\u001b[0m z_mean, z_std, x_pred, x_std \u001b[38;5;241m=\u001b[39m model(x)\n\u001b[0;32m--> 279\u001b[0m kld, x_loss \u001b[38;5;241m=\u001b[39m \u001b[43mget_losses\u001b[49m\u001b[43m(\u001b[49m\u001b[43mz_mean\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mz_std\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_pred\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx_std\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    280\u001b[0m loss \u001b[38;5;241m=\u001b[39m kld \u001b[38;5;241m+\u001b[39m x_loss\n\u001b[1;32m    281\u001b[0m optimizer\u001b[38;5;241m.\u001b[39mzero_grad()\n",
      "File \u001b[0;32m~/Desktop/PhD/TL/Application of Transportability on Bandit with Unobservable Confounder/code/transportability-bandit/CEVAE_transfer/datagenVAE.py:262\u001b[0m, in \u001b[0;36mtrain_datagenerator.<locals>.get_losses\u001b[0;34m(z_mean, z_std, x_pred, x_std, x)\u001b[0m\n\u001b[1;32m    260\u001b[0m     pred_i \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    261\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m mode\u001b[38;5;241m==\u001b[39m\u001b[38;5;241m2\u001b[39m:\n\u001b[0;32m--> 262\u001b[0m     x_loss \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m-\u001b[39m\u001b[43mdist\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mBernoulli\u001b[49m\u001b[43m(\u001b[49m\u001b[43mlogits\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mx_pred\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[43m,\u001b[49m\u001b[43mpred_i\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlog_prob\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[43m,\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39msum()\n\u001b[1;32m    263\u001b[0m     pred_i \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    264\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n",
      "File \u001b[0;32m~/Library/Python/3.9/lib/python/site-packages/torch/distributions/bernoulli.py:111\u001b[0m, in \u001b[0;36mBernoulli.log_prob\u001b[0;34m(self, value)\u001b[0m\n\u001b[1;32m    109\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_validate_sample(value)\n\u001b[1;32m    110\u001b[0m logits, value \u001b[38;5;241m=\u001b[39m broadcast_all(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mlogits, value)\n\u001b[0;32m--> 111\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;241m-\u001b[39m\u001b[43mbinary_cross_entropy_with_logits\u001b[49m\u001b[43m(\u001b[49m\u001b[43mlogits\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mvalue\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mreduction\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mnone\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/Library/Python/3.9/lib/python/site-packages/torch/nn/functional.py:3130\u001b[0m, in \u001b[0;36mbinary_cross_entropy_with_logits\u001b[0;34m(input, target, weight, size_average, reduce, reduction, pos_weight)\u001b[0m\n\u001b[1;32m   3125\u001b[0m         weight \u001b[38;5;241m=\u001b[39m weight\u001b[38;5;241m.\u001b[39mexpand(new_size)\n\u001b[1;32m   3127\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m torch\u001b[38;5;241m.\u001b[39m_C\u001b[38;5;241m.\u001b[39m_nn\u001b[38;5;241m.\u001b[39mbinary_cross_entropy(\u001b[38;5;28minput\u001b[39m, target, weight, reduction_enum)\n\u001b[0;32m-> 3130\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mbinary_cross_entropy_with_logits\u001b[39m(\n\u001b[1;32m   3131\u001b[0m     \u001b[38;5;28minput\u001b[39m: Tensor,\n\u001b[1;32m   3132\u001b[0m     target: Tensor,\n\u001b[1;32m   3133\u001b[0m     weight: Optional[Tensor] \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m   3134\u001b[0m     size_average: Optional[\u001b[38;5;28mbool\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m   3135\u001b[0m     reduce: Optional[\u001b[38;5;28mbool\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m   3136\u001b[0m     reduction: \u001b[38;5;28mstr\u001b[39m \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mmean\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[1;32m   3137\u001b[0m     pos_weight: Optional[Tensor] \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m   3138\u001b[0m ) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m Tensor:\n\u001b[1;32m   3139\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124mr\u001b[39m\u001b[38;5;124;03m\"\"\"Calculate Binary Cross Entropy between target and input logits.\u001b[39;00m\n\u001b[1;32m   3140\u001b[0m \n\u001b[1;32m   3141\u001b[0m \u001b[38;5;124;03m    See :class:`~torch.nn.BCEWithLogitsLoss` for details.\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   3177\u001b[0m \u001b[38;5;124;03m         >>> loss.backward()\u001b[39;00m\n\u001b[1;32m   3178\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[1;32m   3179\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m has_torch_function_variadic(\u001b[38;5;28minput\u001b[39m, target, weight, pos_weight):\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "# NOTE: This cell is not necessary to run, a pretrained model is provided\n",
    "from datagenVAE import GenericDataset, train_datagenerator, savemodel, loadmodel, trainZtoTmodel, dataGeneratorVAE, FullyConnected, DataLoader\n",
    "dataset = GenericDataset(ihdp_x_train[:,:,0])\n",
    "dataloader = DataLoader(dataset, shuffle=True, batch_size=32)\n",
    "device='cpu'\n",
    "plot_curves=False\n",
    "print_logs=True\n",
    "num_epochs=400\n",
    "lr_start=0.02\n",
    "lr_end=0.001\n",
    "x_dim=ihdp_x_train.shape[1]\n",
    "z_dim=1\n",
    "x_mode=[0]*3+[4]+[0]*2+[2]*(x_dim-6)\n",
    "#Remove the following comments to run\n",
    "proxymodel, losses = train_datagenerator(device, plot_curves, print_logs,\n",
    "              dataloader, num_epochs, lr_start, lr_end, x_dim, z_dim,\n",
    "              p_x_z_nn_layers=3, p_x_z_nn_width=30,\n",
    "              q_z_nn_layers=3, q_z_nn_width=30, x_mode=x_mode)\n",
    "savemodel(proxymodel, \"proxygenerator(zdim=\"+str(z_dim)+\")\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generate data by pretrained models"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load the pretrained generative models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from datagenVAE import GenericDataset, train_datagenerator, savemodel, loadmodel, trainZtoTmodel, dataGeneratorVAE, FullyConnected\n",
    "x_dim=x.shape[1]\n",
    "z_dim=1\n",
    "device='cpu'\n",
    "x_mode=[0]*3+[4]+[0]*2+[2]*(x_dim-6)\n",
    "proxymodel = loadmodel(name=\"proxygenerator(zdim=1)\", modeltype=dataGeneratorVAE, args=[x_dim, z_dim, device, 3, 30, 3, 30, x_mode])\n",
    "model_zt = loadmodel(\"ztotgenerator\", modeltype=FullyConnected, args=[[1]+[10]*3+[1]])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generte data "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from datagenVAE import generatedata\n",
    "from cevaetools import create_dfs_datasets\n",
    "main_folder = \"ihdpdata_latent_z\"\n",
    "sub_folder = \"ATE1samplesize20000times10\"\n",
    "ATE = 1\n",
    "zvar_index = 0\n",
    "dataparameters = [20000, proxymodel, model_zt, ATE, zvar_index]\n",
    "generate_df = generatedata\n",
    "param_times=30"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Creation of the directory './data/ihdpdata_latent_z/ATE1samplesize20000times10/ failed. Trying to empty the same folder.\n"
     ]
    }
   ],
   "source": [
    "dfs, datasets = create_dfs_datasets(generate_df, [dataparameters], param_times=10, repeat=True, \n",
    "                    main_folder=main_folder, sub_folder=sub_folder, labels=[\"df20000\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load the generated data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "main_folder = \"ihdpdata_latent_z\"\n",
    "sub_folder = \"ATE1samplesize20000times10\"\n",
    "param_times=30\n",
    "\n",
    "dfs, datasets = load_dfs(main_folder, sub_folder, param_times)\n",
    "data = dfs['df20000'][1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>z</th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "      <th>x6</th>\n",
       "      <th>x7</th>\n",
       "      <th>x8</th>\n",
       "      <th>...</th>\n",
       "      <th>x17</th>\n",
       "      <th>x18</th>\n",
       "      <th>x19</th>\n",
       "      <th>x20</th>\n",
       "      <th>x21</th>\n",
       "      <th>x22</th>\n",
       "      <th>x23</th>\n",
       "      <th>x24</th>\n",
       "      <th>t</th>\n",
       "      <th>y</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.913261</td>\n",
       "      <td>-1.831477</td>\n",
       "      <td>-1.372844</td>\n",
       "      <td>3.322415</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.966596</td>\n",
       "      <td>-0.125728</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.076538</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.013995</td>\n",
       "      <td>-2.196929</td>\n",
       "      <td>-2.115721</td>\n",
       "      <td>2.299220</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.335167</td>\n",
       "      <td>1.038736</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2.580596</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-0.739546</td>\n",
       "      <td>0.464677</td>\n",
       "      <td>0.523929</td>\n",
       "      <td>-0.234220</td>\n",
       "      <td>2.0</td>\n",
       "      <td>-1.037147</td>\n",
       "      <td>0.177296</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.756500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.664744</td>\n",
       "      <td>-1.463216</td>\n",
       "      <td>-2.647700</td>\n",
       "      <td>1.075451</td>\n",
       "      <td>3.0</td>\n",
       "      <td>-0.369426</td>\n",
       "      <td>0.862808</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.084790</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.634887</td>\n",
       "      <td>-1.797094</td>\n",
       "      <td>-1.423108</td>\n",
       "      <td>0.578969</td>\n",
       "      <td>3.0</td>\n",
       "      <td>-1.661022</td>\n",
       "      <td>0.555368</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.191633</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 28 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "          z        x0        x1        x2   x3        x4        x5   x6   x7  \\\n",
       "0  1.913261 -1.831477 -1.372844  3.322415  2.0  0.966596 -0.125728  0.0  0.0   \n",
       "1  2.013995 -2.196929 -2.115721  2.299220  0.0 -0.335167  1.038736  1.0  0.0   \n",
       "2 -0.739546  0.464677  0.523929 -0.234220  2.0 -1.037147  0.177296  1.0  1.0   \n",
       "3  1.664744 -1.463216 -2.647700  1.075451  3.0 -0.369426  0.862808  0.0  0.0   \n",
       "4  1.634887 -1.797094 -1.423108  0.578969  3.0 -1.661022  0.555368  1.0  0.0   \n",
       "\n",
       "    x8  ...  x17  x18  x19  x20  x21  x22  x23  x24    t         y  \n",
       "0  1.0  ...  1.0  0.0  1.0  0.0  0.0  0.0  0.0  1.0  0.0 -1.076538  \n",
       "1  0.0  ...  1.0  1.0  0.0  0.0  1.0  0.0  1.0  0.0  1.0  2.580596  \n",
       "2  0.0  ...  1.0  1.0  0.0  0.0  0.0  0.0  0.0  0.0  0.0  1.756500  \n",
       "3  0.0  ...  1.0  0.0  0.0  0.0  1.0  0.0  0.0  0.0  1.0  1.084790  \n",
       "4  0.0  ...  1.0  0.0  0.0  0.0  0.0  0.0  0.0  0.0  0.0 -0.191633  \n",
       "\n",
       "[5 rows x 28 columns]"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "z = data['z']\n",
    "t = data['t']\n",
    "y = data['y']\n",
    "y_t0 = data.loc[data['t']==0, 'y']\n",
    "y_t1 = data.loc[data['t']==1, 'y']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HjhwQNL52ReVCQ0NLVPWVoZhWO4Pe9ttt8nX19eu+gAAAADAXfFdGgA4jlXJDABA7ZSfny9J8vPzq7SMv7+/pPNThu0xbdo0ffXVV/L399fMmTMvWL6oqEhFRUWW5/aeHwAAAAAAAJ6HlYQAADVm+fLlevbZZ+Xl5aU333xTl1566QWPmTFjhsxms+VROkMEAAAAAAAAdYfDZmYUFhZq//79ysvLU2Vrit94442OOh1QLSyKidrMke1uQECApc7KFBQUSJLNi26vXLlSDz74oCTp9ddfV//+/at13KRJkzR+/HjL87y8PBIaAAAAADwe36UBgHXsTmb88ssvevzxx/XZZ5/p3LlzlZYzmUwqKSmx93QAUOc5o90NCwuTJGVmZlZapnRfaVlrfPTRRxo0aJDOnTunRYsWWZIa1eHr68u6GgAAAABqDb5LAwDb2JXMOHr0qLp27arjx4/r4osvVklJiY4dO6auXbtq3759OnHihEwmk7p27ar69es7KmYAqLOc1e5GRERIkrKysnTgwAG1adOmXJnU1FRJUqdOnayKedWqVbrnnnt09uxZLViwQI888ohVxwMAAABAbcF3aQBgO7uSGTNnztTx48c1efJkPffccxo6dKiWL1+uL7/8UpK0bt06jRgxQg0bNtSnn35q0zlWrlypefPm6dtvv9WZM2fUrl073XfffRo3bpxVjXp6ero+++wzbdy4UT/88IOys7Pl7++vq666Svfcc4+GDRvGhwQAt+esdrdly5bq0qWLUlJStGLFCj311FNl9icnJyszM1O+vr7q3bt3tetdvXq1BgwYoJKSEi1YsEDDhw+v9rEAAMCzOfuWrxkz+zi1fgBwhpr4Lg0Aaiu7FgBft26dWrRooWnTplW4/x//+Ic+/fRTffHFF3rppZesrn/s2LEaMGCAvvzyS1177bW65ZZbdOjQIU2cOFHR0dE6depUteopKSlRp06dNHnyZH3zzTe68sordffdd+uqq67SV199pVGjRqlbt27KycmxOkYAqEnObHcnT54s6XznOi0tzbI9KytLI0eOlCSNGjVKZrPZsi8pKUkdOnRQTExMufrWrl2ru+++WyUlJVq4cCGJDAAAAAB1nrO/SwOA2syuZMahQ4d0zTXXqF69eucr8zpf3Z/v59e+fXt1795dK1assKruVatWKTExUf7+/tqxY4fW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T05OVmZmpnx9fdW7d+9q1XnnnXdWWl9BQYFWr14tSbrrrrtsDbtGxcXFafbs2TKbzdqwYYPl9XK0jz/+WCdPnpTJZGJgCKBKffv2lWEYlT5KZWZmyjAMTZ061XXBwm3UdD8H7skZfT/UDTXVJ4bnysnJqbRvMmTIEEnS9OnTZRiGMjIyXBssYAW+N6ndarpvlJaWpr1790py7feBsI2Pj4/69OkjqeL3y8GDB7V9+3ZJ//t/Xm0GYIWsrCzj6quvNiQZvXr1Mk6ePFntY6Ojo4327dsbH330UZntq1atMlJTU8uVz8vLMx5//HFDkiHJ2LBhg93x2yMpKcmQZPj7+xs7d+60bD9x4oQRHh5uSDImTJhQ5piPPvrIaN++vREdHV2uviNHjhiNGjUyJBmvvfaaZXtJSYkxePBgQ5LRpUsX49y5c867KAd56qmnDElGUFCQ8c0331TrmFdffdVo3769MXjw4DLbDx48aLz11lvGqVOnyh2TlJRkNG7c2JBk3H///Q6JHUDdVfr5kpmZ6epQ4Cbs6eeg9rGl74e6zZY+MfBnQ4YMMSQZ06dPd3UogE343qR2c+Tft7Cw0Jg7d66Rl5dX7jxbt241wsLCDElGt27dnHMxuKDqfCZV9t2eYRjGzp07DZPJZNSrV8/49NNPLdsLCwuNmJgYQ5LRr18/q+PiNlOwysMPP6zvvvtOJpNJjRs31ogRIyos17dv33L3J//555918OBByy2CSn3++edKTExUq1atFB4erqCgIP3666/673//qz/++EPe3t568cUX1atXL2ddVrX07dtXY8aM0Zw5c3T99dcrJiZGfn5+2rRpk3JychQVFaXp06eXOSY3N1d79uzR6dOny9V38cUXa+nSpbr33ns1bNgwLV68WGFhYUpJSdEvv/yikJAQrVixwu0XGv3444/1/PPPS5LatWunefPmVViuSZMmevHFFy3PT5w4oT179qhZs2ZlymVnZ2vw4MEaMWKEIiIi1KJFC506dUq7du3Svn37JEk33XSTFixY4KQrAgDUVfb0c1D72NL3Q91la58YAGoTvjep3Rz59z1z5oxGjRqlCRMmKCIiQq1atVJJSYn27t2rH374QZIUHh6u999/v8aur65LS0vTyJEjLc9//vlnSdKiRYv0ySefWLYnJSWpefPmkir/bk86f/uol156SePHj1fv3r3Vo0cPNW3aVNu2bdPRo0fVvn17LVy40Oo4SWbAKtnZ2ZIkwzCqbFDCwsKqPcjv27evCgoKlJaWptTUVGVnZ8vHx0etWrXSwIEDNXLkyArvjegKiYmJioqK0rx587R9+3YVFxerbdu2iouL07hx4+Tj42NVff3799cll1yihIQEbdu2Tenp6WrevLkee+wxxcfHKyQkxElX4jil7wnp/P3uSu9591etW7eu1sAtNDRUEydOVEpKivbv36+0tDSdOXNGTZo00W233aZBgwZp4MCB8vLiLnkAAMdyRj8Hns3RfT/UXo7uEwOAp+J7k9rNUX/fRo0aKT4+Xqmpqdq9e7d+/PFHnTp1SsHBwerVq5f69++v2NhY+lo1KC8vTzt27Ci3/a9rUBYVFVW7znHjxik8PFwvvfSSvvnmGxUWFqpVq1aaNGmSJk2aZNN6KCbD+NNNowEAAAAAAAAAANwMP20GAAAAAAAAAABujWQGAAAAAAAAAABwayQzAAAAAAAAAACAWyOZAQAAAAAAAAAA3BrJDAAAAAAAAAAA4NZIZgAAAAAAAAAAALdGMgMAAAAAAAAAALg1khkAAAAAAAAAAMCtkcwAAAAAAAAAAABujWQGAAAAAAAAAABwayQzAAAAAAAAAAAOV1BQIG9vbwUEBOjs2bOuDgcejmQGAAAAAI/26aefymQy6corr6y0THZ2tpo2baqGDRtq//79NRgdAABA3fXNN9/o7Nmzuvbaa1WvXj1XhwMPRzIDAAAAgEeLiopSvXr19NNPPyknJ6fCMv/85z91/PhxPfXUU2rXrl3NBggAAFBHffXVV5Kkrl27ujgS1AYkMwA7Pf300zKZTFU+GjVqxFQ6AAAAJwkMDFTHjh1lGIZlwPxnW7Zs0ZIlS3T55ZfrySefdEGEAAAAdctbb70lk8mkKVOmSJKef/75Mt+VrVq1yrUBwiN5uzoAwNOFhIRoyJAhFe5bt26dfvvtN0VGRjKVDgAAwIluvPFGpaWlafv27br11lst24uKijR8+HCZTCYtWrRIPj4+LowSAACgbmjUqJGGDBmi9957T6dPn9bAgQPVoEEDy/5rr73WhdHBU5kMwzBcHQRQGz3//POaMmWKLrvsMm3YsEGtWrVydUgAAAC1VlJSku666y5FR0dr06ZNlu1PP/20pk+frgcffFCLFy92YYQAAAB1S15enoKCghQQEKCcnByZTCZXhwQPRzIDcIInn3xSs2fP1jXXXKN169apadOmrg4JAACgVjtx4oSaNm0qPz8/5eTkqF69etq1a5ciIiJkNpu1e/duNW7c2NVhAgAA1Bmff/65oqOj1bNnT33++eeuDge1AGtmAA507tw5DR8+XLNnz1ZUVJS2bNlCIgMAAKAGNGnSRJdffrkKCgr03XffyTAMDR8+XGfOnNFLL71EIgMAAKCG7dy5U5LUuXNnF0eC2oI1MwAHKS4u1gMPPKB3331Xf//735WUlKRGjRq5OiwAAIA648Ybb9SuXbu0fft2paSkKDk5WTExMRo8eLCrQwMAAKhzUlNTJUmRkZEujgS1BTMzAAc4deqU+vbtq3fffVf9+vXT6tWrSWQAAADUsBtvvFHS+fUzJk6cKF9fXy1YsMDFUQEAANRNzMyAo7FmBmCn/Px83X777dq6dauGDh2q119/XfXq1XN1WAAAAHXOkSNH1LJlS8vzadOm6emnn3ZhRAAAAHVTbm6ugoODFRgYqD/++IPFv+EQzMwA7JCVlaXo6Ght3bpV48aN0+LFi0lkAAAAuEiLFi10ySWXSJLat2+vuLg4F0cEAABQN/34448yDENXX301iQw4DMkMwEa//vqrbrzxRqWmpmrq1Kl6+eWXaZwBAABcqKioSCUlJZKkRYsWycfHx8URAQAA1E3FxcWSpJMnT7o4EtQmLAAO2Gjw4MHatWuXmjZtqgMHDig2NrbCcvPnz2f9DAAAgBrwwgsv6NChQxo6dKh69Ojh6nAAAADqrI4dOyo4OFg7d+7Utddeqw4dOsjLy0uxsbHq2bOnq8ODh2LNDMAG586dk9lsVkFBQZXlQkJC9Ntvv9VQVAAAAHXXF198oZtvvllNmjTRDz/8oODgYFeHBAAAUKdt375dTz/9tP773/8qKytL0vk+W/fu3V0cGTwVyQwAAAAAHumHH37Qv/71L/3+++/67LPP5OXlpY0bNzJABgAAAGoh1swAAAAA4JE+/fRTLV68WFu3blVUVJTWrVtHIgMAAACopZiZAQAAAAAAAAAA3BozMwAAAAAAAAAAgFsjmQEAAAAAAAAAANwayQwAAAAAAAAAAODWSGYAAAAAAAAAAAC3RjIDAAAAAAAAAAC4NZIZAAAAAAAAAADArZHMAAAAAAAAAAAAbo1kBgAAAAAAAAAAcGskMwAAAAAAAAAAgFsjmQEAAAAAAAAAANwayQwAAAAAAAAAAODW/h8+cxKVlE/+/gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1600x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,3, figsize=(16,4),gridspec_kw={\"width_ratios\":[1,3,1]})\n",
    "\n",
    "\n",
    "ax[0].hist(z, bins=50, density=True)\n",
    "ax[0].set_title(\"$z$ distribution\", fontsize=18)\n",
    "ax[0].set_xlabel('$z$', fontsize=16)\n",
    "ax[0].set_ylabel(\"probability\", fontsize=16)\n",
    "ax[0].tick_params(which='major', axis='both', labelsize=16)\n",
    "\n",
    "ax[1].hist(y, bins=30, density=True)\n",
    "ax[1].set_title(\"$y$ distribution\", fontsize=18)\n",
    "ax[1].set_xlabel('$y$', fontsize=16)\n",
    "ax[1].set_ylabel(\"probability\", fontsize=16)\n",
    "ax[1].tick_params(which='major', axis='both', labelsize=16)\n",
    "\n",
    "ax[2].hist(t, bins=30, density=True)\n",
    "ax[2].set_title(\"$t$ distribution\", fontsize=18)\n",
    "ax[2].set_xlabel('$t$', fontsize=16)\n",
    "ax[2].set_ylabel(\"probability\", fontsize=16)\n",
    "ax[2].tick_params(which='major', axis='both', labelsize=16)\n",
    "\n",
    "for i in range(3):\n",
    "    ax[i].spines['right'].set_visible(False)\n",
    "    ax[i].spines['top'].set_visible(False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### check p(y|t) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "there are 16291 samles t=0\n",
      "there are 3709 samles t=1\n"
     ]
    },
    {
     "data": {
      "image/png": "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FRUViouL8+uzpVuywsPDFR4ebqR0AABMYfPmzX6vN23apEGDBslqteraa6/Vjh07mhzzi1/8QjNmzNDSpUu1Y8cOTZgw4ayfERYWpoaGhib7jVwSysjI0BNPPKEffvjBt3/jxo268sorfZeDJOmLL75Qly5d/MJOezA0whIWFqZhw4bJ5XL59jU2NsrlcikjI6NJ+8GDB+vzzz/Xtm3bfNu//uu/atSoUdq2bZsSEhKUlJQkm83m16fH49HmzZub7RMAgI6svLxcTqdTu3bt0ptvvqlly5Zp2rRpkk5Nai0tLW0SNnr16qU777xTjz32mEaPHq3LLrvsrJ+RmJioPXv2aNu2bTpy5Ihv3mffvn01cODAFrd+/fr5+vj5z3+usLAwTZo0Sdu3b9e6dev03HPPyel0+n3WRx99pJtuusl3aai9GL5LyOl0asKECUpNTVVaWpoKCwtVW1vru2to/Pjx6tu3rwoKChQREaGrr77a7/iePXtKkt/+Rx55RE8//bQGDRqkpKQkzZ49W/Hx8U3WawEAoCUd5U6v8ePH6+TJk0pLS5PVatW0adM0efJkSacu2YSGhur999+Xw+HwO27SpEl64403dN99953zM+666y698847GjVqlKqrq7Vq1SrDa7tER0frj3/8ox5++GENGzZMMTExysvL89V62tq1ay/KCruGA0tWVpaqqqqUl5cnt9utlJQUFRcX+ybNlpeXG34q44wZM1RbW6vJkyerurpaN954o4qLi1v9CGoAAMyqS5cuKiwsbHaxtdDQUM2aNUuLFy9uElgOHjyo3r17+5YAOZvw8PAma7e0xtChQ896G/Tvf/97hYSE+N1y3V5a9Syh04veNKekpOSsxza3eI3FYtFTTz2lp556qjXlAAAQNB544AFVV1fr2LFj6tGjh06cOKHDhw9r/vz5euCBB/zWRQm02tparVq1SqGh7f9oQp4lBACAiYSGhuqJJ57wLQq3YMECDR48WDabzW8dNDO4++67lZ6eflE+i6c1AwBwkZzrKkRz5syZc845IpmZmb45osGKwAIAQAfXGW5S4ZIQAAAwPQILAAAwPQILAAAwPQILAAAwPQILAAAwPQILAAAmcvrBwMeOHTvvYyZOnHhRlsf/saKiIr8HHLcnbmsGAASHDwou7ueNap9F3HJzczV16lTfwnGtMWfOHK1fv17btm1rdR/ff/+9fvnLX6qsrExffvml/uVf/kXr16/3a3Pfffdp3rx5vgcgtidGWAAAMIny8nK99957hh9U2B4aGhoUGRmpX/3qV7Lb7c22CQsL089//nMtXbq03eshsAAAcJGMHDnS9zy+6OhoxcTEaPbs2fJ6vZKkt956S8nJyerbt6+kU8/qiYqKavIgw/Xr16tbt27NXjZavXq15s6dq7/+9a+yWCyyWCzNPsfvXLp166YVK1YoJydHNputxXa33367/ud//kcnT540/BlGEFgAALiI1qxZo9DQUG3ZskXPPfecFi9erJdfflmS9NFHHyk1NdXXtlu3bho3bpxWrVrl18eqVat09913N3vZKCsrS48++qiGDBmiw4cP6/Dhw8rKypIkjR07Vt27d29xGzJkiOHzSU1N1d///ndt3rzZ8LFGMIcFQMAt2fi3QJcAXDQJCQlasmSJLBaLrrzySn3++edasmSJcnJytG/fPr/AIkn333+/brjhBh0+fFhxcXGqrKzUhg0b9P777zfbf2RkpLp3767Q0NAmIyMvv/zyWUdCunTpYvh8unbtqujoaO3bt8/wsUYQWAAAuIiuv/56WSwW3+uMjAw9++yzamho0MmTJxUREeHXPi0tTUOGDNGaNWs0c+ZMvfbaa+rXr59GjBhh+LNPX2pqa5GRkTpx4kS79H0al4QAADCJmJgYfffdd03233///b55KKtWrVJ2drZf6Dlf7XFJSJK+/fZbXXrppa069nwxwgIAwEX047kemzZt0qBBg2S1WnXttddqx44dTY75xS9+oRkzZmjp0qXasWOHJkyYcNbPCAsLU0NDQ5P97XFJ6Ouvv9b333+va6+91vCxRhBYAAC4iMrLy+V0OvXAAw9o69atWrZsmZ599llJksPh0P3336+GhgZZrVbfMb169dKdd96pxx57TKNHj9Zll1121s9ITEzUnj17tG3bNl122WXq0aOHwsPDDV8S2rFjh+rr6/Xtt9/q2LFjvnVdUlJSfG0++ugj9e/fXwMGDDDUt1EEFgAALqLx48fr5MmTSktLk9Vq1bRp0zR58mRJpy7ZhIaG6v3335fD4fA7btKkSXrjjTd03333nfMz7rrrLr3zzjsaNWqUqqurtWrVqlat7fLP//zPfpNpT4+inL4NW5LefPNN5eTkGO7bKAILACA4tNPKs22tS5cu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rXrhhRd06623SpLcbrevjx/3efq9H6urq1NdXZ3vtcfjMXIaAACgg7koK9326NFD27Zt0/Hjx+VyueR0OtW/f3+NHDmyVf0VFBRo7ty5bVskAAAwLUOXhGJiYmS1WlVRUeG3v6KiQjabreUPCQnRwIEDlZKSokcffVR33323CgoKJMl3nJE+c3NzVVNT49v2799v5DQAAEAHYyiwhIWFadiwYXK5XL59jY2NcrlcysjIOO9+GhsbfZd0kpKSZLPZ/Pr0eDzavHlzi32Gh4crKirKbwMAAMHL8CUhp9OpCRMmKDU1VWlpaSosLFRtba2ys7MlSePHj1ffvn19IygFBQVKTU3VgAEDVFdXpw0bNujVV1/VihUrJEkWi0WPPPKInn76aQ0aNEhJSUmaPXu24uPjlZmZ2XZnCgAAOizDgSUrK0tVVVXKy8uT2+1WSkqKiouLfZNmy8vLFRJyZuCmtrZWDz30kA4cOKDIyEgNHjxYr732mrKysnxtZsyYodraWk2ePFnV1dW68cYbVVxcrIiIiDY4RQAA0NEZXofFjFiHBTAf1mE5g3VYgOYZ+f19Ue4SAoDry19s9bGbLp/chpUA6Ih4+CEAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA9AgsAADA91mEBYHoXsoaLxDouQDBghAUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJgegQUAAJheaKALANAxLNn4t0CXAKATY4QFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYXqtWul2+fLkWLlwot9ut5ORkLVu2TGlpac22femll/TKK6/oiy++kCQNGzZM//mf/+nXfuLEiVqzZo3fcQ6HQ8XFxa0pDwD8XF/+YquP3XT55DasBEBrGR5hWbdunZxOp/Lz87V161YlJyfL4XCosrKy2fYlJSW655579MEHH6i0tFQJCQkaPXq0Dh486NduzJgxOnz4sG978803W3dGAAAg6BgOLIsXL1ZOTo6ys7N11VVXqaioSF27dtXKlSubbf/666/roYceUkpKigYPHqyXX35ZjY2Ncrlcfu3Cw8Nls9l8W69evVp3RgAA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"there are {len(y_t0)} samles t=0\")\n",
    "print(f\"there are {len(y_t1)} samles t=1\")\n",
    "plt.hist(y_t0, bins=30, alpha=0.5, label='p(y|t=0)', density=True)\n",
    "plt.hist(y_t1, bins=30, alpha=0.5, label='p(y|t=1)', density=True)\n",
    "plt.legend(loc='upper right')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generate source domain dataset and target domain dataset"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Divided by binary covariate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "source_data = data.loc[data['x7']==1.0]\n",
    "target_data = data.loc[data['x7']==0.0]\n",
    "dist_z_source = [0, 1]\n",
    "dist_z_target = [0, 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "there are 10308 samles in source domain\n",
      "there are 9692 samles in target domain\n"
     ]
    },
    {
     "data": {
      "image/png": "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bNu2Te+8846eeuopde3a1dXhoJQiF1nGEXlo9erVhfYXEhKibt26SZI+//zzkobtdchD7ov92b3s2rVLp06dUkBAgB555JF88x955BH5+/vr999/1+7du10QoXsgBxaN3Oda5Dz344z9l3t2wuNlZmaab4hdvXp11wbj5uLj4yVJFStWVJ06dQps07x5cyUlJSk+Pl69e/d2ZnilxpEjRySxv9rDpUuX1L9/f4WHh2vWrFmuDgelmD1y0aJFi3Tu3DllZWWpRo0aat++ve655x47Rul69s5DFy9e1K+//mperrD+li1bZl43bMtD+/bt07hx43Tu3DmFhYWpadOmeuihh1SuXDl7h+lRtm7dqv/85z+6ePGiKlWqpLvuuktdu3ZVQECAxX2wP9vP22+/rV9//VUmk0kRERHq0qWLmjVrZnU/udv59ttvV9myZfPNDwwM1O233674+HjFx8erdevWNsfuiciBRSP3uRY5z348KddR7ITH++CDD5ScnKzAwEA98MADrg7HrSUkJEiSIiIiCm1Tq1atPG1hX6dOndLixYslqcArBGCdF154QQkJCVq9erUqVKjg6nBQitkjF7322mv5prVo0ULLly/3mgcM2DsP3fj038L6JK/lZWseyn3Yw43CwsI0e/ZsPfXUU/YI0SMtXbo037Tq1avrww8/1P33329RH+zP9jNmzJg8v48bN07333+/Fi9erPDwcIv7sfSYFR8fX6r/JuTAopH7XIecZ1+elOsYxg6P9p///EcvvviiJGnixIlW/fNSGl28eFGSFBwcXGib3KcgpqWlOSWm0iQrK0tPPvmkUlNT1bhxYw0ePNjVIXm0DRs2aMGCBXr88cfVvXt3V4eDUszWXPTggw9q+fLl+vXXX3XlyhUlJCRo6dKlioiIUFxcnDp06KAzZ844InSns3ceyu2vqD7Ja/9jSx6qW7eupk2bpvj4eJ07d07nzp1TbGys/vrXvyo1NVX9+vXTxx9/7MDo3VOTJk0UExOjgwcPKi0tTadPn9aGDRt09913648//lC3bt20bds2i/pif7Zdnz59tGbNGh07dkxXrlzR4cOHNWfOHFWqVElff/21unTpoqtXr1rcH/87F48cWDxyn2uQ8+zHE3MdV3bC4V566SWtXbvW6uXef/99tW3bttD5J06c0EMPPaRLly6pW7duGjdunC1hAg43ZMgQbd68WZUqVdKnn34qf39/V4fksVJTU/XMM8+oSpUqeuedd1wdDjyAO+eiuXPn5vk9MjJSkZGRevDBB3XnnXfq2LFjmjZtGrdqgM1syUN9+/bNN61NmzZat26dRo4cqXfeeUejR49Wz549S1V+Gz16dJ7fy5Urpy5duqhz587q0aOHvvjiC40aNUr79+93TYAewl7H6D8XH+rXr6/69eura9euatq0qf7zn/9o/vz5GjVqlK0hexRyIEojcp79eGKuo9gJh/v999/1yy+/WL3cpUuXCp136tQpRUVF6fjx47rvvvu0cuVKmUwmW8IsFXLvLXL58uVC2+Ru99DQUKfEVFo899xz+uCDD1ShQgVt3LhRt9xyi6tD8mijRo3SiRMn9M9//lOVK1d2dTjwAJ6YiypWrKhRo0Zp1KhRWrdunVec6Nk7D914z6zLly8rLCzMpv68mSPz0OTJk/Xuu+/q7Nmz2r17t9q1a2e3vj2VyWTSlClT9MUXX+jAgQNKSkoyD8srTGnenx1xjL5RnTp19PTTT2vWrFlat26dxcVOb/nfmRzoWuQ+5yPnOYc75zqGscPhPvroIxmGYfWrsHs+nDlzRp06ddLhw4fVuXNnrVmzxqob4pZmkZGRkop+El3uvNy2sN2YMWM0e/ZslS9fXhs2bDA/ERAlt3r1avn6+urdd99Vhw4d8ry+/vprSdfvH9WhQwc9/vjjLo4W7sBTc9Gtt94q6frVM97A3nmodu3a5p8TExNt7s9bOToPVaxYUVWrVpXkPfuqPeR+fiXLtktp3p/tfYwuSEmOp7nbubC/h+QZfxNyoGuR+5yLnOdc7prrKHbCo5w9e1adOnXSTz/9pKioKK1du7bAJyOiYLkH+pSUlEJv9rtnzx5JKtETK5HfSy+9pLffflthYWHasGFDoU+cg/WysrK0ffv2fK/Tp09Lun7z6+3bt+u7775zcaTwNs7MRSkpKZLkNU/9tHceCg0NNT+4Inc5W/rzRs7IQ9nZ2UpNTZXkPfuqPeR+fiXLtgv7s2OV5Hiau51//PHHAu/1eeXKFf3444952no7cqD1yH3OQ85zPnfNdRQ74TGSk5PVqVMn/fjjj4qKitK6desUGBjo6rA8yk033aQWLVpIkpYvX55vfmxsrJKSkhQQEKCuXbs6OzyvM27cOL355psKCwvTxo0bzdsetrtw4UKhVyH069dPkjR16lQZhpHniX+ArZydi1asWCFJuuuuuxy2DmdyRB7q0aNHof1dunTJ/BTVhx9+uKRheyxn5aG1a9cqPT1dJpOJL/VukPv5DQ0NVYMGDSxahv3ZMXJycrRy5UpJ1h1PW7durWrVqikjI0OfffZZvvmfffaZrl27pho1aqhly5Z2i9ddkQNLhtznHOQ813DbXGcAHiAlJcX4y1/+YkgyOnfubKSnp7s6JI+1evVqQ5IREhJi7N271zw9OTnZaNy4sSHJGDNmjAsj9A4vv/yyIckoX7688f3337s6nFKlX79+hiRj6tSprg4FXsaWXNSpUyejQYMGxueff55n+po1a4w9e/bka5+WlmY899xzhiRDkrFx40ab43cXJclDn3/+udGgQQOjU6dO+fo7efKkERQUZEgyFi5caJ6elZVl9O3b15BktGjRwsjJyXHcm3JDJclD77zzjtGgQQOjb9++eaYfP37cWLZsmXHlypV8y6xevdqoWLGiIcl48skn7RK7p4iPjze++OILIzMzM8/07Oxs4/333zfKli1rSDJeeeWVPPPZnx3jo48+Mn7++ed800+fPm08/vjjhiTDz8/POHToUL42ffv2NRo0aGC88847+ebNnDnTkGTUrFnTOHr0qHn60aNHjZo1axqSClzO25ADbUPucyxynuN4aq7jAUXwCAMGDNAPP/wgk8mkihUraujQoQW26969u7p37+7c4DxM9+7dNXLkSM2ePVutWrVSVFSUgoODtXnzZl24cEFt2rTR1KlTXR2mR1u7dq3+9re/SZLq1auX7ymTuSpXrqy33nrLmaEBsIEtuei3337T8ePHzcOecm3dulUxMTGKiIhQ48aNVb58ef3+++/av3+/zp8/L19fX7311lvq3Lmzo96W05UkD6WmpuqXX34pcBhpjRo1tHjxYvXu3VuDBg3SBx98oMjISMXFxeno0aMKDw/X8uXLS9WDDEuah5KTk/XLL7+oWrVqedqdO3dOffv21dChQ9W0aVPVrFlTV65c0aFDh3TkyBFJUseOHTVv3jwHvSP3dOzYMfXo0UMVKlRQs2bNFB4ergsXLujgwYPm+5D17t1bkyZNyrMc+7NjrFq1Sk8++aTq16+v2267TcHBwUpMTNT+/ft16dIlBQUFafHixXnuL5crMTFRv/zyi5KTk/PNGzFi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",
      "text/plain": [
       "<Figure size 1600x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"there are {len(source_data)} samles in source domain\")\n",
    "print(f\"there are {len(target_data)} samles in target domain\")\n",
    "\n",
    "#plt.legend(loc='upper right')\n",
    "#plt.show()\n",
    "\n",
    "plot_souce_target(source_data, target_data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Cut it by half"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "# split them into half\n",
    "# sort the data by z\n",
    "sorted_data = data.sort_values(by=['z'])\n",
    "source_data = sorted_data.iloc[: int(len(sorted_data)/2)]\n",
    "target_data = sorted_data.iloc[int(len(sorted_data)/2):]\n",
    "dist_z_source = [0, 1]\n",
    "dist_z_target = [0, 1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>z</th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "      <th>x6</th>\n",
       "      <th>x7</th>\n",
       "      <th>x8</th>\n",
       "      <th>...</th>\n",
       "      <th>x17</th>\n",
       "      <th>x18</th>\n",
       "      <th>x19</th>\n",
       "      <th>x20</th>\n",
       "      <th>x21</th>\n",
       "      <th>x22</th>\n",
       "      <th>x23</th>\n",
       "      <th>x24</th>\n",
       "      <th>t</th>\n",
       "      <th>y</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>15333</th>\n",
       "      <td>-3.926862</td>\n",
       "      <td>-2.726585</td>\n",
       "      <td>-3.938477</td>\n",
       "      <td>3.698471</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.227143</td>\n",
       "      <td>0.982266</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.723973</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11093</th>\n",
       "      <td>-3.604075</td>\n",
       "      <td>-2.717850</td>\n",
       "      <td>-3.332462</td>\n",
       "      <td>2.803056</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.938243</td>\n",
       "      <td>1.298873</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.454258</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17652</th>\n",
       "      <td>-3.599210</td>\n",
       "      <td>-2.820497</td>\n",
       "      <td>-3.851410</td>\n",
       "      <td>2.859086</td>\n",
       "      <td>3.0</td>\n",
       "      <td>-0.854187</td>\n",
       "      <td>0.108455</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.684978</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19516</th>\n",
       "      <td>-3.486589</td>\n",
       "      <td>-2.682178</td>\n",
       "      <td>-3.539554</td>\n",
       "      <td>2.896749</td>\n",
       "      <td>2.0</td>\n",
       "      <td>-1.170320</td>\n",
       "      <td>-0.789343</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.175976</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3137</th>\n",
       "      <td>-3.471052</td>\n",
       "      <td>-2.690933</td>\n",
       "      <td>-4.102636</td>\n",
       "      <td>3.906606</td>\n",
       "      <td>3.0</td>\n",
       "      <td>-0.795868</td>\n",
       "      <td>-0.477202</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.387443</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 28 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "              z        x0        x1        x2   x3        x4        x5   x6  \\\n",
       "15333 -3.926862 -2.726585 -3.938477  3.698471  0.0 -1.227143  0.982266  1.0   \n",
       "11093 -3.604075 -2.717850 -3.332462  2.803056  0.0  0.938243  1.298873  1.0   \n",
       "17652 -3.599210 -2.820497 -3.851410  2.859086  3.0 -0.854187  0.108455  1.0   \n",
       "19516 -3.486589 -2.682178 -3.539554  2.896749  2.0 -1.170320 -0.789343  1.0   \n",
       "3137  -3.471052 -2.690933 -4.102636  3.906606  3.0 -0.795868 -0.477202  1.0   \n",
       "\n",
       "        x7   x8  ...  x17  x18  x19  x20  x21  x22  x23  x24    t         y  \n",
       "15333  0.0  1.0  ...  1.0  1.0  0.0  0.0  0.0  1.0  0.0  1.0  0.0 -0.723973  \n",
       "11093  0.0  1.0  ...  1.0  0.0  1.0  0.0  0.0  1.0  0.0  0.0  0.0  2.454258  \n",
       "17652  0.0  1.0  ...  1.0  0.0  0.0  0.0  0.0  1.0  0.0  1.0  0.0 -0.684978  \n",
       "19516  0.0  1.0  ...  1.0  0.0  0.0  1.0  0.0  0.0  0.0  0.0  0.0 -1.175976  \n",
       "3137   0.0  0.0  ...  1.0  0.0  1.0  0.0  0.0  0.0  0.0  0.0  0.0 -1.387443  \n",
       "\n",
       "[5 rows x 28 columns]"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sorted_data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9eerqF+eJCkoKEg33XSTzTFz3XYuR10bHX3NtoUz9l2a885d8kxx5/LWrVslSbVq1VLbtm2t7vPrr7+WJGVmZqpOnTqqVatWka8hQ4ZIkg4cOGBTzPZcQxx53G+++WaL2+cXx9q1a1dkm7CwMPO/T506VWj9H3/8oaeeeko33XSTqlevLi8vL/MDMHr27ClJOnTokMXYiuPKz587IcdZRo4jx9nD3utXceffrl27JEn169dXw4YNi2xTrVo1i58vZ+cna9h7jSCPOec89y5VJICbyD/ha9SoYVX7Ro0a6Z133tGwYcO0bds2bdu2TZJ0zTXXqFu3bho4cKB69+5t99Ova9asadf2klS3bl2L66pUqaIaNWro2LFjOn78uN37cpT8WIqLXZLq1atXoH1RqlWrZnFd/i9Tubm5LonNXoZhaMiQIVq4cKEkaeDAgVq8eDGFTjhdpUqVdMstt2jt2rX65ptvdP/990uSfv75Z82ePVuSNGfOHHl5ednUr62fL1tw3XYuR10bHX3NtoUz9l2a885d8kxx5/LRo0clSQ0aNLCpzz///FPSleN47NixEtufP3/epv7tuYaU9e8eltrkr5cKn2/x8fEaMGCAcnJyzMsCAwNVpUoVmUwmXbx4UadOndLZs2eLfQ/2xO2sz587IcdZRo4jx5WWI65fxZ1/J06ckPS/gpYllv4PnZ2frGHvNYI85pzznG/WKLeys7P1xx9/SLryi4K17r//fh04cEDz58/Xvffeq/DwcJ04cULLly9Xnz591KVLF/NQ+tKy9ZcoVByGYeixxx7Tu+++K0kaMGCAlixZwjmDMpP/1/WrR72MGjVKubm5GjhwoDp37uyq0Cziug1XKIvzzhmKO5dLWzDJv732lltukXFlzv8SX7giIyNDMTExysnJUVRUlDZt2qRz584pMzNTx44d09GjR7VixQpXh+kxyHFFI8ehNBx1/bLm/CM/ua/ymscodqLc+uqrr8wXt65du9q0bUhIiB577DEtW7ZMBw8e1G+//aYJEybIZDJpy5YtFufKKEuHDx+2uC4nJ0cZGRmSCv+lLP8vHxcuXLC4fWZmpgMiLCw/lpKGr+evd8Rfma3lDrEZhqFhw4bp7bffliTde++9ev/99/kFFGWqY8eOkqTdu3crJydHn376qdavX6+AgAC98sorpeoz//NS3HXLmvXF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uXO69tprNWPGDKYWAQCUe+6c1yh2Am5k1rq9hV6Au/P19VWtWrXUoEEDDR8+XN27d1dCQoIkKSoqSj/99JPi4+PVq1cv1atXT5KUl5enTz75RL169TL3s2nTJvMo0atfMTEx5ja9evXSqlWrdP78+TJ9j47Qp08fjRo1StnZ2Wrfvr169Oihe+65R40bN9YPP/ygyMhITZs2rcA2mZmZ+vXXX/X777+7KGoAgHTlTobNmzcrLi7OnJ/2799vUx/t2rXTK6+8ovvuu4+HwwEAXMrT8xpzdgIAHMrPz08ZGRkaN26coqKi1KlTJ9WvX1/ffPONedTi999/r8zMTLVt29a8XceOHXXkyBHzzz///LN69uypW2+91bysbdu2unTpkrZv327XU8hdJS4uTpGRkZo7d662bt2q3NxcNWrUSBMmTNDYsWPl4+Pj6hABAEWIi4vT3r171aJFC7344ouSpGuuuabEuxMeeOABzZ8/vyxCBADAap6e1yh2AgAcwjAMJSYmas2aNXriiScUFxenTz75RD179lSdOnV055136oUXXtCdd96pAwcOyMvLSzVr1jRv7+PjY779ISMjQ48++qgefvhhPfzww+Y2VatWVVBQkA4cOFDm789R+vfvr/79+1vVNiYmpsDIVmdtAwAoXlBQkHx8fFS1atUCt+p99913xW4XGBjo5MgAALCdp+c1ip0AALv8+9//VkBAgHJzc3X58mUNHDhQzz33nN5++20lJiZq+vTp6tq1qyZNmqT4+HhJ0vnz5+Xr6yuTyVSov9zcXN19991q0KCB4uLiCq338/PTuXPnnP6+AAAoSePGjV0dAgAADuMpeY1iJwDALt26ddObb74pHx8f1alTR97eV1LLU089VaBdWFiYhg0bJkkKDQ3VuXPndPHixUK3bg8fPlxpaWn69ttvzX1d7eTJk7rmmmuc9G4AoPSsnWt77G1NnRwJyoqn3O4HAIDkOXmNYicAwC7+/v7F/gVwypQphZbdeOONkqQ9e/aY/y1Jr732mpYvX66tW7eqRo0ahbb7/fffdeHCBbVu3dresAEAsImPj4/y8vIKLPOU2/0AABWPJ+c1ip0AgDJ3zTXXqE2bNkpKSjIXO9evX69nnnlGc+fOVWhoqI4ePSrpym3r+Q822rJli6699lo1atTIVaEDACqoiIgIbd++Xfv371dAQIBC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1aundu3aSZKWLl1aaH1SUpLS0tLk6+urnj17WtVnv379JFm+TX3dunWSpJtvvrk0IQMAAABAhTFmzBj1799fX3/9tW6++WbdeeedOnjwoMaPH6+oqCidP3/e6r4SEhL05ptv6s8//1SzZs3Ut29fdenSRSdPntScOXPUokULbdq0yXlvBgDgUdyy2ClJkyZNkiTNmDFDu3btMi/PyMjQiBEjJEkjR45UUFCQeV18fLyaN2+u6OjoQv2NGjVKwcHBSkhI0IIFCwqsW7ZsmT788ENzOwAAAABA0VauXKm4uDgFBARo+/btWrNmjT799FPt27dPLVu2VFJSkiZPnmx1f/fff79SU1N14MABbdiwQR999JESEhJ08OBBjR49WmfPntWgQYOUl5fnxHcFAPAUbjlnpyT16dNHo0aN0uzZs9W+fXtFR0fL399fiYmJOn36tCIjIzVt2rQC22RmZurXX3/VhQsXCvUXGhqqjz/+WL1799awYcP0xhtv6LrrrtPvv/+ulJQUSdLkyZOtHikK2KKoeTwBAICVNsZa167bROfGAUCSNH36dEnShAkTCkwrFhoaqnnz5qlz586aM2eOJk+eXGBwiiXXXXddkct9fHz0yiuvaMGCBTp06JD27Nmjli1bOuZNAAA8ltsWOyUpLi5OkZGRmjt3rrZu3arc3Fw1atRIEyZM0NixY+Xj42NTf7fddpt2796t6dOna/369fr8888VGBionj17avTo0br99tud9E6ACsbSl1K+hAIAAJRrhw8fVnJysiRp4MCBhdZ36tRJ4eHhSktLU0JCggYMGGDX/kwmkypVunJDIg+KBQBYw62LnZLUv39/9e/f36q2MTExiomJKbZN06ZNtWjRIvsDAwAAAIAKJv+uuJCQEDVs2LDINm3btlVaWppSUlLsKnbm5eVp6tSpOnfunK6//no1bty41H0BACoOty92AgAAAADcQ2pqqiSpfv36FtuEh4cXaGutgwcP6vnnn5cknTx5UikpKTp06JAaN26s5cuXm0d4AgBQHIqdAAAAAACrnDlzRpLk7+9vsU1AQIAkKSsry6a+T548qcWLFxdY1qZNG7333nu64YYbStw+JydHOTk55p9t3T8AwDPwpzEAAMrQihUr1LVrVwUHB8vf31+tWrXSzJkzlZuba1M/W7du1YgRI9ShQwfVrVtXVapUkb+/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rY+Pj6655hqeWovyy9J1GIBHIKcBAODAYmd2draOHTumU6dOKTg4WGFhYQoICHBU9wAAOEWDBg3M/x48eLA6d+5cYBkAAOUFOQ0AADuLnWvWrNHKlSuVmJio33//vdD6xo0bKyoqSn369NEdd9xhz64AAHC6hQsXujoEAAAcgpwGAKiobC525uXl6c0339Ts2bP1+++/yzAM87qAgAAFBgYqMzNTZ8+e1b59+7Rv3z699dZbaty4sUaNGqVhw4bJy8vLoW8CAAAAAAAAAGwqdn711VcaO3asfv31V1WuXFm9e/fWbbfdpo4dO+qGG25Q5cqVzW0vXryoH3/8UVu3btW6dev01VdfadSoUZo7d65mzZrFSE8AgMs9/PDDMplMmj59usLCwvTwww9bva3JZNK7777rxOgAALAeOQ0AgCtMxtVDM0tQqVIlhYWF6emnn9aDDz6o0NBQq3eUnp6uxYsXa+bMmUpPT1deXl6pAnY3WVlZCgoKUmZmpgIDA10dDpxo1rq9rg7BZmO9P3V1CNbhAUUoA0VdrytVqiSTyaSff/5ZTZs2VaVKlazuz2QyeUwuy0dOqwDK+QOKtv2R4eoQCvim/lBXhyBJGntbU1eHABf46zWbnFYYec2zOev7WfuDbzml37LQ4doazumY72soA468Zts0snPatGkaO3asqlatavOOQkNDNW7cOA0fPlyzZs2yeXsAABwtfz6z2rVrF/gZAIDyhpwGAMAVNhU7n332Wbt3WLVqVYf0AwCAvQYPHlzszwAAlBfkNHia8nhnHQD3YP29DQAAAAAAAADgxmx+GvvVXnzxRXl5eenxxx9X9erVLbb7/PPPtXv3bj3//PP27A4AAJdJTU3V999/rwYNGujGG290dTiAR3G3uTgBT0dOAwB4MrtGdk6ZMkXPP/+8IiMjdfDgQYvtVq5cqalTp9qzKwAAnG7VqlX65z//qW+//bbA8ldeeUVNmzbVP//5T9100002PeEWAABXIKcBACoqu29jr1Klin7++Wd16NBBKSkpjogJAACXWLJkib766itdd9115mW//PKLJkyYIMMw1KpVK1WtWlWLFy/W6tWrXRgpAADFI6cBACoqu25jl6R7771XderU0fTp09W1a1d9/PHHuvPOOx0RGwAAZSolJUWtWrVStWrVzMs+/PBDSdK8efM0dOhQ/fLLL/rb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kZGh119/Xf/+97/11FNPFWpTtWpVtWrVSsnJyVb3m//kWklaunRpofU8uRYA4GjOymkAALg7u25jv3pel1mzZmnWrFlFtnv99df1+uuvF1hmMpl06dIle3YPAIBDffXVV2revLlGjRpVbLuIiAht3LjRpr55ci0qom1/ZLg6BKDCcmZOAwDAndlV7LRnbhXmZQEAuJs///xT//jHP0psZzKZlJWVZVPfPLkWgCXWPLFd4qntsI0zcxoAAO7MrmLn5cuXHRUHAAAu5+/vrxMnTpTYLjU1VSEhITb3z5NrAQBlxdk5DQAAd2VXsRMAAE/SsmVL7dy5U+np6RYLhAcOHNDu3bt12223lWofPLkWAFAWyiKnAQDgjux6QBEAAJ7kgQce0JkzZ/Too4/q3LlzhdZfvHhRI0aMUG5urh544AEXRAgAgHXIaQCAioqRnQAA/NdDDz2kDz/8UKtWrVLz5s115513SpJ2796tUaNGadWqVTp48KC6d++ue++918XRAgBgGTkNAFBRUewEAOC/vLy8tHr1aj322GNatmyZ3nnnHUlSSkqKUlJSJEl33323Fi5c6MowAQAoETkNFYW1D3kDUHFQ7AQA4CoBAQH68MMPNXnyZCUkJOiPP/7Q5cuXFR4erh49eujGG290dYgAAFiFnAYAqIgodgIAUITmzZurefPmrg4DAAC7kdMAABUJxU4AAP4rJSVF69at008//aSMjAyZTCaFhISoZcuWuv322/W3v/3N1SECAGAVchoAoKKi2AkAqPAOHDigRx99VBs2bDAvMwxDkmQymSRJ48eP1+2336633npL4eHhLokTsGhjrKsjAOAmyGkAgIqOYicAoEJLTU1VZGSkjh07JsMwFBISojZt2ig0NFSXL19Wenq6UlJSdOrUKa1du1YdO3ZUUlKSGjRo4OrQAQAogJwGAADFTgDuzNJIpW4TyzYOeLSHH35YR48eVZMmTfT666+rR48eRbb74osvNHbsWP3222965JFHtH79+jKOFACA4pHTAACQKrk6AAAAXCU5OVmbN29W06ZN9e2331r8UihJd911l5KTk9WkSRNt3LhRO3fuLMNIAQAoHjkNAIArGNmJCm/Wur2uDgGAiyxfvlwmk0mvv/66goKCSmwfFBSk119/XXfddZeWL1+um266qQyiBACgZOQ0AACuYGQnAKDC2rlz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",
      "text/plain": [
       "<Figure size 1600x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_souce_target(source_data, target_data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Sample two gaussians"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# check the distibution of z  \n",
    "\n",
    "#mu, std = norm.fit(sorted_data['z']) \n",
    "x = np.arange(-3, 3, 0.1)\n",
    "p = norm.pdf(x, loc=0, scale=1)\n",
    "\n",
    "plt.hist(data['z'], bins=30, density=True, label='P(z)')\n",
    "plt.plot(x, p, label='N(0,1)')\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "# sample the target gaussian by rejection sampling\n",
    "from scipy.stats import norm\n",
    "\n",
    "\n",
    "dist_z_source = [-1, 1]\n",
    "dist_z_target = [1, 1]\n",
    "# target z distribution\n",
    "def p_source(x):\n",
    "    return norm.pdf(x, loc=dist_z_source[0], scale=dist_z_source[1])\n",
    "\n",
    "def p_target(x):\n",
    "    return norm.pdf(x, loc=dist_z_target[0], scale=dist_z_target[1])\n",
    "    \n",
    "# z distribution in the dataset\n",
    "def q(x):\n",
    "    return norm.pdf(x, loc=0, scale=1)\n",
    "\n",
    "def rejection_sampling(sample, p, size):\n",
    "    \n",
    "    x = np.arange(-3, 3, 0.1)\n",
    "    k = max(p(x)/q(x))\n",
    "    c = np.random.uniform(0, 1, size=size)\n",
    "    mask = p(sample) / (k * q(sample)) > c\n",
    "    return mask\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "sample = np.array(data['z'])\n",
    "mask_source = rejection_sampling(sample, p_source, len(data))\n",
    "source_data = data[mask_source]\n",
    "\n",
    "mask_target = rejection_sampling(sample, p_target, len(data))\n",
    "target_data = data[mask_target]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "there are 1608 samles in source domain\n",
      "there are 1811 samles in target domain\n"
     ]
    },
    {
     "data": {
      "image/png": "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c/5xTrETXsPeYqdhGEaLFi2sf6yfr6xfqJdeesmQZNxyyy12xWbvHxSSjE8//bTMdrb8wkslZ6waxrnC2E033WRIMq666qoSyz35B0VOTo5Rp04dQzr3DVxpZs2aZf18pX2jfv7nX7t2bYnlZ86cMS677DJDkvHiiy+WG6ezY3NFsbOgoMC6P6VzhXsKnXCV119/3ZBk1K1bt9Tl7777rvUPjqI/0mxx+vRp6+/X4MGDS20zYcIE63Fuz4kg43b52/f0uO2qMbuiuF297cocd47uS2cVO8s7lvPz840mTZoYkozOnTtbT1gqUlBQYP2ba968eWW2u+OOOwxJxpgxY2zqt4gjY4iz//bYuHFjieXJycnW5cHBwcauXbtKtHn77bety/Py8mz85Oc89thjhiTj4YcfLrHMU78DvogcV3Y7chw5rqz+HSnwGUb545ctx192drZ1Fl9pfRhG8TrBhfvKGfnJ0X3h6BhBHnPNcc49O+HT6tSpI0kl7tlZllq1akmSDh8+XO49Lxx11VVX6fbbb3eoj8jISD344IMl3vfz89Ozzz4rSfr555/1448/OrQdZ1qzZo31/+KFF14otc3IkSN16aWXSjr3gKmyREVFqXv37iXeDwoKsj6Z/IcffvBIbM5SWFiohx9+WAsXLpQkDR48WPPnz5efH0MzXCMqKkqSlJmZqT/++KPYspMnT2rcuHGSpClTpqhevXo297t69Wrr79dzzz1XapsJEyaoevXqdsfMuO1azhobnT1m28MV267Mcecteaa8Y3ndunVKS0uTJL366qsKDAy0qc///e9/2rVrl+rVq6ehQ4eW2e6BBx6QpArvmXghR8YQZ+73zp07q3PnziXe79q1q4KCgiRJ99xzj5o3b16iTdGxdvr0ae3atavMbZTmtttukySlpKTYtV4RT/7+eRNyXNnIceQ4V7Fl/Crv+Fu9erVOnDghSXrmmWdKbfPkk0+qRo0apS5zdX6yhaNjBHnMNcc5Z9SoUmJiYlS9enWlpqaqS5cuevvtt61/9DtT0R9bjii6WW9punTpooCAAEnS1q1bHd6WsxTFEhkZqZYtW5baxt/fX9HR0cXal+aGG24oc9lll10myfYit7NjcwbDMDR06FDrzdoHDRqkBQsWUOiES1111VUKDw+XJH377bfFlk2ePFl///23rrnmGo0YMcKufs//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uWrXrp26du2q++67T9dcc42Sk5P1448/Ki0tTZGRkZKkRYsW6aqrrtKWLVvUoUMHm7fVokULTZ8+3frzpEmTFB4eriVLlqhatWqSpJYt/+9+M88//7z+/e9/66677pIkNWnSRL/88ovmzZunIUOGOOPjAwBQofDwcAUGBqpGjRq65JJLrO9///335a4XFhZm/feBAwcUERFRbHlERIQOHDjg1FgBAKiI2fMaxU4AgO6++27ddttt2rhxo7755ht9/vnnmj59ut566y2dOHFCkZGR1kKnJF155ZWqVauWfv31V7uKndddd12xn7///nt16dLFWug836lTp/Tnn3/q4Ycf1rBhw6zvnz17VuHh4ZX4lAAAOFfz5s09HQIAAE5jlrxGsRMAIEmqXr26evTooR49eig+Pl5Dhw7V888/ryeffLLCdf38/GQYRrH38vPzS7QLCQkp9nNwcHCZfWZnZ0uS3nzzTd1www3Flvn7+1cYEwAArhYaGlru8vvvv19z586VJF1yySXF7nctSQcPHiw2owYAAE8yS16j2AkAKNWVV16pFStW6IorrlBGRoYyMjKsszt/+eUXHT9+XFdeeaUk6aKLLirx1L3vv/++1Bmb57vmmmu0cOFC5efnl2gbERGhyy67TLt379agQYOc+MkAALBfYGCgCgoKir1nz+V+nTp1UnJyssaOHWt9b82aNerUqZMzwwQAwCZmzmsUOwGgisvMzFS/fv300EMP6ZprrlHNmjW1detWTZ8+XXfeeaduvvlmtW7dWoMGDdLMmTN19uxZjRw5Ul27dlX79u0lSdHR0Xr55Ze1aNEiderUSe+9955++ukntW3bttxtjxo1Sq+99pruu+8+TZw4UeHh4frmm290/fXX6/LLL9fkyZM1evRohYeH69Zbb1Vubq62bt2qY8eO6YknnnDH7gEAQJLUuHFjffvtt9qzZ49CQ0NVp04duy73GzNmjLp27ap///vfuu2227RkyRJt3bpVb7zxhgujBgCgdGbOaxQ7AcDF4nq0rLiRB4WGhuqGG27Qq6++qj///FP5+fmKjIzUsGHDNGnSJFksFv3nP//R448/rptuukl+fn669dZb9dprr1n76Nmzp+Lj4zVu3DidOXNGDz30kB544AH9+OOP5W67bt26Wrt2rZ5++ml17dpV/v7+uvbaaxUVFSVJGjp0qGrUqKGXX35ZTz/9tEJCQtS6deti3x4CAMzB2/PlU089pSFDhujKK6/U6dOnlZaWpsaNG9u8/o033qjFixfr2Wef1aRJk9SiRQutWLFCV199teuCdrFly5Zp9uzZ2rFjh/Ly8tS8eXMNGjRIcXFxFV7dUZFVq1bptttukyTFxMToq6++ckbIAOAW3p7TJHPnNYtx4U3WYJcTJ04oPDxcWVlZxabzAvCAdQkVt+k+0WWbP3PmjNLS0tSkSRNVr17dZdtB+cr6f2C8rhj7CHCuV9fsLHe5L5wIORu50j7l7S9Pj9ljx45VYmKiAgICFB0drdDQUK1du1bHjx9X586dtXr16nLvzV2eY8eO6eqrr9bff/8twzAqXez09D6C96hoPLZVVRy3UT7ymn3cldeY2QkAAAAAsNmKFSuUmJio0NBQbdiwQe3atZMkHTlyRNHR0UpJSVF8fLxmzJhRqf4ff/xxHTx4UCNGjNDrr7/uzNABh9haNKUoCngWxU4AVUtFsz9dOPMTAADADKZOnSpJmjBhgrXQKUn16tXTnDlz1KVLFyUlJSk+Pl7h4eF29b18+XK9//77evrpp3XllVdS7AQA2M3P0wEAAAAAAHzD/v37tWXLFknSwIEDSyzv3LmzIiMjlZubq1WrVtnV95EjRzRixAhdfvnl+uc//+mUeAEAVQ8zOwEAAAAfZcsllVxOCWdKTU2VJNWpU0dNmjQptU379u2VkZGh1NRUDRgwwOa+H330UR05ckSffPIJ974DAFQaxU4AAAAAgE3S0tIkSQ0bNiyzTWRkZLG2tliyZIk++ugjjRkzRlFRUZWKLTc3V7m5udafT5w4Ual+AAC+jcvYAQAAAAA2OXnypCQpJCSkzDahoaGSbC82HjhwQI899piaNWtmvR9oZSQkJCg8PNz6Kiq6AgCqFoqdAAAAAACPGT58uI4dO6a33npLNWrUqHQ/EydOVFZWlvWVkZHhxCgBAL6CYicAAG60bNkydevWTbVr11ZISIjatGmj6dOnKz8/3+G+V61aJYvFIovFoptvvtkJ0QIAUFzNmjUlSadOnSqzTXZ2tiQpLCyswv4WLlyolStXasSIEerWrZtDsQUFBSksLKzYCwBQ9XDPTgAA3GTs2LFKTExUQECAoqOjFRoaqrVr12r8+PFauXKlVq9ereDg4Er1fezYMQ0bNkwWi0WGYTg5cgAAzmncuLEklTtrsmhZUdvyLF++XJK0ZcuWEsXOAwcOSJK2bdtmXbZkyRJdcskl9gUNAKhSvL7YuWzZMs2ePVs7duxQXl6emjdvrkGDBikuLk7VqlVzqO9Vq1bptttukyTFxMToq6++ckbIAFDcugT3bq/7RPduDzZZsWKFEhMTFRoaqg0bNqhdu3aSpCNHjig6OlopKSmKj4/XjBkzKtX/448/roMHD2rEiBF6/fXXnRk6ALgH+dIntG3bVpKUmZmptLS0Up/IvnXrVkmy5jpbFK1TmuPHj2vDhg2SpDNnztgTLgB4BjnNo7z6MvaxY8eqf//++vrrr3X99dfr1ltvVXp6usaPH6/o6GidPn260n2fPwMGAKqqokuey3q98MILHo1txYoVHtu+sxU9cGHChAnFTv7q1aunOXPmSJKSkpKUlZVld9/Lly/X+++/ryeeeELXX3+9cwIGABTTrVs3jR07ttLr//zzz7r77rvVuHFjWSwWzZw502mxuVODBg3UoUMHSdLixYtLLE9JSVFGRoaCgoLUu3fvCvtbsWKFDMMo9TV//nxJ5yamFL1ny2xRAEDFzJzXvLbYef4MmG+//VZffvmlPv74Y+3atUutW7e2zoCprPNnwABAVfX3339bXzNnzlRYWFix95566im7+svLy3NRpL5t//792rJliyRp4MCBJZZ37txZkZGRys3N1apVq+zq+8iRIxoxYoQuv/xy/fOf/3RKvAAA58vJyVHTpk01bdo0n78Me9KkSZKkadOmafv27db3MzMzNXLkSEnSqFGjFB4ebl22fPlytWrVSjExMe4NFgDgEt6c17y22MkMGJjVq2t2VvgC3OWSSy6xvsLDw2WxWKw/nzp1SoMGDVJERIRCQ0PVoUOHErf7aNy4saZMmaIHHnhAYWFhGj58uCTpzTffVGRkpGrUqKG+ffvqlVdeUa1atYqt+5///Eft2rVT9erV1bRpU02ePFlnz5619itJffv2lcVi8flZHKmpqZKkOnXqlHq5nyS1b9++WFtbPfroozpy5IjefvttVa9e3bFAAQClio2N1YYNG5SYmGi9+mHPnj129dGhQwe9/PLLuu+++xQUFOSaQN2kT58+Gj16tLKzs9WxY0f16tVL99xzj5o3b64ff/xRUVFRmjJlSrF1srKy9Pvvv+vPP//0UNQAgCJmz2teWexk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75iyx/r16/Xaa6/pgQceUO/evT0dDnwIOdC9qnKetBX51LPIuUBxjNslMU67F+Ny5XGOVDGKnSb12Wefaf78+Ro2bJiio6M9HY7Py8/Pt97A+9JLL/VsMG6WmpoqSapTp46aNGlSapv27dsXawvb7Nq1S1LVO6ZslZ2drYceekgRERGaOXOmp8OBDyEHul9VzpO2Ip96FjkXKI5xuyTGafdiXK4czpFsE+DpAOB8x44d07BhwxQZGamXX37Z0+GYwttvv60jR44oODhYvXr18nQ4bpWWliZJatiwYZltIiMji7VFxQ4cOKAFCxZIku6++27PBuOlnnrqKaWlpWn58uWqXbu2p8OBjyAHekZVzpO2Ip96DjkXKIlxuyTGafdhXK48zpFsQ7HThEaNGqW///5bn3/+ucLCwjwdjs/78ccf9fTTT0uS4uPjFRER4eGI3OvkyZOSVO5loKGhoZKkEydOuCUmX3f27Fndf//9ysrKUuvWrfXII494OiSvs3r1as2bN0/33Xef+vTp4+lw4EPIge5X1fOkrcinnkHOBUpi3C4d47R7MC5XHudItqPY6UXGjRunTz/91O713nrrLXXu3FmS9Mknn2jx4sV68MEHdeuttzo7RK/ljH1Xmn379un2229Xdna27rjjDk2YMMGRMAFJ0ogRI5ScnKy6devqo48+UmBgoKdD8ipZWVl6+OGHddFFF+m1117zdDhwE3Kga5EnUVWRc+GrGLdhVozLlcM5kn0odnqRv/76S7///rvd62VnZ0uSjhw5okcffVSXXXaZXnnlFWeH59Uc3XelOXDggGJiYrR371717NlTS5culcVicSRMn1SzZk1J0qlTp8psU7QfmUVVsTFjxujtt99W7dq1tWbNGrVs2dLTIXmdogfLfPjhh6pXr56nw4GbkANdizzpeeRT9yPnwpcxbrsf47TrMS5XHudI9qHY6UXee+89vffee5VePyUlRYcOHVKDBg3KndLcr18/BQUFKTY2VrGxsZXenjdxdN9d6NChQ4qOjtbOnTt18803a8WKFQoKCnJa/76kcePGksp/Sl7RsqK2KN2TTz6pWbNmqVatWlq9erX1CYQobvny5QoICNCcOXM0Z86cYst+++03SefuM/XVV1/pkksu0ZIlSzwRJpyMHOha5EnPI5+6FzkXvo5x2/0Yp12LcdkxnCPZh2Kn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",
      "text/plain": [
       "<Figure size 1600x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"there are {len(source_data)} samles in source domain\")\n",
    "print(f\"there are {len(target_data)} samles in target domain\")\n",
    "\n",
    "#plt.legend(loc='upper right')\n",
    "#plt.show()\n",
    "\n",
    "plot_souce_target(source_data, target_data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Train on the source domain dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "from models import trainZTtoYmodel, trainXTtoYmodel, trainZtoXmodel, GenericDataset, RMSE_loss\n",
    "\n",
    "number_trained_sample = 1000\n",
    "source_data = source_data.sample(number_trained_sample)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>z</th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "      <th>x2</th>\n",
       "      <th>x3</th>\n",
       "      <th>x4</th>\n",
       "      <th>x5</th>\n",
       "      <th>x6</th>\n",
       "      <th>x7</th>\n",
       "      <th>x8</th>\n",
       "      <th>...</th>\n",
       "      <th>x17</th>\n",
       "      <th>x18</th>\n",
       "      <th>x19</th>\n",
       "      <th>x20</th>\n",
       "      <th>x21</th>\n",
       "      <th>x22</th>\n",
       "      <th>x23</th>\n",
       "      <th>x24</th>\n",
       "      <th>t</th>\n",
       "      <th>y</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>5354</th>\n",
       "      <td>-0.576191</td>\n",
       "      <td>0.621232</td>\n",
       "      <td>0.430660</td>\n",
       "      <td>-0.791288</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.456272</td>\n",
       "      <td>-0.411773</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.164856</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12764</th>\n",
       "      <td>-1.766308</td>\n",
       "      <td>1.579183</td>\n",
       "      <td>1.598987</td>\n",
       "      <td>-1.616467</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-0.772770</td>\n",
       "      <td>1.249049</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.353062</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17184</th>\n",
       "      <td>-1.787700</td>\n",
       "      <td>1.858357</td>\n",
       "      <td>0.328535</td>\n",
       "      <td>0.246739</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.284708</td>\n",
       "      <td>-1.005668</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.952870</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8258</th>\n",
       "      <td>0.297699</td>\n",
       "      <td>-0.307596</td>\n",
       "      <td>0.555152</td>\n",
       "      <td>0.204828</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-0.026260</td>\n",
       "      <td>-1.070737</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-0.240340</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4473</th>\n",
       "      <td>-0.544753</td>\n",
       "      <td>0.509379</td>\n",
       "      <td>1.116381</td>\n",
       "      <td>0.698242</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.179267</td>\n",
       "      <td>-0.089578</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.458248</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 28 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "              z        x0        x1        x2   x3        x4        x5   x6  \\\n",
       "5354  -0.576191  0.621232  0.430660 -0.791288  0.0 -0.456272 -0.411773  0.0   \n",
       "12764 -1.766308  1.579183  1.598987 -1.616467  1.0 -0.772770  1.249049  1.0   \n",
       "17184 -1.787700  1.858357  0.328535  0.246739  0.0  1.284708 -1.005668  0.0   \n",
       "8258   0.297699 -0.307596  0.555152  0.204828  0.0 -0.026260 -1.070737  0.0   \n",
       "4473  -0.544753  0.509379  1.116381  0.698242  0.0 -1.179267 -0.089578  1.0   \n",
       "\n",
       "        x7   x8  ...  x17  x18  x19  x20  x21  x22  x23  x24    t         y  \n",
       "5354   0.0  1.0  ...  1.0  0.0  0.0  0.0  0.0  0.0  0.0  0.0  0.0  0.164856  \n",
       "12764  0.0  1.0  ...  1.0  0.0  0.0  1.0  0.0  0.0  0.0  1.0  1.0 -1.353062  \n",
       "17184  0.0  1.0  ...  1.0  0.0  0.0  1.0  0.0  0.0  0.0  0.0  1.0 -1.952870  \n",
       "8258   0.0  0.0  ...  1.0  0.0  0.0  0.0  0.0  0.0  0.0  0.0  1.0 -0.240340  \n",
       "4473   0.0  1.0  ...  1.0  0.0  0.0  0.0  0.0  0.0  1.0  0.0  0.0 -1.458248  \n",
       "\n",
       "[5 rows x 28 columns]"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "source_data.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Pretrain a decoder using source domain data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0:\n",
      "Epoch loss: 23368.73876953125\n",
      "x: 21681.687744140625, t: 0, y: 1687.0509796142578\n",
      "Epoch 1:\n",
      "Epoch loss: 23171.72412109375\n",
      "x: 21508.11962890625, t: 0, y: 1663.6044311523438\n",
      "Epoch 2:\n",
      "Epoch loss: 22978.7666015625\n",
      "x: 21337.460205078125, t: 0, y: 1641.3063354492188\n",
      "Epoch 3:\n",
      "Epoch loss: 22797.34326171875\n",
      "x: 21173.92333984375, t: 0, y: 1623.4198150634766\n",
      "Epoch 4:\n",
      "Epoch loss: 22612.135986328125\n",
      "x: 21006.485107421875, t: 0, y: 1605.6507568359375\n",
      "Epoch 5:\n",
      "Epoch loss: 22414.8935546875\n",
      "x: 20825.572265625, t: 0, y: 1589.3214263916016\n",
      "Epoch 6:\n",
      "Epoch loss: 22197.201416015625\n",
      "x: 20621.572631835938, t: 0, y: 1575.6285095214844\n",
      "Epoch 7:\n",
      "Epoch loss: 21956.86279296875\n",
      "x: 20395.536254882812, t: 0, y: 1561.3265533447266\n",
      "Epoch 8:\n",
      "Epoch loss: 21681.229736328125\n",
      "x: 20132.806030273438, t: 0, y: 1548.4236755371094\n",
      "Epoch 9:\n",
      "Epoch loss: 21375.447265625\n",
      "x: 19837.820190429688, t: 0, y: 1537.6269989013672\n",
      "Epoch 10:\n",
      "Epoch loss: 21030.158447265625\n",
      "x: 19503.496215820312, t: 0, y: 1526.6622772216797\n",
      "Epoch 11:\n",
      "Epoch loss: 20638.203857421875\n",
      "x: 19120.654052734375, t: 0, y: 1517.5498962402344\n",
      "Epoch 12:\n",
      "Epoch loss: 20211.145385742188\n",
      "x: 18702.713134765625, t: 0, y: 1508.4320373535156\n",
      "Epoch 13:\n",
      "Epoch loss: 19750.394653320312\n",
      "x: 18249.709106445312, t: 0, y: 1500.6854705810547\n",
      "Epoch 14:\n",
      "Epoch loss: 19282.3466796875\n",
      "x: 17788.388305664062, t: 0, y: 1493.9583740234375\n",
      "Epoch 15:\n",
      "Epoch loss: 18847.861328125\n",
      "x: 17359.727172851562, t: 0, y: 1488.13427734375\n",
      "Epoch 16:\n",
      "Epoch loss: 18481.1572265625\n",
      "x: 16997.996704101562, t: 0, y: 1483.1605224609375\n",
      "Epoch 17:\n",
      "Epoch loss: 18179.02294921875\n",
      "x: 16700.540283203125, t: 0, y: 1478.4825897216797\n",
      "Epoch 18:\n",
      "Epoch loss: 17903.191284179688\n",
      "x: 16428.450561523438, t: 0, y: 1474.7405548095703\n",
      "Epoch 19:\n",
      "Epoch loss: 17675.75244140625\n",
      "x: 16204.404663085938, t: 0, y: 1471.3475189208984\n",
      "Epoch 20:\n",
      "Epoch loss: 17473.14892578125\n",
      "x: 16004.84716796875, t: 0, y: 1468.3016815185547\n",
      "Epoch 21:\n",
      "Epoch loss: 17289.575439453125\n",
      "x: 15823.76416015625, t: 0, y: 1465.8111877441406\n",
      "Epoch 22:\n",
      "Epoch loss: 17120.476318359375\n",
      "x: 15656.984619140625, t: 0, y: 1463.49169921875\n",
      "Epoch 23:\n",
      "Epoch loss: 16970.541381835938\n",
      "x: 15509.515625, t: 0, y: 1461.0257415771484\n",
      "Epoch 24:\n",
      "Epoch loss: 16837.728515625\n",
      "x: 15378.715087890625, t: 0, y: 1459.0132446289062\n",
      "Epoch 25:\n",
      "Epoch loss: 16716.140991210938\n",
      "x: 15259.21142578125, t: 0, y: 1456.9296875\n",
      "Epoch 26:\n",
      "Epoch loss: 16605.429931640625\n",
      "x: 15150.51171875, t: 0, y: 1454.9182891845703\n",
      "Epoch 27:\n",
      "Epoch loss: 16505.224487304688\n",
      "x: 15052.15087890625, t: 0, y: 1453.0738372802734\n",
      "Epoch 28:\n",
      "Epoch loss: 16419.753173828125\n",
      "x: 14968.481201171875, t: 0, y: 1451.2719268798828\n",
      "Epoch 29:\n",
      "Epoch loss: 16332.055786132812\n",
      "x: 14882.528564453125, t: 0, y: 1449.5272979736328\n",
      "Epoch 30:\n",
      "Epoch loss: 16259.484985351562\n",
      "x: 14811.732543945312, t: 0, y: 1447.7525787353516\n",
      "Epoch 31:\n",
      "Epoch loss: 16190.137817382812\n",
      "x: 14744.154418945312, t: 0, y: 1445.9833221435547\n",
      "Epoch 32:\n",
      "Epoch loss: 16127.283081054688\n",
      "x: 14683.08056640625, t: 0, y: 1444.20263671875\n",
      "Epoch 33:\n",
      "Epoch loss: 16068.286376953125\n",
      "x: 14625.667846679688, t: 0, y: 1442.6184997558594\n",
      "Epoch 34:\n",
      "Epoch loss: 16016.987915039062\n",
      "x: 14576.327026367188, t: 0, y: 1440.6608428955078\n",
      "Epoch 35:\n",
      "Epoch loss: 15966.788940429688\n",
      "x: 14527.750610351562, t: 0, y: 1439.038330078125\n",
      "Epoch 36:\n",
      "Epoch loss: 15917.6044921875\n",
      "x: 14480.225708007812, t: 0, y: 1437.3788299560547\n",
      "Epoch 37:\n",
      "Epoch loss: 15871.420166015625\n",
      "x: 14435.865966796875, t: 0, y: 1435.554183959961\n",
      "Epoch 38:\n",
      "Epoch loss: 15829.912109375\n",
      "x: 14396.18017578125, t: 0, y: 1433.7319946289062\n",
      "Epoch 39:\n",
      "Epoch loss: 15788.4287109375\n",
      "x: 14356.3642578125, t: 0, y: 1432.0644989013672\n",
      "Epoch 40:\n",
      "Epoch loss: 15752.265380859375\n",
      "x: 14322.032470703125, t: 0, y: 1430.2328033447266\n",
      "Epoch 41:\n",
      "Epoch loss: 15717.121337890625\n",
      "x: 14288.711303710938, t: 0, y: 1428.4098815917969\n",
      "Epoch 42:\n",
      "Epoch loss: 15683.015991210938\n",
      "x: 14256.266479492188, t: 0, y: 1426.7498016357422\n",
      "Epoch 43:\n",
      "Epoch loss: 15651.398193359375\n",
      "x: 14226.54736328125, t: 0, y: 1424.8509216308594\n",
      "Epoch 44:\n",
      "Epoch loss: 15621.822021484375\n",
      "x: 14198.708984375, t: 0, y: 1423.113052368164\n",
      "Epoch 45:\n",
      "Epoch loss: 15591.30908203125\n",
      "x: 14169.912841796875, t: 0, y: 1421.3961029052734\n",
      "Epoch 46:\n",
      "Epoch loss: 15564.074096679688\n",
      "x: 14144.411743164062, t: 0, y: 1419.6622924804688\n",
      "Epoch 47:\n",
      "Epoch loss: 15535.390869140625\n",
      "x: 14117.422973632812, t: 0, y: 1417.9679260253906\n",
      "Epoch 48:\n",
      "Epoch loss: 15509.101928710938\n",
      "x: 14092.780517578125, t: 0, y: 1416.3213653564453\n",
      "Epoch 49:\n",
      "Epoch loss: 15483.4521484375\n",
      "x: 14068.65185546875, t: 0, y: 1414.8004608154297\n",
      "Epoch 50:\n",
      "Epoch loss: 15458.107299804688\n",
      "x: 14044.877685546875, t: 0, y: 1413.2295227050781\n",
      "Epoch 51:\n",
      "Epoch loss: 15433.285522460938\n",
      "x: 14021.573486328125, t: 0, y: 1411.7118530273438\n",
      "Epoch 52:\n",
      "Epoch loss: 15411.762329101562\n",
      "x: 14001.409790039062, t: 0, y: 1410.3524017333984\n",
      "Epoch 53:\n",
      "Epoch loss: 15389.711181640625\n",
      "x: 13980.582641601562, t: 0, y: 1409.1285858154297\n",
      "Epoch 54:\n",
      "Epoch loss: 15366.402221679688\n",
      "x: 13958.605834960938, t: 0, y: 1407.7964477539062\n",
      "Epoch 55:\n",
      "Epoch loss: 15345.788940429688\n",
      "x: 13939.287231445312, t: 0, y: 1406.5017852783203\n",
      "Epoch 56:\n",
      "Epoch loss: 15325.448608398438\n",
      "x: 13919.948608398438, t: 0, y: 1405.4999694824219\n",
      "Epoch 57:\n",
      "Epoch loss: 15306.859619140625\n",
      "x: 13902.581420898438, t: 0, y: 1404.2784729003906\n",
      "Epoch 58:\n",
      "Epoch loss: 15287.232543945312\n",
      "x: 13883.815795898438, t: 0, y: 1403.4167175292969\n",
      "Epoch 59:\n",
      "Epoch loss: 15269.6142578125\n",
      "x: 13866.9404296875, t: 0, y: 1402.6740798950195\n",
      "Epoch 60:\n",
      "Epoch loss: 15250.095581054688\n",
      "x: 13848.239624023438, t: 0, y: 1401.8560256958008\n",
      "Epoch 61:\n",
      "Epoch loss: 15233.989624023438\n",
      "x: 13832.769287109375, t: 0, y: 1401.2202911376953\n",
      "Epoch 62:\n",
      "Epoch loss: 15216.31396484375\n",
      "x: 13815.759399414062, t: 0, y: 1400.5546875\n",
      "Epoch 63:\n",
      "Epoch loss: 15202.578735351562\n",
      "x: 13802.520874023438, t: 0, y: 1400.0580139160156\n",
      "Epoch 64:\n",
      "Epoch loss: 15187.760498046875\n",
      "x: 13788.07666015625, t: 0, y: 1399.6838073730469\n",
      "Epoch 65:\n",
      "Epoch loss: 15176.339477539062\n",
      "x: 13776.964721679688, t: 0, y: 1399.3748168945312\n",
      "Epoch 66:\n",
      "Epoch loss: 15157.907104492188\n",
      "x: 13758.9365234375, t: 0, y: 1398.970703125\n",
      "Epoch 67:\n",
      "Epoch loss: 15147.822998046875\n",
      "x: 13749.173828125, t: 0, y: 1398.6489868164062\n",
      "Epoch 68:\n",
      "Epoch loss: 15134.2783203125\n",
      "x: 13735.786499023438, t: 0, y: 1398.4918594360352\n",
      "Epoch 69:\n",
      "Epoch loss: 15121.785278320312\n",
      "x: 13723.443115234375, t: 0, y: 1398.3421325683594\n",
      "Epoch 70:\n",
      "Epoch loss: 15108.677490234375\n",
      "x: 13710.649780273438, t: 0, y: 1398.027458190918\n",
      "Epoch 71:\n",
      "Epoch loss: 15099.740478515625\n",
      "x: 13701.869873046875, t: 0, y: 1397.8704833984375\n",
      "Epoch 72:\n",
      "Epoch loss: 15086.791259765625\n",
      "x: 13689.1201171875, t: 0, y: 1397.671142578125\n",
      "Epoch 73:\n",
      "Epoch loss: 15077.0771484375\n",
      "x: 13679.557495117188, t: 0, y: 1397.5196990966797\n",
      "Epoch 74:\n",
      "Epoch loss: 15067.664794921875\n",
      "x: 13670.222778320312, t: 0, y: 1397.4419250488281\n",
      "Epoch 75:\n",
      "Epoch loss: 15056.292358398438\n",
      "x: 13658.987182617188, t: 0, y: 1397.3052139282227\n",
      "Epoch 76:\n",
      "Epoch loss: 15048.492431640625\n",
      "x: 13651.342651367188, t: 0, y: 1397.1497344970703\n",
      "Epoch 77:\n",
      "Epoch loss: 15038.70703125\n",
      "x: 13641.660766601562, t: 0, y: 1397.0463333129883\n",
      "Epoch 78:\n",
      "Epoch loss: 15030.535766601562\n",
      "x: 13633.471923828125, t: 0, y: 1397.0639877319336\n",
      "Epoch 79:\n",
      "Epoch loss: 15022.19921875\n",
      "x: 13625.307861328125, t: 0, y: 1396.8912200927734\n",
      "Epoch 80:\n",
      "Epoch loss: 15014.9072265625\n",
      "x: 13618.142456054688, t: 0, y: 1396.7646255493164\n",
      "Epoch 81:\n",
      "Epoch loss: 15007.318725585938\n",
      "x: 13610.58642578125, t: 0, y: 1396.7322845458984\n",
      "Epoch 82:\n",
      "Epoch loss: 14999.612548828125\n",
      "x: 13602.986694335938, t: 0, y: 1396.6260528564453\n",
      "Epoch 83:\n",
      "Epoch loss: 14993.113037109375\n",
      "x: 13596.602416992188, t: 0, y: 1396.5105895996094\n",
      "Epoch 84:\n",
      "Epoch loss: 14986.188720703125\n",
      "x: 13589.715454101562, t: 0, y: 1396.4731140136719\n",
      "Epoch 85:\n",
      "Epoch loss: 14978.024658203125\n",
      "x: 13581.616943359375, t: 0, y: 1396.4078063964844\n",
      "Epoch 86:\n",
      "Epoch loss: 14972.72216796875\n",
      "x: 13576.429931640625, t: 0, y: 1396.2923126220703\n",
      "Epoch 87:\n",
      "Epoch loss: 14965.976806640625\n",
      "x: 13569.77685546875, t: 0, y: 1396.2000427246094\n",
      "Epoch 88:\n",
      "Epoch loss: 14960.056274414062\n",
      "x: 13563.8544921875, t: 0, y: 1396.2017669677734\n",
      "Epoch 89:\n",
      "Epoch loss: 14954.821044921875\n",
      "x: 13558.681640625, t: 0, y: 1396.1395263671875\n",
      "Epoch 90:\n",
      "Epoch loss: 14948.381713867188\n",
      "x: 13552.365600585938, t: 0, y: 1396.0162048339844\n",
      "Epoch 91:\n",
      "Epoch loss: 14943.3359375\n",
      "x: 13547.38720703125, t: 0, y: 1395.9486999511719\n",
      "Epoch 92:\n",
      "Epoch loss: 14938.087768554688\n",
      "x: 13542.165649414062, t: 0, y: 1395.9221954345703\n",
      "Epoch 93:\n",
      "Epoch loss: 14932.396606445312\n",
      "x: 13536.48974609375, t: 0, y: 1395.906837463379\n",
      "Epoch 94:\n",
      "Epoch loss: 14927.74072265625\n",
      "x: 13531.984985351562, t: 0, y: 1395.7555084228516\n",
      "Epoch 95:\n",
      "Epoch loss: 14922.623046875\n",
      "x: 13526.913330078125, t: 0, y: 1395.7098083496094\n",
      "Epoch 96:\n",
      "Epoch loss: 14918.06689453125\n",
      "x: 13522.372192382812, t: 0, y: 1395.6947937011719\n",
      "Epoch 97:\n",
      "Epoch loss: 14912.917236328125\n",
      "x: 13517.285034179688, t: 0, y: 1395.6323699951172\n",
      "Epoch 98:\n",
      "Epoch loss: 14907.94189453125\n",
      "x: 13512.37841796875, t: 0, y: 1395.5635070800781\n",
      "Epoch 99:\n",
      "Epoch loss: 14904.469970703125\n",
      "x: 13508.867919921875, t: 0, y: 1395.6018524169922\n",
      "Epoch 100:\n",
      "Epoch loss: 14900.18603515625\n",
      "x: 13504.69189453125, t: 0, y: 1395.4941177368164\n",
      "Epoch 101:\n",
      "Epoch loss: 14895.08154296875\n",
      "x: 13499.666748046875, t: 0, y: 1395.4150390625\n",
      "Epoch 102:\n",
      "Epoch loss: 14890.94775390625\n",
      "x: 13495.575561523438, t: 0, y: 1395.3721008300781\n",
      "Epoch 103:\n",
      "Epoch loss: 14886.69873046875\n",
      "x: 13491.3603515625, t: 0, y: 1395.338394165039\n",
      "Epoch 104:\n",
      "Epoch loss: 14882.228515625\n",
      "x: 13486.916137695312, t: 0, y: 1395.3123626708984\n",
      "Epoch 105:\n",
      "Epoch loss: 14878.597534179688\n",
      "x: 13483.357666015625, t: 0, y: 1395.2398986816406\n",
      "Epoch 106:\n",
      "Epoch loss: 14874.644775390625\n",
      "x: 13479.4765625, t: 0, y: 1395.1683349609375\n",
      "Epoch 107:\n",
      "Epoch loss: 14871.674438476562\n",
      "x: 13476.523559570312, t: 0, y: 1395.1508026123047\n",
      "Epoch 108:\n",
      "Epoch loss: 14867.412963867188\n",
      "x: 13472.29736328125, t: 0, y: 1395.1156921386719\n",
      "Epoch 109:\n",
      "Epoch loss: 14863.315551757812\n",
      "x: 13468.146850585938, t: 0, y: 1395.1688079833984\n",
      "Epoch 110:\n",
      "Epoch loss: 14860.491577148438\n",
      "x: 13465.39013671875, t: 0, y: 1395.1014404296875\n",
      "Epoch 111:\n",
      "Epoch loss: 14856.644409179688\n",
      "x: 13461.650634765625, t: 0, y: 1394.993911743164\n",
      "Epoch 112:\n",
      "Epoch loss: 14853.786743164062\n",
      "x: 13458.801635742188, t: 0, y: 1394.985122680664\n",
      "Epoch 113:\n",
      "Epoch loss: 14850.702880859375\n",
      "x: 13455.803100585938, t: 0, y: 1394.8997344970703\n",
      "Epoch 114:\n",
      "Epoch loss: 14849.394897460938\n",
      "x: 13454.507690429688, t: 0, y: 1394.887222290039\n",
      "Epoch 115:\n",
      "Epoch loss: 14845.361938476562\n",
      "x: 13450.447875976562, t: 0, y: 1394.9141998291016\n",
      "Epoch 116:\n",
      "Epoch loss: 14840.957641601562\n",
      "x: 13446.070556640625, t: 0, y: 1394.8870849609375\n",
      "Epoch 117:\n",
      "Epoch loss: 14837.583740234375\n",
      "x: 13442.831787109375, t: 0, y: 1394.751968383789\n",
      "Epoch 118:\n",
      "Epoch loss: 14833.846313476562\n",
      "x: 13439.115112304688, t: 0, y: 1394.7312469482422\n",
      "Epoch 119:\n",
      "Epoch loss: 14830.932861328125\n",
      "x: 13436.22021484375, t: 0, y: 1394.7127075195312\n",
      "Epoch 120:\n",
      "Epoch loss: 14828.182739257812\n",
      "x: 13433.478515625, t: 0, y: 1394.7042083740234\n",
      "Epoch 121:\n",
      "Epoch loss: 14825.505981445312\n",
      "x: 13430.861572265625, t: 0, y: 1394.6444244384766\n",
      "Epoch 122:\n",
      "Epoch loss: 14822.839477539062\n",
      "x: 13428.138061523438, t: 0, y: 1394.7012023925781\n",
      "Epoch 123:\n",
      "Epoch loss: 14819.498901367188\n",
      "x: 13424.919921875, t: 0, y: 1394.5789337158203\n",
      "Epoch 124:\n",
      "Epoch loss: 14817.076782226562\n",
      "x: 13422.42529296875, t: 0, y: 1394.6515350341797\n",
      "Epoch 125:\n",
      "Epoch loss: 14814.4404296875\n",
      "x: 13419.921997070312, t: 0, y: 1394.5184631347656\n",
      "Epoch 126:\n",
      "Epoch loss: 14813.332153320312\n",
      "x: 13418.837890625, t: 0, y: 1394.4940872192383\n",
      "Epoch 127:\n",
      "Epoch loss: 14810.044311523438\n",
      "x: 13415.564331054688, t: 0, y: 1394.4798583984375\n",
      "Epoch 128:\n",
      "Epoch loss: 14806.913940429688\n",
      "x: 13412.484375, t: 0, y: 1394.4296264648438\n",
      "Epoch 129:\n",
      "Epoch loss: 14804.359619140625\n",
      "x: 13409.958374023438, t: 0, y: 1394.401351928711\n",
      "Epoch 130:\n",
      "Epoch loss: 14802.558959960938\n",
      "x: 13408.121948242188, t: 0, y: 1394.4369659423828\n",
      "Epoch 131:\n",
      "Epoch loss: 14800.178100585938\n",
      "x: 13405.879150390625, t: 0, y: 1394.2991180419922\n",
      "Epoch 132:\n",
      "Epoch loss: 14797.418212890625\n",
      "x: 13403.145751953125, t: 0, y: 1394.2722778320312\n",
      "Epoch 133:\n",
      "Epoch loss: 14794.703125\n",
      "x: 13400.402954101562, t: 0, y: 1394.300277709961\n",
      "Epoch 134:\n",
      "Epoch loss: 14794.734741210938\n",
      "x: 13400.431518554688, t: 0, y: 1394.3030853271484\n",
      "Epoch 135:\n",
      "Epoch loss: 14792.810791015625\n",
      "x: 13398.625610351562, t: 0, y: 1394.1851654052734\n",
      "Epoch 136:\n",
      "Epoch loss: 14788.3388671875\n",
      "x: 13394.165649414062, t: 0, y: 1394.173225402832\n",
      "Epoch 137:\n",
      "Epoch loss: 14787.120361328125\n",
      "x: 13392.959106445312, t: 0, y: 1394.1612091064453\n",
      "Epoch 138:\n",
      "Epoch loss: 14785.084594726562\n",
      "x: 13390.909301757812, t: 0, y: 1394.175308227539\n",
      "Epoch 139:\n",
      "Epoch loss: 14782.27392578125\n",
      "x: 13388.19775390625, t: 0, y: 1394.076171875\n",
      "Epoch 140:\n",
      "Epoch loss: 14780.18212890625\n",
      "x: 13386.124389648438, t: 0, y: 1394.0576934814453\n",
      "Epoch 141:\n",
      "Epoch loss: 14778.233276367188\n",
      "x: 13384.224975585938, t: 0, y: 1394.0081024169922\n",
      "Epoch 142:\n",
      "Epoch loss: 14776.568603515625\n",
      "x: 13382.53955078125, t: 0, y: 1394.0292053222656\n",
      "Epoch 143:\n",
      "Epoch loss: 14776.096557617188\n",
      "x: 13382.119995117188, t: 0, y: 1393.9765625\n",
      "Epoch 144:\n",
      "Epoch loss: 14773.446411132812\n",
      "x: 13379.420654296875, t: 0, y: 1394.0257720947266\n",
      "Epoch 145:\n",
      "Epoch loss: 14771.528076171875\n",
      "x: 13377.6162109375, t: 0, y: 1393.9118194580078\n",
      "Epoch 146:\n",
      "Epoch loss: 14770.114624023438\n",
      "x: 13376.195922851562, t: 0, y: 1393.9186248779297\n",
      "Epoch 147:\n",
      "Epoch loss: 14767.503051757812\n",
      "x: 13373.609252929688, t: 0, y: 1393.8938598632812\n",
      "Epoch 148:\n",
      "Epoch loss: 14765.796142578125\n",
      "x: 13371.94677734375, t: 0, y: 1393.8494110107422\n",
      "Epoch 149:\n",
      "Epoch loss: 14765.219360351562\n",
      "x: 13371.394287109375, t: 0, y: 1393.8250427246094\n",
      "Epoch 150:\n",
      "Epoch loss: 14762.197509765625\n",
      "x: 13368.39599609375, t: 0, y: 1393.8014678955078\n",
      "Epoch 151:\n",
      "Epoch loss: 14761.317138671875\n",
      "x: 13367.5322265625, t: 0, y: 1393.7848205566406\n",
      "Epoch 152:\n",
      "Epoch loss: 14759.302612304688\n",
      "x: 13365.5302734375, t: 0, y: 1393.772331237793\n",
      "Epoch 153:\n",
      "Epoch loss: 14757.239135742188\n",
      "x: 13363.478149414062, t: 0, y: 1393.760971069336\n",
      "Epoch 154:\n",
      "Epoch loss: 14755.974487304688\n",
      "x: 13362.276733398438, t: 0, y: 1393.6978302001953\n",
      "Epoch 155:\n",
      "Epoch loss: 14754.284545898438\n",
      "x: 13360.61376953125, t: 0, y: 1393.6708374023438\n",
      "Epoch 156:\n",
      "Epoch loss: 14753.147094726562\n",
      "x: 13359.499877929688, t: 0, y: 1393.6471710205078\n",
      "Epoch 157:\n",
      "Epoch loss: 14751.280883789062\n",
      "x: 13357.609497070312, t: 0, y: 1393.6715545654297\n",
      "Epoch 158:\n",
      "Epoch loss: 14750.104736328125\n",
      "x: 13356.483276367188, t: 0, y: 1393.621566772461\n",
      "Epoch 159:\n",
      "Epoch loss: 14748.372924804688\n",
      "x: 13354.78564453125, t: 0, y: 1393.5873107910156\n",
      "Epoch 160:\n",
      "Epoch loss: 14747.647827148438\n",
      "x: 13354.095581054688, t: 0, y: 1393.5522918701172\n",
      "Epoch 161:\n",
      "Epoch loss: 14745.898315429688\n",
      "x: 13352.334106445312, t: 0, y: 1393.5639877319336\n",
      "Epoch 162:\n",
      "Epoch loss: 14744.7685546875\n",
      "x: 13351.235595703125, t: 0, y: 1393.532943725586\n",
      "Epoch 163:\n",
      "Epoch loss: 14742.865234375\n",
      "x: 13349.33056640625, t: 0, y: 1393.5347290039062\n",
      "Epoch 164:\n",
      "Epoch loss: 14742.932373046875\n",
      "x: 13349.468627929688, t: 0, y: 1393.4637908935547\n",
      "Epoch 165:\n",
      "Epoch loss: 14740.453979492188\n",
      "x: 13347.018798828125, t: 0, y: 1393.4354095458984\n",
      "Epoch 166:\n",
      "Epoch loss: 14739.432373046875\n",
      "x: 13346.021362304688, t: 0, y: 1393.4112548828125\n",
      "Epoch 167:\n",
      "Epoch loss: 14738.766967773438\n",
      "x: 13345.360473632812, t: 0, y: 1393.4063262939453\n",
      "Epoch 168:\n",
      "Epoch loss: 14736.691284179688\n",
      "x: 13343.31591796875, t: 0, y: 1393.375259399414\n",
      "Epoch 169:\n",
      "Epoch loss: 14735.808471679688\n",
      "x: 13342.40966796875, t: 0, y: 1393.3988037109375\n",
      "Epoch 170:\n",
      "Epoch loss: 14733.93212890625\n",
      "x: 13340.547485351562, t: 0, y: 1393.3848114013672\n",
      "Epoch 171:\n",
      "Epoch loss: 14733.18798828125\n",
      "x: 13339.859985351562, t: 0, y: 1393.3280715942383\n",
      "Epoch 172:\n",
      "Epoch loss: 14731.888793945312\n",
      "x: 13338.615478515625, t: 0, y: 1393.2732391357422\n",
      "Epoch 173:\n",
      "Epoch loss: 14731.22412109375\n",
      "x: 13337.907470703125, t: 0, y: 1393.3167877197266\n",
      "Epoch 174:\n",
      "Epoch loss: 14728.906494140625\n",
      "x: 13335.647094726562, t: 0, y: 1393.2594909667969\n",
      "Epoch 175:\n",
      "Epoch loss: 14728.492309570312\n",
      "x: 13335.182495117188, t: 0, y: 1393.3097381591797\n",
      "Epoch 176:\n",
      "Epoch loss: 14727.122802734375\n",
      "x: 13333.900634765625, t: 0, y: 1393.2222290039062\n",
      "Epoch 177:\n",
      "Epoch loss: 14725.723876953125\n",
      "x: 13332.547241210938, t: 0, y: 1393.176513671875\n",
      "Epoch 178:\n",
      "Epoch loss: 14725.373657226562\n",
      "x: 13332.199340820312, t: 0, y: 1393.1742095947266\n",
      "Epoch 179:\n",
      "Epoch loss: 14724.037353515625\n",
      "x: 13330.830444335938, t: 0, y: 1393.2068786621094\n",
      "Epoch 180:\n",
      "Epoch loss: 14722.5361328125\n",
      "x: 13329.373291015625, t: 0, y: 1393.1629028320312\n",
      "Epoch 181:\n",
      "Epoch loss: 14721.442504882812\n",
      "x: 13328.290893554688, t: 0, y: 1393.1515502929688\n",
      "Epoch 182:\n",
      "Epoch loss: 14720.720092773438\n",
      "x: 13327.588623046875, t: 0, y: 1393.1314392089844\n",
      "Epoch 183:\n",
      "Epoch loss: 14720.290161132812\n",
      "x: 13327.210693359375, t: 0, y: 1393.0795593261719\n",
      "Epoch 184:\n",
      "Epoch loss: 14718.360473632812\n",
      "x: 13325.260864257812, t: 0, y: 1393.099624633789\n",
      "Epoch 185:\n",
      "Epoch loss: 14717.55419921875\n",
      "x: 13324.464599609375, t: 0, y: 1393.0895462036133\n",
      "Epoch 186:\n",
      "Epoch loss: 14716.721435546875\n",
      "x: 13323.686157226562, t: 0, y: 1393.035400390625\n",
      "Epoch 187:\n",
      "Epoch loss: 14715.49609375\n",
      "x: 13322.5, t: 0, y: 1392.9960479736328\n",
      "Epoch 188:\n",
      "Epoch loss: 14714.58056640625\n",
      "x: 13321.590576171875, t: 0, y: 1392.989990234375\n",
      "Epoch 189:\n",
      "Epoch loss: 14713.783081054688\n",
      "x: 13320.7783203125, t: 0, y: 1393.0049133300781\n",
      "Epoch 190:\n",
      "Epoch loss: 14713.162963867188\n",
      "x: 13320.149291992188, t: 0, y: 1393.0136032104492\n",
      "Epoch 191:\n",
      "Epoch loss: 14712.31298828125\n",
      "x: 13319.375244140625, t: 0, y: 1392.937515258789\n",
      "Epoch 192:\n",
      "Epoch loss: 14710.829223632812\n",
      "x: 13317.89794921875, t: 0, y: 1392.9314880371094\n",
      "Epoch 193:\n",
      "Epoch loss: 14710.382202148438\n",
      "x: 13317.451171875, t: 0, y: 1392.931137084961\n",
      "Epoch 194:\n",
      "Epoch loss: 14709.450439453125\n",
      "x: 13316.491455078125, t: 0, y: 1392.9590148925781\n",
      "Epoch 195:\n",
      "Epoch loss: 14708.421020507812\n",
      "x: 13315.53271484375, t: 0, y: 1392.8882904052734\n",
      "Epoch 196:\n",
      "Epoch loss: 14707.708862304688\n",
      "x: 13314.835083007812, t: 0, y: 1392.8738250732422\n",
      "Epoch 197:\n",
      "Epoch loss: 14706.695190429688\n",
      "x: 13313.8564453125, t: 0, y: 1392.8388061523438\n",
      "Epoch 198:\n",
      "Epoch loss: 14706.070922851562\n",
      "x: 13313.23974609375, t: 0, y: 1392.8312377929688\n",
      "Epoch 199:\n",
      "Epoch loss: 14705.60009765625\n",
      "x: 13312.760009765625, t: 0, y: 1392.8400802612305\n"
     ]
    },
    {
     "data": {
      "image/png": "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MECj0UjblRER2ZurjzOu3j8icj5bxxnXexYkEREREbVaDLc2KrluwrVyk7ObQURERER1YLi1wV/STuD+Jen44kC+s5tCRERERHVguLVBaDsvCAHsO3PV2U0hIiIiojow3NpgcOd2AIBDZ6/BVG12cmuIiIiI6FYMtzboFugNvzZKVFTV4NjFEmc3h4iIiIhuwXBrA5lMhsGd/QAA+84UO7k1RERERHQrhlsbWZYmcN0tERERUfPDcGsjrrslIiIiar4Ybm3EdbdEREREzRfDrY247paIiIio+WK4bQCuuyUiIiJqnhhuG4DrbomIiIiaJ4bbBrh53e3RCyXObg4RERER3cBw2wDW6265NIGIiIiouWC4baDf1t3ypjIiIiKi5oLhtoGkdbfnirnuloiIiKiZYLhtIMu628oqM9fdEhERETUTDLcNJJPJEB3OdbdEREREzQnDbSNYwu2Bs9ec3BIiIiIiAhhuG2VQeO2626yzxaiu4bpbIiIiImdjuG2ECK0P1B5uKDfVIOeSwdnNISIiImr1GG4bQS6XYZBlaUIetwQjIiIicjaG20ayhNv9DLdERERETsdw20iWdbcHzxbDbBZObg0RubKVK1eiU6dO8PDwQHR0NA4cOHDX+o0bNyIiIgIeHh7o3bs3tm7desfaF154ATKZDO+9956dW01E1LQYbhupV7AaXkoF9BVV+KWw1NnNISIXtWHDBiQlJeGNN97A4cOH0bdvX8THx6OwsLDO+r1792LSpEmYPn06jhw5grFjx2Ls2LE4fvz4bbWbNm3Cvn37EBwc7OhuEBE5HMNtI7kp5IgKawsA2M9H8RKRgyxbtgzPPfccpk6disjISKxevRpeXl747LPP6qxfsWIFRo0ahXnz5qFHjx5YsmQJ+vfvjw8++MCq7uLFi5g1axbWrVsHd3f3pugKEZFDMdzaQTRvKiMiBzKZTMjKykJsbKx0TC6XIzY2FpmZmXV+JjMz06oeAOLj463qzWYznnrqKcybNw89e/asV1uMRiMMBoPVi4ioOWG4tQPLutv9ecUQgutuici+rly5gpqaGgQFBVkdDwoKgk6nq/MzOp3unvVvv/023Nzc8NJLL9W7LSkpKdBoNNIrJCTEhp4QETkew60d9OmogbtChitlRly4VuHs5hAR3VNWVhZWrFiB1NRUyGSyen8uOTkZer1eep0/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",
      "text/plain": [
       "<Figure size 800x800 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from models import GenericDataset, train_decoder\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "# get the training data\n",
    "dataset = GenericDataset(np.array(source_data))\n",
    "dataloader = DataLoader(dataset, shuffle=True, batch_size=100)\n",
    "device='cpu'\n",
    "plot_curves=False\n",
    "print_logs=True\n",
    "num_epochs=200\n",
    "lr_start=0.0002\n",
    "lr_end=0.00005\n",
    "x_dim=25\n",
    "z_dim=1\n",
    "x_mode=[0]*3+[4]+[0]*2+[2]*(x_dim-6)\n",
    "p_t_z_nn = False\n",
    "\n",
    "decoder, losses = train_decoder(device, plot_curves, print_logs, \n",
    "                                  dataloader, num_epochs, lr_start, lr_end, \n",
    "                                  x_dim, z_dim, p_t_z_nn, p_t_z_nn_layers=3,\n",
    "                                  p_t_z_nn_width=30, p_x_z_nn_layers=3, p_x_z_nn_width=30, \n",
    "                                  p_y_nn_layers =3, p_y_nn_width=30,\n",
    "                                  q_z_nn_layers=3, q_z_nn_width=30,\n",
    "                                  x_mode=x_mode, y_loss_type = 2, y_separate_heads=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABjYAAAGGCAYAAADYTbhfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAA9hAAAPYQGoP6dpAABnVElEQVR4nO3deVyU5f7/8fcAgsgIipqp4JJaWppLahqaC6222aKVZWnlkplLm0tRmh0166R43CtTO3pMKzz5jUpzS9IMk2xXSxS0XEBlcUGE+/eHv5kjsc0wM8zc8Ho+HvN4yNzXfV2fuRvs+vi5r/uyGIZhCAAAAAAAAAAAwAT8vB0AAAAAAAAAAACAoyhsAAAAAAAAAAAA06CwAQAAAAAAAAAATIPCBgAAAAAAAAAAMA0KGwAAAAAAAAAAwDQobAAAAAAAAAAAANOgsAEAAAAAAAAAAEyDwgYAAAAAAAAAADANChsAAAAAAAAAAMA0KGwAAAAAAAAAAADToLABAAAAAAAAAABMg8IGAJ/10ksvyWKx6PXXX3d7340bN5bFYtGmTZvc3re73XLLLbJYLNqwYYNL/QwcOFAWi0UDBw50T2Awrcr6XaisnxsAABSNfOMC8g2URWX9711ZPzfgiyhsAPBJBw8e1FtvvaU6depoxIgR3g7Ho7Zs2aKJEyfq3XffLfL4xIkTJUnPPfec8vPzyzEyAAAAoGIi3/ifipBvLF68WBMnTjRFIcmTuA4AKhMKGwB80osvvqgzZ87ohRdeUEhIiLfD8aiFCxdq0qRJ2rZtW5HHO3furJtvvllJSUn697//XeZx6tWrpyuuuEL16tUrcx+AmfE7AAAAbMg3/qci5BuLFy/WpEmTKv0/6HMdPI+cAvAdFDYA+JxDhw5p2bJlCgwM1GOPPebtcDxu+/btkqRrr7222DbDhg2TJE2fPr3M40ydOlW//fabpk6dWuY+ADPjdwAAAEjkG0Uh3wAcw/cc8B0UNgD4nLffflt5eXnq3bu3wsPDvR2OR504cUJ79+6VJHXq1KnYdrZr8fPPP+vrr78ur/AAAACACod8ozDyDQCA2VDYAOARkydPlsViUc+ePZWVlaV//OMf6tSpk2rWrKmgoCC1aNFCU6dOVV5eXoHzDMOwP/u1f//+RfZ95MgRWSwWWSwWffHFFyXGMWLECFksFl133XUyDMOh2L///nt7/6W9pkyZ4lCff/f777/LYrEUSKTatm1boO/XXnvNfiwwMFD33nuvpAtLycuipE3OevToIYvFookTJ8owDL399tu69tprFRoaqurVq6tLly4uLUuXpA8++EC33nqr6tatqypVqqhGjRpq3ry57rzzTs2ZM0dnz54t8rxNmzapb9++atCggYKCglS7dm1FR0frvffeK/T9sbFt1rh48eJi43H0euTm5uqf//ynOnTooBo1ahS5CWRqaqpeeOEFtW3bVmFhYQoODlbTpk111113aenSpcV+tv3792v06NG66qqrZLVaVa1aNbVo0UKjRo1SSkpKsbE7YtmyZYqKilL16tUVFhama6+9VgsXLnT496As1/3i63b+/HnNmDFD7dq1k9Vq1SWXXKI+ffpo165d9vanT5/Wa6+9platWikkJES1atXS/fffrz/++KPYuE6cOKF3331X/fr1U+vWrRUeHq6qVauqUaNG6t+/v7755ptiz/X27wAAAHAf8o2SVZZ8Y/HixbJYLNq8ebMkadKkSYWu4f79+yW5No/8+2coLUcwDEPvvfeeunTpUuR83JENqJ3JFZy5Ds4gpyiMnALwIQYAeECfPn0MSca9995rNGnSxJBkWCwWw2q1GpLsr4ceeqjAeT/88IP92F9//VVs/5dddpkhyZg0aVKxbb7//nvD39/f8PPzM3bs2FHgWKNGjQxJxsaNGwudt3LlSqNu3brFvqpXr26P8bPPPnPuwvx/n376qVG3bl0jJCTEkGQEBgYWGufvfb///vuGJKNu3bplGvPRRx81JBmPPvpooWPdu3c3JBkvvfSScddddxmSjICAACM0NLTAf6+XX365TGMPGjSoQD9Wq9WoVq1agfeSk5MLnTdmzBj7cYvFYtSoUcPw9/e3v9erVy8jMzOz0Hm2/77vvfeeS9dj7NixxnXXXWe/HjVr1jQsFkuB783SpUuNqlWr2mMKDAw0atWqZQQEBNjfS0pKKjTGv//9byMoKMjeJigoyAgODrb/XL16deOLL75w4OoWlJ+fX+B6WywWo2bNmoafn58hyXjggQdK/OyGUfbrbrtuEyZMMKKjo+3Xw/Y9t/23T0xMNNLS0ox27doZkoyqVasW+OyXXHKJceDAgSJje+WVV+zt/P39jZo1axa4jhaLxYiNjS3yXG/+DgAAAPci3yhZZck3VqxY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",
      "text/plain": [
       "<Figure size 1600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# test the decoder on source domain data and target domain data\n",
    "plot_py_zt(source_data, target_data, decoder.y_nn, num_test_sample=1000, loss_type = 2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Pretrain a VAE for the proxy $X$ using source domain data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0:\n",
      "Epoch loss: 23471.779296875\n",
      "x: 21795.118408203125, t: 0, y: 1651.2770538330078, kld: 25.38362169265747\n",
      "Epoch 1:\n",
      "Epoch loss: 23367.363525390625\n",
      "x: 21718.574951171875, t: 0, y: 1629.7302856445312, kld: 19.05807590484619\n",
      "Epoch 2:\n",
      "Epoch loss: 23243.367431640625\n",
      "x: 21619.17138671875, t: 0, y: 1610.184585571289, kld: 14.011236667633057\n",
      "Epoch 3:\n",
      "Epoch loss: 23107.398681640625\n",
      "x: 21505.367919921875, t: 0, y: 1591.9717712402344, kld: 10.059119284152985\n",
      "Epoch 4:\n",
      "Epoch loss: 22971.54736328125\n",
      "x: 21380.65966796875, t: 0, y: 1583.8083801269531, kld: 7.079085469245911\n",
      "Epoch 5:\n",
      "Epoch loss: 22816.894287109375\n",
      "x: 21239.089599609375, t: 0, y: 1572.6972045898438, kld: 5.108078360557556\n",
      "Epoch 6:\n",
      "Epoch loss: 22638.486572265625\n",
      "x: 21074.500244140625, t: 0, y: 1559.822509765625, kld: 4.163746029138565\n",
      "Epoch 7:\n",
      "Epoch loss: 22426.869873046875\n",
      "x: 20870.478271484375, t: 0, y: 1551.5818786621094, kld: 4.809587597846985\n",
      "Epoch 8:\n",
      "Epoch loss: 22184.1396484375\n",
      "x: 20635.341552734375, t: 0, y: 1541.6329040527344, kld: 7.16469144821167\n",
      "Epoch 9:\n",
      "Epoch loss: 21897.109130859375\n",
      "x: 20348.942138671875, t: 0, y: 1535.7733917236328, kld: 12.394034743309021\n",
      "Epoch 10:\n",
      "Epoch loss: 21612.086181640625\n",
      "x: 20068.067993164062, t: 0, y: 1523.6994171142578, kld: 20.318873047828674\n",
      "Epoch 11:\n",
      "Epoch loss: 21215.956298828125\n",
      "x: 19665.234497070312, t: 0, y: 1520.0765228271484, kld: 30.64542007446289\n",
      "Epoch 12:\n",
      "Epoch loss: 20830.552368164062\n",
      "x: 19265.4599609375, t: 0, y: 1518.2268676757812, kld: 46.86571931838989\n",
      "Epoch 13:\n",
      "Epoch loss: 20473.5048828125\n",
      "x: 18893.621948242188, t: 0, y: 1515.7921447753906, kld: 64.09114217758179\n",
      "Epoch 14:\n",
      "Epoch loss: 20175.545166015625\n",
      "x: 18595.397827148438, t: 0, y: 1513.0953674316406, kld: 67.0517954826355\n",
      "Epoch 15:\n",
      "Epoch loss: 19816.290283203125\n",
      "x: 18252.361572265625, t: 0, y: 1506.6756896972656, kld: 57.253355503082275\n",
      "Epoch 16:\n",
      "Epoch loss: 19550.094848632812\n",
      "x: 17993.761352539062, t: 0, y: 1505.214859008789, kld: 51.11873531341553\n",
      "Epoch 17:\n",
      "Epoch loss: 19289.11181640625\n",
      "x: 17743.113525390625, t: 0, y: 1499.2808532714844, kld: 46.717369556427\n",
      "Epoch 18:\n",
      "Epoch loss: 19041.825317382812\n",
      "x: 17503.1240234375, t: 0, y: 1493.4651336669922, kld: 45.23597311973572\n",
      "Epoch 19:\n",
      "Epoch loss: 18869.269775390625\n",
      "x: 17327.358276367188, t: 0, y: 1495.721206665039, kld: 46.19029688835144\n",
      "Epoch 20:\n",
      "Epoch loss: 18726.229614257812\n",
      "x: 17185.840087890625, t: 0, y: 1494.0635375976562, kld: 46.32596445083618\n",
      "Epoch 21:\n",
      "Epoch loss: 18524.613647460938\n",
      "x: 16989.435546875, t: 0, y: 1491.0702667236328, kld: 44.10804080963135\n",
      "Epoch 22:\n",
      "Epoch loss: 18330.73583984375\n",
      "x: 16800.056884765625, t: 0, y: 1489.4672241210938, kld: 41.21184802055359\n",
      "Epoch 23:\n",
      "Epoch loss: 18231.831420898438\n",
      "x: 16699.799438476562, t: 0, y: 1490.755142211914, kld: 41.27661848068237\n",
      "Epoch 24:\n",
      "Epoch loss: 18101.65625\n",
      "x: 16570.924072265625, t: 0, y: 1486.2174987792969, kld: 44.514665603637695\n",
      "Epoch 25:\n",
      "Epoch loss: 18026.37353515625\n",
      "x: 16498.246337890625, t: 0, y: 1483.343002319336, kld: 44.784029960632324\n",
      "Epoch 26:\n",
      "Epoch loss: 17913.023803710938\n",
      "x: 16391.322021484375, t: 0, y: 1476.7161102294922, kld: 44.9854302406311\n",
      "Epoch 27:\n",
      "Epoch loss: 17807.238037109375\n",
      "x: 16283.254150390625, t: 0, y: 1478.2122802734375, kld: 45.77173972129822\n",
      "Epoch 28:\n",
      "Epoch loss: 17704.740966796875\n",
      "x: 16181.12255859375, t: 0, y: 1475.5874481201172, kld: 48.0309796333313\n",
      "Epoch 29:\n",
      "Epoch loss: 17629.71240234375\n",
      "x: 16103.555297851562, t: 0, y: 1471.266616821289, kld: 54.89051914215088\n",
      "Epoch 30:\n",
      "Epoch loss: 17626.733520507812\n",
      "x: 16097.536865234375, t: 0, y: 1473.3094635009766, kld: 55.8873815536499\n",
      "Epoch 31:\n",
      "Epoch loss: 17571.28515625\n",
      "x: 16049.145263671875, t: 0, y: 1471.8340606689453, kld: 50.305840492248535\n",
      "Epoch 32:\n",
      "Epoch loss: 17451.474243164062\n",
      "x: 15934.689086914062, t: 0, y: 1466.7255554199219, kld: 50.05930948257446\n",
      "Epoch 33:\n",
      "Epoch loss: 17460.45263671875\n",
      "x: 15934.751831054688, t: 0, y: 1468.2072296142578, kld: 57.49377393722534\n",
      "Epoch 34:\n",
      "Epoch loss: 17365.258544921875\n",
      "x: 15839.169921875, t: 0, y: 1465.7374420166016, kld: 60.351176261901855\n",
      "Epoch 35:\n",
      "Epoch loss: 17355.221801757812\n",
      "x: 15830.100952148438, t: 0, y: 1463.366928100586, kld: 61.75426006317139\n",
      "Epoch 36:\n",
      "Epoch loss: 17298.013305664062\n",
      "x: 15773.653198242188, t: 0, y: 1459.3108673095703, kld: 65.04909563064575\n",
      "Epoch 37:\n",
      "Epoch loss: 17322.0849609375\n",
      "x: 15790.447631835938, t: 0, y: 1464.2012023925781, kld: 67.43629121780396\n",
      "Epoch 38:\n",
      "Epoch loss: 17276.416015625\n",
      "x: 15749.523193359375, t: 0, y: 1458.635498046875, kld: 68.25728178024292\n",
      "Epoch 39:\n",
      "Epoch loss: 17243.492919921875\n",
      "x: 15713.608642578125, t: 0, y: 1459.2544250488281, kld: 70.62993097305298\n",
      "Epoch 40:\n",
      "Epoch loss: 17208.775634765625\n",
      "x: 15677.880859375, t: 0, y: 1460.6191711425781, kld: 70.27569770812988\n",
      "Epoch 41:\n",
      "Epoch loss: 17236.689208984375\n",
      "x: 15702.8232421875, t: 0, y: 1460.7076416015625, kld: 73.15843677520752\n",
      "Epoch 42:\n",
      "Epoch loss: 17233.807983398438\n",
      "x: 15698.803833007812, t: 0, y: 1457.6624755859375, kld: 77.34189176559448\n",
      "Epoch 43:\n",
      "Epoch loss: 17208.345336914062\n",
      "x: 15669.50927734375, t: 0, y: 1458.7303619384766, kld: 80.10534238815308\n",
      "Epoch 44:\n",
      "Epoch loss: 17189.13134765625\n",
      "x: 15643.881103515625, t: 0, y: 1461.3979949951172, kld: 83.85217761993408\n",
      "Epoch 45:\n",
      "Epoch loss: 17183.109252929688\n",
      "x: 15641.55615234375, t: 0, y: 1457.7718200683594, kld: 83.78133201599121\n",
      "Epoch 46:\n",
      "Epoch loss: 17233.364501953125\n",
      "x: 15688.813110351562, t: 0, y: 1459.8584289550781, kld: 84.69288110733032\n",
      "Epoch 47:\n",
      "Epoch loss: 17169.75537109375\n",
      "x: 15622.362548828125, t: 0, y: 1460.8554382324219, kld: 86.53778266906738\n",
      "Epoch 48:\n",
      "Epoch loss: 17215.394287109375\n",
      "x: 15670.394775390625, t: 0, y: 1455.5711822509766, kld: 89.42822694778442\n",
      "Epoch 49:\n",
      "Epoch loss: 17181.782348632812\n",
      "x: 15633.17431640625, t: 0, y: 1460.303726196289, kld: 88.30445098876953\n",
      "Epoch 50:\n",
      "Epoch loss: 17202.639892578125\n",
      "x: 15649.475219726562, t: 0, y: 1462.322280883789, kld: 90.84228467941284\n",
      "Epoch 51:\n",
      "Epoch loss: 17173.102661132812\n",
      "x: 15622.7958984375, t: 0, y: 1457.2527770996094, kld: 93.05392074584961\n",
      "Epoch 52:\n",
      "Epoch loss: 17172.864990234375\n",
      "x: 15615.3671875, t: 0, y: 1460.913314819336, kld: 96.58473014831543\n",
      "Epoch 53:\n",
      "Epoch loss: 17180.1171875\n",
      "x: 15626.100463867188, t: 0, y: 1456.859634399414, kld: 97.15733051300049\n",
      "Epoch 54:\n",
      "Epoch loss: 17206.24951171875\n",
      "x: 15648.314453125, t: 0, y: 1460.909652709961, kld: 97.02520942687988\n",
      "Epoch 55:\n",
      "Epoch loss: 17163.007446289062\n",
      "x: 15603.14013671875, t: 0, y: 1462.2644653320312, kld: 97.60296583175659\n",
      "Epoch 56:\n",
      "Epoch loss: 17183.82275390625\n",
      "x: 15629.575561523438, t: 0, y: 1456.078353881836, kld: 98.16898965835571\n",
      "Epoch 57:\n",
      "Epoch loss: 17167.195434570312\n",
      "x: 15608.10546875, t: 0, y: 1457.9796295166016, kld: 101.11061191558838\n",
      "Epoch 58:\n",
      "Epoch loss: 17130.690795898438\n",
      "x: 15573.936767578125, t: 0, y: 1459.2550964355469, kld: 97.49887275695801\n",
      "Epoch 59:\n",
      "Epoch loss: 17166.7431640625\n",
      "x: 15613.483032226562, t: 0, y: 1458.6996307373047, kld: 94.56050872802734\n",
      "Epoch 60:\n",
      "Epoch loss: 17161.668579101562\n",
      "x: 15608.597534179688, t: 0, y: 1458.6209411621094, kld: 94.45006275177002\n",
      "Epoch 61:\n",
      "Epoch loss: 17138.352172851562\n",
      "x: 15584.156127929688, t: 0, y: 1457.5071258544922, kld: 96.68908596038818\n",
      "Epoch 62:\n",
      "Epoch loss: 17141.892700195312\n",
      "x: 15584.306518554688, t: 0, y: 1458.4218444824219, kld: 99.16404008865356\n",
      "Epoch 63:\n",
      "Epoch loss: 17135.878784179688\n",
      "x: 15576.891967773438, t: 0, y: 1458.0400848388672, kld: 100.9467830657959\n",
      "Epoch 64:\n",
      "Epoch loss: 17127.766967773438\n",
      "x: 15573.932495117188, t: 0, y: 1451.2200927734375, kld: 102.61440086364746\n",
      "Epoch 65:\n",
      "Epoch loss: 17118.587280273438\n",
      "x: 15559.250732421875, t: 0, y: 1453.0794525146484, kld: 106.25706672668457\n",
      "Epoch 66:\n",
      "Epoch loss: 17086.734619140625\n",
      "x: 15518.6220703125, t: 0, y: 1459.391586303711, kld: 108.72105693817139\n",
      "Epoch 67:\n",
      "Epoch loss: 17109.106323242188\n",
      "x: 15548.617553710938, t: 0, y: 1454.0918273925781, kld: 106.39671611785889\n",
      "Epoch 68:\n",
      "Epoch loss: 17136.856811523438\n",
      "x: 15570.918579101562, t: 0, y: 1458.5977630615234, kld: 107.3402853012085\n",
      "Epoch 69:\n",
      "Epoch loss: 17141.258544921875\n",
      "x: 15577.273315429688, t: 0, y: 1456.62255859375, kld: 107.36324214935303\n",
      "Epoch 70:\n",
      "Epoch loss: 17117.965576171875\n",
      "x: 15553.088012695312, t: 0, y: 1458.669662475586, kld: 106.20790576934814\n",
      "Epoch 71:\n",
      "Epoch loss: 17140.907958984375\n",
      "x: 15572.310668945312, t: 0, y: 1462.4123077392578, kld: 106.18496704101562\n",
      "Epoch 72:\n",
      "Epoch loss: 17125.781005859375\n",
      "x: 15565.070434570312, t: 0, y: 1458.1208038330078, kld: 102.58980464935303\n",
      "Epoch 73:\n",
      "Epoch loss: 17112.304443359375\n",
      "x: 15554.080810546875, t: 0, y: 1456.3958587646484, kld: 101.82791900634766\n",
      "Epoch 74:\n",
      "Epoch loss: 17119.139282226562\n",
      "x: 15553.491577148438, t: 0, y: 1458.4293060302734, kld: 107.21832323074341\n",
      "Epoch 75:\n",
      "Epoch loss: 17116.403442382812\n",
      "x: 15546.99462890625, t: 0, y: 1457.5531921386719, kld: 111.85545539855957\n",
      "Epoch 76:\n",
      "Epoch loss: 17179.612548828125\n",
      "x: 15608.968383789062, t: 0, y: 1458.893081665039, kld: 111.75107479095459\n",
      "Epoch 77:\n",
      "Epoch loss: 17089.594848632812\n",
      "x: 15523.998779296875, t: 0, y: 1456.7398986816406, kld: 108.8558440208435\n",
      "Epoch 78:\n",
      "Epoch loss: 17139.359130859375\n",
      "x: 15573.140380859375, t: 0, y: 1458.0386199951172, kld: 108.18008708953857\n",
      "Epoch 79:\n",
      "Epoch loss: 17131.243774414062\n",
      "x: 15562.145629882812, t: 0, y: 1459.403793334961, kld: 109.6944990158081\n",
      "Epoch 80:\n",
      "Epoch loss: 17109.023559570312\n",
      "x: 15538.900512695312, t: 0, y: 1458.5889129638672, kld: 111.5338888168335\n",
      "Epoch 81:\n",
      "Epoch loss: 17068.572998046875\n",
      "x: 15499.507202148438, t: 0, y: 1457.6796112060547, kld: 111.38603401184082\n",
      "Epoch 82:\n",
      "Epoch loss: 17110.6669921875\n",
      "x: 15544.558837890625, t: 0, y: 1455.2071533203125, kld: 110.90108394622803\n",
      "Epoch 83:\n",
      "Epoch loss: 17121.40087890625\n",
      "x: 15553.244995117188, t: 0, y: 1460.6246032714844, kld: 107.53169250488281\n",
      "Epoch 84:\n",
      "Epoch loss: 17060.240966796875\n",
      "x: 15497.548461914062, t: 0, y: 1453.2011260986328, kld: 109.49144649505615\n",
      "Epoch 85:\n",
      "Epoch loss: 17128.951904296875\n",
      "x: 15555.799926757812, t: 0, y: 1459.809829711914, kld: 113.34222412109375\n",
      "Epoch 86:\n",
      "Epoch loss: 17101.787231445312\n",
      "x: 15526.909423828125, t: 0, y: 1461.7777404785156, kld: 113.1001787185669\n",
      "Epoch 87:\n",
      "Epoch loss: 17077.348999023438\n",
      "x: 15508.412719726562, t: 0, y: 1456.3777923583984, kld: 112.55874729156494\n",
      "Epoch 88:\n",
      "Epoch loss: 17078.268920898438\n",
      "x: 15506.35791015625, t: 0, y: 1458.2069091796875, kld: 113.70394039154053\n",
      "Epoch 89:\n",
      "Epoch loss: 17115.674682617188\n",
      "x: 15545.700561523438, t: 0, y: 1452.982162475586, kld: 116.991868019104\n",
      "Epoch 90:\n",
      "Epoch loss: 17127.436157226562\n",
      "x: 15557.880249023438, t: 0, y: 1453.613021850586, kld: 115.94320964813232\n",
      "Epoch 91:\n",
      "Epoch loss: 17117.966918945312\n",
      "x: 15550.439331054688, t: 0, y: 1454.0550689697266, kld: 113.4724988937378\n",
      "Epoch 92:\n",
      "Epoch loss: 17091.512451171875\n",
      "x: 15523.724731445312, t: 0, y: 1455.5171813964844, kld: 112.2706651687622\n",
      "Epoch 93:\n",
      "Epoch loss: 17156.124267578125\n",
      "x: 15584.696655273438, t: 0, y: 1460.3441314697266, kld: 111.08330154418945\n",
      "Epoch 94:\n",
      "Epoch loss: 17089.908813476562\n",
      "x: 15522.064208984375, t: 0, y: 1456.3535766601562, kld: 111.4907579421997\n",
      "Epoch 95:\n",
      "Epoch loss: 17067.135375976562\n",
      "x: 15499.264770507812, t: 0, y: 1456.0779418945312, kld: 111.79280662536621\n",
      "Epoch 96:\n",
      "Epoch loss: 17099.448364257812\n",
      "x: 15525.8505859375, t: 0, y: 1459.1006774902344, kld: 114.49695110321045\n",
      "Epoch 97:\n",
      "Epoch loss: 17132.16455078125\n",
      "x: 15553.3701171875, t: 0, y: 1460.1568756103516, kld: 118.6377763748169\n",
      "Epoch 98:\n",
      "Epoch loss: 17108.746215820312\n",
      "x: 15530.387451171875, t: 0, y: 1459.0904998779297, kld: 119.26827335357666\n",
      "Epoch 99:\n",
      "Epoch loss: 17119.542724609375\n",
      "x: 15542.653198242188, t: 0, y: 1458.0824584960938, kld: 118.80701541900635\n",
      "Epoch 100:\n",
      "Epoch loss: 17099.822875976562\n",
      "x: 15523.207275390625, t: 0, y: 1457.226089477539, kld: 119.3896656036377\n",
      "Epoch 101:\n",
      "Epoch loss: 17072.345092773438\n",
      "x: 15494.222045898438, t: 0, y: 1458.0138244628906, kld: 120.1090726852417\n",
      "Epoch 102:\n",
      "Epoch loss: 17107.767578125\n",
      "x: 15527.051147460938, t: 0, y: 1456.3039245605469, kld: 124.41293048858643\n",
      "Epoch 103:\n",
      "Epoch loss: 17107.2685546875\n",
      "x: 15524.971435546875, t: 0, y: 1459.2923431396484, kld: 123.0044994354248\n",
      "Epoch 104:\n",
      "Epoch loss: 17097.76416015625\n",
      "x: 15518.712158203125, t: 0, y: 1457.312484741211, kld: 121.73977088928223\n",
      "Epoch 105:\n",
      "Epoch loss: 17102.332763671875\n",
      "x: 15518.158813476562, t: 0, y: 1458.5036315917969, kld: 125.67032241821289\n",
      "Epoch 106:\n",
      "Epoch loss: 17095.311279296875\n",
      "x: 15510.778442382812, t: 0, y: 1456.3998260498047, kld: 128.13278484344482\n",
      "Epoch 107:\n",
      "Epoch loss: 17104.964965820312\n",
      "x: 15517.37939453125, t: 0, y: 1458.9059448242188, kld: 128.6796932220459\n",
      "Epoch 108:\n",
      "Epoch loss: 17110.384033203125\n",
      "x: 15530.744750976562, t: 0, y: 1454.8421630859375, kld: 124.79687309265137\n",
      "Epoch 109:\n",
      "Epoch loss: 17093.465942382812\n",
      "x: 15509.649169921875, t: 0, y: 1458.3282470703125, kld: 125.48875141143799\n",
      "Epoch 110:\n",
      "Epoch loss: 17058.887329101562\n",
      "x: 15473.821533203125, t: 0, y: 1454.860855102539, kld: 130.20489120483398\n",
      "Epoch 111:\n",
      "Epoch loss: 17077.511474609375\n",
      "x: 15488.009155273438, t: 0, y: 1455.031723022461, kld: 134.47028827667236\n",
      "Epoch 112:\n",
      "Epoch loss: 17049.699462890625\n",
      "x: 15459.008911132812, t: 0, y: 1454.799301147461, kld: 135.89155197143555\n",
      "Epoch 113:\n",
      "Epoch loss: 17131.210327148438\n",
      "x: 15540.24560546875, t: 0, y: 1456.6761016845703, kld: 134.2884340286255\n",
      "Epoch 114:\n",
      "Epoch loss: 17073.129272460938\n",
      "x: 15485.601318359375, t: 0, y: 1454.8846282958984, kld: 132.64312267303467\n",
      "Epoch 115:\n",
      "Epoch loss: 17067.314208984375\n",
      "x: 15482.110107421875, t: 0, y: 1451.2955627441406, kld: 133.90863800048828\n",
      "Epoch 116:\n",
      "Epoch loss: 17104.216674804688\n",
      "x: 15514.235595703125, t: 0, y: 1456.4806823730469, kld: 133.5005226135254\n",
      "Epoch 117:\n",
      "Epoch loss: 17065.163696289062\n",
      "x: 15476.955444335938, t: 0, y: 1458.0002899169922, kld: 130.20786666870117\n",
      "Epoch 118:\n",
      "Epoch loss: 17088.973999023438\n",
      "x: 15498.35205078125, t: 0, y: 1460.8443450927734, kld: 129.77722072601318\n",
      "Epoch 119:\n",
      "Epoch loss: 17103.108154296875\n",
      "x: 15515.360107421875, t: 0, y: 1458.2182159423828, kld: 129.5300579071045\n",
      "Epoch 120:\n",
      "Epoch loss: 17053.538696289062\n",
      "x: 15466.374755859375, t: 0, y: 1456.0011749267578, kld: 131.16271781921387\n",
      "Epoch 121:\n",
      "Epoch loss: 17062.69775390625\n",
      "x: 15472.594360351562, t: 0, y: 1454.8838958740234, kld: 135.2194700241089\n",
      "Epoch 122:\n",
      "Epoch loss: 17084.997924804688\n",
      "x: 15489.506591796875, t: 0, y: 1458.7212524414062, kld: 136.77007865905762\n",
      "Epoch 123:\n",
      "Epoch loss: 17064.358276367188\n",
      "x: 15478.947265625, t: 0, y: 1454.7983093261719, kld: 130.61268711090088\n",
      "Epoch 124:\n",
      "Epoch loss: 17090.801147460938\n",
      "x: 15505.271850585938, t: 0, y: 1458.6065673828125, kld: 126.9225721359253\n",
      "Epoch 125:\n",
      "Epoch loss: 17105.945190429688\n",
      "x: 15518.95458984375, t: 0, y: 1458.8347473144531, kld: 128.15589237213135\n",
      "Epoch 126:\n",
      "Epoch loss: 17058.46875\n",
      "x: 15469.20263671875, t: 0, y: 1460.0977630615234, kld: 129.1682939529419\n",
      "Epoch 127:\n",
      "Epoch loss: 17070.673583984375\n",
      "x: 15487.10205078125, t: 0, y: 1455.2582550048828, kld: 128.3134183883667\n",
      "Epoch 128:\n",
      "Epoch loss: 17085.864501953125\n",
      "x: 15501.509399414062, t: 0, y: 1455.3711395263672, kld: 128.9837827682495\n",
      "Epoch 129:\n",
      "Epoch loss: 17074.994995117188\n",
      "x: 15488.615844726562, t: 0, y: 1455.4864501953125, kld: 130.89276790618896\n",
      "Epoch 130:\n",
      "Epoch loss: 17107.458862304688\n",
      "x: 15517.694091796875, t: 0, y: 1456.9789733886719, kld: 132.78592586517334\n",
      "Epoch 131:\n",
      "Epoch loss: 17098.078002929688\n",
      "x: 15509.9267578125, t: 0, y: 1457.035659790039, kld: 131.11577129364014\n",
      "Epoch 132:\n",
      "Epoch loss: 17127.241821289062\n",
      "x: 15539.368530273438, t: 0, y: 1459.522720336914, kld: 128.35090923309326\n",
      "Epoch 133:\n",
      "Epoch loss: 17092.777221679688\n",
      "x: 15507.098999023438, t: 0, y: 1456.8014221191406, kld: 128.87661170959473\n",
      "Epoch 134:\n",
      "Epoch loss: 17054.797607421875\n",
      "x: 15468.543823242188, t: 0, y: 1455.4930572509766, kld: 130.76087188720703\n",
      "Epoch 135:\n",
      "Epoch loss: 17057.02734375\n",
      "x: 15470.063842773438, t: 0, y: 1455.1200256347656, kld: 131.84357357025146\n",
      "Epoch 136:\n",
      "Epoch loss: 17027.43603515625\n",
      "x: 15445.08642578125, t: 0, y: 1453.686782836914, kld: 128.66296100616455\n",
      "Epoch 137:\n",
      "Epoch loss: 17035.779907226562\n",
      "x: 15452.702392578125, t: 0, y: 1456.2886810302734, kld: 126.78864192962646\n",
      "Epoch 138:\n",
      "Epoch loss: 17041.73681640625\n",
      "x: 15457.817504882812, t: 0, y: 1456.4739074707031, kld: 127.44568157196045\n",
      "Epoch 139:\n",
      "Epoch loss: 17075.487915039062\n",
      "x: 15488.085327148438, t: 0, y: 1459.097900390625, kld: 128.30457210540771\n",
      "Epoch 140:\n",
      "Epoch loss: 17090.752685546875\n",
      "x: 15514.67431640625, t: 0, y: 1451.1769714355469, kld: 124.90119934082031\n",
      "Epoch 141:\n",
      "Epoch loss: 17097.777587890625\n",
      "x: 15517.940551757812, t: 0, y: 1459.0778045654297, kld: 120.75936126708984\n",
      "Epoch 142:\n",
      "Epoch loss: 17041.891723632812\n",
      "x: 15463.81103515625, t: 0, y: 1457.2337036132812, kld: 120.84691905975342\n",
      "Epoch 143:\n",
      "Epoch loss: 17094.618530273438\n",
      "x: 15516.222412109375, t: 0, y: 1456.5482482910156, kld: 121.8478479385376\n",
      "Epoch 144:\n",
      "Epoch loss: 17070.037841796875\n",
      "x: 15491.413940429688, t: 0, y: 1456.4540710449219, kld: 122.16992568969727\n",
      "Epoch 145:\n",
      "Epoch loss: 17061.492797851562\n",
      "x: 15482.969360351562, t: 0, y: 1457.1095275878906, kld: 121.41381072998047\n",
      "Epoch 146:\n",
      "Epoch loss: 17074.326049804688\n",
      "x: 15496.127685546875, t: 0, y: 1456.0187072753906, kld: 122.17948150634766\n",
      "Epoch 147:\n",
      "Epoch loss: 17044.9208984375\n",
      "x: 15469.899169921875, t: 0, y: 1452.5507049560547, kld: 122.47062969207764\n",
      "Epoch 148:\n",
      "Epoch loss: 17086.339477539062\n",
      "x: 15506.730590820312, t: 0, y: 1456.0735473632812, kld: 123.53541374206543\n",
      "Epoch 149:\n",
      "Epoch loss: 17022.56982421875\n",
      "x: 15444.261962890625, t: 0, y: 1454.4476928710938, kld: 123.86023616790771\n",
      "Epoch 150:\n",
      "Epoch loss: 17047.504638671875\n",
      "x: 15463.83154296875, t: 0, y: 1458.7071533203125, kld: 124.96577739715576\n",
      "Epoch 151:\n",
      "Epoch loss: 17066.629760742188\n",
      "x: 15485.91064453125, t: 0, y: 1454.2257080078125, kld: 126.49313259124756\n",
      "Epoch 152:\n",
      "Epoch loss: 17037.514770507812\n",
      "x: 15451.546020507812, t: 0, y: 1457.6824188232422, kld: 128.2862367630005\n",
      "Epoch 153:\n",
      "Epoch loss: 17095.535034179688\n",
      "x: 15507.372924804688, t: 0, y: 1459.123046875, kld: 129.0391845703125\n",
      "Epoch 154:\n",
      "Epoch loss: 17087.819458007812\n",
      "x: 15503.318603515625, t: 0, y: 1453.949478149414, kld: 130.55117988586426\n",
      "Epoch 155:\n",
      "Epoch loss: 17072.84375\n",
      "x: 15484.606689453125, t: 0, y: 1458.1091613769531, kld: 130.12780666351318\n",
      "Epoch 156:\n",
      "Epoch loss: 17085.43359375\n",
      "x: 15499.254516601562, t: 0, y: 1457.2117156982422, kld: 128.96710872650146\n",
      "Epoch 157:\n",
      "Epoch loss: 17061.562377929688\n",
      "x: 15470.830810546875, t: 0, y: 1459.9199523925781, kld: 130.8114709854126\n",
      "Epoch 158:\n",
      "Epoch loss: 17047.763671875\n",
      "x: 15459.189575195312, t: 0, y: 1455.61279296875, kld: 132.96132946014404\n",
      "Epoch 159:\n",
      "Epoch loss: 17084.587280273438\n",
      "x: 15498.529174804688, t: 0, y: 1451.2843780517578, kld: 134.77381038665771\n",
      "Epoch 160:\n",
      "Epoch loss: 17127.516845703125\n",
      "x: 15533.368041992188, t: 0, y: 1457.5328674316406, kld: 136.61593914031982\n",
      "Epoch 161:\n",
      "Epoch loss: 17055.711059570312\n",
      "x: 15464.1416015625, t: 0, y: 1454.8335418701172, kld: 136.73602199554443\n",
      "Epoch 162:\n",
      "Epoch loss: 17042.831909179688\n",
      "x: 15446.017333984375, t: 0, y: 1458.6980743408203, kld: 138.1166181564331\n",
      "Epoch 163:\n",
      "Epoch loss: 17053.1806640625\n",
      "x: 15456.960815429688, t: 0, y: 1457.6594696044922, kld: 138.56074714660645\n",
      "Epoch 164:\n",
      "Epoch loss: 17039.71533203125\n",
      "x: 15444.373779296875, t: 0, y: 1456.4346466064453, kld: 138.90721797943115\n",
      "Epoch 165:\n",
      "Epoch loss: 17047.09423828125\n",
      "x: 15454.261596679688, t: 0, y: 1453.4877319335938, kld: 139.34496879577637\n",
      "Epoch 166:\n",
      "Epoch loss: 17030.525024414062\n",
      "x: 15430.723754882812, t: 0, y: 1459.9418640136719, kld: 139.85934925079346\n",
      "Epoch 167:\n",
      "Epoch loss: 17108.626708984375\n",
      "x: 15512.913940429688, t: 0, y: 1456.1327514648438, kld: 139.58029747009277\n",
      "Epoch 168:\n",
      "Epoch loss: 17046.439086914062\n",
      "x: 15453.213256835938, t: 0, y: 1455.8638000488281, kld: 137.36224555969238\n",
      "Epoch 169:\n",
      "Epoch loss: 17032.41015625\n",
      "x: 15436.986450195312, t: 0, y: 1459.1380004882812, kld: 136.28550815582275\n",
      "Epoch 170:\n",
      "Epoch loss: 17099.115966796875\n",
      "x: 15505.39111328125, t: 0, y: 1455.911361694336, kld: 137.8133249282837\n",
      "Epoch 171:\n",
      "Epoch loss: 17031.702880859375\n",
      "x: 15436.978759765625, t: 0, y: 1455.0172271728516, kld: 139.706955909729\n",
      "Epoch 172:\n",
      "Epoch loss: 17066.790771484375\n",
      "x: 15470.026000976562, t: 0, y: 1455.8244171142578, kld: 140.94028759002686\n",
      "Epoch 173:\n",
      "Epoch loss: 17032.7265625\n",
      "x: 15436.056274414062, t: 0, y: 1454.5362548828125, kld: 142.13423538208008\n",
      "Epoch 174:\n",
      "Epoch loss: 17159.03515625\n",
      "x: 15559.089965820312, t: 0, y: 1457.369873046875, kld: 142.5751142501831\n",
      "Epoch 175:\n",
      "Epoch loss: 17049.999389648438\n",
      "x: 15451.44091796875, t: 0, y: 1461.340103149414, kld: 137.2181739807129\n",
      "Epoch 176:\n",
      "Epoch loss: 17037.000122070312\n",
      "x: 15448.689697265625, t: 0, y: 1453.3385314941406, kld: 134.9718599319458\n",
      "Epoch 177:\n",
      "Epoch loss: 17085.98046875\n",
      "x: 15491.512939453125, t: 0, y: 1458.9971160888672, kld: 135.47074794769287\n",
      "Epoch 178:\n",
      "Epoch loss: 17039.57080078125\n",
      "x: 15445.6962890625, t: 0, y: 1456.9951782226562, kld: 136.87924575805664\n",
      "Epoch 179:\n",
      "Epoch loss: 17038.643188476562\n",
      "x: 15444.662353515625, t: 0, y: 1456.140609741211, kld: 137.84013557434082\n",
      "Epoch 180:\n",
      "Epoch loss: 17080.271606445312\n",
      "x: 15485.77294921875, t: 0, y: 1455.6224060058594, kld: 138.87645435333252\n",
      "Epoch 181:\n",
      "Epoch loss: 17030.111083984375\n",
      "x: 15433.87060546875, t: 0, y: 1456.6360321044922, kld: 139.60437488555908\n",
      "Epoch 182:\n",
      "Epoch loss: 17034.996826171875\n",
      "x: 15442.068481445312, t: 0, y: 1453.6537017822266, kld: 139.27470111846924\n",
      "Epoch 183:\n",
      "Epoch loss: 17055.558227539062\n",
      "x: 15457.379028320312, t: 0, y: 1459.6568908691406, kld: 138.52224349975586\n",
      "Epoch 184:\n",
      "Epoch loss: 17021.9501953125\n",
      "x: 15429.06005859375, t: 0, y: 1454.7811737060547, kld: 138.10891723632812\n",
      "Epoch 185:\n",
      "Epoch loss: 17041.519653320312\n",
      "x: 15445.56787109375, t: 0, y: 1456.724136352539, kld: 139.2276029586792\n",
      "Epoch 186:\n",
      "Epoch loss: 17020.234375\n",
      "x: 15425.191772460938, t: 0, y: 1455.1754760742188, kld: 139.86704540252686\n",
      "Epoch 187:\n",
      "Epoch loss: 17108.7958984375\n",
      "x: 15514.407104492188, t: 0, y: 1456.0918426513672, kld: 138.29692840576172\n",
      "Epoch 188:\n",
      "Epoch loss: 17042.211547851562\n",
      "x: 15451.850830078125, t: 0, y: 1454.2872009277344, kld: 136.07353973388672\n",
      "Epoch 189:\n",
      "Epoch loss: 17076.582153320312\n",
      "x: 15484.236450195312, t: 0, y: 1456.7164154052734, kld: 135.62910747528076\n",
      "Epoch 190:\n",
      "Epoch loss: 17044.475830078125\n",
      "x: 15449.9482421875, t: 0, y: 1458.3082733154297, kld: 136.219331741333\n",
      "Epoch 191:\n",
      "Epoch loss: 17069.967895507812\n",
      "x: 15480.078369140625, t: 0, y: 1454.8963928222656, kld: 134.99289989471436\n",
      "Epoch 192:\n",
      "Epoch loss: 17065.623779296875\n",
      "x: 15474.357299804688, t: 0, y: 1458.9247283935547, kld: 132.34151935577393\n",
      "Epoch 193:\n",
      "Epoch loss: 17031.687255859375\n",
      "x: 15446.803466796875, t: 0, y: 1452.8015594482422, kld: 132.08217906951904\n",
      "Epoch 194:\n",
      "Epoch loss: 17064.70166015625\n",
      "x: 15475.955322265625, t: 0, y: 1455.6788024902344, kld: 133.06754875183105\n",
      "Epoch 195:\n",
      "Epoch loss: 17060.047241210938\n",
      "x: 15470.033203125, t: 0, y: 1455.1070709228516, kld: 134.90691661834717\n",
      "Epoch 196:\n",
      "Epoch loss: 17032.34130859375\n",
      "x: 15439.474731445312, t: 0, y: 1455.9890747070312, kld: 136.8772487640381\n",
      "Epoch 197:\n",
      "Epoch loss: 17078.284423828125\n",
      "x: 15480.12158203125, t: 0, y: 1459.7207946777344, kld: 138.44200897216797\n",
      "Epoch 198:\n",
      "Epoch loss: 17061.533325195312\n",
      "x: 15461.752319335938, t: 0, y: 1460.2821197509766, kld: 139.49924659729004\n",
      "Epoch 199:\n",
      "Epoch loss: 17034.138671875\n",
      "x: 15435.437744140625, t: 0, y: 1459.2603607177734, kld: 139.4405336380005\n"
     ]
    },
    {
     "data": {
      "image/png": "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f/whunTpIh544AFbDcki1xt/SUmJeOaZZ0RSUpLIyMgQv/32m+jbt6/o0qWLqKyslK7Rksf/5JNPCnd3d7Fz506Rl5cnPcrLy6U2N/q5r6mpET179hSjRo0SKSkpYsuWLcLHx0csWLDAFkNqljiPch7lPMp5tCnmUQa3Fvj4449FSEiIUCgUYsCAAWLv3r227pJV3H///SIgIEAoFArRvn17cf/994szZ85I5ysqKsRTTz0l2rVrJ5ydncWECRNEXl6eDXt863bs2CEA1HlMmzZNCGEsY/Piiy8KPz8/oVQqxciRI0V6errZNS5fviweeOAB4erqKlQqlZg+fbooKSmxwWgsd73xl5eXi1GjRgkfHx/h4OAgQkNDxWOPPVYnIGnJ469v7ADEihUrpDYN+bk/f/68GDNmjHBychLe3t5i3rx5QqfTNfFomjfOo0acRzmPch613jwqq+0QEREREVGLx5xbIiIiImo1GNwSERERUavB4JaIiIiIWg0Gt0RERETUajC4JSIiIqJWg8EtEREREbUaDG6JiIiIqNVgcEtERERErQaDWyIiIiJqNRjcEhEREVGrweCWiIiIiFoNBrdERERE1GowuCX6i507d0Imk2Hnzp227goRUatw/vx5yGQyrFy58rrtOP9SY2BwS0RE1Irt2bMHixYtQnFx8U1f49NPP71hYErUXDC4JSIiasX27NmDl19+mcEttRkMbomIiIio1WBwS63Ojh07IJPJsH79+jrn1qxZA5lMhqSkJIuvu27dOkRHR8PJyQne3t548MEHkZOTY9ZGrVZj+vTpCAoKglKpREBAAMaNG4fz589LbQ4ePIi4uDh4e3vDyckJYWFheOSRRyzuDxHRjSxatAjz588HAISFhUEmk0Emk0lzUk1NDV599VV06tQJSqUSHTp0wD//+U9UVVVJ1+jQoQNSU1Oxa9cu6fXDhw8HABQWFuKZZ55Br1694OrqCpVKhTFjxuDIkSONOg7Ov2QJe1t3gKixDR8+HMHBwVi9ejUmTJhgdm716tXo1KkTYmJiLLrmypUrMX36dPTv3x+LFy9Gfn4+PvzwQ/z55584fPgwPDw8AACTJk1CamoqZs2ahQ4dOqCgoACJiYnIysqSno8aNQo+Pj54/vnn4eHhgfPnz+OHH35orOETEUkmTpyIU6dO4ZtvvsH7778Pb29vAICP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",
      "text/plain": [
       "<Figure size 800x800 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from models import GenericDataset, train_ProxyVAE\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "# get the training data (exclude z)\n",
    "source_proxy = np.array(source_data.iloc[:, 1:])\n",
    "dataset = GenericDataset(source_proxy)\n",
    "dataloader = DataLoader(dataset, shuffle=True, batch_size=100)\n",
    "device='cpu'\n",
    "plot_curves=False\n",
    "print_logs=True\n",
    "num_epochs=200\n",
    "lr_start=0.0002\n",
    "lr_end=0.00005\n",
    "x_dim=25\n",
    "z_dim=1\n",
    "x_mode=[0]*3+[4]+[0]*2+[2]*(x_dim-6)\n",
    "\n",
    "p_t_z_nn = False\n",
    "\n",
    "source_VAE, losses = train_ProxyVAE(device, plot_curves, print_logs, \n",
    "                                  dataloader, num_epochs, lr_start, lr_end, \n",
    "                                  x_dim, z_dim, p_t_z_nn, p_t_z_nn_layers=3,p_t_z_nn_width=30, \n",
    "                                  p_x_z_nn_layers=3, p_x_z_nn_width=30, \n",
    "                                  p_y_nn_layers =3, p_y_nn_width=30,\n",
    "                                  q_z_nn_layers=3, q_z_nn_width=30,\n",
    "                                  x_mode=x_mode, y_loss_type = 2, y_separate_heads=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test on the target domain dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [],
   "source": [
    "from models import ProxyVAE\n",
    "from env import eva_causal, eva_random, eva_negative\n",
    "from copy import deepcopy\n",
    "\n",
    "\n",
    "\n",
    "# seeds for the target domain running\n",
    "seeds = [1,2,3,4,5]\n",
    "# seed for target domain data sampling\n",
    "seed = 1\n",
    "np.random.seed(seed)\n",
    "random.seed(seed)\n",
    "N = 1000\n",
    "#test_data = data.sample(N)        # target domain N(0, 1)\n",
    "test_data = target_data.sample(N)\n",
    "\n",
    "# Hyperparamer setting\n",
    "beta = 0.1\n",
    "vae_freq = [1000, 200, 100, 50, 25, 15, 10, 8, 6, 5]\n",
    "lr = 0.005\n",
    "batch_size = 32\n",
    "y_separate_heads = True\n",
    "update_decoder = True\n",
    "\n",
    "total_regret_vs_vae_freq = {\"Causal\":[], \"VAE\":[], \"VAE(prior)\": [], \"Random\": [] }\n",
    "\n",
    "for j in range(len(vae_freq)):\n",
    "\n",
    "    reward_causal_transDe_episodes = []\n",
    "    reward_causal_NoDe_episodes = []\n",
    "    reward_causal_sourceVAE_episodes = []\n",
    "    reward_negative_episodes = []\n",
    "    reward_random_episodes = []\n",
    "\n",
    "    regret_causal_transDe_episodes = []\n",
    "    regret_causal_NoDe_episodes = []\n",
    "    regret_causal_sourceVAE_episodes = []\n",
    "    regret_negative_episodes = []\n",
    "    regret_random_episodes = []\n",
    "\n",
    "    for i in range(5):\n",
    "\n",
    "        seed = seeds[i]\n",
    "        np.random.seed(seed)\n",
    "        random.seed(seed)\n",
    "        torch.manual_seed(seed)\n",
    "\n",
    "\n",
    "        target_VAE = ProxyVAE(x_dim, z_dim, device, p_t_z_nn, p_t_z_nn_layers=3,p_t_z_nn_width=30, \n",
    "                          p_x_z_nn_layers=3, \n",
    "                      p_x_z_nn_width=30, p_y_zt_nn_layers = 3, p_y_zt_nn_width=30, q_z_nn_layers=3, q_z_nn_width=30, x_mode=x_mode, y_loss_type=2, y_separate_heads=y_separate_heads)\n",
    "        target_VAE_transD = ProxyVAE(x_dim, z_dim, device, p_t_z_nn, p_t_z_nn_layers=3, p_t_z_nn_width=3, \n",
    "                                 p_x_z_nn_layers=3, \n",
    "                      p_x_z_nn_width=30, p_y_zt_nn_layers = 3, p_y_zt_nn_width=30, q_z_nn_layers=3, q_z_nn_width=30, x_mode=x_mode, y_loss_type=2, y_separate_heads=y_separate_heads)\n",
    "        #target_VAE_transD.decoder = deepcopy(source_VAE.decoder)\n",
    "        target_VAE_transD.decoder = deepcopy(decoder)\n",
    "        #target_VAE_transD.encoder = deepcopy(source_VAE.encoder)\n",
    "        source_vae = deepcopy(source_VAE)\n",
    "\n",
    "        reward_causal_transDe, regret_causal_transDe, transVAE_z, true_z = eva_causal(test_data, target_VAE_transD, beta=beta, vae_freq=vae_freq[j], lr=lr, batch_size=batch_size, train = True, update_decoder=update_decoder)\n",
    "        reward_causal_NoDe, regret_causal_NoDe, randomVAE_z, _ = eva_causal(test_data, target_VAE, beta=1, vae_freq=vae_freq[j], lr=lr, batch_size=batch_size, train=True)\n",
    "        reward_causal_sourceVAE, regret_causal_sourceVAE, sourceVAE_z, _ = eva_causal(test_data, source_vae, beta=1, vae_freq=vae_freq[j], lr=lr, batch_size=batch_size, train=True)\n",
    "        reward_random, regret_random = eva_random(test_data, N) \n",
    "\n",
    "        reward_causal_transDe_episodes.append(reward_causal_transDe)\n",
    "        reward_causal_NoDe_episodes.append(reward_causal_NoDe)\n",
    "        reward_causal_sourceVAE_episodes.append(reward_causal_sourceVAE)\n",
    "        reward_random_episodes.append(reward_random)\n",
    "\n",
    "        regret_causal_transDe_episodes.append(regret_causal_transDe)\n",
    "        regret_causal_NoDe_episodes.append(regret_causal_NoDe)\n",
    "        regret_causal_sourceVAE_episodes.append(regret_causal_sourceVAE)\n",
    "        regret_random_episodes.append(regret_random) \n",
    "    \n",
    "\n",
    "    total_regret_vs_vae_freq[\"Causal\"].append(np.mean(np.array([regret_causal_transDe_episodes[i][-1] for i in range(len(seeds))])))  \n",
    "    total_regret_vs_vae_freq[\"VAE\"].append(np.mean(np.array([regret_causal_NoDe_episodes[i][-1] for i in range(len(seeds))])))\n",
    "    total_regret_vs_vae_freq[\"VAE(prior)\"].append(np.mean(np.array([regret_causal_sourceVAE_episodes[i][-1] for i in range(len(seeds))])))     \n",
    "    total_regret_vs_vae_freq[\"Random\"].append(np.mean(np.array([regret_random_episodes[i][-1] for i in range(len(seeds))])))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkgAAAGwCAYAAABSN5pGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAA9hAAAPYQGoP6dpAACUz0lEQVR4nOzdd1xV9f/A8de9l8tegjIUxC3uPdAyN67S8psNzdly5arMhjkqS8uysu3IHJWVliMV9x65B+IWB6CigCjjAuf3x/lx5QIq6IUD3Pfz8fg8vJxz7rnvDxe5bz5TpyiKghBCCCGEMNNrHYAQQgghRFEjCZIQQgghRDaSIAkhhBBCZCMJkhBCCCFENpIgCSGEEEJkIwmSEEIIIUQ2kiAJIYQQQmRjp3UARUFGRgaXL1/Gzc0NnU6ndThCCCGEyANFUbh58yZly5ZFr7dum48kSMDly5cJDAzUOgwhhBBCPIALFy4QEBBg1XtKggS4ubkB6jfY3d1d42gKlslkYs2aNXTs2BGj0ah1OIXKVusu9bateoPt1l3qbVv1Brh+/ToVK1Y0f45bkyRIYO5Wc3d3t4kEydnZGXd3d5v7j2SrdZd621a9wXbrLvW2rXqDWnegQIbHyCBtIYQQQohsJEESQgghhMhGEiQhhBBCiGxkDJIQQogSIT09HTs7O5KTk0lPT9c6nEJjMplKbL2NRiMGg0GT15YESQghRLGmKArR0dHcuHEDPz8/Lly4YFNr2imKUqLr7enpiZ+fX6HXTRIkIYQQxVp0dDRxcXGUKVOGjIwM3NzcrL5oYFGWkZFBYmIirq6uJareiqJw+/Ztrly5AoC/v3+hvr4kSEIIIYqt9PR04uLi8PHxoVSpUiQkJODo6FiiEoX7ycjIIDU1tUTW28nJCYArV67g4+NTqN1tJes7KYQQwqZkroPj7OyscSSioGS+t5nvdWGRBEkIIUSxVxLH3giVVu+tJEhCCCGEENlIgiSEEEIIkY0kSEIIIYS4qwoVKvDFF19oHUahkwRJCCGE0Eh0dDTDhw+nUqVKODg4EBgYyOOPP866deu0Ds3myTR/IYQQQgPnzp2jZcuWeHp6Mm3aNOrUqYPJZGL16tUMHTqU48ePax2iTZMWJCGEECWLosCtW9oURclzmEOGDEGn07F792569uxJtWrVqFWrFqNHj2bnzp0ATJ8+nTp16uDi4kJgYCBDhgwhMTHRfI8JEybQsGFDi/t+8cUXVKhQwfz1xo0badq0KS4uLnh6etKyZUvOnz8PwOnTp+nevTu+vr64urrSpEkT1q5d+xDf/JJDWpCyuHbrGu7u7lqHIYQQ4mHcvg1a/S5PTAQXl/tedv36dVatWsWHH36ISy7Xe3p6AqDX6/nyyy+pWLEiZ86cYciQIbz55pt88803eQonLS2NHj168NJLL7Fo0SJSU1PZvXu3eep8YmIiXbp04cMPP8TBwYF58+bx+OOPExERQfny5fNe7xJIEqQs9lzeQyX/SlqHIYQQooQ7deoUiqIQHBx8z+tGjhxpflyhQgU++OADXn311TwnSAkJCcTHx9OtWzcqV64MQI0aNczn69WrR7169cxfT548mSVLlvDPP/8wbNiwfNSo5JEEKYtdF3fxTKNntA5DCCHEw3B2VltytHrtPFDy2BW3du1apkyZwvHjx0lISCAtLY3k5GRu376dp9XDvby86N+/P6GhoXTo0IH27dvTq1cv875miYmJTJgwgRUrVhAVFUVaWhpJSUlERkbmKb6STMYgZbHr8i6tQxBCCPGwdDq1m0uLksdVn6tWrYpOp7vnQOxz587RrVs36taty59//snevXuZOXMmAKmpqYDaBZc92cq+JcecOXPYsWMHLVq04LfffqNatWrmMU6vv/46S5Ys4aOPPmLLli0cOHCAOnXqmO9vyyRBymLf5X2Y0gt3rxchhBC2x8vLi9DQUGbOnMmtW7dynI+Li2Pv3r1kZGTw2Wef0bx5c6pVq8bly5ctritTpgzR0dEWSdKBAwdy3K9BgwaMGzeO7du3U7t2bRYuXAjAtm3b6N+/P08++SR16tTBz8+Pc+fOWbWuxZUkSFkkpyVzMOag1mEIIYSwATNnziQ9PZ2mTZvy559/cvLkScLDw/nyyy8JCQmhSpUqmEwmvvrqK86cOcMvv/zCd999Z3GP1q1bc/XqVWbMmMHp06eZOXMm//77r/n82bNnGTduHDt27OD8+fOsWbOGkydPmschVa1alb/++osDBw5w8OBBnn/+eTIyMgr1+1BUSYKUzfYL27UOQQghhA2oVKkS+/bto02bNowZM4batWvToUMH1q1bx7fffku9evWYPn06n3zyCbVr12bBggVMmTLF4h41atTg66+/5qeffqJBgwbs3r2b119/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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ploting the regret\n",
    "from plot_functions import plot_regret, plot_total_regret_vs_freq\n",
    "\n",
    "#plot_regret(regret_causal_transDe_episodes, regret_causal_NoDe_episodes, regret_causal_sourceVAE_episodes, regret_negative_episodes, regret_random_episodes, dist_z_source=dist_z_source, dist_z_target=dist_z_target)\n",
    "color_list = ['red', 'blue', 'green', 'black']\n",
    "num_update = [int(1000/freq) for freq in vae_freq]\n",
    "plot_total_regret_vs_freq(total_regret_vs_vae_freq, num_update, color_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ploting p(z) generated by VAE with transferred decoder\n",
    "z = np.random.randn(1000)\n",
    "z = [transVAE_z, true_z]\n",
    "labels = ['posterior', 'ground truth']\n",
    "name = 'IHDP_dist_z_'+str(dist_z_source[0])+'_'+str(dist_z_target[0])+'.tikz'\n",
    "plot_z_comparasion(z, labels, name, z_index=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
