{
 "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\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\n",
    "import numpy as np\n",
    "import jax\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This following script loads trained models and evaluate their rollout accuracy. \n",
    "\n",
    "Each test episode is 100 frames long. The models get observations for the first 50 frames and perform prediction purely in the latent space in the final 50 frames.\n",
    "\n",
    "Errors are measured as L2 distance in the pixel space."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_conf = json.load(open('../data/image_data_conf.json'))\n",
    "mixing_matrix = random.normal(random.PRNGKey(0), (8, 12))\n",
    "mixing_function = lambda x: x @ mixing_matrix\n",
    "\n",
    "test_data_config = data_conf['test_data_conf']\n",
    "mixing_function = lambda x: x / 255\n",
    "test_data = dataset.DataLoader(\n",
    "    generate_data.get_images,\n",
    "    test_data_config,\n",
    "    50,\n",
    "    data_conf[\"test_data_seed\"],\n",
    "    mixing_function,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:48<00:00,  2.05it/s]\n",
      "100%|██████████| 100/100 [01:16<00:00,  1.31it/s]\n"
     ]
    }
   ],
   "source": [
    "# change the below to the logging directories and the checkpoint ids for the models.\n",
    "rssm_path = '../pretrain/image_rssm'\n",
    "rssm_chkpt_id = 0\n",
    "vcd_path = '../pretrain/image_vcd'\n",
    "vcd_chkpt_id = 0\n",
    "\n",
    "rssm_error = evaluation.image_rollout_error(test_data, RSSM.ImageRSSM, rssm_path, rssm_chkpt_id, 50, None)\n",
    "vcd_error = evaluation.image_rollout_error(test_data, VCD.ImageVCD, vcd_path, vcd_chkpt_id, 50, None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f120b5997c0>"
      ]
     },
     "execution_count": 6,
     "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",
    "plt.fill_betweenx([0,1000], [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()"
   ]
  }
 ],
 "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
}
