{
 "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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This following script loads trained models and evaluate their rollout accuracy. \n",
    "\n",
    "Each test episode is 200 frames long. The models get observations for the first 100 frames and perform prediction purely in the latent space in the final 100 frames.\n",
    "\n",
    "Errors are measured as L2 distance in the ground-truth states."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_conf = json.load(open('../data/mixed_state_data_conf.json'))\n",
    "test_data_config = data_conf['test_data_conf']\n",
    "mixing_matrix = random.normal(random.PRNGKey(0), (8, 12))\n",
    "mixing_function = lambda x: x @ mixing_matrix\n",
    "\n",
    "test_data = dataset.DataLoader(\n",
    "    generate_data.get_states,\n",
    "    test_data_config,\n",
    "    1000,\n",
    "    data_conf[\"test_data_seed\"],\n",
    "    mixing_function,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# change the below to the logging directories and the checkpoint ids for the models.\n",
    "rssm_path = '../pretrain/mixed_state_rssm'\n",
    "rssm_chkpt_id = 0\n",
    "vcd_path = '../pretrain/mixed_state_vcd'\n",
    "vcd_chkpt_id = 0\n",
    "\n",
    "rssm_error = evaluation.state_rollout_error(test_data, RSSM.RSSM, rssm_path, rssm_chkpt_id, 100, mixing_matrix)\n",
    "vcd_error = evaluation.state_rollout_error(test_data, VCD.VCD, vcd_path, vcd_chkpt_id, 100, mixing_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f41208e4820>"
      ]
     },
     "execution_count": 7,
     "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",
    "plt.fill_betweenx([0,30], [0,0], [100,100], color='k', alpha=0.1)\n",
    "plt.ylim([0, 20])\n",
    "plt.xlim([0,199])\n",
    "plt.xlabel('time')\n",
    "plt.ylabel('L2 error')\n",
    "plt.legend()"
   ]
  },
  {
   "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
}
