{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from data import dataset, generate_data\n",
    "from models import RSSM, MultiRSSM, VCD, adaptation_model\n",
    "import json\n",
    "from jax import random\n",
    "from jax import numpy as jnp\n",
    "from matplotlib import pyplot as plt\n",
    "from experiments import evaluation, adaptation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set the number of episodes for adaptation\n",
    "transfer_data_size = 4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_conf = json.load(open('../data/mixed_state_adapt_conf.json'))\n",
    "train_data_config = data_conf['train_data_conf']\n",
    "mixing_matrix = random.normal(random.PRNGKey(0), (8, 12))\n",
    "mixing_function = lambda x: x @ mixing_matrix\n",
    "\n",
    "\n",
    "train_data = dataset.DataLoader(\n",
    "    generate_data.get_states,\n",
    "    train_data_config,\n",
    "    transfer_data_size,\n",
    "    data_conf[\"train_data_seed\"],\n",
    "    mixing_function,\n",
    ")\n",
    "\n",
    "test_data_config = data_conf['test_data_conf']\n",
    "test_data = dataset.DataLoader(\n",
    "    generate_data.get_states,\n",
    "    test_data_config,\n",
    "    1000,\n",
    "    data_conf[\"train_data_seed\"],\n",
    "    mixing_function,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mThe Kernel crashed while executing code in the the current cell or a previous cell. Please review the code in the cell(s) to identify a possible cause of the failure. Click <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. View Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."
     ]
    }
   ],
   "source": [
    "rssm_path = '../pretrain/mixed_state_rssm'\n",
    "rssm_chkpt_id = 0\n",
    "rssm_error, rssm_adapt_state = adaptation.adapt(train_data, test_data, adaptation_model.AdaptRSSM, RSSM.RSSM, rssm_path, rssm_chkpt_id, mixing_matrix)\n",
    "\n",
    "vcd_path = '../pretrain/mixed_state_vcd'\n",
    "vcd_chkpt_id = 0\n",
    "vcd_error, rssm_adapt_state = adaptation.adapt(train_data, test_data, adaptation_model.AdaptVCD, VCD.VCD, vcd_path, vcd_chkpt_id, mixing_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5a3c2e5910>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(jnp.median(rssm_error, axis=1), label='RSSM')\n",
    "plt.fill_between(jnp.arange(200), jnp.quantile(rssm_error, 0.75, axis=1), jnp.quantile(rssm_error, 0.25, axis=1), alpha=0.3)\n",
    "plt.plot(jnp.median(vcd_error, axis=1), label='VCD')\n",
    "plt.fill_between(jnp.arange(200), jnp.quantile(vcd_error, 0.75, axis=1), jnp.quantile(vcd_error, 0.25, axis=1), alpha=0.3)\n",
    "\n",
    "plt.fill_betweenx([0,40], [0,0], [100,100], color='k', alpha=0.1)\n",
    "plt.ylim([0, 40])\n",
    "plt.xlim([0,199])\n",
    "plt.xlabel('time')\n",
    "plt.ylabel('L2 error')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f582135f700>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# show identified intervention targets.\n",
    "plt.imshow(rssm_adapt_state.params['params']['intervention_targets'], cmap='Blues')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.13",
   "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.13"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "ad9a1871afe6dac80ccb59962037e7f5f3f6d5fbffcdc0af077d19cff6e0fa57"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
