{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from itertools import product\n",
    "from scipy.optimize import minimize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "class LinearMixtureMDP():\n",
    "    def __init__(self, action_space, delta, xi_norm, seed=1):\n",
    "        np.random.seed(seed)\n",
    "        self.state_space = ['x_1', 'x_2', 'x_3', 'x_4', 'x_5']\n",
    "        self.action_space = action_space\n",
    "        self.initial_state = 'x_1'\n",
    "        self.nu = [np.zeros(4),\n",
    "                   np.array([0,0,0,1]),\n",
    "                   np.array([0,0,0,1])]\n",
    "        self.p = 0.1\n",
    "        self.theta = np.array(([self.p, 1 - 2*self.p, self.p], [self.p, 1 - 2*self.p, self.p]))\n",
    "        # self.theta = np.array(([0, 1 - self.p, self.p], [0, 1 - self.p, self.p]))\n",
    "        self.delta = delta\n",
    "        self.H = 3\n",
    "        Xi = np.full(len(self.action_space[0]), 1)\n",
    "        self.Xi = xi_norm * Xi / np.linalg.norm(Xi, 1)\n",
    "        self.xi_norm = xi_norm\n",
    "    \n",
    "    def reset(self):\n",
    "        self.S = [self.initial_state]\n",
    "        self.A = [] # save the action history\n",
    "        self.R = [] # save the reward history\n",
    "        self.h = 0 # reset the step to 0\n",
    "        self.current_state = self.initial_state # reset the current state to initial state\n",
    "\n",
    "    def psi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            psi = np.array([1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_2':\n",
    "            psi = np.array([0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_3':\n",
    "            psi = np.array([0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_4':\n",
    "            psi = np.array([0, 0, 1, 0])\n",
    "        elif current_state == 'x_5':\n",
    "            psi = np.array([0, 0, 0, 1])\n",
    "        else:\n",
    "            raise ValueError(f\"Error: The value {current_state} is not allow!\")\n",
    "        return psi\n",
    "    \n",
    "    def add_state(self, s):\n",
    "        self.S.append(s)\n",
    "        self.current_state = s\n",
    "\n",
    "    def phi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            phi = np.array(([1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A, 0], \n",
    "                           [1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A], \n",
    "                           [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_2':\n",
    "            phi = np.array(([0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A, 0],\n",
    "                            [0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A],\n",
    "                            [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_4':\n",
    "            phi = np.array(([0, 0, 1, 0], [0, 0, 1, 0], [0, 0, 1, 0]))\n",
    "        elif current_state == 'x_5':\n",
    "            phi = np.array(([0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]))\n",
    "        return phi\n",
    "        \n",
    "    def update_state(self, phi, h):\n",
    "        # calculate the transition probability\n",
    "        prob = self.theta[h] @ phi\n",
    "        sprime = np.random.choice(range(1,5), size = 1, p = prob)[0]\n",
    "        return self.state_space[sprime] # return a string\n",
    "    \n",
    "    def next_state(self, phi, h):\n",
    "        next_state = self.update_state(phi, h)\n",
    "        self.add_state(next_state)\n",
    "        return next_state\n",
    "    \n",
    "    def generate_reward(self, psi):\n",
    "        reward = np.dot(psi, self.nu[self.h])\n",
    "        self.R.append(reward)\n",
    "        return reward\n",
    "    \n",
    "    def step(self, a):\n",
    "        self.A.append(a)\n",
    "        psi = self.psi(self.current_state, a)\n",
    "        r = self.generate_reward(psi)\n",
    "        if self.h < self.H-1:\n",
    "            phi = self.phi(self.current_state, a)\n",
    "            self.next_state(phi, self.h)\n",
    "            self.h += 1\n",
    "\n",
    "class LinearMixtureMDP_test():\n",
    "    \"\"\"Perturbed Environment\"\"\"\n",
    "    def __init__(self, nominal_MDP, q, seed=1):\n",
    "        np.random.seed(seed)\n",
    "        self.state_space = nominal_MDP.state_space\n",
    "        self.action_space = nominal_MDP.action_space\n",
    "        self.initial_state = 'x_1'\n",
    "        # self.theta = nominal_MDP.theta\n",
    "        self.nu = nominal_MDP.nu\n",
    "        self.delta = nominal_MDP.delta\n",
    "        self.Xi = nominal_MDP.Xi\n",
    "        self.xi_norm = nominal_MDP.xi_norm\n",
    "        self.H = 3\n",
    "        self.q = q\n",
    "        self.theta = np.array(([self.q, 1 - self.q, 0], [nominal_MDP.p, 1 - 2*nominal_MDP.p, nominal_MDP.p]))\n",
    "        # self.theta = np.array(([self.q, 1 - self.q, 0], [0, 1 - nominal_MDP.p, nominal_MDP.p]))\n",
    "\n",
    "    def reset(self):\n",
    "        self.S = [self.initial_state]\n",
    "        self.A = [] # save the action history\n",
    "        self.R = [] # save the reward history\n",
    "        self.h = 0 # reset the step to 0\n",
    "        self.current_state = self.initial_state # reset the current state to initial state\n",
    "\n",
    "    def psi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            psi = np.array([1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_2':\n",
    "            psi = np.array([0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_3':\n",
    "            psi = np.array([0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_4':\n",
    "            psi = np.array([0, 0, 1, 0])\n",
    "        elif current_state == 'x_5':\n",
    "            psi = np.array([0, 0, 0, 1])\n",
    "        else:\n",
    "            raise ValueError(f\"Error: The value {current_state} is not allow!\")\n",
    "        return psi\n",
    "    \n",
    "    def add_state(self, s):\n",
    "        self.S.append(s)\n",
    "        self.current_state = s\n",
    "\n",
    "    def phi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            phi = np.array(([1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A, 0], \n",
    "                           [1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A], \n",
    "                           [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_2':\n",
    "            phi = np.array(([0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A, 0],\n",
    "                            [0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A],\n",
    "                            [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_4':\n",
    "            phi = np.array(([0, 0, 1, 0], [0, 0, 1, 0], [0, 0, 1, 0]))\n",
    "        elif current_state == 'x_5':\n",
    "            phi = np.array(([0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]))\n",
    "        return phi\n",
    "    \n",
    "    def update_state(self, phi, h):\n",
    "        # calculate the transition probability\n",
    "        prob = self.theta[h] @ phi\n",
    "        sprime = np.random.choice(range(1,5), size = 1, p = prob)[0]\n",
    "        return self.state_space[sprime] # return a string\n",
    "    \n",
    "    def next_state(self, phi, h):\n",
    "        next_state = self.update_state(phi, h)\n",
    "        self.add_state(next_state)\n",
    "        return next_state\n",
    "    \n",
    "    def generate_reward(self, psi):\n",
    "        reward = np.dot(psi, self.nu[self.h])\n",
    "        self.R.append(reward)\n",
    "        return reward\n",
    "    \n",
    "    def step(self, a):\n",
    "        self.A.append(a)\n",
    "        psi = self.psi(self.current_state, a)\n",
    "        r = self.generate_reward(psi)\n",
    "        if self.h < self.H-1:\n",
    "            phi = self.phi(self.current_state, a)\n",
    "            self.next_state(phi, self.h)\n",
    "            self.h += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class DRTTR_TV():\n",
    "    def __init__(self, A, H, lam, dataset, Rho, delta, xi_norm):\n",
    "        self.lam = lam\n",
    "        self.H = H\n",
    "        self.action_space = A\n",
    "        self.w = [np.zeros(4) for _ in range(self.H)]\n",
    "        self.Lambda = [self.lam * np.diag(np.ones(3)) for _ in range(self.H)]\n",
    "        self.Rho = Rho\n",
    "        self.dataset = dataset\n",
    "        Xi = np.full(len(self.action_space[0]), 1)\n",
    "        self.Xi = xi_norm * Xi / np.linalg.norm(Xi, 1)\n",
    "        self.xi_norm = xi_norm\n",
    "        self.delta = delta\n",
    "        self.nu = [np.zeros(4),\n",
    "                   np.array([0,0,0,1]),\n",
    "                   np.array([0,0,0,1])]\n",
    "    \n",
    "    def psi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            psi = np.array([1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_2':\n",
    "            psi = np.array([0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_3':\n",
    "            psi = np.array([0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_4':\n",
    "            psi = np.array([0, 0, 1, 0])\n",
    "        elif current_state == 'x_5':\n",
    "            psi = np.array([0, 0, 0, 1])\n",
    "        else:\n",
    "            raise ValueError(f\"Error: The value {current_state} is not allow!\")\n",
    "        return psi\n",
    "\n",
    "    def phi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            phi = np.array(([1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A, 0], \n",
    "                           [1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A], \n",
    "                           [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_2':\n",
    "            phi = np.array(([0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A, 0],\n",
    "                            [0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A],\n",
    "                            [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_4':\n",
    "            phi = np.array(([0, 0, 1, 0], [0, 0, 1, 0], [0, 0, 1, 0]))\n",
    "        elif current_state == 'x_5':\n",
    "            phi = np.array(([0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]))\n",
    "        return phi\n",
    "\n",
    "    def get_action(self, h, state):\n",
    "        Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "        return self.action_space[np.argmax(Q_h)]\n",
    "\n",
    "    def get_Q_func(self, h, state, action):\n",
    "        if h == self.H-1:\n",
    "            reward_feature = self.psi(state, action)\n",
    "            reward_parameter = self.nu[h]\n",
    "            return np.dot(reward_feature, reward_parameter)\n",
    "        else:\n",
    "            phi_s_a = self.phi(state, action)\n",
    "            phi_V_h_plus_one_s_a = [np.dot(phi_s_a[i], self.V_hat[h + 1]) for i in range(3)]\n",
    "            theta_hat = self.theta_hat[h]\n",
    "            def Q_alpha(alpha):\n",
    "                first_part = np.dot(np.minimum(phi_V_h_plus_one_s_a, alpha), theta_hat)\n",
    "                second_part = self.Rho[h]*(alpha - np.min(np.minimum(phi_V_h_plus_one_s_a, alpha)))\n",
    "                return - first_part + second_part\n",
    "            result = minimize(Q_alpha, self.H/2, method = 'Nelder-Mead', bounds=[(0,self.H)])\n",
    "            reward_feature = self.psi(state, action)\n",
    "            reward_parameter = self.nu[h]\n",
    "            reward = np.dot(reward_feature, reward_parameter)\n",
    "            return np.min([reward - result.fun, self.H - h])\n",
    "        \n",
    "    def indicator(self, condition):\n",
    "        return 1 if condition else 0\n",
    "    \n",
    "    def update_Q(self):\n",
    "        # parameter estimation\n",
    "        self.theta_hat = [None for _ in range(self.H-1)]\n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            # Prepare for Ridge Regression\n",
    "            Phi = np.zeros((0,3))\n",
    "            indicator_stack = np.zeros(0)\n",
    "            for n in range(self.dataset['k']):\n",
    "                state_temp = self.dataset['state'][n][h]\n",
    "                action_temp = self.dataset['action'][n][h]\n",
    "                target_temp = self.dataset['state'][n][h+1]\n",
    "                phi_temp = self.phi(state_temp, action_temp) # prepare the basis modes for s_h^k a_h^k\n",
    "                for j in range(4):\n",
    "                    feature_temp = phi_temp[:, j]\n",
    "                    self.Lambda[h] += np.outer(feature_temp, feature_temp)\n",
    "                    Phi = np.vstack((Phi, feature_temp))\n",
    "                for s in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                    indicator_stack = np.hstack((indicator_stack, self.indicator(s == target_temp)))\n",
    "            \n",
    "            # Update theta estimation\n",
    "            Lambda_h_inverse = np.linalg.inv(self.Lambda[h])\n",
    "            theta_hat_h = Lambda_h_inverse @ Phi.T @ indicator_stack\n",
    "            if np.product(theta_hat_h) < 0: # Normalize the parameter estimation\n",
    "                theta_hat_h -= np.min(theta_hat_h)\n",
    "            self.theta_hat[h] = theta_hat_h / np.sum(theta_hat_h)\n",
    "\n",
    "        # Backward Induction\n",
    "        self.V_hat = [np.zeros(4) for _ in range(self.H)] # initialize future cumulative reward, i.e., value function\n",
    "        self.V_hat[2] = np.array([0, self.delta+self.xi_norm, 0, 1]) # the last stage value function is the maximum reward which is known\n",
    "        \n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            V_h = []\n",
    "            for state in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                if state == 'x_3':\n",
    "                    V_h.append(0) # just a placeholder\n",
    "                else:\n",
    "                    Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "                    V_h.append(np.max(Q_h))\n",
    "            self.V_hat[h] = np.array(V_h)\n",
    "\n",
    "class DRTTR_KL():\n",
    "    def __init__(self, A, H, lam, dataset, Rho, delta, xi_norm):\n",
    "        self.lam = lam\n",
    "        self.H = H\n",
    "        self.action_space = A\n",
    "        self.w = [np.zeros(4) for _ in range(self.H)]\n",
    "        self.Lambda = [self.lam * np.diag(np.ones(3)) for _ in range(self.H)]\n",
    "        self.Rho = Rho\n",
    "        self.dataset = dataset\n",
    "        Xi = np.full(len(self.action_space[0]), 1)\n",
    "        self.Xi = xi_norm * Xi / np.linalg.norm(Xi, 1)\n",
    "        self.xi_norm = xi_norm\n",
    "        self.delta = delta\n",
    "        self.nu = [np.zeros(4),\n",
    "                   np.array([0,0,0,1]),\n",
    "                   np.array([0,0,0,1])]\n",
    "    \n",
    "    def psi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            psi = np.array([1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_2':\n",
    "            psi = np.array([0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_3':\n",
    "            psi = np.array([0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_4':\n",
    "            psi = np.array([0, 0, 1, 0])\n",
    "        elif current_state == 'x_5':\n",
    "            psi = np.array([0, 0, 0, 1])\n",
    "        else:\n",
    "            raise ValueError(f\"Error: The value {current_state} is not allow!\")\n",
    "        return psi\n",
    "\n",
    "    def phi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            phi = np.array(([1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A, 0], \n",
    "                           [1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A], \n",
    "                           [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_2':\n",
    "            phi = np.array(([0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A, 0],\n",
    "                            [0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A],\n",
    "                            [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_4':\n",
    "            phi = np.array(([0, 0, 1, 0], [0, 0, 1, 0], [0, 0, 1, 0]))\n",
    "        elif current_state == 'x_5':\n",
    "            phi = np.array(([0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]))\n",
    "        return phi\n",
    "\n",
    "    def get_action(self, h, state):\n",
    "        Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "        return self.action_space[np.argmax(Q_h)]\n",
    "\n",
    "    def get_Q_func(self, h, state, action):\n",
    "        if h == self.H-1:\n",
    "            reward_feature = self.psi(state, action)\n",
    "            reward_parameter = self.nu[h]\n",
    "            return np.dot(reward_feature, reward_parameter)\n",
    "        else:\n",
    "            if self.Rho[h] == 0:\n",
    "                phi_s_a = self.phi(state, action) # get the basis modes\n",
    "                phi_V_h_plus_one_s_a = [np.dot(phi_s_a[i], self.V_hat[h + 1]) for i in range(3)] # take expectations to get feature\n",
    "                theta_hat = self.theta_hat[h]\n",
    "                result = np.dot(phi_V_h_plus_one_s_a, theta_hat) # take expectation wrt i~theta\n",
    "                reward_feature = self.psi(state, action) \n",
    "                reward_parameter = self.nu[h] # calculate the immediate reward\n",
    "                reward = np.dot(reward_feature, reward_parameter) \n",
    "                return np.min([reward + result, self.H - h]) # reward + future cumulative reward = Qfunc\n",
    "            else:\n",
    "                phi_s_a = self.phi(state, action)\n",
    "                phi_V_h_plus_one_s_a = [np.dot(phi_s_a[i], self.V_hat[h + 1]) for i in range(3)]\n",
    "                theta_hat = self.theta_hat[h]\n",
    "                def Q_alpha(alpha):\n",
    "                    first_part = alpha * np.log(np.dot(theta_hat, np.exp(-np.array(phi_V_h_plus_one_s_a)/alpha)))\n",
    "                    second_part = self.Rho[h] * alpha \n",
    "                    return first_part + second_part\n",
    "                result = minimize(Q_alpha, self.H/2, method = 'Nelder-Mead', bounds=[(0.01, self.H/np.min([self.Rho[h], 1]))])\n",
    "                reward_feature = self.psi(state, action)\n",
    "                reward_parameter = self.nu[h]\n",
    "                reward = np.dot(reward_feature, reward_parameter)\n",
    "                return np.min([reward - result.fun, self.H - h])\n",
    "            \n",
    "    def indicator(self, condition):\n",
    "        return 1 if condition else 0\n",
    "\n",
    "    def update_Q(self):\n",
    "        # parameter estimation\n",
    "        self.theta_hat = [None for _ in range(self.H-1)]\n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            # Prepare for Ridge Regression\n",
    "            Phi = np.zeros((0,3))\n",
    "            indicator_stack = np.zeros(0)\n",
    "            for n in range(self.dataset['k']):\n",
    "                state_temp = self.dataset['state'][n][h]\n",
    "                action_temp = self.dataset['action'][n][h]\n",
    "                target_temp = self.dataset['state'][n][h+1]\n",
    "                phi_temp = self.phi(state_temp, action_temp) # prepare the basis modes for s_h^k a_h^k\n",
    "                for j in range(4):\n",
    "                    feature_temp = phi_temp[:, j]\n",
    "                    self.Lambda[h] += np.outer(feature_temp, feature_temp)\n",
    "                    Phi = np.vstack((Phi, feature_temp))\n",
    "                for s in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                    indicator_stack = np.hstack((indicator_stack, self.indicator(s == target_temp)))\n",
    "            \n",
    "            # Update theta estimation\n",
    "            Lambda_h_inverse = np.linalg.inv(self.Lambda[h])\n",
    "            theta_hat_h = Lambda_h_inverse @ Phi.T @ indicator_stack\n",
    "            if np.product(theta_hat_h) < 0: # Normalize the parameter estimation\n",
    "                theta_hat_h -= np.min(theta_hat_h)\n",
    "            self.theta_hat[h] = theta_hat_h / np.sum(theta_hat_h)\n",
    "\n",
    "        # Backward Induction\n",
    "        self.V_hat = [np.zeros(4) for _ in range(self.H)] # initialize future cumulative reward, i.e., value function\n",
    "        self.V_hat[2] = np.array([0, self.delta+self.xi_norm, 0, 1]) # the last stage value function is the maximum reward which is known\n",
    "        \n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            V_h = []\n",
    "            for state in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                if state == 'x_3':\n",
    "                    V_h.append(0) # just a placeholder\n",
    "                else:\n",
    "                    Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "                    V_h.append(np.max(Q_h))\n",
    "            self.V_hat[h] = np.array(V_h)\n",
    "    \n",
    "class DRTTR_chi2():\n",
    "    def __init__(self, A, H, lam, dataset, Rho, delta, xi_norm):\n",
    "        self.lam = lam\n",
    "        self.H = H\n",
    "        self.action_space = A\n",
    "        self.w = [np.zeros(4) for _ in range(self.H)]\n",
    "        self.Lambda = [self.lam * np.diag(np.ones(3)) for _ in range(self.H)]\n",
    "        self.Rho = Rho\n",
    "        self.dataset = dataset\n",
    "        Xi = np.full(len(self.action_space[0]), 1)\n",
    "        self.Xi = xi_norm * Xi / np.linalg.norm(Xi, 1)\n",
    "        self.xi_norm = xi_norm\n",
    "        self.delta = delta\n",
    "        self.nu = [np.zeros(4),\n",
    "                   np.array([0,0,0,1]),\n",
    "                   np.array([0,0,0,1])]\n",
    "    \n",
    "    def psi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            psi = np.array([1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_2':\n",
    "            psi = np.array([0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_3':\n",
    "            psi = np.array([0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_4':\n",
    "            psi = np.array([0, 0, 1, 0])\n",
    "        elif current_state == 'x_5':\n",
    "            psi = np.array([0, 0, 0, 1])\n",
    "        else:\n",
    "            raise ValueError(f\"Error: The value {current_state} is not allow!\")\n",
    "        return psi\n",
    "\n",
    "    def phi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            phi = np.array(([1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A, 0], \n",
    "                           [1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A], \n",
    "                           [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_2':\n",
    "            phi = np.array(([0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A, 0],\n",
    "                            [0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A],\n",
    "                            [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_4':\n",
    "            phi = np.array(([0, 0, 1, 0], [0, 0, 1, 0], [0, 0, 1, 0]))\n",
    "        elif current_state == 'x_5':\n",
    "            phi = np.array(([0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]))\n",
    "        return phi\n",
    "\n",
    "    def get_action(self, h, state):\n",
    "        Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "        return self.action_space[np.argmax(Q_h)]\n",
    "\n",
    "    def get_Q_func(self, h, state, action):\n",
    "        if h == self.H-1:\n",
    "            reward_feature = self.psi(state, action)\n",
    "            reward_parameter = self.nu[h]\n",
    "            return np.dot(reward_feature, reward_parameter)\n",
    "        else:\n",
    "            if self.Rho[h] == 0:\n",
    "                phi_s_a = self.phi(state, action) # get the basis modes\n",
    "                phi_V_h_plus_one_s_a = [np.dot(phi_s_a[i], self.V_hat[h + 1]) for i in range(3)] # take expectations to get feature\n",
    "                theta_hat = self.theta_hat[h]\n",
    "                result = np.dot(phi_V_h_plus_one_s_a, theta_hat) # take expectation wrt i~theta\n",
    "                reward_feature = self.psi(state, action) \n",
    "                reward_parameter = self.nu[h] # calculate the immediate reward\n",
    "                reward = np.dot(reward_feature, reward_parameter) \n",
    "                return np.min([reward + result, self.H - h]) # reward + future cumulative reward = Qfunc\n",
    "            else:\n",
    "                phi_s_a = self.phi(state, action)\n",
    "                phi_V_h_plus_one_s_a = [np.dot(phi_s_a[i], self.V_hat[h + 1]) for i in range(3)]\n",
    "                theta_hat = self.theta_hat[h]\n",
    "                def Q_alpha(alpha):\n",
    "                    first_part = np.dot(np.minimum(phi_V_h_plus_one_s_a, alpha), theta_hat)\n",
    "                    # second_part = self.Rho[h]*(alpha - np.min(np.minimum(phi_V_h_plus_one_s_a, alpha)))\n",
    "                    first_order_term = np.dot(np.minimum(phi_V_h_plus_one_s_a, alpha), theta_hat)\n",
    "                    second_order_term = np.dot(np.minimum(phi_V_h_plus_one_s_a, alpha) ** 2, theta_hat)\n",
    "                    variance = np.max([second_order_term - first_order_term ** 2, 0])\n",
    "                    second_part= np.sqrt(self.Rho[h] * variance)\n",
    "                    return - first_part + second_part\n",
    "                result = minimize(Q_alpha, self.H/2, method = 'Nelder-Mead', bounds=[(0,self.H)])\n",
    "                reward_feature = self.psi(state, action)\n",
    "                reward_parameter = self.nu[h]\n",
    "                reward = np.dot(reward_feature, reward_parameter)\n",
    "                return np.min([reward - result.fun, self.H - h])\n",
    "            \n",
    "    def indicator(self, condition):\n",
    "        return 1 if condition else 0\n",
    "\n",
    "    def update_Q(self):\n",
    "        # parameter estimation\n",
    "        self.theta_hat = [None for _ in range(self.H-1)]\n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            # Prepare for Ridge Regression\n",
    "            Phi = np.zeros((0,3))\n",
    "            indicator_stack = np.zeros(0)\n",
    "            for n in range(self.dataset['k']):\n",
    "                state_temp = self.dataset['state'][n][h]\n",
    "                action_temp = self.dataset['action'][n][h]\n",
    "                target_temp = self.dataset['state'][n][h+1]\n",
    "                phi_temp = self.phi(state_temp, action_temp) # prepare the basis modes for s_h^k a_h^k\n",
    "                for j in range(4):\n",
    "                    feature_temp = phi_temp[:, j]\n",
    "                    self.Lambda[h] += np.outer(feature_temp, feature_temp)\n",
    "                    Phi = np.vstack((Phi, feature_temp))\n",
    "                for s in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                    indicator_stack = np.hstack((indicator_stack, self.indicator(s == target_temp)))\n",
    "            \n",
    "            # Update theta estimation\n",
    "            Lambda_h_inverse = np.linalg.inv(self.Lambda[h])\n",
    "            theta_hat_h = Lambda_h_inverse @ Phi.T @ indicator_stack\n",
    "            if np.product(theta_hat_h) < 0: # Normalize the parameter estimation\n",
    "                theta_hat_h -= np.min(theta_hat_h)\n",
    "            self.theta_hat[h] = theta_hat_h / np.sum(theta_hat_h)\n",
    "\n",
    "        # Backward Induction\n",
    "        self.V_hat = [np.zeros(4) for _ in range(self.H)] # initialize future cumulative reward, i.e., value function\n",
    "        self.V_hat[2] = np.array([0, self.delta+self.xi_norm, 0, 1]) # the last stage value function is the maximum reward which is known\n",
    "        \n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            V_h = []\n",
    "            for state in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                if state == 'x_3':\n",
    "                    V_h.append(0) # just a placeholder\n",
    "                else:\n",
    "                    Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "                    V_h.append(np.max(Q_h))\n",
    "            self.V_hat[h] = np.array(V_h)\n",
    "\n",
    "class TTR():\n",
    "    def __init__(self, A, H, lam, dataset, delta, xi_norm):\n",
    "        self.lam = lam\n",
    "        self.H = H\n",
    "        self.action_space = A\n",
    "        self.w = [np.zeros(4) for _ in range(self.H)]\n",
    "        self.Lambda = [self.lam * np.diag(np.ones(3)) for _ in range(self.H)]\n",
    "        self.dataset = dataset\n",
    "        Xi = np.full(len(self.action_space[0]), 1)\n",
    "        self.Xi = xi_norm * Xi / np.linalg.norm(Xi, 1)\n",
    "        self.xi_norm = xi_norm\n",
    "        self.delta = delta\n",
    "        self.nu = [np.zeros(4),\n",
    "                   np.array([0,0,0,1]),\n",
    "                   np.array([0,0,0,1])]\n",
    "        \n",
    "    def psi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            psi = np.array([1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_2':\n",
    "            psi = np.array([0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_3':\n",
    "            psi = np.array([0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])\n",
    "        elif current_state == 'x_4':\n",
    "            psi = np.array([0, 0, 1, 0])\n",
    "        elif current_state == 'x_5':\n",
    "            psi = np.array([0, 0, 0, 1])\n",
    "        else:\n",
    "            raise ValueError(f\"Error: The value {current_state} is not allow!\")\n",
    "        return psi\n",
    "\n",
    "    def phi(self, current_state, A):\n",
    "        if current_state == 'x_1':\n",
    "            phi = np.array(([1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A, 0], \n",
    "                           [1 - self.delta - self.Xi @ A, 0, 0, self.delta + self.Xi @ A], \n",
    "                           [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A])) \n",
    "        elif current_state == 'x_2':\n",
    "            phi = np.array(([0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A, 0],\n",
    "                            [0, 1 - self.delta - self.Xi @ A, 0, self.delta + self.Xi @ A],\n",
    "                            [0, 0, 1 - self.delta - self.Xi @ A, self.delta + self.Xi @ A]))\n",
    "        elif current_state == 'x_4':\n",
    "            phi = np.array(([0, 0, 1, 0], [0, 0, 1, 0], [0, 0, 1, 0]))\n",
    "        elif current_state == 'x_5':\n",
    "            phi = np.array(([0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]))\n",
    "        return phi\n",
    "    \n",
    "    def get_action(self, h, state):\n",
    "        Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "        return self.action_space[np.argmax(Q_h)]\n",
    "    \n",
    "    def get_Q_func(self, h, state, action):\n",
    "        if h == self.H-1: # if we are in the last stage, then the Qfunc is simply the reward func\n",
    "            reward_feature = self.psi(state, action) \n",
    "            reward_parameter = self.nu[h]\n",
    "            return np.dot(reward_feature, reward_parameter)\n",
    "        else:\n",
    "            phi_s_a = self.phi(state, action) # get the basis modes\n",
    "            phi_V_h_plus_one_s_a = [np.dot(phi_s_a[i], self.V_hat[h + 1]) for i in range(3)] # take expectations to get feature\n",
    "            theta_hat = self.theta_hat[h]\n",
    "            result = np.dot(phi_V_h_plus_one_s_a, theta_hat) # take expectation wrt i~theta\n",
    "            reward_feature = self.psi(state, action) \n",
    "            reward_parameter = self.nu[h] # calculate the immediate reward\n",
    "            reward = np.dot(reward_feature, reward_parameter) \n",
    "            return np.min([reward + result, self.H - h]) # reward + future cumulative reward = Qfunc\n",
    "        \n",
    "    def indicator(self, condition):\n",
    "        return 1 if condition else 0\n",
    "\n",
    "    def update_Q(self):\n",
    "        # parameter estimation\n",
    "        self.theta_hat = [None for _ in range(self.H-1)]\n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            # Prepare for Ridge Regression\n",
    "            Phi = np.zeros((0,3))\n",
    "            indicator_stack = np.zeros(0)\n",
    "            for n in range(self.dataset['k']):\n",
    "                state_temp = self.dataset['state'][n][h]\n",
    "                action_temp = self.dataset['action'][n][h]\n",
    "                target_temp = self.dataset['state'][n][h+1]\n",
    "                phi_temp = self.phi(state_temp, action_temp) # prepare the basis modes for s_h^k a_h^k\n",
    "                for j in range(4):\n",
    "                    feature_temp = phi_temp[:, j]\n",
    "                    self.Lambda[h] += np.outer(feature_temp, feature_temp)\n",
    "                    Phi = np.vstack((Phi, feature_temp))\n",
    "                for s in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                    indicator_stack = np.hstack((indicator_stack, self.indicator(s == target_temp)))\n",
    "            \n",
    "            # Update theta estimation\n",
    "            Lambda_h_inverse = np.linalg.inv(self.Lambda[h])\n",
    "            theta_hat_h = Lambda_h_inverse @ Phi.T @ indicator_stack\n",
    "            if np.product(theta_hat_h) < 0: # Normalize the parameter estimation\n",
    "                theta_hat_h -= np.min(theta_hat_h)\n",
    "            self.theta_hat[h] = theta_hat_h / np.sum(theta_hat_h)\n",
    "\n",
    "        # Backward Induction\n",
    "        self.V_hat = [np.zeros(4) for _ in range(self.H)] # initialize future cumulative reward, i.e., value function\n",
    "        self.V_hat[2] = np.array([0, self.delta+self.xi_norm, 0, 1]) # the last stage value function is the maximum reward which is known\n",
    "        \n",
    "        for h in range(self.H-2, -1, -1):\n",
    "            V_h = []\n",
    "            for state in ['x_2', 'x_3', 'x_4', 'x_5']:\n",
    "                if state == 'x_3':\n",
    "                    V_h.append(0) # just a placeholder\n",
    "                else:\n",
    "                    Q_h = [self.get_Q_func(h, state, action) for action in self.action_space]\n",
    "                    V_h.append(np.max(Q_h))\n",
    "            self.V_hat[h] = np.array(V_h)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Offline_Dataset_Collection(sample_size, env, seed=1):\n",
    "    np.random.seed(seed)\n",
    "    history = {'k': 0, 'r': [], 'state': [], 'action': []}\n",
    "    epoch = sample_size\n",
    "    for t in range(epoch):\n",
    "        env.reset()\n",
    "        for h in range(env.H):\n",
    "            random_action_index = np.random.choice(range(0, len(env.action_space)), size = 1)[0]\n",
    "            action = env.action_space[random_action_index]\n",
    "            env.step(action)\n",
    "            \n",
    "        # log the trajectory\n",
    "        history['r'].append(env.R)\n",
    "        history['state'].append(env.S)\n",
    "        history['action'].append(env.A)\n",
    "        history['k'] += 1\n",
    "    return history\n",
    "def train_once(dataset, action_space, H, lam, delta, xi_norm):\n",
    "    agent = TTR(A=action_space, H=H, lam=lam, dataset=dataset, delta=delta, xi_norm=xi_norm)\n",
    "    agent.update_Q()\n",
    "    return agent\n",
    "\n",
    "def train_once_DR_TV(dataset, action_space, H, lam, Rho, delta, xi_norm):\n",
    "    agent = DRTTR_TV(A=action_space, H=H, lam=lam, dataset=dataset, Rho=Rho, delta=delta, xi_norm=xi_norm)\n",
    "    agent.update_Q()\n",
    "    return agent\n",
    "\n",
    "def train_once_DR_KL(dataset, action_space, H, lam, Rho, delta, xi_norm):\n",
    "    agent = DRTTR_KL(A=action_space, H=H, lam=lam, dataset=dataset, Rho=Rho, delta=delta, xi_norm=xi_norm)\n",
    "    agent.update_Q()\n",
    "    return agent\n",
    "\n",
    "def train_once_DR_chi2(dataset, action_space, H, lam, Rho, delta, xi_norm):\n",
    "    agent = DRTTR_chi2(A=action_space, H=H, lam=lam, dataset=dataset, Rho=Rho, delta=delta, xi_norm=xi_norm)\n",
    "    agent.update_Q()\n",
    "    return agent\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.35\n",
    "rho_KL = 5\n",
    "rho_chi2 = 10\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.4\n",
    "xi_norm = 0.4\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.35\n",
    "rho_KL = 5\n",
    "rho_chi2 = 10\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.4\n",
    "xi_norm = 0.3\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.7\n",
    "rho_KL = 10\n",
    "rho_chi2 = 20\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.4\n",
    "xi_norm = 0.4\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.7\n",
    "rho_KL = 10\n",
    "rho_chi2 = 20\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.4\n",
    "xi_norm = 0.3\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.35\n",
    "rho_KL = 5\n",
    "rho_chi2 = 10\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.3\n",
    "xi_norm = 0.3\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.35\n",
    "rho_KL = 5\n",
    "rho_chi2 = 10\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.3\n",
    "xi_norm = 0.2\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.7\n",
    "rho_KL = 10\n",
    "rho_chi2 = 20\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.3\n",
    "xi_norm = 0.3\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "T1 = 500\n",
    "H = 3\n",
    "rho_TV = 0.7\n",
    "rho_KL = 10\n",
    "rho_chi2 = 20\n",
    "lam = 0.1\n",
    "actions = list(product([-1, 1], repeat=4))\n",
    "action_space = [np.array(action) for action in actions]\n",
    "delta = 0.3\n",
    "xi_norm = 0.2\n",
    "Rho_TV = [rho_TV, 0]\n",
    "Rho_KL = [rho_KL, 0]\n",
    "Rho_chi2 = [rho_chi2, 0]\n",
    "replication = 10\n",
    "agent_dic = {}\n",
    "DR_agent_TV_dic = {}\n",
    "DR_agent_KL_dic = {}\n",
    "DR_agent_chi2_dic = {}\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "\n",
    "\n",
    "for rep in range(replication):\n",
    "    Offline_Dataset = Offline_Dataset_Collection(T1, env, seed=rep)\n",
    "    agent = train_once(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_TV = train_once_DR_TV(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_TV, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_KL = train_once_DR_KL(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_KL, delta=delta, xi_norm=xi_norm)\n",
    "    DR_agent_chi2 = train_once_DR_chi2(dataset=Offline_Dataset, action_space=action_space, H=H, lam=lam, Rho=Rho_chi2, delta=delta, xi_norm=xi_norm)\n",
    "    \n",
    "    agent_dic[str(rep)] = agent\n",
    "    DR_agent_TV_dic[str(rep)] = DR_agent_TV\n",
    "    DR_agent_KL_dic[str(rep)] = DR_agent_KL\n",
    "    DR_agent_chi2_dic[str(rep)] = DR_agent_chi2\n",
    "\n",
    "\n",
    "Points = 10\n",
    "Perturbation = [x / Points for x in range(Points+1)]\n",
    "# Perturbation = [0.5]\n",
    "T2 = 100\n",
    "R_TTR = []\n",
    "R_DRTTR_TV = []\n",
    "R_DRTTR_KL = []\n",
    "R_DRTTR_chi2 = []\n",
    "env = LinearMixtureMDP(action_space, delta, xi_norm)\n",
    "for q in Perturbation:\n",
    "    REWARD = 0\n",
    "    REWARD_DR_TV = 0\n",
    "    REWARD_DR_KL = 0\n",
    "    REWARD_DR_chi2 = 0\n",
    "    for rep in range(replication):\n",
    "        reward = 0\n",
    "        reward_DR_TV = 0\n",
    "        reward_DR_KL = 0\n",
    "        reward_DR_chi2 = 0\n",
    "        env_test = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_TV = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_KL = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        env_test_DR_chi2 = LinearMixtureMDP_test(env, q=q, seed=rep)\n",
    "        agent = agent_dic[str(rep)]\n",
    "        DR_agent_TV = DR_agent_TV_dic[str(rep)]\n",
    "        DR_agent_KL = DR_agent_KL_dic[str(rep)]\n",
    "        DR_agent_chi2 = DR_agent_chi2_dic[str(rep)]\n",
    "\n",
    "\n",
    "        for t in range(T2):\n",
    "            env_test.reset()\n",
    "            env_test_DR_TV.reset()\n",
    "            env_test_DR_KL.reset()\n",
    "            env_test_DR_chi2.reset()\n",
    "            for h in range(H):\n",
    "                # VTR\n",
    "                current_state = env_test.current_state\n",
    "                action = agent.get_action(h, current_state)\n",
    "                env_test.step(action)\n",
    "            \n",
    "                # DRVTR_TV\n",
    "                current_state_DR_TV = env_test_DR_TV.current_state\n",
    "                action_DR_TV = DR_agent_TV.get_action(h, current_state_DR_TV)\n",
    "                env_test_DR_TV.step(action_DR_TV)\n",
    "\n",
    "                # DRVTR_KL\n",
    "                current_state_DR_KL = env_test_DR_KL.current_state\n",
    "                action_DR_KL = DR_agent_KL.get_action(h, current_state_DR_KL)\n",
    "                env_test_DR_KL.step(action_DR_KL)\n",
    "\n",
    "                # DRVTR_chi2\n",
    "                current_state_DR_chi2 = env_test_DR_chi2.current_state\n",
    "                action_DR_chi2 = DR_agent_chi2.get_action(h, current_state_DR_chi2)\n",
    "                env_test_DR_chi2.step(action_DR_chi2)\n",
    "\n",
    "            reward += np.sum(env_test.R) / T2   \n",
    "            reward_DR_TV += np.sum(env_test_DR_TV.R) / T2  \n",
    "            reward_DR_KL += np.sum(env_test_DR_KL.R) / T2  \n",
    "            reward_DR_chi2 += np.sum(env_test_DR_chi2.R) / T2  \n",
    "             \n",
    "        \n",
    "        REWARD += reward / replication \n",
    "        REWARD_DR_TV += reward_DR_TV / replication \n",
    "        REWARD_DR_KL += reward_DR_KL / replication \n",
    "        REWARD_DR_chi2 += reward_DR_chi2 / replication \n",
    "\n",
    "    R_TTR.append(REWARD)\n",
    "    R_DRTTR_TV.append(REWARD_DR_TV)\n",
    "    R_DRTTR_KL.append(REWARD_DR_KL)\n",
    "    R_DRTTR_chi2.append(REWARD_DR_chi2)\n",
    "\n",
    "plt.plot(Perturbation, R_TTR, label = 'TTR')\n",
    "plt.plot(Perturbation, R_DRTTR_TV, label = 'DRTTR_TV')\n",
    "plt.plot(Perturbation, R_DRTTR_KL, label = 'DRTTR_KL')\n",
    "plt.plot(Perturbation, R_DRTTR_chi2, label = 'DRTTR_chi2')\n",
    "plt.legend(fontsize=16)\n",
    "plt.xlabel('Perturbation', size=16)\n",
    "plt.ylabel('Average reward', size=16)\n",
    "plt.savefig(f'robustness_{delta}_{xi_norm}_{rho_TV}_{rho_KL}_{rho_chi2}.pdf', dpi=1000, bbox_inches='tight', pad_inches=0.0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
