{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "RArNFcAnHweS",
   "metadata": {
    "id": "RArNFcAnHweS",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "# Packages setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "dc84ef1d-ebe6-4d60-99f7-cc0eabdfdfb9",
   "metadata": {
    "id": "dc84ef1d-ebe6-4d60-99f7-cc0eabdfdfb9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from tqdm.notebook import tqdm\n",
    "import gymnasium as gym\n",
    "import warnings\n",
    "import pickle\n",
    "import itertools\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import copy\n",
    "import os\n",
    "import random\n",
    "from collections import deque\n",
    "np.set_printoptions(suppress=True, precision=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c5af0737-082a-4ee7-9a07-61cb5f22dba2",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/home/jupyter'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5da144d8-0f0f-47a2-93cd-7a77c14651f0",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "bnlm_FIdIIRQ",
   "metadata": {
    "id": "bnlm_FIdIIRQ",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "# Data generation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7ZStDqRB7oTP",
   "metadata": {
    "id": "7ZStDqRB7oTP",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Cartpole"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 214,
   "id": "CWJ0DNyeIMC5",
   "metadata": {
    "id": "CWJ0DNyeIMC5",
    "tags": []
   },
   "outputs": [],
   "source": [
    "env = gym.make(\"CartPole-v1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "id": "OrTiyWUY9tCC",
   "metadata": {
    "id": "OrTiyWUY9tCC",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def behavior_policy(state, epsilon=0):\n",
    "    angle = state[2]\n",
    "    if np.random.binomial(1, epsilon) == 1:\n",
    "        return np.random.choice([0,1])\n",
    "    else:\n",
    "        if angle < 0:\n",
    "            return 0\n",
    "        else:\n",
    "            return 1\n",
    "        \n",
    "def random_policy(state, action_size=2, batch=True):\n",
    "    if batch:\n",
    "        size = state.shape[0]\n",
    "        return torch.randint(0, action_size, (size,)).long()\n",
    "    \n",
    "    return np.random.choice([0, 1])\n",
    "\n",
    "def nondyna_policy(state, action=1, batch=True):\n",
    "    if batch:\n",
    "        size = state.shape[0]\n",
    "        return torch.randint(action, action+1, (size,)).long()\n",
    "    \n",
    "    return action\n",
    "def cartpole_policy(state, batch=True):\n",
    "    if batch:\n",
    "        pos = state[:,0]\n",
    "        angle = state[:,2]\n",
    "        prob_1 = 1 - 1/(1+torch.exp(angle-pos))\n",
    "        return torch.bernoulli(prob_1).long()\n",
    "    \n",
    "    pos = state[0]\n",
    "    angle = state[2]\n",
    "    prob_0 = 1/(1+np.exp(angle-pos))\n",
    "    prob_1 = 1 - prob_0\n",
    "    return np.random.binomial(1, prob_1)\n",
    "\n",
    "def angle_policy(state, batch=True):\n",
    "    if batch:\n",
    "        angle = state[:,2]\n",
    "        return (angle>=0).long()\n",
    "    \n",
    "    return behavior_policy(state)\n",
    "def mc_oracle(env, num_episodes, target, gamma):\n",
    "    rewards = np.zeros(num_episodes)\n",
    "\n",
    "    for i in tqdm(range(num_episodes)):\n",
    "        obs = env.reset()[0]\n",
    "        done = False\n",
    "        reward = 0\n",
    "        gam_pow = 1\n",
    "        while not done:\n",
    "            a = target(obs, batch=False)\n",
    "            next_obs, r, done, info, _ = env.step(a)\n",
    "            reward += gam_pow * adapt_r(obs)\n",
    "            obs = next_obs\n",
    "            gam_pow *= gamma\n",
    "            \n",
    "        rewards[i] = reward\n",
    "    mc_rewards_target_policy = np.mean(np.array(rewards))\n",
    "    return mc_rewards_target_policy\n",
    "\n",
    "class HD_obs:\n",
    "    def __init__(self, env, num_episodes, behavior, epsilon=0.3, aug_dim=10):\n",
    "        self.env = env\n",
    "        self.num_episodes = num_episodes\n",
    "        self.behavior = behavior\n",
    "        self.epsilon = epsilon\n",
    "        self.aug_dim = aug_dim\n",
    "        self.state_size = env.observation_space.shape[0]\n",
    "    def get_hd_obs(self):\n",
    "        sars = []\n",
    "        sars_by_episode = []\n",
    "        initial_states = []\n",
    "\n",
    "        for i in tqdm(range(self.num_episodes)):\n",
    "            obs = self.env.reset()[0]\n",
    "            done = False\n",
    "            initial = True\n",
    "            cur_sar = []\n",
    "            noise = np.zeros(self.aug_dim)\n",
    "\n",
    "            while not done:\n",
    "                a = self.behavior(obs, self.epsilon)\n",
    "                noise = self.AR1_noise(obs, noise, aug_dim=self.aug_dim)\n",
    "                obs_hd = np.concatenate((obs, noise))\n",
    "\n",
    "                if initial:\n",
    "                    initial_states.append(obs_hd)\n",
    "                    initial = False\n",
    "                next_obs, r, done, info,_ = self.env.step(a)\n",
    "                if self.state_size==4:\n",
    "                    adaptive_r = self.adapt_r(obs)\n",
    "                else:\n",
    "                    adaptive_r = r\n",
    "                    \n",
    "                next_noise = self.AR1_noise(next_obs, noise, aug_dim=self.aug_dim)\n",
    "                next_obs_hd = np.concatenate((next_obs, next_noise))\n",
    "\n",
    "                cur_sar.append([obs_hd, a, adaptive_r, next_obs_hd, done])\n",
    "\n",
    "                obs = next_obs\n",
    "                noise = next_noise\n",
    "                if self.state_size==8 and len(cur_sar)>1000: #stop lunar lander if it falls in one episode too long\n",
    "                    cur_sar[-1][4]=True\n",
    "                    break\n",
    "            sars_by_episode.append(cur_sar)\n",
    "\n",
    "        sars = [item for cur_sar in sars_by_episode for item in cur_sar]\n",
    "        return sars, sars_by_episode, initial_states\n",
    "    \n",
    "    def AR1_noise(self, obs, last, coef=1,aug_dim=10):\n",
    "        pass\n",
    "    \n",
    "    def adapt_r(self, obs):\n",
    "        pass\n",
    "    \n",
    "class cartpole_HD(HD_obs):\n",
    "    def __init__(self, env, num_episodes, behavior, epsilon=0.3, aug_dim=10):\n",
    "        super().__init__(env, num_episodes, behavior, epsilon,aug_dim)\n",
    "    \n",
    "    def adapt_r(self, obs):\n",
    "        return (1 - 2*obs[0]**2-5*obs[2]**2 )\n",
    "    \n",
    "    def AR1_noise(self, obs, last, coef=1,aug_dim=10):\n",
    "        mean = np.mean(obs)\n",
    "        std = np.std(obs)\n",
    "        noise = coef*last + np.random.normal(2*mean, 5*std, aug_dim)\n",
    "        return noise\n",
    "    \n",
    "class lunar_HD(HD_obs):\n",
    "    def __init__(self, env, num_episodes, behavior, epsilon=0.3, aug_dim=10):\n",
    "        super().__init__(env, num_episodes, behavior, epsilon,aug_dim)\n",
    "    \n",
    "    def AR1_noise(self, obs, last, coef=0.99,aug_dim=10):\n",
    "        mean = np.mean(obs)\n",
    "        std = np.std(obs)\n",
    "        noise = coef*last + np.random.normal(mean, std, aug_dim)\n",
    "        return noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "kj_WPSM9-IyM",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "kj_WPSM9-IyM",
    "outputId": "41325e94-24a5-40f1-f9da-9d9e4d7ad541",
    "tags": []
   },
   "outputs": [],
   "source": [
    "print(\"Monte Carlo reward of target policy is:\", mc_oracle(env, 50000, angle_policy, .99)) #29.87"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5dd0360-3907-4fd9-9d82-4f16db18e9bc",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "id": "vv8PbhGR4SDo",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 49,
     "referenced_widgets": [
      "601cc7d0987d45179ae1682796477633",
      "d7e28ab1c8c143b094cccbcd2bba142e",
      "2520b69322dd401da2b45c3e8794eb8c",
      "75c582a2dc7f4f0daa99725779a581e9",
      "4de8fb98003d48c5be987b577bc77215",
      "25255d249e8246daa0c756a7a79b5451",
      "f27c0656c60f4b6ca31cd7ae82a90881",
      "55c2b4452ec9455fb15a66ef65020cd8",
      "8a32947b92cf4bfa843602f19bd4a67b",
      "e1e8b12c81bb463d8ae894171ad53f4c",
      "2ce0003cfa8249159faccc99febd0eea"
     ]
    },
    "id": "vv8PbhGR4SDo",
    "outputId": "f1a35c20-bb36-44ef-8d85-95c8fd77bdcb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "743ecc939f7640e1be8c131f78aa1cf9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "generator = cartpole_HD(env, 1000, behavior_policy, .1, 296)\n",
    "sars, sars_by_episode, initial_states = generator.get_hd_obs()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ebf3e6b0-76c9-444c-b877-89103ce4759a",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Lunar Lander"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0a797e25-8424-409b-a5bc-b034a33fb480",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "#pip install swig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1b256150-c28a-4fc2-a01c-1e7c153b3d6e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "#pip install gymnasium[box2d]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8896fc16-ce08-452d-95d2-e3b9ecc45e16",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "env = gym.make(\"LunarLander-v2\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "9c2e0570-bcae-463f-abdf-e162f07b9b79",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "class DQN(nn.Module):\n",
    "    def __init__(self, in_dim, action_size):\n",
    "        super().__init__()\n",
    "        self.fc1 = nn.Linear(in_dim, 64)\n",
    "        self.fc2 = nn.Linear(64, 64)\n",
    "        self.fc3 = nn.Linear(64, action_size)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = torch.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "\n",
    "def target_lunar(state, batch=True):\n",
    "    policy_net.eval()\n",
    "    with torch.no_grad():\n",
    "        if batch:\n",
    "            a = torch.argmax(policy_net(state[:,:8]), axis=1).long()\n",
    "            return a\n",
    "        else:\n",
    "            state = torch.tensor(state).double().view(1,-1)\n",
    "            a = np.argmax(policy_net(state).squeeze(1).numpy())\n",
    "            return a  \n",
    "\n",
    "def behavior_lunar(state, epsilon=1):\n",
    "    if np.random.binomial(1, epsilon) == 1:\n",
    "        return np.random.choice([0,1,2,3])\n",
    "    else:\n",
    "        return target_lunar(state, False)\n",
    "\n",
    "def mc_oracle_lunar(env, num_episodes, target_model, gamma):\n",
    "    rewards = np.zeros(num_episodes)\n",
    "    \n",
    "    for i in tqdm(range(num_episodes)):\n",
    "        obs = env.reset()[0]\n",
    "        done = False\n",
    "        reward = 0\n",
    "        gam_pow = 1\n",
    "        for step in range(1000):\n",
    "            a = target_lunar(obs, False)\n",
    "            next_obs, r, done, info, _ = env.step(a)\n",
    "            reward += gam_pow * r\n",
    "            obs = next_obs\n",
    "            gam_pow *= gamma\n",
    "            if done:\n",
    "                break\n",
    "            \n",
    "        rewards[i] = reward\n",
    "    mc_rewards_target_policy = np.mean(np.array(rewards))\n",
    "    return mc_rewards_target_policy    \n",
    "\n",
    "class Agent:\n",
    "    def __init__(self, obs_size, action_size, batch_size=64, n_layers=3):\n",
    "        # general info\n",
    "        self._state_size = obs_size \n",
    "        self._action_size = action_size\n",
    "        self._batch_size = batch_size\n",
    "        self.criterion_DQN = nn.MSELoss()\n",
    "        # allow large replay exp space\n",
    "        self._experience = deque(maxlen=1000000)\n",
    "        \n",
    "        self._gamma = 0.99\n",
    "        # initialize with high exploration, which will decay later\n",
    "        self._epsilon = 1.0 \n",
    "        \n",
    "        # Build Q Network\n",
    "        self._policy_network = DQN(obs_size, action_size, n_layers).double()\n",
    "        \n",
    "        # Build Target Network - Build clone of Q Network\n",
    "        self._target_network = copy.deepcopy(self._policy_network)\n",
    "        \n",
    "        self.optimizer = optim.Adam(self._policy_network .parameters(), lr=0.0001)\n",
    "        \n",
    "        self.update_target_network()\n",
    "    \n",
    "    # add new experience to the replay exp\n",
    "    def memorize_experience(self, state, action, reward, next_state, done):\n",
    "        self._experience.append((state, action, reward, next_state, done))\n",
    "    \n",
    "    def update_target_network(self):\n",
    "        return self._target_network.load_state_dict(self._policy_network.state_dict())\n",
    "    \n",
    "    def choose_action(self, state):\n",
    "        if np.random.rand() < self._epsilon: # exploration\n",
    "            action = np.random.choice(self._action_size)\n",
    "        else:\n",
    "            state = torch.tensor(state).view(1,-1).double()\n",
    "            self._policy_network.eval()\n",
    "            with torch.no_grad():\n",
    "                qhat = self._policy_network(state) # output Q(s,a) for all a of current state\n",
    "            action = torch.argmax(qhat[0])\n",
    "            action = int(action)\n",
    "            \n",
    "        return action\n",
    "    \n",
    "    def target_policy(self, state):\n",
    "        self._policy_network.eval()\n",
    "        with torch.no_grad():\n",
    "            qhat = self._policy_network(state)\n",
    "        return torch.argmax(qhat, axis=1)\n",
    "     \n",
    "    def experience_replay(self):\n",
    "        # take a mini-batch from replay experience\n",
    "        self.optimizer.zero_grad()\n",
    "        self._policy_network.train()\n",
    "        \n",
    "        batch_size = min(len(self._experience), self._batch_size)\n",
    "        mini_batch = random.sample(self._experience, batch_size)\n",
    "        mini_batch = data_format(mini_batch)\n",
    "        order = torch.arange(batch_size)\n",
    "        \n",
    "        sample_states, sample_actions, sample_rewards, sample_next_states, sample_dones  = mini_batch\n",
    "        self._target_network.eval()\n",
    "        with torch.no_grad():   \n",
    "            sample_qhat_next = self._target_network(sample_next_states)\n",
    "            \n",
    "        sample_qhat = self._policy_network(sample_states).gather(1, sample_actions.unsqueeze(1)).squeeze(1)\n",
    "        \n",
    "        #sample_qhat_targets = sample_qhat.detach().clone()\n",
    "        # set all Q values terminal states to 0\n",
    "        sample_qhat_targets = sample_rewards + self._gamma * torch.amax(sample_qhat_next, axis=1) * (torch.ones(batch_size) - sample_dones)\n",
    "        \n",
    "        loss_DQN = self.criterion_DQN(sample_qhat, sample_qhat_targets.detach())\n",
    "\n",
    "        loss_DQN.backward()\n",
    "        self.optimizer.step()\n",
    "        \n",
    "        return loss_DQN.item()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "61e73193-d960-4d8e-9d00-82a5c16098af",
   "metadata": {},
   "source": [
    "**Train the DQN agent**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0b5243b-9415-4f2c-beb5-4242009659b8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "env = gym.make(\"LunarLander-v2\")\n",
    "NUM_EPISODES = 500\n",
    "agent = Agent(8, 4, batch_size=64, n_layers=2)\n",
    "state_size = env.observation_space.shape[0]\n",
    "timestep=0\n",
    "rewards = []\n",
    "\n",
    "for episode in range(NUM_EPISODES):\n",
    "    state = env.reset()[0]\n",
    "    total_reward = 0\n",
    "    done = False\n",
    "    render_env = episode % 5 == 0\n",
    "    for step in range(500):\n",
    "        action = agent.choose_action(state)\n",
    "        next_state, reward, done, info,_ = env.step(action)\n",
    "        total_reward += reward\n",
    "        \n",
    "        agent.memorize_experience(state, action, reward, next_state, done)\n",
    "        agent.experience_replay()\n",
    "        state = next_state\n",
    "        timestep += 1  \n",
    "        if done:\n",
    "            break\n",
    "    rewards.append(total_reward)   \n",
    "    # update target network each episode\n",
    "    agent.update_target_network()\n",
    "    # decaying exploration\n",
    "    agent._epsilon = max(0.1, 0.995 * agent._epsilon) \n",
    "\n",
    "    if render_env:\n",
    "        print(f\"Episode {episode}, Reward: {total_reward}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d6fee93d-f431-476c-947c-3dc3b7469b01",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "model_path = \"dqn_lunar_lander.pt\" #saving trained DQN\n",
    "torch.save(policy_net.state_dict(), model_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a2c188d0-36b7-4014-a558-3c9e28b81df0",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "policy_net = DQN(8, 4)\n",
    "model_path = \"dqn_lunar_lander.pt\"\n",
    "policy_net.load_state_dict(torch.load(model_path, map_location=torch.device('cpu'))) #loaidng trained model\n",
    "policy_net = policy_net.double()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e1ef4857-c4b0-4e81-b550-9699866f7a81",
   "metadata": {},
   "source": [
    "Calculate the oracle value of optimized policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "d43691ac-8e8f-4fde-b2e8-a3424e9ef61f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cfa4a8cc412a4667b9cca59fa61c2799",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "oracle_lunar = mc_oracle_lunar(env, 10000, policy_net, 0.99)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "24c08cd2-1322-4d80-a241-a1b36c019f67",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "print(\"Monte Carlo reward of target policy is:\", oracle_lunar) #61.70"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "93d3a80b-ff39-434e-ad00-e98e070f219f",
   "metadata": {},
   "source": [
    "Generator behavior experiences using optimized model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "611490e7-fb76-4af7-93c1-8efa089fb819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f9cf9179ab5c4838bc986f2b8db32e79",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/2000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "generator = lunar_HD(env, 1000, behavior_lunar, .1, 292)\n",
    "sars, sars_by_episode, initial_states = generator.get_hd_obs()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "68208552-8d7b-494a-8e2f-8386e34af4be",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"/home/jupyter/01_data.pickle\", 'wb') as f:\n",
    "    pickle.dump(sars_by_episode, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "413c0e8d-2585-42f4-a64f-403d634559fa",
   "metadata": {
    "id": "EB4PeYUX-gTY",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "# Utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17e2221c-5f88-4ba0-88be-cf2acbdb7136",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "id": "25fd047b-41ef-4f59-bdb8-8bb554dc5f8b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def load_combs(path):\n",
    "    with open(path, 'rb') as f:\n",
    "        dics = pickle.load(f)\n",
    "        MSEs = torch.tensor(list(dics[0].keys())).numpy()\n",
    "        sort_index = np.argsort(MSEs)\n",
    "        sort_MSEs = MSEs[sort_index]\n",
    "        sort_combs = torch.tensor(list(dics[0].values()))[sort_index]\n",
    "        sort_bias = torch.tensor(list(dics[2].values()))[sort_index]\n",
    "    return sort_MSEs, sort_combs, sort_bias\n",
    "\n",
    "def seaborn_plot(df, ax, title, xticks, mse=True, ylabel=False):\n",
    "    x_values = np.log(xticks)  # Manually set x-axis values in log scale\n",
    "    \n",
    "    df_long = pd.melt(df, var_name='Method', value_name='Value')\n",
    "    df_long['x'] = np.tile(x_values, len(df.columns))\n",
    "\n",
    "    markers = ['o', 's', 'D', '^', 'v', 'X']\n",
    "    method_marker_dict = {method: markers[i] for i, method in enumerate(df.columns)}\n",
    "    \n",
    "    for method, marker in method_marker_dict.items():\n",
    "        subset = df_long[df_long['Method'] == method[0]]\n",
    "        sns.scatterplot(data=subset, x='x', y='Value', label=method[0], marker=marker,s=100, ax=ax, legend=False)\n",
    "        sns.lineplot(data=subset, x='x', y='Value', linewidth=2, ax=ax, legend=False)\n",
    "\n",
    "    if mse:\n",
    "        ax.set_yscale('log')\n",
    "        ax.set_title(title)\n",
    "        if ylabel:\n",
    "            ax.set_ylabel('MSE')\n",
    "        else:\n",
    "            ax.set_ylabel('')\n",
    "    else:\n",
    "        #ax.set_yscale('symlog', linthresh=50)\n",
    "        ax.set_xlabel('No. of trajectories')\n",
    "        if ylabel:\n",
    "            ax.set_ylabel('Bias')\n",
    "        else:\n",
    "            ax.set_ylabel('')\n",
    "    ax.set_xticklabels(xticks)\n",
    "    ax.set_xticks(x_values)\n",
    "    ax.grid(True)\n",
    "\n",
    "def plot_helper(df, title, xticks=None, xlabel=\"x\", ylabel=\"y\"):\n",
    "    plt.figure(figsize=(6, 4))\n",
    "    if xticks is None:\n",
    "        xticks = np.arange(df.shape[0])\n",
    "        set_xtick = False\n",
    "    else:\n",
    "        set_xtick = True\n",
    "    for column in df.columns:\n",
    "        #plt.scatter(xticks, df[column], label=column[0])\n",
    "        plt.plot(xticks, df[column], linestyle='-', label=column[0])\n",
    "    if set_xtick:\n",
    "        plt.xticks(xticks)\n",
    "    plt.title(title)\n",
    "    plt.xlabel(xlabel)\n",
    "    plt.ylabel(ylabel)\n",
    "    #plt.legend()\n",
    "    plt.legend(loc='upper left', bbox_to_anchor=(1, 1))\n",
    "    plt.grid(True)\n",
    "    plt.show()\n",
    "\n",
    "def history(data, window=2):\n",
    "    terminal = data[4]\n",
    "    states = data[0]\n",
    "    actions = data[1]\n",
    "    num_exp = terminal.shape[0]\n",
    "    state_dim = states.shape[1]\n",
    "    his_dim_state = (states.shape[1]+1)*window\n",
    "    index_terminals = torch.cat([torch.tensor([-1]), torch.nonzero(terminal).squeeze()[:-1]])\n",
    "    index_onestep = index_terminals + 1 \n",
    "    index_twostep = index_terminals + 2  \n",
    "    history_states = []\n",
    "    for i in range(num_exp):\n",
    "        if i in index_onestep:\n",
    "            his_dim_state = (state_dim+1)*window\n",
    "            state = torch.cat([torch.zeros(his_dim_state), states[i]])\n",
    "        elif i in index_twostep:\n",
    "            his_dim_state = (state_dim+1)*(window-1)\n",
    "            state2 = states[i]\n",
    "            state1 = torch.cat([torch.tensor([actions[i-1]]), states[i-1]])\n",
    "            padding = torch.zeros(his_dim_state)\n",
    "            state = torch.cat([padding, state1, state2])\n",
    "        else:\n",
    "            if window==2:\n",
    "                state3 = states[i]\n",
    "                state2 = torch.cat([torch.tensor([actions[i-1]]), states[i-1]])\n",
    "                state1 = torch.cat([torch.tensor([actions[i-2]]), states[i-2]])\n",
    "                state = torch.cat([state1, state2, state3])\n",
    "            else:\n",
    "                pass\n",
    "        history_states.append(state)\n",
    "    return [*data, torch.stack(history_states)]    \n",
    "\n",
    "def encode(data, model, target_policy=None):\n",
    "    #Encode the original (s,a,r,s') tuple by abstraction\n",
    "    #data = [s,a,r,s',terminal] or [x,a,r,x',terminal,s,s']\n",
    "    data = copy.deepcopy(data)\n",
    "    sample_s = torch.cat([data[0], data[3][-1].unsqueeze(0)])\n",
    "    model.eval()\n",
    "    if target_policy is None:\n",
    "        with torch.no_grad():\n",
    "            all_states = model.encode(sample_s)\n",
    "            phi_s = all_states[:-1]\n",
    "            phi_s_next = all_states[1:]\n",
    "    else: \n",
    "        if len(data)==5:\n",
    "            pi_s = target_policy(sample_s)\n",
    "        else:\n",
    "            pi_s = target_policy( torch.cat([data[5], data[6][-1].unsqueeze(0)]) )\n",
    "        with torch.no_grad():\n",
    "            all_states = model.forward_encode(sample_s, pi_s)\n",
    "            phi_s = all_states[:-1]\n",
    "            phi_s_next = all_states[1:]\n",
    "    data[0] = phi_s\n",
    "    data[3] = phi_s_next\n",
    "    return data\n",
    "        \n",
    "def data_format(data):\n",
    "    s = torch.stack([torch.tensor(i[0]) for i in data]).double()\n",
    "    a = torch.tensor([i[1] for i in data]).long()\n",
    "    r = torch.tensor([i[2] for i in data])\n",
    "    s_next = torch.stack([torch.tensor(i[3]) for i in data]).double()\n",
    "    terminal = torch.stack([torch.tensor(i[4], dtype=torch.long) for i in data])\n",
    "    return [s,a,r,s_next,terminal]\n",
    "\n",
    "class SmoothLoss(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "\n",
    "    def forward(self, x, y):\n",
    "        diff = x - y\n",
    "        distance = 0.15*x.shape[1]\n",
    "        root_norm = torch.sqrt(torch.sum(diff ** 2, dim=1))\n",
    "        loss = torch.square(root_norm - distance)\n",
    "        return loss.mean()\n",
    "    \n",
    "class CollapseLoss(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "\n",
    "    def forward(self, x, y):\n",
    "        diff = x - y\n",
    "        root_norm = torch.sqrt(torch.sum(diff ** 2, dim=1))\n",
    "        loss = torch.exp(-root_norm)\n",
    "        return loss.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d715c86e-43eb-4a5f-9385-5405f0083db9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4de54275-b6e9-4df2-9722-c4385f44a2e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2acc21d16be24223b3672b996ffc2d6c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/12 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e3dad8de4e644c98aa73b692513cb1c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4236f45182244788a6e278f4ccea769c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7f5e84933cf54873b1925b0db900b649",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4faa1bd6447844d3a82e80c903e3f946",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a660e16cc10a44288f13f2b1527e808f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae79a661f5324d95864a8f6731c1e014",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "644101a61da644d38ff7613c63835fa0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "long_episodes = [sar for sar in sars_by_episode if len(sar)>=1000]\n",
    "short_episodes = [sar for sar in sars_by_episode if len(sar)<1000]\n",
    "\n",
    "dim1 = [200]\n",
    "dim2 = [50,30]\n",
    "dim3 = [20,10]\n",
    "dim4 = [8,4,2]\n",
    "combinations = list(itertools.product(dim1, dim2, dim3, dim4))\n",
    "dic = {}\n",
    "dic_mse = {}\n",
    "dic_bias = {}\n",
    "target_policy= target_lunar\n",
    "for comb in tqdm(combinations):\n",
    "    encoder_dim1, encoder_dim2, encoder_dim3, encoder_dim4 = comb\n",
    "\n",
    "    ite_params = [ {\"encoder_dim\":encoder_dim1, \"action_size\":4},\n",
    "               {\"encoder_dim\":encoder_dim2, \"action_size\":4},\n",
    "                 {\"encoder_dim\":encoder_dim3, \"action_size\":4},\n",
    "               {\"encoder_dim\":encoder_dim4, \"action_size\":4}]\n",
    "    modelnames = [\"forward\", \"backward\",\"forward\", \"backward\"]\n",
    "    mses = []\n",
    "    biases = []\n",
    "    MSE = 0\n",
    "    for j in range(20):       \n",
    "        #random_episodes = random.sample(sars_by_episode, 80)\n",
    "        #sample = [item for cur_sar in random_episodes for item in cur_sar]\n",
    "        #sample = data_format(sample)\n",
    "        random_episodes = random.sample(long_episodes, 24)\n",
    "        random_episodes.extend(random.sample(short_episodes, 16))\n",
    "        sample = [item for cur_sar in random_episodes for item in cur_sar]\n",
    "        sample = data_format(sample)\n",
    "        iterative_model, iterative_loss, ite_data = train_iterative(sample, modelnames, target_policy, ite_params)\n",
    "        FQE_data = [ite_data[0], ite_data[1], ite_data[2], ite_data[3], ite_data[4], ite_data[6]]\n",
    "        FQE_value = train_FQE(FQE_data, 20, target_policy)\n",
    "        \n",
    "        error = (FQE_value - 61.70)\n",
    "        square_error = (FQE_value - 61.70)**2\n",
    "        biases.append(error)\n",
    "        mses.append(square_error)\n",
    "        MSE += square_error\n",
    "    MSE = MSE/20.\n",
    "    dic_mse[MSE] = mses\n",
    "    dic[MSE] = comb\n",
    "    dic_bias[MSE] = biases\n",
    "    \n",
    "with open(\"/home/jupyter/0.1_dim1_200.pickle\", 'wb') as f:\n",
    "    pickle.dump((dic, dic_mse, dic_bias), f)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "FonDdu9nH4jy",
   "metadata": {
    "id": "FonDdu9nH4jy",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "# Models"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "UobfQ-j7xlN4",
   "metadata": {
    "id": "UobfQ-j7xlN4",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Forward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "id": "UAxT_P7eyZvO",
   "metadata": {
    "id": "UAxT_P7eyZvO",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class Encoder_linear(torch.nn.Module):\n",
    "    def __init__(self, obs_size, out_dim, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.obs_size = obs_size\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(obs_size, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.2))\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, out_dim))\n",
    "        #self.net.append(nn.Tanh())\n",
    "        \n",
    "        self.encoder_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, s):\n",
    "        x = self.encoder_net(s)\n",
    "        return x\n",
    "\n",
    "class Encoder_conv(nn.Module):\n",
    "    def __init__(self, out_dim):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 64, 3, stride=2)\n",
    "        self.pool1 = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 32, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(32, 16, 3, padding=1)\n",
    "\n",
    "        self.fc1 = nn.Linear(16 * 4 * 4, 64)\n",
    "        self.fc2 = nn.Linear(64, out_dim)\n",
    "\n",
    "        self.flatten = nn.Flatten()\n",
    "        self.relu = nn.ReLU()\n",
    "        self.tanh = nn.Tanh()\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, s):\n",
    "        x = self.conv1(s)\n",
    "        x = self.relu(x)\n",
    "        x = self.pool1(x)\n",
    "\n",
    "        x = self.conv2(x)\n",
    "        x = self.relu(x)\n",
    "        # Skip pooling here due to dimension consideration\n",
    "\n",
    "        x = self.conv3(x)\n",
    "        x = self.relu(x)\n",
    "\n",
    "        x = self.flatten(x)\n",
    "        x = self.fc1(x)\n",
    "        x = self.relu(x)\n",
    "        #x = self.tanh(self.fc2(x))\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "\n",
    "class Transition(torch.nn.Module):\n",
    "    def __init__(self, in_dim, out_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.action_size = action_size\n",
    "        self.activation = activation\n",
    "        self.out_dim = out_dim\n",
    "        self.hidden_size = 2*n_nodes\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "        \n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            if i < n_layers-2:\n",
    "                self.net.append(self.activation)\n",
    "                if dropout:\n",
    "                    self.net.append(nn.Dropout(0.2))\n",
    "\n",
    "        self.T_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.lstm = nn.LSTMCell(n_nodes, 2*n_nodes)\n",
    "        self.fcs = [nn.Linear(2*n_nodes, out_dim, dtype=torch.float64) for i in range(action_size)]\n",
    "\n",
    "        self.tanh = nn.Tanh()\n",
    "\n",
    "        self.train()\n",
    "\n",
    "    def forward(self, x):\n",
    "        h_0 = torch.zeros(x.shape[0], self.hidden_size, dtype=torch.float64)\n",
    "        c_0 = torch.zeros(x.shape[0], self.hidden_size, dtype=torch.float64)\n",
    "        x = self.T_net(x)\n",
    "        h_1, c_1 = self.lstm(x, (h_0, c_0))\n",
    "        x_list = [fc(h_1) for fc in self.fcs]\n",
    "        x = torch.stack(x_list, dim=1)\n",
    "        #x = self.fc(h_1)\n",
    "        return x\n",
    "\n",
    "class Reward(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.action_size = action_size\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.2))\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, action_size))\n",
    "        self.reward_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, x):\n",
    "        x = self.reward_net(x)\n",
    "        return x\n",
    "\n",
    "class Decoder(torch.nn.Module):\n",
    "    #one of the penalty we used in experiments\n",
    "    def __init__(self, in_dim, out_dim, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.2))\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, out_dim))\n",
    "        self.decoder_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, x):\n",
    "        x = self.decoder_net(x)\n",
    "        return x\n",
    "\n",
    "class FQE(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        self.action_size = action_size\n",
    "        self.activation = activation\n",
    "\n",
    "        self.action_net = nn.Sequential(\n",
    "            nn.Linear(1, 16),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(16, in_dim) )\n",
    "        self.xa_net = nn.Linear(2*in_dim, in_dim)\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.2))\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, action_size))\n",
    "        self.FQE_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, x, pi_s):\n",
    "        pi_s = pi_s.double().view(-1,1)\n",
    "        action_pi = self.action_net(pi_s)\n",
    "        x = torch.cat([x, action_pi], axis=1)\n",
    "        phi1_s = self.xa_net(x)\n",
    "        x = self.FQE_net(phi1_s)\n",
    "        return x\n",
    "    \n",
    "    def forward_encode(self, x, pi_s):\n",
    "        pi_s = pi_s.double().view(-1,1)\n",
    "        action_pi = self.action_net(pi_s)\n",
    "        x = torch.cat([x, action_pi], axis=1)\n",
    "        phi1_s = self.xa_net(x)\n",
    "        return phi1_s\n",
    "    \n",
    "    \n",
    "class Forward_model(torch.nn.Module):\n",
    "    \"An assemble model for training with above forward abstraction objectives\"\n",
    "    def __init__(self, obs_size, encoder_dim, action_size, encoder_layers=3,\n",
    "                 transition_layers=3, reward_layers=5, FQE_layers=3, activation=nn.ReLU()):\n",
    "        super().__init__()\n",
    "        self.obs_size = obs_size\n",
    "        self.encoder_dim = encoder_dim\n",
    "        self.action_size = action_size\n",
    "\n",
    "        self.encoder = Encoder_linear(obs_size, encoder_dim, encoder_layers, activation=activation)\n",
    "        self.transition = Transition(encoder_dim, encoder_dim, action_size, transition_layers, activation=activation)\n",
    "        self.reward = Reward(encoder_dim, action_size, reward_layers, activation=activation)\n",
    "        self.FQE = FQE(encoder_dim, action_size, FQE_layers, activation=activation)\n",
    "        \n",
    "    def forward(self, inputs):\n",
    "        s, pi_s = inputs\n",
    "        x = self.encoder(s)\n",
    "        x_t = self.transition(x)\n",
    "        x_r = self.reward(x)\n",
    "        x_f = self.FQE(x, pi_s)\n",
    "        return x, x_r, x_t, x_f\n",
    "    \n",
    "    def forward_encode(self, s, pi_s):\n",
    "        #this return phi1(s), it takes information from target policy and is Q-pi irrelevant\n",
    "        x = self.encoder(s)\n",
    "        phi1_s = self.FQE.forward_encode(x, pi_s)\n",
    "        return phi1_s\n",
    "    \n",
    "    def encode(self, s):\n",
    "        # this is the model-irrelevant representation\n",
    "        return self.encoder(s)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19725587-69cb-4640-9de5-9afab23634a3",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "dfuIlTWRxq2k",
   "metadata": {
    "id": "dfuIlTWRxq2k",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Backward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "id": "ZIhf98TPxvU_",
   "metadata": {
    "id": "ZIhf98TPxvU_",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class Inverse(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(2*in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.3))\n",
    "\n",
    "        if action_size == 2:\n",
    "            self.net.append(nn.Linear(n_nodes, 1))\n",
    "            #self.net.append(nn.Sigmoid())\n",
    "        else:\n",
    "            self.net.append(nn.Linear(n_nodes, action_size))\n",
    "\n",
    "        self.inverse_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, x, x_next):\n",
    "        x = torch.cat([x, x_next], -1)\n",
    "        x = self.inverse_net(x)\n",
    "        return x\n",
    "\n",
    "\n",
    "class Density(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(2*in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.3))\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, 1))\n",
    "\n",
    "        self.density_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, x, x_next):\n",
    "        x_next_flipped = torch.flip(x_next, dims=[0])\n",
    "        x_pos = torch.cat([x, x_next], -1)\n",
    "        x_neg = torch.cat([x, x_next_flipped], -1)\n",
    "        x = torch.cat([x_pos, x_neg], 0)\n",
    "        \n",
    "        x = self.density_net(x)\n",
    "        x = x.flatten()\n",
    "        return x\n",
    "\n",
    "class Rho(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.action_size = action_size\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.3))\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, action_size))\n",
    "        self.rho_net = nn.Sequential(*self.net)\n",
    "        \n",
    "        self.train()\n",
    "    def forward(self, x):\n",
    "        x = self.rho_net(x)\n",
    "        return x\n",
    "\n",
    "class Backward_model(torch.nn.Module):\n",
    "    \"An assemble model for training with above backward abstraction objectives\"\n",
    "    def __init__(self, obs_size, encoder_dim, action_size, encoder_layers=3,\n",
    "                 inverse_layers=5, density_layers=5, rho_layers=3):\n",
    "        super().__init__()\n",
    "        self.obs_size = obs_size\n",
    "        self.encoder_dim = encoder_dim\n",
    "        self.action_size = action_size\n",
    "\n",
    "        self.encoder = Encoder_linear(obs_size, encoder_dim, encoder_layers)\n",
    "        self.inverse = Inverse(encoder_dim, action_size, inverse_layers)\n",
    "        self.density = Density(encoder_dim, action_size, density_layers)\n",
    "        self.rho = Rho(encoder_dim, action_size, rho_layers)\n",
    "    def forward(self, inputs):\n",
    "        s, s_next = inputs\n",
    "        x = self.encoder(s)\n",
    "        x_next = self.encoder(s_next)\n",
    "        x_i = self.inverse(x, x_next)\n",
    "        x_d = self.density(x, x_next)\n",
    "        x_rho = self.rho(x)\n",
    "        return x, x_next, x_i, x_d, x_rho\n",
    "    \n",
    "    def encode(self, s):\n",
    "        #this return phi2(s), the backward model irrelevant representation\n",
    "        phi2_s = self.encoder(s)\n",
    "        return phi2_s\n",
    "\n",
    "class Behavior(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=64, activation=nn.ReLU(), dropout=True):\n",
    "        super().__init__()\n",
    "        assert n_layers >= 1\n",
    "        self.action_size = action_size\n",
    "        self.activation = activation\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(self.activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(self.activation)\n",
    "            if dropout:\n",
    "                self.net.append(nn.Dropout(0.3))\n",
    "                \n",
    "        if action_size == 2:\n",
    "            self.net.append(nn.Linear(n_nodes, 1))\n",
    "        else:\n",
    "            self.net.append(nn.Linear(n_nodes, action_size))\n",
    "            \n",
    "        self.behavior_net = nn.Sequential(*self.net)\n",
    "        \n",
    "        self.train()\n",
    "    def forward(self, s):\n",
    "        x = self.behavior_net(s)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b9bc2df-0e21-443c-9609-0aa3cee0814e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "-LHTBTnfxHBn",
   "metadata": {
    "id": "-LHTBTnfxHBn",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "# Train Abstraction"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "jyND4_QbxM-n",
   "metadata": {
    "id": "jyND4_QbxM-n",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Train Forward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "f7fa14e8-e902-4442-b057-9c9f8a54c7af",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def train_step(model, optimizer, s, a, r, s_next, terminal, observed_s, observed_next, target_policy,\n",
    "               alpha_r=1., alpha_t=1., alpha_f=1., alpha_p=0.1):\n",
    "    optimizer.zero_grad()\n",
    "    model.train()\n",
    "    \n",
    "    mse_loss = nn.MSELoss()\n",
    "    smooth_loss = SmoothLoss()\n",
    "    collapse_loss = CollapseLoss()\n",
    "    \n",
    "    batch_size = s.shape[0]\n",
    "    order = torch.arange(batch_size)\n",
    "    observed_s = observed_s.requires_grad_()\n",
    "    pi_s = target_policy(observed_s)\n",
    "    pi_s_next = target_policy(observed_next)\n",
    "\n",
    "    outputs_encoder, outputs_reward, outputs_transition, outputs_FQE = model((s, pi_s))\n",
    "\n",
    "    with torch.no_grad():\n",
    "        model.eval()\n",
    "        x_next = model.encoder(s_next)\n",
    "        FQE_next = model.FQE(x_next, pi_s_next)\n",
    "        x_next_hat = model.transition(x_next)\n",
    "    model.train()\n",
    "    \n",
    "    x_next_flip = torch.flip(x_next, dims=[0])\n",
    "    x_next_hat_flip = torch.flip(x_next_hat, dims=[0])\n",
    "    \n",
    "    # Compute the losses\n",
    "    x_next_targets = outputs_transition.detach().clone()\n",
    "    x_next_targets[order, a] = x_next\n",
    "\n",
    "    FQE_targets = outputs_FQE.detach().clone()\n",
    "    FQE_targets[order, a] = r + .99 * FQE_next[order, pi_s_next] *\\\n",
    "                    (torch.ones(batch_size, dtype=torch.float64) - terminal)\n",
    "\n",
    "    r_targets = outputs_reward.detach().clone()\n",
    "    r_targets[order, a] = r\n",
    "\n",
    "    loss_reward = mse_loss(outputs_reward, r_targets)\n",
    "    loss_transition = mse_loss(outputs_transition, x_next_targets)\n",
    "    loss_FQE = mse_loss(outputs_FQE, FQE_targets)\n",
    "    loss_collapse1 = collapse_loss(outputs_encoder, x_next_flip) #by revsersing the order, the loss is calculated on random samples of states\n",
    "    loss_collapse2 = collapse_loss(x_next_hat_flip, outputs_transition)\n",
    "    loss_smooth = smooth_loss(x_next, outputs_encoder) #if two states are consective then they should be closer in abstract state space as well\n",
    "    \n",
    "    loss_penalty = loss_collapse1 + loss_collapse2 + loss_smooth\n",
    "\n",
    "    l_phi_1 = alpha_r*loss_reward + alpha_t*loss_transition + alpha_f*loss_FQE + alpha_p*loss_penalty\n",
    "    \n",
    "    l_phi_1.backward()\n",
    "    optimizer.step()\n",
    "    \n",
    "    return alpha_r*loss_reward.item(), alpha_t*loss_transition.item(), alpha_f*loss_FQE.item(), alpha_p*loss_penalty.item()\n",
    "\n",
    "def train_forward(data, target_policy, params={}):\n",
    "    #data = [s,a,r,s',terminal] or [x,a,r,x',terminal,s,s']\n",
    "    obs_size = data[0][0].shape[0]\n",
    "    action_size = params.get(\"action_size\", 2)\n",
    "    encoder_dim = params.get(\"encoder_dim\", 10)\n",
    "    encoder_layers = params.get(\"encoder_layers\", 3)\n",
    "    transition_layers = params.get(\"transition_layers\", 3)\n",
    "    reward_layers = params.get(\"reward_layers\", 5)\n",
    "    FQE_layers = params.get(\"FQE_layers\", 3)\n",
    "    lr = params.get(\"lr\", 0.001)\n",
    "    num_epochs = params.get(\"num_epochs\", 30)\n",
    "    alphar = params.get(\"alpha_r\",1.)\n",
    "    alphat = params.get(\"alpha_t\",1.)\n",
    "    alphaf = params.get(\"alpha_f\",1.)\n",
    "    #alphap = params.get(\"alpha_p\",1.)\n",
    "    alphap = min(1, 20/obs_size)\n",
    "    \n",
    "    observed = False if len(data)==5 else True\n",
    "    model = Forward_model(obs_size, encoder_dim, action_size, encoder_layers,\n",
    "                     transition_layers, reward_layers, FQE_layers).double()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    \n",
    "    batch_size = max((data[1].shape[0])//20,10)\n",
    "    dataset = TensorDataset(*data)\n",
    "    batch_data = DataLoader(dataset, batch_size=batch_size)\n",
    "    gen_len = len(batch_data)\n",
    "    epoch_loss = []\n",
    "    \n",
    "    for epoch in tqdm(range(num_epochs)):\n",
    "        running_loss = np.zeros(4)\n",
    "        for batch in batch_data:\n",
    "            if observed:\n",
    "                s, a, r, s_next, terminal, observed_s, observed_next = batch\n",
    "            else:\n",
    "                s, a, r, s_next, terminal = batch\n",
    "                observed_s = s.clone().detach()\n",
    "                observed_next = s_next.clone().detach()\n",
    "                \n",
    "            batch_loss = train_step(model, optimizer, s, a, r, s_next,terminal,\n",
    "                            observed_s, observed_next, target_policy, alphar, alphat, alphaf, alphap)\n",
    "\n",
    "            running_loss += np.array(batch_loss)\n",
    "        epoch_loss.append(running_loss / gen_len )\n",
    "    return model, epoch_loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ef15fe0-724d-470f-9caa-a2a347e6298e",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_all = pd.DataFrame(forward_loss, columns=['reward', 'trans', 'fqe', \"penalty\"])\n",
    "df_wto = df_all[['reward', 'trans', \"penalty\"]]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f3a97065-e1e3-448a-b1dc-26444b2efa30",
   "metadata": {},
   "source": [
    "* Optimal forward model 4D: (1, 0.7, 0.3, 0.1)\n",
    "* Worst forward model 4D: (1, 0.7, 1, 0.1)\n",
    "* Optimal forward model 20D: (0.3, 0.1, 0.7, 1)\n",
    "* Worst forward model 20D: (0.3, 0.1, 0.3, 0.3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1e0010f3-6168-4990-bfdd-649887cca97e",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Train Backward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "id": "e73a9f37-9acb-47f6-99d0-99310da6e637",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def back_train_step(model, behavior_model, optimizer, s, a, s_next, observed_s, target_policy, \n",
    "                   action_size, alpha_i=1., alpha_d=1., alpha_rho=1., alpha_p=0.5):\n",
    "    optimizer.zero_grad()\n",
    "    model.train()\n",
    "    \n",
    "    mse_loss = nn.MSELoss()\n",
    "    smooth_loss = SmoothLoss()\n",
    "    collapse_loss = CollapseLoss()\n",
    "    bce_loss = nn.BCEWithLogitsLoss()\n",
    "    \n",
    "    batch_size, s_size = s.shape\n",
    "    order = torch.arange(batch_size)\n",
    "    \n",
    "    pi_a_s = (target_policy(observed_s)==a).double() #the probability of target policy taking action a.\n",
    "    behavior_model.eval()\n",
    "    with torch.no_grad():\n",
    "        b_a_s = behavior_model(s) #b_a_s computational graph breaken\n",
    "        \n",
    "    if action_size > 2:\n",
    "        b_a_s = torch.softmax(b_a_s, dim=1)\n",
    "        b_a_s = b_a_s[order, a.long()] \n",
    "        rho_a_s = (pi_a_s/b_a_s)\n",
    "        \n",
    "        inv_loss = nn.CrossEntropyLoss()\n",
    "    else:\n",
    "        b_a_s = torch.sigmoid(b_a_s).view(-1,)\n",
    "        for i in range(batch_size):\n",
    "            if not a[i]:\n",
    "                b_a_s[i] = 1. - b_a_s[i]\n",
    "        rho_a_s = (pi_a_s/b_a_s)\n",
    "        \n",
    "        a = a.double()\n",
    "        inv_loss = bce_loss\n",
    "        \n",
    "    s_next_flipped = torch.flip(s_next, dims=[0])\n",
    "    contrastive_labels = torch.cat([torch.ones(batch_size), torch.zeros(batch_size)])\n",
    "    \n",
    "    x, x_next, x_inverse, x_density, x_rho = model((s, s_next))\n",
    "    \n",
    "    x_next_flip = torch.flip(x_next, dims=[0])\n",
    "    x_rho_targets = x_rho.detach().clone()\n",
    "    x_rho_targets[order, a.long()] = rho_a_s\n",
    "    if action_size == 2:\n",
    "        a = a.view(-1,1)\n",
    "    loss_inverse = inv_loss(x_inverse, a)\n",
    "    loss_density = bce_loss(x_density, contrastive_labels)\n",
    "    loss_rho = mse_loss(x_rho, x_rho_targets)\n",
    "    loss_collapse = collapse_loss(x, x_next_flip)\n",
    "    loss_smooth = smooth_loss(x, x_next)\n",
    "    loss_penalty = loss_collapse + loss_smooth\n",
    "\n",
    "    l_phi_2 = alpha_i*loss_inverse + alpha_d*loss_density + alpha_rho*loss_rho + alpha_p *loss_penalty\n",
    "    \n",
    "    l_phi_2.backward()\n",
    "    optimizer.step()\n",
    "    \n",
    "    return alpha_i*loss_inverse.item(), alpha_d*loss_density.item(), alpha_rho*loss_rho.item(), alpha_p*loss_penalty.item()\n",
    "\n",
    "def train_backward(data, target_policy, params={}):\n",
    "    #data=[s,a,r,s',terminal] or [x,a,r,x',terminal,s,s']\n",
    "    obs_size = data[0][0].shape[0]\n",
    "    action_size = params.get(\"action_size\", 2)\n",
    "    encoder_dim = params.get(\"encoder_dim\", 10)\n",
    "    encoder_layers = params.get(\"encoder_layers\", 3)\n",
    "    inverse_layers = params.get(\"inverse_layers\", 3)\n",
    "    density_layers = params.get(\"density_layers\", 3)\n",
    "    rho_layers = params.get(\"rho_layers\", 3)\n",
    "    \n",
    "    alphai = params.get(\"alpha_i\",1.)\n",
    "    alphad = params.get(\"alpha_d\",1.)\n",
    "    alpharho = params.get(\"alpha_rho\",1.)\n",
    "    #alpharho = min(1., 20/obs_size)\n",
    "    alphap = min(1., 10/obs_size)\n",
    "    #alphap = params.get(\"alpha_p\",1.)\n",
    "\n",
    "    lr = params.get(\"lr\", 0.001)\n",
    "    num_epochs = params.get(\"num_epochs\", 30)\n",
    "    #encoder_gap = params.get(\"encoder_gap\", 3)\n",
    "    observed = False if len(data)==5 else True\n",
    "\n",
    "    behavior_fitted, b_loss = train_behavior(data[:2], 30, action_size)\n",
    "        \n",
    "    model = Backward_model(obs_size, encoder_dim, action_size, encoder_layers,\n",
    "                     inverse_layers, density_layers, rho_layers).double()\n",
    "    \n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    \n",
    "    batch_size = max((data[1].shape[0])//20,10)\n",
    "    dataset = TensorDataset(*data)\n",
    "    batch_data = DataLoader(dataset, batch_size=batch_size)\n",
    "    gen_len = len(batch_data)\n",
    "    epoch_loss = []\n",
    "    \n",
    "    for epoch in tqdm(range(num_epochs)):\n",
    "        running_loss = np.zeros(4)\n",
    "        for batch in batch_data:\n",
    "            if observed:\n",
    "                s, a, _, s_next, _, observed_s,_ = batch #need to batch history states as well.\n",
    "            else:\n",
    "                s, a, _, s_next, _= batch\n",
    "                observed_s = s.clone().detach()\n",
    "                \n",
    "            batch_loss = back_train_step(model, behavior_fitted, optimizer, s, a, s_next, observed_s,\n",
    "                                         target_policy, action_size, alphai, alphad, alpharho, alphap)\n",
    "\n",
    "            running_loss += np.array(batch_loss)\n",
    "        epoch_loss.append(running_loss / gen_len )\n",
    "    return model, epoch_loss\n",
    "\n",
    "def back_train_step_h(model, behavior_model, optimizer, s, a, s_next, observed_s, h_s, target_policy, \n",
    "                   action_size, alpha_i=1., alpha_d=1., alpha_rho=1., alpha_p=0.5):\n",
    "    optimizer.zero_grad()\n",
    "    model.train()\n",
    "    \n",
    "    mse_loss = nn.MSELoss()\n",
    "    smooth_loss = SmoothLoss()\n",
    "    collapse_loss = CollapseLoss()\n",
    "    bce_loss = nn.BCEWithLogitsLoss()\n",
    "    \n",
    "    batch_size, s_size = s.shape\n",
    "    order = torch.arange(batch_size)\n",
    "    \n",
    "    pi_a_s = (target_policy(observed_s)==a).double() #the probability of target policy taking action a.\n",
    "    behavior_model.eval()\n",
    "    with torch.no_grad():\n",
    "        b_a_s = behavior_model(h_s) #b_a_s computational graph breaken\n",
    "        \n",
    "    if action_size > 2:\n",
    "        b_a_s = torch.softmax(b_a_s, dim=1)\n",
    "        b_a_s = b_a_s[order, a.long()] \n",
    "        rho_a_s = (pi_a_s/b_a_s)\n",
    "        \n",
    "        inv_loss = nn.CrossEntropyLoss()\n",
    "    else:\n",
    "        b_a_s = torch.sigmoid(b_a_s).view(-1,)\n",
    "        for i in range(batch_size):\n",
    "            if not a[i]:\n",
    "                b_a_s[i] = 1. - b_a_s[i]\n",
    "        rho_a_s = (pi_a_s/b_a_s)\n",
    "        \n",
    "        a = a.double()\n",
    "        inv_loss = bce_loss\n",
    "        \n",
    "    s_next_flipped = torch.flip(s_next, dims=[0])\n",
    "    contrastive_labels = torch.cat([torch.ones(batch_size), torch.zeros(batch_size)])\n",
    "    \n",
    "    x, x_next, x_inverse, x_density, x_rho = model((s, s_next))\n",
    "    \n",
    "    x_next_flip = torch.flip(x_next, dims=[0])\n",
    "    x_rho_targets = x_rho.detach().clone()\n",
    "    x_rho_targets[order, a.long()] = rho_a_s\n",
    "    if action_size == 2:\n",
    "        a = a.view(-1,1)\n",
    "    loss_inverse = inv_loss(x_inverse, a)\n",
    "    loss_density = bce_loss(x_density, contrastive_labels)\n",
    "    loss_rho = mse_loss(x_rho, x_rho_targets)\n",
    "    loss_collapse = collapse_loss(x, x_next_flip)\n",
    "    loss_smooth = smooth_loss(x, x_next)\n",
    "    loss_penalty = loss_collapse + loss_smooth\n",
    "\n",
    "    l_phi_2 = alpha_i*loss_inverse + alpha_d*loss_density + alpha_rho*loss_rho + alpha_p *loss_penalty\n",
    "    \n",
    "    l_phi_2.backward()\n",
    "    optimizer.step()\n",
    "    \n",
    "    return alpha_i*loss_inverse.item(), alpha_d*loss_density.item(), alpha_rho*loss_rho.item(), alpha_p*loss_penalty.item()\n",
    "\n",
    "def train_backward_his(data, target_policy, params={}):\n",
    "    #data=[s,a,r,s',terminal] or [x,a,r,x',terminal,s,s']\n",
    "    obs_size = data[0][0].shape[0]\n",
    "    action_size = params.get(\"action_size\", 2)\n",
    "    encoder_dim = params.get(\"encoder_dim\", 10)\n",
    "    encoder_layers = params.get(\"encoder_layers\", 3)\n",
    "    inverse_layers = params.get(\"inverse_layers\", 3)\n",
    "    density_layers = params.get(\"density_layers\", 3)\n",
    "    rho_layers = params.get(\"rho_layers\", 3)\n",
    "    \n",
    "    alphai = params.get(\"alpha_i\",1.)\n",
    "    alphad = params.get(\"alpha_d\",1.)\n",
    "    alpharho = params.get(\"alpha_rho\",1.)\n",
    "    #alpharho = min(1., 20/obs_size)\n",
    "    alphap = min(1., 10/obs_size)\n",
    "    #alphap = params.get(\"alpha_p\",1.)\n",
    "\n",
    "    lr = params.get(\"lr\", 0.001)\n",
    "    num_epochs = params.get(\"num_epochs\", 30)\n",
    "    #encoder_gap = params.get(\"encoder_gap\", 3)\n",
    "    observed = False if len(data)==5 else True\n",
    "    history_data = history(data)\n",
    "\n",
    "    behavior_fitted, b_loss = train_behavior([history_data[-1],history_data[1]], 30, action_size)\n",
    "        \n",
    "    model = Backward_model(obs_size, encoder_dim, action_size, encoder_layers,\n",
    "                     inverse_layers, density_layers, rho_layers).double()\n",
    "    \n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    \n",
    "    batch_size = max((data[1].shape[0])//20,10)\n",
    "    #dataset = TensorDataset(*data)\n",
    "    #batch_data = DataLoader(dataset, batch_size=batch_size)\n",
    "    dataset = TensorDataset(*history_data)\n",
    "    batch_data = DataLoader(dataset, batch_size=batch_size)\n",
    "    gen_len = len(batch_data)\n",
    "    epoch_loss = []\n",
    "    \n",
    "    for epoch in tqdm(range(num_epochs)):\n",
    "        running_loss = np.zeros(4)\n",
    "        for batch in batch_data:\n",
    "            if observed:\n",
    "                s, a, _, s_next, _,observed_s, _, h_s = batch\n",
    "            else:\n",
    "                s, a, _, s_next, _, h_s= batch\n",
    "                observed_s = s.clone().detach()\n",
    "                \n",
    "            batch_loss = back_train_step_h(model, behavior_fitted, optimizer, s, a, s_next, observed_s,h_s,\n",
    "                                         target_policy, action_size, alphai, alphad, alpharho, alphap)\n",
    "\n",
    "            running_loss += np.array(batch_loss)\n",
    "        epoch_loss.append(running_loss / gen_len )\n",
    "    return model, epoch_loss\n",
    "\n",
    "def train_behavior(data, num_epochs, action_size, n_layers=3, n_nodes=64, lr=0.001):\n",
    "    #data=[s,a] or [x,a]\n",
    "    in_dim = data[0][0].shape[0]\n",
    "    if action_size > 2:\n",
    "        b_loss = nn.CrossEntropyLoss()\n",
    "    else:\n",
    "        b_loss = nn.BCEWithLogitsLoss()\n",
    "        \n",
    "    batch_size = max((data[1].shape[0])//20,10)\n",
    "    model = Behavior(in_dim, action_size, n_layers, n_nodes).double()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    dataset = TensorDataset(*data)\n",
    "    batch_data = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n",
    "    gen_len = len(batch_data)\n",
    "    epoch_loss = []\n",
    "    \n",
    "    for epoch in range(num_epochs):\n",
    "        running_loss = 0\n",
    "        for s, a in batch_data:\n",
    "            if action_size == 2:\n",
    "                a = a.double()\n",
    "                a = a.view(-1,1)\n",
    "                \n",
    "            optimizer.zero_grad()\n",
    "            model.train()\n",
    "            \n",
    "            b_a_s = model(s)\n",
    "            loss_behavior = b_loss(b_a_s, a)\n",
    "            loss_behavior.backward()\n",
    "            optimizer.step()\n",
    "            \n",
    "            running_loss += loss_behavior.item()\n",
    "            \n",
    "        epoch_loss.append(running_loss / gen_len )\n",
    "    return model, epoch_loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "780238ec-9e56-45df-a8e6-32c301e25b22",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "e4e4d3ae-35a2-480f-a201-836fe50f36c8",
   "metadata": {},
   "source": [
    "**optimal**\n",
    "* optimal alpha_i, alpha_d, alpha_rho, alpha_p: (0.5 , 0.1 , 0.05, 0.3), (0.1 , 0.1 , 0.01, 0.3)\n",
    "* worset alpha_i, alpha_d, alpha_rho, alpha_p: (1, 0.3, 0.1, 0.3), (0.1, 0.6, 0.05, 0.1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0842204d-4bf2-4855-a0f9-28532cfb8256",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Train Iterative"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "id": "459a0ca7-fc18-438a-9931-2eec3299f864",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def train_iterative(data, modelnames, target_policy, params):\n",
    "    #data=[s,a,r,s',terminal]\n",
    "    observed_s = data[0].detach().clone()\n",
    "    observed_next = data[3].detach().clone()\n",
    "    data = copy.deepcopy(data) \n",
    "    for i, model_name in enumerate(modelnames):\n",
    "        model_params = params[i]\n",
    "        if i==0:\n",
    "            if model_name==\"forward\":\n",
    "                forward_model, _ = train_forward(data, target_policy, model_params)\n",
    "                data = encode(data, forward_model, target_policy)\n",
    "            else:\n",
    "                \n",
    "                backward_model,_ = train_backward(data, target_policy, model_params)\n",
    "                data = encode(data, backward_model)\n",
    "            data.extend([observed_s, observed_next])\n",
    "        else:\n",
    "            if model_name==\"forward\":\n",
    "                \n",
    "                model, loss = train_forward(data, target_policy, model_params)\n",
    "                data = encode(data, model, target_policy)\n",
    "            else:\n",
    "                \n",
    "                model, loss = train_backward_his(data, target_policy, model_params)\n",
    "                data = encode(data, model)\n",
    "                \n",
    "    return model, loss, data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "py_PbegjrHL6",
   "metadata": {
    "id": "py_PbegjrHL6",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "# Policy Value Evaluation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "Yb9lzY63rLTa",
   "metadata": {
    "id": "Yb9lzY63rLTa",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### FQE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "id": "c1F0h2lTrqSB",
   "metadata": {
    "id": "c1F0h2lTrqSB",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class FQE_eval(torch.nn.Module):\n",
    "    def __init__(self, in_dim, action_size, n_layers=2, n_nodes=32, activation=nn.ReLU()):\n",
    "        super().__init__()\n",
    "        self.action_size = action_size\n",
    "\n",
    "        self.net = []\n",
    "        self.net.append(nn.Linear(in_dim, n_nodes))\n",
    "        self.net.append(activation)\n",
    "\n",
    "        for i in range(n_layers-1):\n",
    "            self.net.append(nn.Linear(n_nodes, n_nodes))\n",
    "            self.net.append(activation)\n",
    "\n",
    "        self.net.append(nn.Linear(n_nodes, action_size))\n",
    "        self.FQE_net = nn.Sequential(*self.net)\n",
    "\n",
    "        self.train()\n",
    "    def forward(self, x):\n",
    "        x = self.FQE_net(x)\n",
    "        return x\n",
    "    \n",
    "def train_FQE_step(model, optimizer, x, a, r, x_next, terminal, observed_s_next, target_policy, gamma=0.99):\n",
    "    optimizer.zero_grad()\n",
    "    model.train()\n",
    "    criterion_FQE = nn.MSELoss()\n",
    "\n",
    "    batch_size = x.shape[0]\n",
    "    order = torch.arange(batch_size)\n",
    "    pi_s_next = target_policy(observed_s_next)  #the policy is based on observed state space\n",
    "\n",
    "    outputs_FQE = model(x)\n",
    "    with torch.no_grad():\n",
    "        FQE_next = model(x_next)\n",
    "\n",
    "    FQE_targets = outputs_FQE.detach().clone()\n",
    "\n",
    "    FQE_targets[order, a] = r + gamma * FQE_next[order, pi_s_next] * (torch.ones(batch_size) - terminal)\n",
    "\n",
    "    loss_FQE = criterion_FQE(outputs_FQE, FQE_targets)\n",
    "\n",
    "    loss_FQE.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    return loss_FQE.item()\n",
    "\n",
    "def train_FQE(data, num_epochs, target_policy, n_layers=3, n_nodes=32, lr=0.001):  \n",
    "    #data = [x,a,r,x',terminal,s']\n",
    "    action_size =len(torch.unique(data[1]))\n",
    "    obs_size = data[0][0].shape[0]\n",
    "    model = FQE_eval(obs_size, action_size, n_layers, n_nodes).double()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    \n",
    "    terminal_index = torch.nonzero(data[4]).squeeze().long() #the next index of True terminal is the initial state of the next episode\n",
    "    terminal_index = terminal_index[:-1] #remove the last terminal state index\n",
    "    init_index = torch.cat([torch.tensor([0]), terminal_index+1]) #the first state is always initial\n",
    "    observed_init_index = torch.cat([torch.tensor([0]), terminal_index]) #use s_next to get initial observed states\n",
    "    initial_x = data[0][init_index]\n",
    "    observed_init = data[5][observed_init_index]\n",
    "    target_init = target_policy(observed_init) \n",
    "    num_episode = initial_x.shape[0]\n",
    "    \n",
    "    batch_size = max((data[1].shape[0])//20,10)\n",
    "    dataset = TensorDataset(*data)\n",
    "    batch_data = DataLoader(dataset, batch_size=batch_size)\n",
    "    \n",
    "    for epoch in tqdm(range(num_epochs)):\n",
    "        for x, a, r, x_next, terminal, observed_s_next in batch_data:\n",
    "            batch_loss = train_FQE_step(model, optimizer, x, a, r, x_next, terminal, observed_s_next, target_policy)\n",
    "            \n",
    "        model.eval()\n",
    "        with torch.no_grad():\n",
    "            preds = model(initial_x) #Q-value estimation is based on abstracted space\n",
    "        estimated_value = preds[np.arange(num_episode), target_init]\n",
    "        estimated_value = estimated_value.mean()\n",
    "    return estimated_value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9dd9e514-b597-41ec-b0d7-85d3c4724d5b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a611c022-55a8-44c3-b33a-b4428a0e0475",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "target_policy = target_lunar\n",
    "sample = data_format([item for cur_sar in sars_by_episode[:30] for item in cur_sar])\n",
    "observed_next = sample[3]\n",
    "fqe_data = [*sample, observed_next]\n",
    "fqe_data[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8279a0b7-fda7-460f-93a3-6b8be11c4ad9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "value_original = []\n",
    "for i in range(10):\n",
    "    fqe_value = train_FQE(fqe_data, 20, target_policy, 3, 64)\n",
    "    value_original.append(fqe_value)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad124ae2-b16e-40a9-b900-6e34833e1a24",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "e347c59c-8834-45dd-b914-3f3a71ae1add",
   "metadata": {},
   "source": [
    "**FQE results**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0e62bf2-e2e5-42f4-81d8-3c933d2b627c",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_sizes= [5,8,10,15,30]\n",
    "target_policy = angle_policy\n",
    "epsilons = [0.1, 0.3, 0.5, 0.7]\n",
    "for epsilon in epsilons:\n",
    "    with open(f\"/home/jupyter/{epsilon}_data.pickle\", 'rb') as f:\n",
    "        data = pickle.load(f)\n",
    "    total_bias = []\n",
    "    for size in tqdm(sample_sizes):\n",
    "        samples = data[size]\n",
    "        oracle = np.repeat(29.87,1)\n",
    "        biases = []\n",
    "        for j in range(30):\n",
    "            sample = samples[j]\n",
    "            sample = [i.to(device) for i in sample]\n",
    "            observed_next = sample[3]\n",
    "            fqe_data = [*sample, observed_next]\n",
    "            fqe_value = train_FQE(fqe_data, 20, target_policy, 6, 64)\n",
    "            bias = torch.tensor([fqe_value]) - oracle\n",
    "            biases.append(bias)\n",
    "        total_bias.append(biases)\n",
    "    with open(f\"/home/jupyter/{epsilon}_FQE_bias.pickle\", 'wb') as f:\n",
    "        pickle.dump(total_bias, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "AO3jrNJqrOjD",
   "metadata": {
    "id": "AO3jrNJqrOjD",
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Cartpole"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "78b5bce4-92c1-47b7-b9d2-9776bb953846",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### Experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "077d698d-db9f-45a5-ba42-f674d6c9bac9",
   "metadata": {},
   "source": [
    "**forward**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df1e2076-9252-48b1-93fc-446421e5dae3",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample = data_format([item for cur_sar in sars_by_episode[:30] for item in cur_sar])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "7d94fac9-de03-4bc0-b040-24010021c15e",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c97760498ed1467c9e89adc0727af9b6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "forward_params = {\"encoder_dim\":50,\n",
    "                 \"action_size\":4}\n",
    "target_policy= angle_policy\n",
    "forward_model, forward_loss = train_forward(sample, target_policy, forward_params)\n",
    "#df_ite = pd.DataFrame(forward_loss, columns=[['loss1', 'loss2', 'loss3', \"loss4\"]])\n",
    "#plot_helper(df_ite, \"forward_loss\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "a58f6834-b07a-453d-8455-2528346fb815",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "307f4aba78e74b33ab1595e162e7663e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "forward abstraction: tensor(34.2014, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "for_sample = encode(sample, forward_model, target_policy)\n",
    "observed_next = sample[3]\n",
    "fqe_data = [*for_sample, observed_next]\n",
    "fqe_value = train_FQE(fqe_data, 30, target_policy, 3, 64)\n",
    "print(\"forward abstraction:\", fqe_value)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c69ef6c5-0e11-4f62-b0d0-7ad5452682b4",
   "metadata": {},
   "source": [
    "**backward**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75735e59-c13b-4e1f-937e-170b68ce2ebe",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "backward_params = {\"encoder_dim\":2,\n",
    "                 \"action_size\":4}\n",
    "target_policy= target_lunar\n",
    "back_model, back_loss = train_backward(sample, target_policy, backward_params)\n",
    "df_ite = pd.DataFrame(back_loss, columns=[['loss1', 'loss2', 'loss3', \"loss4\"]])\n",
    "plot_helper(df_ite, \"back_loss\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e08da89-b424-401a-81a5-151a54701033",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "back_sample = encode(sample, back_model)\n",
    "observed_next = sample[3]\n",
    "fqe_data = [*back_sample, observed_next]\n",
    "for i in range(3):\n",
    "    fqe_value = train_FQE(fqe_data, 30, target_policy, 3, 64)\n",
    "    print(\"backward abstraction:\", fqe_value)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f6cdbdd4-7d03-4d0c-a126-84a193c8ee71",
   "metadata": {},
   "source": [
    "**iterative**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "80aaba59-3ab2-46a1-8122-b650b2b32d94",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample = data01[5][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "fz8UfyNgrR7C",
   "metadata": {
    "id": "fz8UfyNgrR7C",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "789d3430e70a4549a35ed20a39993e0c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b0a9f16a0e6d481b98bf2757b3667fef",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1ef6642a07fb45869cfd770ec3b1b3a3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "08313b755d984c72b8c2e84fbf05451e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "target_policy = angle_policy\n",
    "\n",
    "ite_params = [ {\"encoder_dim\":100, \"action_size\":2},\n",
    "               {\"encoder_dim\":50, \"action_size\":2},\n",
    "              {\"encoder_dim\":20, \"action_size\":2},\n",
    "               {\"encoder_dim\":4, \"action_size\":2} ]\n",
    "\n",
    "modelnames = [\"backward\", \"forward\",\"backward\", \"forward\"]\n",
    "iterative_model, iterative_loss, ite_data = train_iterative(sample, modelnames, target_policy, ite_params)\n",
    "df_ite = pd.DataFrame(iterative_loss, columns=[['loss1', 'loss2', 'loss3', \"loss4\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "5cf3ae07-e469-4741-a30e-a10d973001ba",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5d3b403934b1435aa2bc5635620e71e8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iterative abstraction: tensor(30.8186, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "fqe_data = [*ite_data[:5], ite_data[6]]\n",
    "fqe_value = train_FQE(fqe_data, 20, target_policy)\n",
    "print(\"iterative abstraction:\", fqe_value)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "2eafc17d-b1fb-42e2-96b9-00393cafc04f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[tensor([  7.5735,  -4.6205,   0.9376, -20.8441], dtype=torch.float64),\n",
       " tensor([  1.3222, -10.7175,  -9.4268, -22.3561], dtype=torch.float64),\n",
       " tensor([ -0.4557, -17.4751,  -7.4317, -25.9426], dtype=torch.float64),\n",
       " tensor([ -1.6783, -10.4396,   0.3252, -26.2515], dtype=torch.float64),\n",
       " tensor([  2.1572, -12.8926,   1.2913, -25.0317], dtype=torch.float64),\n",
       " tensor([ -0.4857, -11.1069,  -6.6110, -24.0912], dtype=torch.float64),\n",
       " tensor([ -3.3395, -20.5988,  -3.5974, -26.0309], dtype=torch.float64),\n",
       " tensor([ -2.5058, -16.7634,  -5.1463, -25.7939], dtype=torch.float64),\n",
       " tensor([ -0.0325,  -7.3735,   1.2537, -25.3858], dtype=torch.float64),\n",
       " tensor([ -3.0525, -16.3138,  -6.2945, -26.5105], dtype=torch.float64),\n",
       " tensor([  5.6056, -16.5317,   4.6369, -25.0822], dtype=torch.float64),\n",
       " tensor([  1.3595, -13.2269,  -4.2513, -26.0748], dtype=torch.float64),\n",
       " tensor([  4.7477, -10.9545,   1.3571, -26.4763], dtype=torch.float64),\n",
       " tensor([  0.5140, -10.2203,  -4.9394, -25.1164], dtype=torch.float64),\n",
       " tensor([  0.2797, -12.4253,   0.0528, -25.2629], dtype=torch.float64),\n",
       " tensor([ -0.8077,  -8.7414,   2.7147, -25.8132], dtype=torch.float64),\n",
       " tensor([  7.3905, -16.4806,   2.2887, -24.2027], dtype=torch.float64),\n",
       " tensor([-7.4553e-04, -8.8911e+00, -2.4662e+00, -2.4109e+01],\n",
       "        dtype=torch.float64),\n",
       " tensor([  1.7878, -15.8472,  -4.2968, -23.3428], dtype=torch.float64),\n",
       " tensor([  4.8541,  -7.2072,   4.1510, -24.1234], dtype=torch.float64),\n",
       " tensor([  1.5180, -16.5621,   3.3661, -25.7149], dtype=torch.float64),\n",
       " tensor([ -3.6634, -20.3204,  -5.1335, -26.0246], dtype=torch.float64),\n",
       " tensor([  4.5400, -13.7499,  -1.6355, -24.6772], dtype=torch.float64),\n",
       " tensor([ -1.1703,  -8.1326,  -2.1373, -25.6766], dtype=torch.float64),\n",
       " tensor([ -1.2289, -13.8537,  -6.2349, -27.2116], dtype=torch.float64),\n",
       " tensor([  1.7216, -10.7195,   1.7829, -24.3441], dtype=torch.float64),\n",
       " tensor([  2.9682, -10.8847,   0.1343, -25.8930], dtype=torch.float64),\n",
       " tensor([  1.2749, -11.6310,   2.8914, -25.5465], dtype=torch.float64),\n",
       " tensor([  0.5761, -12.7751,  -1.4184, -25.2418], dtype=torch.float64),\n",
       " tensor([ -1.8559,  -8.6758,  -5.9570, -26.1926], dtype=torch.float64)]"
      ]
     },
     "execution_count": 230,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_bias[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0bc4153e-3bbb-405a-b5ff-aff693cf046e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "366ec05b-2399-44d7-856b-1d88f82d50df",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "aa3fe270db5242c3a8cc461dfad698d8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/4 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b5de449a5550437eab93d60bf26bb79e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3dbf9ea201ab49dd86b88c0d088a99d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "858893a698724fe8991f8df8205857da",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d0ad6502613944b496763f5ab268a7d7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "076517c23a9f4afdbe84f0c0cc89d6b3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cb3d2f26e52b422ba37eb0abc276e2aa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5ac14664fb0146b39c8173e729486fc4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6ffb54e38d144345adeacee84ebb2744",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f209573ed98842c99553337f0a5ac4ad",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d4c70f203111475b8381e2d8adb5ddd3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d5957e60dd1e4786a4b7cddcd0999c8b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "150b955d2ac6485b94766741f3af44e4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d0363e75ff594bc89270b1d9251f165e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7d0687e094f2477eb23ac19eadb466b3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "caf39df221b74fb8a115dfc6ef8d76cb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3502c8e4da2c4577915021752eab3b81",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b04829aa211449fdabad7e0a2a420834",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f45c383707f14d5ca02ea0d63c5d939a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "97aeed19b02a41cf845c4701b46e43c7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cf01660d70c24377b4e8db0a483866d8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ce2222a030e14956ab1a1ef9deec8e7e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "65ff04cc343d429ba2c5a5a4475415ff",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4bec22fdbefa4c25bbffd1d541960843",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3a5c63ccf9a946fcb9778eede298bf30",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "238452d75a58438ab2ebd453b8c1e889",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c5f80c2c2a064504ac131a8d60d9c35a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0486c293650d444688734ecd1011c724",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fb1a1f0a45f242349edbf0baf4bc4739",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e11cf165428243f1898339a177a73dc1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "85a6f294ef2440feb63d4514cb5fab95",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "87caa4bacf444434845284c9942fe432",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7b04f65901f4218920a582bf145ea59",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "77ea760d78194be1914225aec5641729",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0d758473d50845cb92f91826c05325f2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a44aa1188655436ca388394148b2093d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "31eeee8ed007408aa610f98cd495b4b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ad9ee97457f14affa361fcde4d46b2ab",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ed16a68b086c46a6bc2868121793f2c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7eaf0281d2f8460e9a8b0d81adfb87de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d7f0dc9b25c64f458ab750c175c6cd1d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "72aace3eb9694eeaaab0afd653e08619",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d2d4375170d343b6937a866e92a2b993",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "79933b10870e4fe0a9de26e8fb59ecdd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "aabf4c1d747248bba341ae3c92ccda71",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b8974e76651845fe911d91e73639d832",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ee27d48ecc7748e9acec58b8cb6aedda",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d23b8d2d088a4d09a4d6f8f2610e375b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sample_sizes= [10,20,35,60]\n",
    "target_policy = angle_policy\n",
    "forward_params = {\"encoder_dim\":10,\n",
    "                 \"action_size\":4, \"lr\":0.0005}\n",
    "\n",
    "backward_params = {\"encoder_dim\":10,\n",
    "                 \"action_size\":4, \"lr\":0.0005}\n",
    "\n",
    "ite_params = [ {\"encoder_dim\":100, \"action_size\":4},\n",
    "               {\"encoder_dim\":50, \"action_size\":4},\n",
    "                {\"encoder_dim\":20, \"action_size\":4},\n",
    "               {\"encoder_dim\":6, \"action_size\":4, \"lr\":0.0005}]\n",
    "modelnames = [\"backward\",\"forward\",\"backward\",\"forward\"]\n",
    "\n",
    "data_dic = {}\n",
    "total_bias = []\n",
    "for size in tqdm(sample_sizes):\n",
    "    oracle = torch.tensor(29.87).repeat(4)\n",
    "    biases = []\n",
    "    data_list = []\n",
    "    for j in range(30):\n",
    "        random_episodes = random.sample(sars_by_episode, size)\n",
    "        sample = [item for cur_sar in random_episodes for item in cur_sar]\n",
    "        sample=data_format(sample)\n",
    "        data_list.append(sample)\n",
    "        observed_next = sample[3]\n",
    "        \n",
    "        observed_sample = [*sample, observed_next]\n",
    "        observed_value = train_FQE(observed_sample, 20, target_policy)\n",
    "        \n",
    "        forward_model, forward_loss = train_forward(sample, target_policy, forward_params)\n",
    "        back_model, back_loss = train_backward(sample, target_policy, backward_params)\n",
    "        for_model_sample = [*encode(sample, forward_model, target_policy), observed_next]\n",
    "        back_model_sample = [*encode(sample, back_model), observed_next]\n",
    "        for_value = train_FQE(for_model_sample, 20, target_policy)\n",
    "        back_value = train_FQE(back_model_sample, 20, target_policy)\n",
    "        \n",
    "        ite_model, ite_loss, ite_data = train_iterative(sample, modelnames, target_policy, ite_params)\n",
    "        fqe_data = [*ite_data[:5], ite_data[6]]\n",
    "        ite_value = train_FQE(fqe_data, 20, target_policy)\n",
    "        \n",
    "        bias = torch.tensor([for_value, back_value, ite_value, observed_value]) - oracle\n",
    "        biases.append(bias)\n",
    "    total_bias.append(biases)\n",
    "    data_dic[sum(size)] = data_list\n",
    "with open(\"c_0.1_bias.pickle\", 'wb') as f:\n",
    "    pickle.dump(total_bias, f)\n",
    "    \n",
    "with open(\"c_0.1_data.pickle\", 'wb') as f:\n",
    "    pickle.dump(data_dic, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ff1fdb8c-099a-4cc5-898c-bad49b86e0f0",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.1$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "id": "f4352728-ec97-4e37-844e-2a2333977ec4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"/home/jupyter/results/0.1_bias.pickle\", 'rb') as f:\n",
    "    results01=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.1_FQE_bias.pickle\", 'rb') as f:\n",
    "    results01_FQE=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.1_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results01_markov=pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "id": "038b96ce-85ef-41f3-a03d-ba0a45590611",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error1 = []\n",
    "for i in range(5):\n",
    "    samples_01 = torch.stack(results01[i])[:,:3]\n",
    "    samples_fqe = torch.stack(results01_FQE[i])\n",
    "    samples_markov = torch.stack(results01_markov[i])\n",
    "    all_error1.append( torch.cat([samples_01, samples_markov, samples_fqe], axis=1) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "id": "46a68d23-25ee-4280-93b4-571b053428f8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample_sizes=[5,8,10,15,30]\n",
    "biases = []\n",
    "mses = []\n",
    "for i in [0,1,3,4]:\n",
    "    sample_bias = all_error1[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse1 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"two-step\", \"MSA\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias1 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "99f7774f-c0a0-466b-ad49-cd6dba37304f",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "plot_helper(np.log(df_mse1), \"\\u03B5=0.1\", log_samples_sizes, xlabel=\"log(Sample size)\", ylabel=\"log(MSE)\")\n",
    "plot_helper(df_bias1, \"\\u03B5=0.1\", log_samples_sizes, xlabel=\"log(Sample size)\", ylabel=\"Bias\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "90ba6851-6fb5-42fe-bab5-f03e40071844",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.3$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 316,
   "id": "047fa56f-2f4b-4187-be7a-b5233d88e2b5",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"/home/jupyter/results/0.3_bias.pickle\", 'rb') as f:\n",
    "    results03=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.3_FQE_bias.pickle\", 'rb') as f:\n",
    "    results03_FQE=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.3_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results03_markov=pickle.load(f)\n",
    "for i in range(5):\n",
    "    results03[i] = torch.tensor(results03[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "497f6723-af72-4fe9-bafd-cd8dd628fac2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error3 = []\n",
    "for i in range(5):\n",
    "    if isinstance(results03[i], list):\n",
    "        samples_03 = torch.stack(results03[i])[:,:3]\n",
    "    else:\n",
    "        samples_03 = results03[i][:,:3]\n",
    "    samples_fqe = torch.stack(results03_FQE[i])\n",
    "    samples_markov = torch.stack(results03_markov[i])\n",
    "    all_error3.append( torch.cat([samples_03, samples_markov, samples_fqe], axis=1) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "074911d9-4070-455a-8b78-aebbdd3b291f",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample_sizes=[5,8,15,30]\n",
    "biases = []\n",
    "mses = []\n",
    "for i in [0,1,3,4]:\n",
    "    sample_bias = all_error3[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse3 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias3 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a28f2c0-a4ff-4567-b438-605b05797216",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23d2c688-1f94-407f-8e33-c6282fac06d5",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "plot_helper(np.log(df_mse3), \"\\u03B5=0.3\", sample_sizes, xlabel=\"Sample size\", ylabel=\"log(MSE)\")\n",
    "plot_helper(df_bias3, \"\\u03B5=0.3\", sample_sizes, xlabel=\"Sample size\", ylabel=\"Bias\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "65d105bc-ae63-45df-aeff-2b16ef4a8afd",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.5$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 315,
   "id": "3f23268d-c9f2-49ff-af9c-44ca88a04fd9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"/home/jupyter/results/0.5_bias.pickle\", 'rb') as f:\n",
    "    results05=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.5_FQE_bias.pickle\", 'rb') as f:\n",
    "    results05_FQE=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.5_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results05_markov=pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "adad1340-d006-4f58-9626-3739848055fa",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error5 = []\n",
    "for i in range(5):\n",
    "    if isinstance(results05[i], list):\n",
    "        samples_05 = torch.stack(results05[i])[:,:3]\n",
    "    else:\n",
    "        samples_05 = results05[i][:,:3]\n",
    "    samples_fqe = torch.stack(results05_FQE[i])\n",
    "    samples_markov = torch.stack(results05_markov[i])\n",
    "    all_error5.append( torch.cat([samples_05, samples_markov, samples_fqe], axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "9cc6afff-8e20-4278-bc86-d46b6848bdbf",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample_sizes=[5,8,15,30]\n",
    "biases = []\n",
    "mses = []\n",
    "for i in [0,1,3,4]:\n",
    "    sample_bias = all_error5[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse5 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias5 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "83193461-d6a1-4c2d-a9b9-def97c786427",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "plot_helper(np.log(df_mse5), \"\\u03B5=0.5\", sample_sizes, xlabel=\"Sample size\", ylabel=\"log(MSE)\")\n",
    "plot_helper(df_bias5, \"\\u03B5=0.5\", sample_sizes, xlabel=\"Sample size\", ylabel=\"Bias\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f80f744d-a82e-4e03-b71f-d3fbc9e85a18",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.7$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "73227d82-f469-4e47-a44a-a36997d3b2a8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"/home/jupyter/results/0.7_bias.pickle\", 'rb') as f:\n",
    "    results07=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.7_FQE_bias.pickle\", 'rb') as f:\n",
    "    results07_FQE=pickle.load(f)\n",
    "with open(\"/home/jupyter/results/0.7_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results07_markov=pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "6835efbf-515f-4cdd-9fcc-c85fffdf561d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error7 = []\n",
    "for i in range(5):\n",
    "    samples_07 = torch.stack(results07[i])[:,:3]\n",
    "    samples_fqe = torch.stack(results07_FQE[i])\n",
    "    samples_markov = torch.stack(results07_markov[i])\n",
    "    all_error7.append( torch.cat([samples_07, samples_markov, samples_fqe], axis=1) )\n",
    "\n",
    "biases = []\n",
    "mses = []\n",
    "for i in [0,1,3,4]:\n",
    "    sample_bias = all_error7[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse7 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias7 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"two-step\", \"markov\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d0fe741-32a5-49c9-9adc-fef092bac330",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "plot_helper(np.log(df_mse7), \"\\u03B5=0.7\", sample_sizes, xlabel=\"Sample size\", ylabel=\"log(MSE)\")\n",
    "plot_helper(df_bias7, \"\\u03B5=0.7\", sample_sizes, xlabel=\"Sample size\", ylabel=\"Bias\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "1003d98a-d664-4716-8b5f-d1e2908c18b7",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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4fpZV0OfS6VcmhCNxRQIIXFQeBgclbD8WfhlvsoO6DG2ufdOiFartqyAxswGiIqKIiYmhn/84x8kJiaSkZHB/fff717fvXt3kpOTefTRR3nqqafYs2cPL774os9rdO7cmZKSEhYvXszAgQMJDg6mR48eXHHFFUybNo23336bsLAw7r//fjp27FijLI+36dOn884773Dddddx7733Eh0dzb59+5g3bx7vvvtunRrujhkzhtGjRzN58mReeuklunfvzq5du9A0jYkTJ/J///d/DBs2jCeeeIIpU6awevVqXn/9dd544w0AevXqxcSJE/nDH/7Am2++iclk4q677vLJNBg7diznnnsuV155Jc899xw9e/YkMzOTb775hquuuoqhQ4fW91dRJxIIqIP6lLBobpqmERoVQGhUAJ0HeGazVJTYqhoSF3M8QzUmLsgpc/fTAnVTLC+zlLzMUnavyXIvj4gL8jQlrgoSBIXVPlvWaDLQsWcUlkCjz4FHM+lEAWWFVnS7p7SHaqAa2SgHpLZKsi7qx25zVN3At7tv5Pt8LbVTWW6rsb6izI698lQBwIvVl63e5Wg0dDugqX9gIy7ppHoDVBRCQFhjvMVWp74BVn8N2KufyGgGjbDoQMKiA0nuG+3zfFulg4LsMvKzSz2BguwyCrLKavRfAagstZO1v5Cs/YU+yw0GjfCqLALVj0B9jUoIITDUXON1GoL8exeNLqYbXPIipD0IG95TzYVLc9W6QyvViOmuAgIDfwvmxk+VFaKxyDG1nYvtAWn3qZG9QwUEtn8JeVW1eHWHp6H613+FbhdCv8nQaxIEhp/8tYVoz/xd4xgCPeuc5prbT18Ly5+D1a+D0w75B+DTySozZ+KzEJ7U+PstRBvkLyugsbIBAAwGA/PmzePPf/4z/fr1o1evXrz66qukpaUBqgTPv/71L+68804GDBjAsGHDePLJJ32a/Y4cOZI77riDKVOmcOLECR555BEeffRRPvjgA/7yl79w6aWXYrVaGT16NAsXLqxR1sdbUlISK1eu5L777mP8+PFUVlaSmprKxIkTMdRjYtMXX3zB3XffzXXXXUdpaSndu3fn2WefBdRs/s8++4xZs2bxxBNPkJiYyOOPP87UqVPdz//ggw+47bbbGDNmDB06dODJJ590NxcGdf924cKF/O1vf+Pmm28mNzeXhIQERo8e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1iwsX74cw4cPR21tLd599108/PDDuPbaa/PdtILW1taWMrrk4MGD2LNnDzweDzweD5YtW4a5c+eisrIS9fX1uOOOOzBmzBhcdtlleWx18VmyZAlmzpyJ4cOHo7W1FevWrcO2bdvw4osvoqysDAsXLsTPfvYzeDwelJaW4tZbb0VdXR3OO++8fDe94DBTE5ir2mOm6gMzNXeYqQnMVO0xU/WBmZpbzFUFMzU7mKv6wFyloiAoK+bNmyeqqqqExWIRQ4YMEfPmzRP79+/Pd7NyrqWlRdx2221i+PDhwmaziVGjRolf/vKXIhgM5rtpBe3ll18WANK+rrnmGuHz+cSll14qKioqhNlsFiNGjBDXX3+9OHbsWL6bXXSuvfZaMWLECGGxWERFRYWYPn262LJli7re7/eLm266SZSXl4uSkhIxZ84c0djYmMcWFy5magJzVXvMVH1gpuYOMzWBmao9Zqo+MFNzi7mqYKZmB3NVH5irVAwkIYTIbdcDERERERERERERERHlCu8RQERERERERERERERUxNgRQERERERERERERERUxNgRQERERERERERERERUxNgRQERERERERERERERUxNgRQERERERERERERERUxNgRQERERERERERERERUxNgRQERERERERERERERUxNgRQERERERERERERERUxNgRQP2Wz+fD3LlzUVpaCkmS0NzcnPX3vPfee3HWWWdl/X1666KLLsKiRYvy3QwiKkDM1HTMVCLqC+ZqOuYqEfUWMzUdM5Wo/2FHAOXMggULIEkSHnzwwZTlzz33HCRJynl71q5di+3bt+P1119HY2MjysrK0rbR+g/34sWLsXXrVs32p3X7Nm7ciPvvv1+z/RFR9jBTmalEpC3mKnOViLTDTGWmEpH+sCOAcspms2HlypVoamrKd1NQX1+PCRMm4Gtf+xoqKyv7dDISDoe7tZ3T6cSAAQN6/T7ZEgqFAAAejwculyvPrSGi7mKmMlOJSFvMVeYqEWmHmcpMJSJ9YUcA5dTFF1+MyspKrFixotPtNmzYgNraWlitVowcORKrVq3q8Xt1to+LLroIq1atwquvvgpJknDRRRelvX7NmjVYtmwZ3nvvPUiSBEmSsGbNGgCAJEl4/PHHccUVV8DhcGD58uWIRCJYuHAhampqYLfbMW7cODzyyCMp+8zUg//EE09gwoQJ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",
      "text/plain": [
       "<Figure size 1400x600 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(2, 4, figsize=(14, 6), sharex=True)\n",
    "seaborn_plot(df_mse1, axes[0,0], \"\\u03B5=0.1\", ylabel=True)\n",
    "seaborn_plot(df_bias1, axes[1,0],\"\\u03B5=0.1\", False, ylabel=True)\n",
    "\n",
    "seaborn_plot(df_mse3, axes[0,1], \"\\u03B5=0.3\")\n",
    "seaborn_plot(df_bias3, axes[1,1],  \"\\u03B5=0.3\",False)\n",
    "\n",
    "seaborn_plot(df_mse5, axes[0,2], \"\\u03B5=0.5\")\n",
    "seaborn_plot(df_bias5, axes[1,2],  \"\\u03B5=0.5\",False)\n",
    "\n",
    "seaborn_plot(df_mse7, axes[0,3], \"\\u03B5=0.7\")\n",
    "seaborn_plot(df_bias7, axes[1,3], \"\\u03B5=0.7\",False)\n",
    "handles, labels = axes[0,0].get_legend_handles_labels()\n",
    "fig.legend(handles, labels, loc='upper right', bbox_to_anchor=(1.1, 0.95))\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b9557ced-94b9-448c-baf7-f714067b1845",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "### Lunar Lander"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ceb0bfb-76fc-4a05-b378-6f508fabaa54",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "f3e072f6-c447-43fc-9bd7-49b38a5e31f1",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "long_episodes = [sar for sar in sars_by_episode if len(sar)>=1000]\n",
    "short_episodes = [sar for sar in sars_by_episode if 100<len(sar)<1000]\n",
    "random_episodes = random.sample(long_episodes, 24)\n",
    "random_episodes.extend(random.sample(short_episodes, 16))\n",
    "sample = [item for cur_sar in random_episodes for item in cur_sar]\n",
    "sample = data_format(sample)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "3e0dc10d-882b-4549-94f2-423271fabbd2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "random_episodes = random.sample(long_episodes, 8)\n",
    "random_episodes.extend(random.sample(short_episodes, 2))\n",
    "sample = [item for cur_sar in random_episodes for item in cur_sar]\n",
    "sample = data_format(sample)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0986fdb4-8910-45d9-b91e-d3569c83c560",
   "metadata": {},
   "source": [
    "**forward**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "c7374f43-3b5b-4885-a841-64aad5b2dbba",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7450028a7f34f4a91fe0a0fa76509d3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "783e461bcab540b8a97c46299b224631",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "forward abstraction: tensor(47.5792, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "forward_params = {\"encoder_dim\":100,\n",
    "                 \"action_size\":4}\n",
    "target_policy= target_lunar\n",
    "forward_model, forward_loss = train_forward(sample, target_policy, forward_params)\n",
    "df_for = pd.DataFrame(forward_loss, columns=[['loss1', 'loss2', 'loss3', \"loss4\"]])\n",
    "\n",
    "for_sample = encode(sample, forward_model, target_policy)\n",
    "observed_next = sample[3]\n",
    "fqe_data = [*for_sample, observed_next]\n",
    "fqe_value = train_FQE(fqe_data, 20, target_policy)\n",
    "print(\"forward abstraction:\", fqe_value)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "938bfd35-d9a1-42f6-9698-5b2aadc63a8b",
   "metadata": {},
   "source": [
    "**Backward**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "fa011d87-3e6d-46c7-abc1-1826a2489ce8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae34af32a58e47bea69106924a102a5c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "13372d2515a64e0095d172bcdaa5142d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "backward abstraction: tensor(64.8255, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "backward_params = {\"encoder_dim\":100,\n",
    "                 \"action_size\":4}\n",
    "target_policy= target_lunar\n",
    "back_model, back_loss = train_backward(sample, target_policy, backward_params)\n",
    "df_back = pd.DataFrame(back_loss, columns=[['loss1', 'loss2', 'loss3', \"loss4\"]])\n",
    "\n",
    "back_sample = encode(sample, back_model)\n",
    "observed_next = sample[3]\n",
    "fqe_data = [*back_sample, observed_next]\n",
    "\n",
    "fqe_value = train_FQE(fqe_data, 20, target_policy)\n",
    "print(\"backward abstraction:\", fqe_value)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "64b9d38a-5dfb-4507-9131-263693d17000",
   "metadata": {},
   "source": [
    "**Iterative**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "8d410f6e-f3fb-4fef-a3ea-2cf025f86a84",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "610ba28ce2334b7d9cf598520be43f18",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8f762692b78a4610a3eac135a8ab18ed",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9cdbd7a9c7f04bddac2b3f8e299ffb5e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a4f035f1b5424746b4f7adfcadb2c178",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cdb59172e291464db28fdb794089c0a2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iterative abstraction: tensor(18.2870, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "target_policy = target_lunar\n",
    "\n",
    "ite_params = [ {\"encoder_dim\":100, \"action_size\":4},\n",
    "               {\"encoder_dim\":50, \"action_size\":4},\n",
    "                {\"encoder_dim\":30, \"action_size\":4},\n",
    "               {\"encoder_dim\":10, \"action_size\":4}]\n",
    "\n",
    "modelnames = [\"forward\", \"backward\",\"forward\", \"backward\"]\n",
    "#modelnames = [\"backward\",\"forward\",\"backward\",\"forward\"]\n",
    "\n",
    "iterative_model, iterative_loss, ite_data = train_iterative(sample, modelnames, target_policy, ite_params)\n",
    "#df_ite = pd.DataFrame(iterative_loss, columns=[['reward', 'trans', 'fqe', \"penalty\"]])\n",
    "fqe_data = [*ite_data[:5], ite_data[6]]\n",
    "fqe_value = train_FQE(fqe_data, 20, target_policy)\n",
    "print(\"iterative abstraction:\", fqe_value)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "d415c55c-cbd6-4f81-ab79-128b77fd07a8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"lunar_0.1_bias_10_60.pickle\", 'rb') as f:\n",
    "    total_bias1 = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6d60cd65-7a9d-4226-8cbb-05159182d1ff",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d3cc8e4-5305-466d-be1c-7b2ea69f203b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b9f5346a69174a96ad585a6cc75967af",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/4 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d9dd73f526a04d38bd91cf580cd2590a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f5942329bd6492b928654f4b2fbd785",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3d30fa937b8641deab19778e0abe65a3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "afd2fc0700674bd981b6acc2cb858237",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "83c96150134c4761b02ab7e5f30cfb10",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4a7dce9e5dcc48ec9f8f68457a1fc677",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "12d3d4ca8ec54ba99d90fca93346a374",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ebf74c4ed22b43008952d4168d796bf6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "81db9129d32744d28d934c2e9f16f8ee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cef8191a46834811830e728fc8a7473d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7e20a9031e1b4176a4760c755415b7bc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "80c546a494ff437eb0c07dd2e28d2574",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9592277702514380bf7d3562ee95b1d9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "42a6618a6ce6444687901ec99d77c54d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5fbe1b8e10e64063939dda736f560282",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "21e3aa4282d349f0be4753a3b40aa8e3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6e178671bcde4f2099ab27eedeb87769",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "315f1653e78b474288e81fddef494b18",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/30 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sample_sizes= [(7,3),(14,6),(25,10),(45,15)]\n",
    "long_episodes = [sar for sar in sars_by_episode if len(sar)>=1000]\n",
    "short_episodes = [sar for sar in sars_by_episode if 300<len(sar)<1000]\n",
    "target_policy = target_lunar\n",
    "forward_params = {\"encoder_dim\":10,\n",
    "                 \"action_size\":4, \"lr\":0.0005}\n",
    "\n",
    "backward_params = {\"encoder_dim\":10,\n",
    "                 \"action_size\":4, \"lr\":0.0005}\n",
    "\n",
    "ite_params = [ {\"encoder_dim\":100, \"action_size\":4},\n",
    "               {\"encoder_dim\":50, \"action_size\":4},\n",
    "                {\"encoder_dim\":20, \"action_size\":4},\n",
    "               {\"encoder_dim\":6, \"action_size\":4,\"lr\":0.0003}]\n",
    "\n",
    "#modelnames = [\"forward\", \"backward\",\"forward\", \"backward\"]\n",
    "modelnames = [\"backward\",\"forward\",\"backward\",\"forward\"]\n",
    "\n",
    "data_dic = {}\n",
    "total_bias = []\n",
    "for size in tqdm(sample_sizes):\n",
    "    oracle = torch.tensor(61.70).repeat(4)\n",
    "    biases = []\n",
    "    data_list = []\n",
    "    for j in range(20):\n",
    "        random_episodes = random.sample(long_episodes, size[0])\n",
    "        random_episodes.extend(random.sample(short_episodes, size[1]))\n",
    "        sample = [item for cur_sar in random_episodes for item in cur_sar]\n",
    "        sample=data_format(sample)\n",
    "        data_list.append(sample)\n",
    "        observed_next = sample[3]\n",
    "        \n",
    "        observed_sample = [*sample, observed_next]\n",
    "        observed_value = train_FQE(observed_sample, 20, target_policy)\n",
    "        \n",
    "        forward_model, forward_loss = train_forward(sample, target_policy, forward_params)\n",
    "        back_model, back_loss = train_backward(sample, target_policy, backward_params)\n",
    "        for_model_sample = [*encode(sample, forward_model, target_policy), observed_next]\n",
    "        back_model_sample = [*encode(sample, back_model), observed_next]\n",
    "        for_value = train_FQE(for_model_sample, 20, target_policy)\n",
    "        back_value = train_FQE(back_model_sample, 20, target_policy)\n",
    "        \n",
    "        ite_model, ite_loss, ite_data = train_iterative(sample, modelnames, target_policy, ite_params)\n",
    "        fqe_data = [*ite_data[:5], ite_data[6]]\n",
    "        ite_value = train_FQE(fqe_data, 20, target_policy)\n",
    "        \n",
    "        bias = torch.tensor([for_value, back_value, ite_value, observed_value]) - oracle\n",
    "        biases.append(bias)\n",
    "    total_bias.append(biases)\n",
    "    data_dic[sum(size)] = data_list\n",
    "with open(\"lunar_0.1_bias_bfbfnew.pickle\", 'wb') as f:\n",
    "    pickle.dump(total_bias, f)\n",
    "    \n",
    "with open(\"lunar_0.1_data_bfbfnew.pickle\", 'wb') as f:\n",
    "    pickle.dump(data_dic, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "477a68f5-e1ba-4e24-93f7-fbf9d7fcff35",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.1$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "422e1dd9-9d4e-4c7f-9ab3-d4b86d3675c2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"lunar_0.1_bias.pickle\", 'rb') as f:\n",
    "    results01=pickle.load(f)\n",
    "with open(\"lunar0.1_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results01_markov=pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a1237ed-916c-4c00-b0a6-4f73ae188ab5",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "b1443b46-f03c-4f1a-9426-3d07e7d92101",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error1 = []\n",
    "for i in range(4):\n",
    "    samples_01 = torch.stack(results01[i])[:,:3]\n",
    "    samples_fqe = torch.stack(results01[i])[:,3].view(-1,1)\n",
    "    samples_markov = torch.stack(results01_markov[i])\n",
    "    all_error1.append( torch.cat([samples_01, samples_markov, samples_fqe], axis=1) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1f538c0e-620c-46a8-b5b7-74dd1fe882cf",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "9a9bdb70-f3e8-4587-b32c-30560e912185",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample_sizes=[10,20,35,60]\n",
    "biases = []\n",
    "mses = []\n",
    "for i in range(4):\n",
    "    sample_bias = all_error1[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse1 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias1 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef3690b6-0b5b-4441-a095-c737b0765513",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "8982bb93-5dea-4dcd-b7d0-8acbd3b602c9",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.3$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "f83b2700-79e4-40d7-a6a0-8782979fc7cd",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"lunar_0.3_bias.pickle\", 'rb') as f:\n",
    "    results03=pickle.load(f)\n",
    "with open(\"lunar0.3_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results03_markov=pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7732f44-bb6c-49ec-b7b9-70e81fde65d7",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "d5836ba5-6f16-4555-a0c8-e8a76a8a9943",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error3 = []\n",
    "for i in range(4):\n",
    "    samples_03 = torch.stack(results03[i])[:,:3]\n",
    "    samples_fqe = torch.stack(results03[i])[:,3].view(-1,1)\n",
    "    samples_markov = torch.stack(results03_markov[i])\n",
    "    all_error3.append( torch.cat([samples_03, samples_markov, samples_fqe], axis=1) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "f90d12ac-cc2b-4bc5-8103-4682120357a4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample_sizes=[10,20,35,60]\n",
    "biases = []\n",
    "mses = []\n",
    "for i in range(4):\n",
    "    sample_bias = all_error3[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse3 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias3 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "69675acb-2341-44d3-a4dd-ae67cb12d583",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af544d3b-b3b3-4456-aae5-772a3bdd37fd",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "3dcb0a36-d6d6-4283-be02-83ea58fee717",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "#### $\\epsilon=0.5$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "6fff76f4-1061-4a79-9b50-b546311282c6",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "with open(\"lunar_0.5_bias.pickle\", 'rb') as f:\n",
    "    results05=pickle.load(f)\n",
    "with open(\"lunar0.5_markov_auto_bias.pickle\", 'rb') as f:\n",
    "    results05_markov=pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "id": "d53a8f63-52e3-4ac7-bb8f-bc0fbb09cab6",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_error5 = []\n",
    "for i in range(4):\n",
    "    samples_05 = torch.stack(results05[i])[:,:3]\n",
    "    samples_fqe = torch.stack(results05[i])[:,3].view(-1,1)\n",
    "    samples_markov = torch.stack(results05_markov[i])\n",
    "    all_error5.append( torch.cat([samples_05, samples_markov, samples_fqe], axis=1) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 187,
   "id": "fdf4b300-c1bc-4329-8330-2c557b988502",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sample_sizes=[10,20,35,60]\n",
    "biases = []\n",
    "mses = []\n",
    "for i in range(4):\n",
    "    sample_bias = all_error5[i].numpy()\n",
    "    bias = np.mean(sample_bias, axis=0)\n",
    "    mse = np.mean(np.array(sample_bias)**2, axis=0)\n",
    "    biases.append(bias)\n",
    "    mses.append(mse)\n",
    "df_mse5 = pd.DataFrame(np.stack(mses), columns=[[\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]])\n",
    "df_bias5 = pd.DataFrame(np.stack(biases), columns=[[\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "id": "02ba047f-4e34-4a4b-9d1b-21c06187ac25",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from scipy.stats import t\n",
    "names = [\"forward\", \"backward\", \"DSA\", \"MSA\", \"auto-encoder\", \"FQE\"]\n",
    "def errorplot(all_error, ax, title, xticks, mse=True, ylabel=False):\n",
    "    x_pos = np.arange(len(xticks))\n",
    "    for i in range(6):\n",
    "        data = torch.stack(all_error)[torch.tensor([0,1,2,3]),:,i].numpy()\n",
    "        mses = np.mean(data**2, axis=1)\n",
    "        biases = np.mean(data, axis=1)\n",
    "        n = data.shape[1]\n",
    "        stds = np.std(data, axis=1) / np.sqrt(n)\n",
    "        confidence_interval = stds * t.ppf(0.975, df=n-1) \n",
    "        markers = ['o', 's', 'D', '^', 'v', 'X']\n",
    "        colors = ['#1f77b4', '#ff7f0e', '#2ca02c', '#d62728', '#9467bd', '#8c564b']\n",
    "        if mse:\n",
    "            ax.errorbar(x_pos, mses, yerr=confidence_interval, fmt=markers[i], capsize=8, label=names[i], color=colors[i])\n",
    "            ax.plot(x_pos, mses, \"-\", color=colors[i])\n",
    "            #sns.lineplot(data=pd.DataFrame({\"x\":x_pos, \"Value\":mses}), x='x', y='Value', linewidth=2, ax=ax, legend=False)\n",
    "        else:\n",
    "            ax.errorbar(x_pos, np.abs(biases), yerr=confidence_interval, fmt=markers[i], capsize=8, label=names[i], color=colors[i])\n",
    "            ax.plot(x_pos, np.abs(biases), \"-\", color=colors[i])\n",
    "            #sns.lineplot(data=pd.DataFrame({\"x\":x_pos, \"Value\":biases}), x='x', y='Value', linewidth=2, ax=ax, legend=False)\n",
    "    if mse:\n",
    "        ax.set_title(title)\n",
    "        ax.set_yscale('log')\n",
    "        if ylabel:\n",
    "            ax.set_ylabel('MSE')\n",
    "        else:\n",
    "            ax.set_ylabel('')\n",
    "    else:\n",
    "        #ax.set_yscale('symlog', linthresh=50)\n",
    "        ax.set_xlabel('No. of trajectories')\n",
    "        if ylabel:\n",
    "            ax.set_ylabel('Absolute bias')\n",
    "        else:\n",
    "            ax.set_ylabel('')\n",
    "            \n",
    "    ax.set_xticklabels(xticks)\n",
    "    ax.set_xticks(x_pos)\n",
    "    ax.grid(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "472cdd2e-c2cb-41c7-94a0-6f4db355831b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "fig, axes = plt.subplots(2, 3, figsize=(10, 6), sharex=True)\n",
    "errorplot(all_error1, axes[0,0], \"\\u03B5=0.1\", [10,20,35,60], ylabel=True)\n",
    "errorplot(all_error1, axes[1,0],\"\\u03B5=0.1\", [10,20,35,60], False, ylabel=True)\n",
    "\n",
    "errorplot(all_error3, axes[0,1], \"\\u03B5=0.3\", [10,20,35,60])\n",
    "errorplot(all_error3, axes[1,1],  \"\\u03B5=0.3\", [10,20,35,60],False)\n",
    "\n",
    "errorplot(all_error5, axes[0,2], \"\\u03B5=0.5\", [10,20,35,60])\n",
    "errorplot(all_error5, axes[1,2],  \"\\u03B5=0.5\", [10,20,35,60],False)\n",
    "\n",
    "handles, labels = axes[0,0].get_legend_handles_labels()\n",
    "fig.legend(handles, labels, loc='upper right', bbox_to_anchor=(1.14, 0.95))\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [
    "RArNFcAnHweS",
    "bnlm_FIdIIRQ",
    "dfuIlTWRxq2k",
    "-LHTBTnfxHBn",
    "jyND4_QbxM-n",
    "TGMcR_G_xQfX",
    "py_PbegjrHL6",
    "AO3jrNJqrOjD",
    "aTIzugypw-d1"
   ],
   "gpuType": "L4",
   "machine_shape": "hm",
   "provenance": []
  },
  "environment": {
   "kernel": "conda-env-pytorch-pytorch",
   "name": "workbench-notebooks.m125",
   "type": "gcloud",
   "uri": "us-docker.pkg.dev/deeplearning-platform-release/gcr.io/workbench-notebooks:m125"
  },
  "kernelspec": {
   "display_name": "PyTorch 1-13 (Local)",
   "language": "python",
   "name": "conda-env-pytorch-pytorch"
  },
  "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.10.15"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "051daf1749574215a54f91cfcab70fdd": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "0aff06efc9cb46ffbbb935a703c460e1": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "1b40a65820844bd1a2e639eb8162721a": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "FloatProgressModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "FloatProgressModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "ProgressView",
      "bar_style": "success",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_387fcd88298f485da262e24b06d82e53",
      "max": 50,
      "min": 0,
      "orientation": "horizontal",
      "style": "IPY_MODEL_7a0ff8f4438a43eeaa61ce137f0c4ebb",
      "value": 50
     }
    },
    "2520b69322dd401da2b45c3e8794eb8c": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "FloatProgressModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "FloatProgressModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "ProgressView",
      "bar_style": "success",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_55c2b4452ec9455fb15a66ef65020cd8",
      "max": 100,
      "min": 0,
      "orientation": "horizontal",
      "style": "IPY_MODEL_8a32947b92cf4bfa843602f19bd4a67b",
      "value": 100
     }
    },
    "25255d249e8246daa0c756a7a79b5451": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "2ce0003cfa8249159faccc99febd0eea": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "2de921b21f6542d9b9c17710a1818b2b": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_3bf1ae60735d47b0b9a75aff6dae57d7",
      "placeholder": "​",
      "style": "IPY_MODEL_c9253b3e9e9e4875bfaaae65b3bddb90",
      "value": "100%"
     }
    },
    "2ecca85b6a4145fb8ed11e5681e0df25": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "322c513cd2004ba8bd0d1e782811759e": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "387fcd88298f485da262e24b06d82e53": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "3bf1ae60735d47b0b9a75aff6dae57d7": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "4da779f87a3c431e941238c32e88178e": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "4de8fb98003d48c5be987b577bc77215": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "55c2b4452ec9455fb15a66ef65020cd8": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "601cc7d0987d45179ae1682796477633": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HBoxModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HBoxModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HBoxView",
      "box_style": "",
      "children": [
       "IPY_MODEL_d7e28ab1c8c143b094cccbcd2bba142e",
       "IPY_MODEL_2520b69322dd401da2b45c3e8794eb8c",
       "IPY_MODEL_75c582a2dc7f4f0daa99725779a581e9"
      ],
      "layout": "IPY_MODEL_4de8fb98003d48c5be987b577bc77215"
     }
    },
    "67eafd6c657c4fee93f941378f5b9238": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "75c582a2dc7f4f0daa99725779a581e9": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_e1e8b12c81bb463d8ae894171ad53f4c",
      "placeholder": "​",
      "style": "IPY_MODEL_2ce0003cfa8249159faccc99febd0eea",
      "value": " 100/100 [00:00&lt;00:00, 125.83it/s]"
     }
    },
    "7a0ff8f4438a43eeaa61ce137f0c4ebb": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "ProgressStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "ProgressStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "bar_color": null,
      "description_width": ""
     }
    },
    "816f1b60959b46f0afac2252aef2c049": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "827f928992ff49768a9c78b4ace16e95": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "ProgressStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "ProgressStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "bar_color": null,
      "description_width": ""
     }
    },
    "89bfa8ccd0714fb1853049b7bc1d7722": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_67eafd6c657c4fee93f941378f5b9238",
      "placeholder": "​",
      "style": "IPY_MODEL_0aff06efc9cb46ffbbb935a703c460e1",
      "value": " 30/30 [00:14&lt;00:00,  2.11it/s]"
     }
    },
    "8a32947b92cf4bfa843602f19bd4a67b": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "ProgressStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "ProgressStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "bar_color": null,
      "description_width": ""
     }
    },
    "9b8627c6b2cc4f02ae0c3420e2a34a26": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "a8a22943fc9b4a4f9481841c51fe211a": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HBoxModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HBoxModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HBoxView",
      "box_style": "",
      "children": [
       "IPY_MODEL_2de921b21f6542d9b9c17710a1818b2b",
       "IPY_MODEL_aa678c29e02b40ceae26d05340c6feb5",
       "IPY_MODEL_89bfa8ccd0714fb1853049b7bc1d7722"
      ],
      "layout": "IPY_MODEL_322c513cd2004ba8bd0d1e782811759e"
     }
    },
    "aa678c29e02b40ceae26d05340c6feb5": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "FloatProgressModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "FloatProgressModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "ProgressView",
      "bar_style": "success",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_816f1b60959b46f0afac2252aef2c049",
      "max": 30,
      "min": 0,
      "orientation": "horizontal",
      "style": "IPY_MODEL_827f928992ff49768a9c78b4ace16e95",
      "value": 30
     }
    },
    "c5f59e8817bb4141996f69369ad51b50": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_9b8627c6b2cc4f02ae0c3420e2a34a26",
      "placeholder": "​",
      "style": "IPY_MODEL_de9fcc49ef7749f0ab526227440e09fe",
      "value": "100%"
     }
    },
    "c7e138be7b934e4880429006ee21b0ec": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_4da779f87a3c431e941238c32e88178e",
      "placeholder": "​",
      "style": "IPY_MODEL_051daf1749574215a54f91cfcab70fdd",
      "value": " 50/50 [00:12&lt;00:00,  4.16it/s]"
     }
    },
    "c9253b3e9e9e4875bfaaae65b3bddb90": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "d7e28ab1c8c143b094cccbcd2bba142e": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_25255d249e8246daa0c756a7a79b5451",
      "placeholder": "​",
      "style": "IPY_MODEL_f27c0656c60f4b6ca31cd7ae82a90881",
      "value": "100%"
     }
    },
    "de9fcc49ef7749f0ab526227440e09fe": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "e1e8b12c81bb463d8ae894171ad53f4c": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "f27c0656c60f4b6ca31cd7ae82a90881": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "f97a9d791fbb4f24b2452e3f5a156349": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HBoxModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HBoxModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HBoxView",
      "box_style": "",
      "children": [
       "IPY_MODEL_c5f59e8817bb4141996f69369ad51b50",
       "IPY_MODEL_1b40a65820844bd1a2e639eb8162721a",
       "IPY_MODEL_c7e138be7b934e4880429006ee21b0ec"
      ],
      "layout": "IPY_MODEL_2ecca85b6a4145fb8ed11e5681e0df25"
     }
    }
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
