{
 "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\n",
    "import os\n",
    "from flax import serialization\n",
    "import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set the number of episodes for adaptation\n",
    "transfer_data_size = 40"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_conf = json.load(open('../data/image_adapt_conf.json'))\n",
    "train_data_config = data_conf['train_data_conf']\n",
    "mixing_function = lambda x: x/255\n",
    "\n",
    "\n",
    "train_data = dataset.DataLoader(\n",
    "    generate_data.get_images,\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_images,\n",
    "    test_data_config,\n",
    "    200,\n",
    "    data_conf[\"train_data_seed\"],\n",
    "    mixing_function,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "training on adaptation data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "kl: 1.88, int: 0.00: 100%|██████████| 5000/5000 [1:08:48<00:00,  1.21it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [06:48<00:00,  4.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "training on adaptation data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "kl: 5.31, int: 2.26: 100%|██████████| 5000/5000 [1:19:16<00:00,  1.05it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [06:42<00:00,  4.03s/it]\n"
     ]
    }
   ],
   "source": [
    "rssm_path = '../pretrain/image_rssm'\n",
    "rssm_chkpt_id = 0\n",
    "rssm_error, rssm_adapt_state = adaptation.adapt(train_data, test_data, adaptation_model.AdaptRSSM, RSSM.ImageRSSM, rssm_path, rssm_chkpt_id, None, 5000, 50)\n",
    "\n",
    "vcd_path = '../pretrain/image_vcd'\n",
    "vcd_chkpt_id = 0\n",
    "vcd_error, rssm_adapt_state = adaptation.adapt(train_data, test_data, adaptation_model.AdaptVCD, VCD.ImageVCD, vcd_path, vcd_chkpt_id, None, 5000, 50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f75e83b2100>"
      ]
     },
     "execution_count": 8,
     "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,2)), label='RSSM')\n",
    "plt.fill_between(jnp.arange(100), jnp.quantile(rssm_error, 0.75, axis=(1,2)), jnp.quantile(rssm_error, 0.25, axis=(1,2)), alpha=0.3)\n",
    "plt.plot(jnp.median(vcd_error, axis=(1,2)), label='VCD')\n",
    "plt.fill_between(jnp.arange(100), jnp.quantile(vcd_error, 0.75, axis=(1,2)), jnp.quantile(vcd_error, 0.25, axis=(1,2)), alpha=0.3)\n",
    "\n",
    "plt.fill_betweenx([0,800], [0,0], [50,50], color='k', alpha=0.1)\n",
    "plt.ylim([0, 800])\n",
    "plt.xlim([0,100])\n",
    "plt.xlabel('time')\n",
    "plt.ylabel('L2 error')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f75e83b2e80>"
      ]
     },
     "execution_count": 9,
     "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
}
