{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, '../..')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tnrange, tqdm_notebook\n",
    "\n",
    "from causal_meta.utils.data_utils import generate_data_categorical\n",
    "from models import StructuralModel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 10\n",
    "model = StructuralModel(N, dtype=torch.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_episodes = 500\n",
    "batch_size = 100 # 1\n",
    "num_test = 10000\n",
    "num_training = 10 # 100\n",
    "num_transfers = 10 # 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "optimizer = torch.optim.SGD(model.modules_parameters(), lr=1.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fee89e05f09c4ea69ad3493003ede06a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "losses = np.zeros((2, num_training, num_transfers, num_episodes))\n",
    "\n",
    "for k in tnrange(num_training):\n",
    "    pi_A_1 = np.random.dirichlet(np.ones(N))\n",
    "    pi_B_A = np.random.dirichlet(np.ones(N), size=N)\n",
    "    for j in tnrange(num_transfers, leave=False):\n",
    "        model.set_ground_truth(pi_A_1, pi_B_A)\n",
    "        pi_A_2 = np.random.dirichlet(np.ones(N))\n",
    "        x_val = torch.from_numpy(generate_data_categorical(num_test, pi_A_2, pi_B_A))\n",
    "        for i in range(num_episodes):\n",
    "            x_transfer = torch.from_numpy(generate_data_categorical(batch_size, pi_A_2, pi_B_A))\n",
    "            model.zero_grad()\n",
    "            loss_A_B = -torch.mean(model.model_A_B(x_transfer))\n",
    "            loss_B_A = -torch.mean(model.model_B_A(x_transfer))\n",
    "            loss = loss_A_B + loss_B_A\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                val_loss_A_B = -torch.mean(model.model_A_B(x_val))\n",
    "                val_loss_B_A = -torch.mean(model.model_B_A(x_val))\n",
    "\n",
    "            losses[:, k, j, i] = [val_loss_A_B.item(), val_loss_B_A.item()]\n",
    "\n",
    "            loss.backward()\n",
    "            optimizer.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "flat_losses = -losses.reshape((2, -1, num_episodes))\n",
    "losses_25, losses_50, losses_75 = np.percentile(flat_losses, (25, 50, 75), axis=1)\n",
    "\n",
    "plt.figure(figsize=(9, 5))\n",
    "\n",
    "ax = plt.subplot(1, 1, 1)\n",
    "ax.plot(losses_50[0], color='C0', label=r'$A \\rightarrow B$', lw=2)\n",
    "ax.fill_between(np.arange(num_episodes), losses_25[0], losses_75[0], color='C0', alpha=0.2)\n",
    "ax.plot(losses_50[1], color='C3', label=r'$B \\rightarrow A$', lw=2)\n",
    "ax.fill_between(np.arange(num_episodes), losses_25[1], losses_75[1], color='C3', alpha=0.2)\n",
    "ax.set_xlim([0, flat_losses.shape[1] - 1])\n",
    "ax.tick_params(axis='both', which='major', labelsize=13)\n",
    "ax.legend(loc=4, prop={'size': 13})\n",
    "ax.set_xlabel('Number of examples', fontsize=14)\n",
    "ax.set_ylabel(r'$\\log P(D\\mid \\cdot \\rightarrow \\cdot)$', fontsize=14)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "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.6.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
