{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 39,
   "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": 40,
   "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": 41,
   "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": 42,
   "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",
    "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",
    "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",
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": []
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAAEPCAYAAABcA4N7AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3Xd8jdcDx/HPc7NlTwkRSczECIlNrarau1Zrt/bWlv5oqS6tUptSo2jtPavVWrU3QUSEBCE7ZOfmnt8fT0oVyZXcSHDer1de5N7nnnueus03ZytCCCRJkiTpWTQFXQFJkiSpcJNBIUmSJGVLBoUkSZKULRkUkiRJUrZkUEiSJEnZkkEhSZIkZUsGhSRJkpQtGRSSJElStmRQSJIkSdkyLugKGIKTk5Pw9PQs6GpIkiS9VE6dOhUthHDO6bpXIig8PT05efJkQVdDkiTppaIoyk19rpNdT5IkSVK2ZFBIkiRJ2ZJBIUmSJGVLBoUkSZKULRkUkiRJUrZkUEiSJEnZkkEhSZIkZeu1DorYpHQmb7tEUpq2oKsiSZJUaL3WQXHoWjTLDofSavYhLt5OKOjqSJIkFUqvdVC08SvGrx/UIiU9kw7zDrPkUChCiIKuliRJUqHyWgcFQC1vR3aOeIP6ZZ2YvP0SHyw/SWxSekFXS5IkqdB47YMCwMHSlEU9qzGxtS8HrkbTfOYBjoTEFHS1JEmSCgUZFFkURaFPXS82Dq5DEVNjuv90lOm/X0WbqSvoqkmSJBWo1zootPHxhE3/Dl1KysPHKha3ZfuwenSo6s6svcF0X3SMO/Ep2ZQiSZL0anutg+LU5oUkLVzK6eYNuXdk/8PHLc2MmdbZjx+6+BF4J4HmMw+yJ/BuAdZUkiSp4LzQoFAUZYmiKJGKolx8xvO2iqJsUxTlnKIogYqi9MnP+hTr0I3fRtchKeU+0X0GsntUF+Li7z18vn1Vd7YPf4MSDhb0X3GKz7ZcJDUjMz+rJEmSVOgoL3I6qKIo9YFEYLkQouJTnv8fYCuEGKsoijMQBLgKIbKdhlStWjWRl4OLrt25yLnPP8R3/03uOmi4M6IDbdp/jLWpNQBp2ky+2x3E4kOhlHe1Zk53f0q7WOX6/SRJkgoDRVFOCSGq5XTdC21RCCEOALHZXQJYK4qiAFZZ1+b7sunSxSrS8cfdKLMmU0Qxo8rE9SzpX5/FJ+aRlJGEmbERn7byZWnv6kQ+SKP17EOsPRku11xIkvRaKGxjFHMAH+AOcAEYIYR4YdOOyjd9h+p7DqJ0aEbTo6l4Dp/N0B+asPTiUlK0KTQq78KuEW9QpYQdH68/z4jVZ3mQmvGiqidJklQgCltQvA2cBYoBVYA5iqLYPO1CRVH6K4pyUlGUk1FRUQargMbSEt+vf8Bj2VLczJ35aGk8Ud9Npc2qZqy4tALbIrDy/Zp82LQsOy5E0HLWIc6Fxxvs/SVJkgqbwhYUfYCNQnUNCAXKP+1CIcRCIUQ1IUQ1Z2dng1fEslYtym3bhX3XrrQ+Lpi08D6bN31Ly40tWXt1Nf0blGRN/1pk6gQd5x9m4YEQdDrZFSVJ0qunsAVFGPAmgKIoRYFywPWCqoyRlSVuEyfisWwpRU0c+GKljp5/6ph66CtabmpJaPpetgytRROfony98wp9lp0gOjGtoKorSZKUL170rKdVQEPACbgHTARMAIQQCxRFKQYsA9wABZgihFiZU7l5nfWkj8zEJCKnfU/8qtVkuhdlRXtbdlpdp7hVcfpX6k9iTBW+3BGErYUJP3SuQr0yTvlaH0mSpLzSd9bTCw2K/PIiguIfSUePEvG/8WRERJDSsQnTA+5y7v5lPKw9aOPZi7X7nLkelcygBqUY9VZZTIwKW6NNkiRJJYMiH2UmJhH5/VTiV6/B1NOTiBEdmZGxm6C4IEpae+KQ3ooDZ4tR1cOBWV2rUsKhyAurmyRJkr4K5TqKQic6GH55B67vh+cITCMrS9wmTcJj6RJEejqOo6cz53J1pteegomRMWfS5lCq6o9cSzxMi1n72XE+Ih9vQpIkKX+93kERGwp3zsDyNrCwAVxYD5n6r4uwrF0br61bsevSmbily/AePoeVJSYwtf5ULM00UHQ5ph6zGL51JZ9sPC+3/5Ak6aUku54yUuH8ajg8B2KCwbYE1BoE/j3BzFrvYpKOHCFi/AQyIiJw6N0bh2FD2B3xJ/PPLSD8QRiZKe44aVuzqNN7lHN96tIQSZKkF0qOUTwvnQ6Cf4PDs+Hm32BmC9X6QM2BYOOmVxH/Hbtw+/prTKtUYlvINmaemkdM2l10KR50K/sB/2vYBo3m9W7QSZJUsGRQ5MWtk2pgXN4KihFU7gy1h0JRX71e/t/WhfOI4WSaGLEycD2zTy8gQ4nFhrJ80+hj6nvUNFy9JUmSnoMMCkOIDYWj8+HMCshIhtJNoM4w8GoAipLtSx9rXXh54fb1VxSpWpXUjDTG7F7I/shVKMYPqOJYl8/rfYy3nbfh6y9JkpQNGRSGlBwLJxfDsYWQFAmulaHOcKjQDoxMsn3pw9bF3btq62L4MDTm5hy7cZdhO2aSbPE7GqMM2pduz9CqQ3AuYvjtSCRJkp5GBkV+yEiFC2vVbqnoq2Dj/mjg2/zZA9SZiUlETp1K/JrHWxeJaVrGbznC7tsrMbU/ipmxKX0q9qZ3hd5Ymljm//1IkvRak0GRn3Q6uPY7/D0Lbh4CMxsI6K2Ghk2xZ74s6fBh7kyYgPbuvcdaFzvORzBu658I+10oVudwMHdgsN9gOpTtgIkm+xaLJElSbsmgeFFun1Kn1l7aDIoGKr2jDny7PnGAH/Cf1kXJkrhOnoxlzRrciU9h1JqznIg4SzHvvSSIIDxtPBnpP5LGHo1RchgTkSRJel4yKF60uBtwdAGcXg4ZSVCqsTqO4d3wqQPfSUeOEPHZRDLCw7F7pxMuH34I1jb8eCCE6XuCcHC6hp3770Sk3KSKcxXGVBtDFZcqL/quJEl6hcmgKCjJsXBqKRz7ERLvQdFK6kypih2eGPjWpaQQPXcuMUuXYeRgj+v4CVi/3ZTztxIYueYsN2Lu06RGGNfSNxCdGk0TjyaM8B+Bp61nwdybJEmvFBkUBU2bBhfWqQPfUVfApnjWwHevJwa+UwIDifj0U9IuXcbqzTdx/exT0u0c+XxbIGtP3qKSuzl1Ay6x6fpK0jLT6FS2EwP9BuJkIbcylyQp92RQFBY6HVz7Aw7PghsHswa+e6krvm3dH14mtFpif15O1OzZKMbGuIwZjV2XLuwKvMcnGy+QkanjwxbFuMNWNlzdgKmRKb0r9qaXby+KmMjdaSVJen4yKAqjO2fUge/ATeq4RfmW4NcdSr/5sFsqPSyMu5MmkXT4CBb+/rh9MZkYx2KMXnuWo9djaVnJjYFNbFh6eR6/3/wdJwsnBlcZTPvS7THWGBfwDUqS9DKRQVGYxYepYxjnVkFyDFg6Q6XOUKUbuFZCCEHC5i3cmzIFkZyM48AB2Pd7n0VHbzFtTxDO1mZM71wFC+twpp2cxtmos3jZejHKfxQNSzSUM6QkSdKLDIqXQWYGBP8O536FoN2gy1AHv/26QuXOaFM13Pv6G+7v3IlZmdK4Tp5MiLM3I1afITQmiYENSjHyzTIcitjHjFMzuHH/Bv4u/oypNobKzpUL+u4kSSrkZFC8bJJj4eIGOPsr3DmtbkZYuglU6caDu1bc/fIbtHfvYt+9O1ZDh/HlnzdZfSKcyu62zOhShRKOZmwK3sTcs3OJTY2lacmmjPAfgYeNR0HfmSRJhZQMipdZVJAaGOfXwoM7YG5LZum2RJ1UiNvyB8ZFi+I68TP+di7PuI0XSMvQMamNL52rlSBZm8zPgT+zLHAZGZkZvFPuHQb6DcTB3KGg70qSpEKmUAaFoihLgFZApBDiqUuXFUVpCMwATIBoIUSDnMp95YLiH7pMCN0PZ1fB5W2gTSElw4uIIxak3YnHpkVzlKFj+HBvOIdDYmhe0ZVvOlTCrogpUclRzD83n43BGzE3NqdfxX685/seFsYWBX1XkiQVEnkOCkVRej7PGwohlutRqfpAIrD8aUGhKIodcBhoJoQIUxTFRQgRmVO5r2xQ/Fvqfbi0Bc6tQlz/m5gr1kRfskYxN8flo49Y61qD73+/iqOlGdO7+FGnlLrG4nr8dWacnsFf4X/hYuHCkKpDaFuqLUYaowK+IUmSCpohgkL3n4f+uVB5ymMIIfT6yaMoiiew/RlBMRgoJoSYoE9Z/3gtguLfYkPh/BrS9v1KxB+JpESbUaSUHdqBg+l/pTjXY1MYUL8Uo98qi6mxeoreqXunmH5yOuejz+Nt603vCr1p4d0CMyOzAr4ZSZIKiiGCouS/vnUHfgV2AKuBe0BRoBvQHOgmhDiiZ8U8eXZQ/NPlVAGwBmY+q6WiKEp/oD+Ah4dHwM2bN/V5+1eLEIgbh4lf9D2R2y4jdOAYoOFCjUZMvl0V62LlmdG1CqWcrbIuF/x+83cWnF9AcFwwDuYOdC3flS7lusgxDEl6DRl0jEJRlM1AkBBi7FOe+xYoK4Ror2fFPHl2UMwBqgFvAhbAEaClEOJqdmW+di2Kp8i4dZO7n4wi8cRlzOwzcKsez1UHLzbq6lPp7T50rFPh4foKIQRHI46y4tIKDt4+iKnGlNalWtPDtwel7EoV8J1IkvSiGDooHgDthRB/POW5JsBGIcSzT+55/HpPnh0U4wBzIcSkrO8XA7uFEOuyK1MGxSP39+zh7uefkxkbh52fMUVLh5FhZMwFq7qUe/sDrCs0A6NHK7ivx19nxeUVbAvZRlpmGnWL16Wnb09qu9WWC/ck6RWnb1Bo9CwvDfU3/aepDqTrW7EcbAHeUBTFWFGUIkBN4LKByn4t2DRtSqldu7Dr1In4sxlc/9uPYF1jvBNPYr3xXdKnloM9EyBO7arztvNmYu2J7Om0hyFVhnA55jIDfh9Ax20d2RS8ifRMQ/3TSpL0stK3RTEP6At8Cqzj0RhFZ2AysFgIMUSPclYBDQGnrDImoo5JIIRYkHXNR0AfQAf8JISYkVO5skXxdEnHj3P3089Iv3kT8VYzNjraUj3zIE2Mz6BBoPi0UQ9ZKlH94WvSMtPYeX0nKy6vIDguGEdzR7qW70rncp3lOIYkvWIM3fVkASxEHbz+76ynX4H+QojUXNY1z2RQPJsuLY3oefOJWbwYjbUNB5q+x5LUIgyy/JOumr2Yah+Aew2oPRjKt37YLfXPOMbyS8s5dPsQZkZm6jiGTw+87bwL+K4kSTKEfFlwpyhKWdTuIDcgAjiW00DziyCDImepQUFETPiU1AsXyKxWk8UlG/Cb1pphDsfpY7wb8wc3wdYDag2Eqj0eOzPjv+MY9YrXo6dvT2q51ZLjGJL0EjNYUCiKYgp8C/wqhDhhoPoZlAwK/YjMTOJWriR63nwyExJI9SzNr+612WLvw0jvm/Q12on5nWNgap11ZsYAsHu0V1Rsaixrg9ay6soqYlNjKWNfhp6+PWnh1QJTI9MCvDNJknLD0F1PyairpQ8YonKGJoPi+ehSUkjYto3Y5ctJvxZCurUdm0vUZLtXLQbUMKYnOzC9sgUQ4NsWag156jjG8kvLuRZ/TY5jSNJLytBB8Tdqi2KuISpnaDIockcIQfKRI8T+vJzE/fvJNDLir2JV2FuhEd1b+9JRuxOj0z9DWkLWOMYQKN/qsXGMIxFHWHFphRzHkKSXkKGDohawChgG7BCFbMtZGRR5l37jBrErfyF2/QaU1BQuOHpxrGoT2rzfmvqpe1GOzYe4G2pXVM1BUPW9x8YxQuJDWHFJHcdI16XzRvE36FmhJzVda8pxDEkqpAwdFOGALWAJaIFI/rXPEyCEECWf9toXQQaF4WQ+eED8+g3cWfozxpF3uWdhz4UaTWkypi8+mefgyFwIO6Ke/e3f84lxjJiUGNZeXcvqK6uJTY2lrH1Zevj2kOMYklQIGToolvF4MDxBCNFH79oZmAwKwxOZmcT/8SdBcxdhe/UCKUam3KzWkFofDsbNIRGOzFPP/gbwzVqP4f7o8/a0cYxu5bvRzacbNqZ6LeKXJCmfFcrzKPKLDIr8FXXmPCemLcD99AFMdJnEVAjAd3h/7P28UI4vhFNZ4xglaj4ax8jaxvyfcYzll5bz9+2/sTezZ7j/cNqXbi+3OpekAiaDQjK4a0E32ff9QnyO/45D2gPSi3tQ4v3e2DV7E03QRjg6D+Jvgl1JqDnwiXGMyzGXmXJ8CqcjT+Pj4MMnNT+hqkvVArwjSXq95deCOz+gHGD+3+f0Obgov8igeLH+vnyHXbNXUuPUHsok3EZYW+PUtQv2Xbtgcv9MtuMYQgh239jNtJPTuJd8jxZeLRgdMJqilkUL+K4k6fVj6DEKO9SzKGr981DWn899cFF+kEHx4mXqBOtPhrFl5W4aXvyTuhEX0Gg0WDd9C4cePbFwzkQ5Ng8CN6sv8G2bNY4RAEByRjKLLy5m2cVlGGmM+KDSB/Ss0FMepCRJL5Chg2Ie0BjoBxwE2gMJqBsF1ga6CiFO5anGeSCDouAkpmmZv+8am3efomXI37QKP45JShLmlSrh0LMHNrUqoJxZkjWOcR+K+UP1flChA5gW4daDW3x/8nv2hu3F3cqdj6p/RKMSjeSUWkl6AQwdFCHA58AvQAZQ/Z9gUBRlPmAphHiuM7YNSQZFwbsVl8x3u4PYcyqUdpFn6RJ+BPOIWxg7O2PfvRt27VpiHLYLTiyG6CAwtwW/7lCtDziX42jEUb49/i3X4q9R260242qMk4v2JCmf5ccWHk2FEIey/t5CCLEv67m3gNVCCMc81jnXZFAUHqfD4vhi+yXO3oylnfYWfSKOYnL6OIqpKTatW+HYrx9mmgg4uRgubQVdBni+AdX6kFG2GWtDNjP37FxSMlLoWr4rg6oMktNpJSmfGDoorgPDhRDbFUW5DCwXQnyT9dwg4EsZFNI/hBBsOx/Bt7uucDs+hS4uWvpFnkD3205EWhq2bdviNGQIpnamcGYFnFoK8WFg6QxVexBbsR2zQzez4eoG7M3tGV51OO1Kt5PTaSXJwAwdFMuBcCHEeEVR/gd8BvyMukq7F7BVCNE9j3XONRkUhVNqRiaLD4Uy769rpGl1fFDJnm4h+0heuxohBPbvdMJxwEBMnJ0g5E+1lXF1NwgBpZtw2bcZU+4d4HTkGTmdVpLygaGDohRQTAhxUFEUE2AK0AUoAuwGhgkhYvJY51yTQVG4RT5IZfqeq6w5GY6rjTnfNXSj9G9riV+/AcXICPvu3XHs/wHG9vaQcAtOL1cHvxPvImzc2VWuPtMSrxCZGk1L75aM8h8lp9NKkgHIBXdSoXMuPJ4x685xLTKRbjU8GOtnRfLCH0nYtg2NuTkOvXvh0KcPRtbWkJkBQbvg5BK4/hfJRib85FWFn3UxGBmZ0L9yf3r49pDTaSUpDwzdoigvhLhikJrlAxkUL4/UjEym/36VRQevU9zOgqmd/PAnnqjZc3iwezcaW1sc+/bFocd7aIoUUV8UE6KOY5z5hfCMBKa5urPXROBuWYyPa4yjYYmGcjqtJOWCoYNCB9wD/gL+BP4SQoTkolJLgFZApBCiYjbXVQeOAl2EEOtzKlcGxcvn5I1YPlx3jhsxyfSu48nYZuVRrgURNXMWifv3Y+ToiNOA/th16YLGLKvVkJEKl7bAySUciTrDt46OhJgaU8e+AmPf+Apv+1IFe1OS9JIxdFC8BTTK+goAjIDbZIUGanCE6VFOfSARddbUU4NCURQj4HcgFVgig+LVlZyu5bvdQSw7fAMvJ0u+f6cyASUdSD59hqiZM0k+dgxjV1ecBg/Crn17FBOTRy++e5GMk4tZE7KVedbmpGg0dHOsyqAGU7C2KVZwNyVJL5F8G6NQFMUKqI+6UvtNoDLqeRTGer7eE9ieTVCMJGtRX9Z1MihecYdDovlo3XkiElL44A1vRr1VFnMTI5KOHiXqhxmknDuHiYcHzkOHYNOyJYrRv6bJpiUSe+ZnZgcuYYNRGvY6wQibCrSr8z80xaoU3E1J0ksgP4OiHGrL4k2gIeAAXBBC6PV/ZXZBoShKceBX1BBajAyK10Zimpavdlxm1fEwyrhYMa2zH5Xd7RBCkLhvH1EzZ5F25QpmZUrjNGwY1m+99fi4hBBcuryRKaencybzPr5paXxi5EqVgIFQoT2YWBTczUlSIWXorqe+qD+8GwFuQBBqt9OfwL7nmRqbQ1CsA6YJIY5mHZb0zKBQFKU/0B/Aw8Mj4ObNm/pWQSrE9gVFMm7DBaIS0xjcsBTDGpfB1FiD0Ol48NtvRM2aTXpoKOYVKuA8cgSW9eo9FhhCCHYGrWP6qelEapNolZjEqCQdLhU6gncj8KwHFnYFeIeSVHjkx2B2MjAfmC6EiMhDxTx5dlCE8mhnWqes9+wvhNicXZmyRfFqSUjJ4PNtgWw8fRsfNxumd/bDx03dxkNotSRs2070nDlk3L6NRUAAziOGY1mjxmNlJGck89OFRSy7uAxjoaN/wgN6xsZgqmjAzQ+8GoBXffCoBaaWBXGbklTgDB0U01BbE5WBeGA/WS0KIcTl56yYJ9mMUfzrumXIrqfX2u+X7vHJxgskpKQz4s0yDGxQCmMjDQAiPZ34DRuInr8AbWQklnXq4DxqJBaVKj1WRviDcKaemMpf4X9RwtyZj619aXD3Gsqtk+o+UxoTKFFDDQ2vBlA8AIzl2d7S6yG/Di6yRw2MhqhdUT5AJGpgvKvH61dlvdYJdbrtRMAEQAix4D/XLkMGxWsvNimdz7ZcZPv5CPzcbZnW2Y/SLtYPn9elphL36ypiFi0iMy4OqzffxHn4cMzLlX2snMN3DvPt8W+5nnCdusXq8nHVYXjHR0DoAbi+HyLOAQJMioBHbfDOanG4Vn54rKskvWrydWV2VqvgTaBr1p9CHlwk5aft5+/w6eaLJKVn8mHTsvSr542R5tHYRGZiEnErlhOzZCm6xERsmjfHadhQzLy8Hl6Toctg9ZXVzD87nxRtCt19ujPQbyDWptaQEgc3/obQ/Wp4RGWtLzW3U8c1vBqo4eFUFuTiPukVYeiup2I8GsxuDHgAOuAsjxbg7c5TjfNABsXrIepBGv/bdIHfL92jWkl7vn/HD0+nx8cXMuPjiVmylNgVKxDp6di2a4vz4MGYFC/+8JqYlBhmn5nNxuCN2JvbM9J/JG1Lt0WjaB4V9OAuhB6E0H1w/QAkZC0TsnLN6qbK+rIv+QLuXJLyR34MZgvgAo9WZ+8XQtzPa0UNQQbF60MIwaYzt5m4NRBtpmBc8/L0qFUSjebx3/K10dHELFpE3KqsnWo7d8Zp0ECMnZweXhMYE8iUY1M4G3WWCo4VGFdjHFVcnjHLO+6G2kUVekD9SopUH7f3fDS+4VUfrFzy58YlKR8YOig6orYaYg1ROUOTQfH6uZuQytgN59l/NYra3o5816kyJRyKPHFdRkQE0fMXEL9hA4qpKQ49e+LYry9GNlmzqIRgR+gOfjj5A5EpkbT2bs3IgJG4FMnmB74QatfUP8Fx4xCkJajPufg+am2UrCun4kqFmtw9VnrlCSFYcyKcL7ZfAmBCK1+6Vi/x1A0C02/cIGrWbO7v3KluPPh+Pxzeew+NhboQLzkjmUUXFvFz4M+YaB7tTmtqpMcMqEwt3D33KDjCjoI2BRQNuFWBSu+AX1co4mDQ+5ekvDJ4UCiKUhX4FHX7DjughhDitKIoXwMH5BiFVFDCY5P5eP15jlyPoUFZZ77tWBlXW/OnXpt6+TKRM2aQtP8Axs7OOA0ZjF3Hjg/3kQq/H853J79jX/g+PKw9+Lj6x9R3r/98u9Nq0+DWCTU0gvfAnTNgZAa+bSGgN5SsIwfEpULB0F1P9YA/gOtZfw4FqmUFxZdARSFEuzzWOddkUEg6nWDlsZt8s/MKJkYKk9pUoH3V4s/8AZ988iSR038g5fRpdR+pYcOwadkCRaMOaB++fZgpJ6YQmhBK3eJ1GVt9LF62Xk8tK0d3L6gHMZ1fA2n3wbGMGhh+3cCywE4QliSDB8UhIAZoh7pzbDqPgqIDMEMI4ZHHOueaDArpHzeik/hw3TlO3ozjLd+ifN2+Es7WTz/cSAhB4v79RP0wg7SgIMzKl8d55AisGjRAURQydBmsuryK+efmk6pN5V2fdxngN0CdTpsb6UkQuBlOLYNbx8HIFHzaqKHhWU+2MqQXztBBkQx0EELsztoGPINHQVEf+E0IUWC7rsmgkP4tUydYciiUqXuCsDQ14ot2FWlV+dlbjwudjvs7dxE1axYZYWFY+PvjMnoURaqp///EpMQw68wsNgVvevZ02ud1L1BtZZxbrQ6EO5YG/15QpTtYOuX8ekkyAEMHRSzwvhBi41OCogswUwjhmuda55IMCulprkU+YMzac5y7lUCrym581b4SthYmz7xeZGQQv2Ej0XPnoo2KwrL+G7iMGoW5jw8AgdGBfHP8G85FnaOiY0XG1RyHn7Nf3iqZnqwexnRqGYQfVbcU8Wmd1cp4AzR5CCNJyoGhg2Ir6gB2o6yHMoAAIcQZRVH2ANFCiO55qXBeyKCQnkWbqWPB/hBm/BGMq605s7pVxd/DPtvX6FJSiPvlF6IX/YQuIQGbFs1xHj4cU09PhBBsv76dH079QFRKFG1KtWGk/0icizjnvbKRl7NaGasgNR4cvLNaGe+ClQHKl6T/MHRQ+AF/AzeA9aizn2YDfqgn3lUXQgTlpcJ5IYNCysnpsDiGrzpDREIqY5qWZWD9Uk8s0vuvzPv3iVmyhNiflyPS07Hr2BGnIYMxKVqUpIwkFp1fxPJLyzHRmDDAbwDv+byn33TanGSkwKWtaisj7LDayijfUm1leDWQrQzJYPJjeqw/MBV1eqwR6hYeB4HRQogzeahrnsmgkPSRkJLB/zZeYMeFCOqVdmJ6Fz9crJ8+jfbftFFRRC/4kbi1a1E0GuzffRfHD97H2N6esPthTD0xlX231Om0Y2uMpb57fcNVOiooq5Xxq7oflb3no1aGdVHDvY/0WsrPE+7MUU+1ixdCJOeyfgYlg0LSlxCC1SfC+XxbIFZmxkzrXIUGZfXr1km/dYvH5PqcAAAgAElEQVTo2XNI2LoVjaUljv364tCzJxpLSw7dPsS3x7/lxv0b1Ctej4+rf5z76bRPk5EKl7fB6Z/hxkHQGEO5Fmorw7uRbGVIuWKwoFAUxRS4C/QWQmw1UP0MSgaF9LyC7z1g6K9nCLr3gAH1vRnTtBymxvr9sE29epWombNI3LsXI0dHnAYMwK5rFzKNFH698isLzi0gVZvKe77vMaDyAKxMrQxb+ehgNTDO/grJMWDnobYyqr4H1gU2p0R6CRl6jCISeE8IsccQlTM0GRRSbqRmZPLF9kv8ciwMP3dbZnfzx8Pxyf2iniXl7Fkif5hB8rFjmBQrhtPQodi2bUNMehyzTs9i87XNOJg7MKbaGFp5t3q+1d360KbBle3qWEboAVCMoFxzCOgDpRrJczSkHBk6KBYCCCH6G6BuBieDQsqLXRciGLvhPDoBX7WvSNsqxXN+URYhBEmHDxM1/QdSAwMxLVUK5xHDsX7rLS7FXOKrY19xIfoC1YpWY0KtCZSyK5U/NxETorYyzvwCydFg6wH+PdSxDFv970d6vRg6KNoDs4BjwGYgAnXb8YeEEH/mrqp5J4NCyqtbccmMWH2WUzfj6FzNnUltKlDE1Fjv1wshePDbHqJmziQ9NBTzSpVwGT0Ki1o12RC8gRmnZpCckUyvCr3oX7k/RUz0b7k8F206BO2Ak0vVQ5gUDZR6E/x7Qtlm8phX6TH5cR7F0whAQZ5wJ70CtJk6ZvwRzNx91/B2smROd3983Gyeqwyh1ZKwZQtRc+aijYigSO1aFB33CUkejvxw6ge2hGyhmGUxxtUYRyOPRjkXmBexoXD2F7WV8eAOWDqru9hW7QnOZXN+vfTKM3RQNMjpGiHEfj3rZnAyKCRDOnwtmpFrzhKfksGElj70qFXyuccXdGlpxK9eTfT8BWQmJuLYty9OgwdxJiGQL49+ybX4azQs0ZBxNcZR3Cqfu4Z0mXBtr9o1dXU36LRQopbayqjQDkwtcy5DeiUVyvMoFEVZArQCIoUQFZ/y/LvA2KxvE4FBQohzOZUrg0IytJjEND5cd46/gqJo6luU7zpVxq7I83fbaOPiiPz2OxI2b8bEwwO3zydhWrMaKy+tZP65+QghGOA3gF6+vTAxevb2IgaTGKmu/D69HGKugak1VOqohkYxf7kx4WumsAZFfdQAWP6MoKgDXBZCxCmK0hyYJISomVO5Miik/KDTCZb8Hcq3u6/gbGXGjK5VqeGVu8OHko4cIWLSJDJuhmHbtg0uY8cSZZrGtye+ZW/YXrxtvZlQawLVXasb+C6eQQj1gKXTyyFwk3rQkksFNTAqd5aHLL0mCmVQACiK4glsf1pQ/Oc6e+CiECLHdrkMCik/nb8Vz7BVZwiPTWZkk7IMaVQaoxy2/3gaXWoq0QsWEPPTYoysrHAZOxbbdm05cOsA3xz/htuJt2nl3Yox1cbgZPECd5BNTYCLG9TQ+OeQJZ9Wamh41peL+V5hr0JQfAiUF0K8n1OZMiik/PYgNYNPN19k89k71PJ2YEaXqs88RS8nqVevcnfiJFLOnKFIrVq4TZpIpntRFp1fxNLApVgYWTDcfzjvlH0Hoxe9FuLuBTi9As6vVgPEriRU7aFufy6n2b5yXuqgUBSlETAPqCeEiHnGNf2B/gAeHh4BN2/eNHxlJelfhBBsOH2bz7ZcxMxYw/fv+PGmT+72WxI6HfFr1xL5/TREejpOgwbi2K8fN1Ju89XRrzh29xgVHSsyofYEKjhWMPCd6CEjBS5vhzPLsxbzaaD0W+rajLLN4EWMp0j57qUNCkVRKgObgOZCiKv6lClbFNKLFBKVyLBfz3Ap4j596noyrnl5zIxz95t/xr1I7n39NQ9++w3T0qVwmzwZi6pV2Rm6k6knphKbGkuXcl0Y5j8MG9Pnm6prMLHX1Sm2Z3+BBxFZ02y7qV1TTmUKpk6SQeRLUCiKogF8AUfgpBAiKRcV8+QZQaEoigfwJ9BTCHFY3zJlUEgvWmpGJlN2XWHZ4RtUKGbD7G5V8XbO/Z5OD/76i7uTv0AbEYFd1y64jB5NsrnC7DOzWRO0Bnszez6s/iEtvVoafisQfWVq4dofcGYFBO0CkQkeddRWhm9bOc32JZQf24wPASaihgSoZ1CcVhRlM/CnEGKWHmWsAhoCTsC9rPJMAIQQCxRF+QnoCPzTj6TV5yb0CYqEhASio6NJT0/PqThJ0ltKRibB0alsupTAO7XL0THAPddl6ZKSiJo1m9gVKzBydMB1/His336bS7GX+PLIl1yMuUgN1xqMrzUeb1tvA95FLjy492iabWwImNlAxX+m2VaV02xfEoZecPcBMB9YAuwB1vLoKNQxQBshRI6L8vJLTkGRmppKWFgY7u7uWFhYFNxvZNIrRwjB/QdJnA26zrjf7lCrjCtftKuIlZn+23/8V8rFQCI++5S0S5exatAA188+RePmqm4FcnoGKdoU+lTowweVP8DCuMCOqlcJATcPq4FxaYs6zbZoRaj0DlTsoO5sKxVahg6Ky8BWIcTYp5yZ3RJYXJjPzA4PD8fKygp7++yPwJSk3IqNjeV48B0Gb76Jh0MRZnfzp5K7ba7LE1otsStWEjVrFigKzsOH4fDee8RkxDP95HS2Xd9GcavifFLjExqUKLDf0R6XEg8X16vbn98+pT7mXkMNDN92YONWsPWTnmDooEgFWggh/nxKUDQEdgshcjdX0AByCorg4GA8PT0xMZEzNaT8kZGRwY0bN4g1cmDE6rPEJKUxrrkPfet65qkFm37rNne/mEzS/gOY+/ri+sVkLCpU4MTdE3x59EuuJ1yncYnGjKsxDjerQvSDODZUXch3cSPcuwAo4FlPDQ2ftmDpmGMRUv7TNyj0XUkTDXg+47lywG09yykQWq0WY+PcdwVIUk6MjY3RarXU9HZk14g3aFDWhS+2X6LfzyeJvJ+a63JN3YtTYsECiv8wnYzISG6805l7U74lwNqX9a3XM9J/JIfvHKbtlrYsubiEDF2GAe8qDxy84I3RMOgQDDkODcbCg7uwfRR8XwZWdFBnUqXEF3RNJT3o26KYDzQHGqMONGcAAUA4cAjYIYQYk4/1zFZOLYrLly/j4+PzAmskvY7+/TkTQrD8yE2+2nkZMyMNo94qS8/aJTE2yv0q58yEBCKnTSd+7VqMi7nh+tlnWDdsyJ3EO0w5PoW/wv+ilG0pJtSaQDXXHH9JfPGEgHsX1VXgFzdAfBgYmarrMyp2UA9dkjOnXihDdz05AoeBEqhnUtTP+r48EAnUEUIk5KnGeSCDQioMnvY5uxGdxMStgey/GkV5V2u+aFeR6p5520cp+dQpIj6bSHpICNbNm+H6v/9h7OzMvvB9fHPsG+4k3aFNqTaMDhiNo0Uh7eIRAm6fVgMjcKO6PsPYAso1U2dPlX4LTAqsN/u1YdCup6zV0dWAb1Cns4YAxsAcoHZBhsTrRlGUHL88PT31uq5hw4YA9O7d+7HHixQpgr+/P0uWLCnYm30FeDpZsqxPdX7sEcCDVC3vLDjC6LVniXqQlusyiwQE4LVpI07Dh5H4x15CWrQkbvUaGhSvz+Z2m3m/0vvsDN1J843N+f7E90QlRxnwjgxEUcA9AJp9DaMuQe+d6jYhoQdhzXswtTRsHABX90BmIelOe4298JXZ+eF1alEcPXr0se/bt2+Pn58fkyZNeviYoij899+1du3a9O7dmwEDBjx8zMbGBl9fX3r37s3OnTvZunUrAPfu3WPmzJn89ddfrFu3jk6dOuXfDb1CcvqcJadrmfvXNRYeuI65iREfNi3HuzU98tQdlRYayt2Jk0g+fhwLf3/cPp+EWZkyhCaEsvD8QnaG7sRYMaZ9mfb0qdgn/8++yKtMLdw4oLY0Lm9T95uysAefNmpLw7OePAvcgArtFh754XUKiv/y9PSkXr16rFy5MtvrFEVh/PjxfPnll08817t3b/744w9u3br18LHExERKlChBzZo12b17t8Hr/SrS93N2PSqRiVsDORgcja+bDV+0q0BAydx3RwkhSNi0mchvvyUzORnH9/vhNHAgGjMzwu+Hs/jiYraEbAEBLb1b8n6l9/G09cz1+70w2nQI+VMNjaCdkJ4Ili7qYUsVO6pTb+XOtnmib1DoNRVIUZTszsPWAQnAKdT1FPf0q6JUmFlZWVG2bFnCwsIKuiqvHG9nK5b3rcHui3eZvP0SHecf4Z0Ad8Y2L4+Tldlzl6coCnYd2mPVsAH3pkwhZv4CHuzchevEzyhRpw6T6kxioN9AlgUuY8PVDWwN2crbnm/zfqX3KedQLh/u0ECMTdUxi3LNID0Zgveo4xmnl8PxhWDjDhXbQ4UOcjV4PtM3jhXUabANgZKAedafDQEfwAv4FLioKIqvwWspvXCZmZmEh4dTqlSpgq7KK0lRFJpXcuOP0Q0Y2KAUm87cpvH3+1hx5AaZuty18o0dHCj+3XeUWPwTQqcjrG8/wgcOIi0kBFdLV8bVGMfujrvpW7EvB28fpNO2TgzbO4zzUecNe3P5wbSI2pLovBw+ugYdFoFrRTi6ABY1gllVYe8XEKXXPqLSc9J3ccF0YAYQIIQ488+DiqIEoG7n8Tlqi2IP8BXQ3sD1zBefbwvk0p37BVoH32I2TGxdANtIP4VWqwUgMjKSr7/+moSEBCZMmFDAtXq1WZoZM655eToFFOezLYF8uiWQNSfDmdy2Iv4eudtJwKpuXby3byNuxQqiF/zI9TZtsXunE85Dh+Lo5MTIgJH0qdiHX6/8yspLK3l357vUcqtF/8r9qVa0WuHf4sbMWj2Fr3JnSIlTt0O/uAEOTYeD36sbFQb0Bt82YFLAW5y8IvRtUXyJeizpmX8/KIQ4hRoSXwohbgFTUafOSi+Z27dvY2JigomJCcWLF2fevHksWbKEmjVzPIlWMoDSLtb88n5N5nSvStSDNDrMO8y4DeeJTcrdJpYaMzMc33+fUnt+w75rV+LXrSfk7WZEL/gRXUoKtma2DPIbxJ5OexgdMJrguGD6/taXXrt7cfDWwScmQxRaFvbq7rU9N8OYIGjyOSTehU39YVp52DUOIq8UdC1fevq2KMqirs5+miigdNbfQ4CXZsVMYflNvjBwcXFhx44d6HQ6QkJCmDBhAn379sXPz4/y5csXdPVeC4qi0KpyMRqWc2HW3mCWHApl18W7fNysHF2re+Tq+FVjBwdcP52A/bvvEjltGlEzZhC3ejXOI0dg26YNliaW9KnYh27lu7Hp2iaWXFzC4L2D8XHwoX/l/jT2aIxGeUkGjK1coN5IqDMcbhyEU8vgxE9wbD6UqKW2Miq0k62MXND3E3ADeNaRpP2zngd1+/CnnkgnFW4mJiZUq1aNGjVq0K1bN3bu3IlWq2XMmAJbcP/asjIz5n8tfNg54g183KwZv+ki7ef9zbnw3G93YebtRYm5c/BY/jPGTk5EjPuE0E6dSDp6DABzY3O6le/GzvY7mVxnMkkZSYzaN4oOWzqw/fp2tDqtoW4v/2k04N0A3lkKY65A0y8hORo2D4Rp5WDnx3DvUkHX8qWib1BMBtopinJeUZSJiqIMyvrzPNAWtfsJoAnqym3pJVeuXDmGDBnCzp07OXHiREFX57VUtqg1qz6oxcyuVbibkEq7eX/zv00XiMtldxSAZY0aeK5dQ7GpU8mMjyesd++HA94AJkYmtC/Tnq3ttvJd/e9QFIVPDn5C602tWX91PemZL9l5LpZOUGcYDD0JvXdAmaZwainMrw0/vaXuN5WeXNC1LPT0XZm9CmgGJAL/A+Zm/fkAaCqEWJ116WigSz7UUyoA48aNw9LSksmTJxd0VV5biqLQtkpx9o5pQN+6Xqw5EU7jaftYfTwMXS5nRykaDbatW1Fq506cx4wm+eRJrrdpS8Tnn6ONUTsEjDRGNPdqzoY2G5jZaCa2ZrZ8fuRzWmxswS+XfyFFm2LI28x/StbutR1/gtFX4O2vITUetgxWxzJ2fAh3LxZ0LQstvTsfhRC/CyHqABaAK2AhhKgrhPjjX9ekCiHkevtXhIuLC8OHD2f79u2cOXMm5xdI+cba3IRPW/myY3g9yrhYM27jBTrMP8yFW7nfPUdjbo7TBx+oA95duhC/dh0hTd8m+seF6FLVHW81iobGHo1Z1XIVPzb5EXdrd6Ycn0KzDc1YfGExiemJhrrFF8fSEWoPUXe17bNLXadxejksqAuL3oTTKyD9uU95fqXJldmSZCAv6nMmhGDz2dt8teMKMUlpvFezJB82LYdtkbydt5J2PZTIadNI3LsXYzc3XEaOwKZ1a5T/rH4+de8Ui84v4u87f2Ntas27Pu/yns972Jrl/qCmApccC+fXwMmlEB0EpllTcAN6g1vlgq5dvsmPM7NNUbcaL4e64O7fhBDii+eupYHIoJAKgxf9ObufmsEPv1/l58M3sCtiqq7H8HdHk4vZUf+WdPw4kd9+R2pgIOa+vriMHYtlzRpPXBcYHcjC8wv5M/xPihgXoUu5LvSs0BMnC6c8vX+BEgLCj6kzpgI3gTYVivmrgVGxI5hZFXQNDcrQ24wXQz13whMQqCu1yfq7+hchctypS1GUJUArIFIIUfEpzyvATKAFkAz0FkKczqlcGRRSYVBQn7NLd+7z2ZaLnLwZh7+HHV+0q0iFYnn77V7odNzfsYPI6T+gjYjAqlEjXD76EDNv7yeuDY4L5qcLP7H7xm5MNCZ0KNOBQX6DsDd/yY8eTomD82vVVkbUZTC1Us8CD+gNxaoUdO0MwtBB8QvqWomOQBhQE3X9RF/UweumQoibepRTH3VAfPkzgqIFMAw1KGoCM4UQOa74kkEhFQYF+TnT6QQbz9zmm52XiUtOp0etkoxuWg5bi7x1R+lSU4ldvoKYH39El5qKfZfOOA0ZgrHjk+dchN0PY/HFxWy9thUrUys+qv4Rrb1bF/6V3jkRAm6dUFsZFzeCNgXcqqiBUamTulL8JWXooAgDPgTWA1qgetaqbBRF+QqoKIRoq2fFPIHtzwiKH4F9WbOsUBQlCGgohIjIrkwZFFJhUBg+ZwkpGUzfE8SKozextTBh+JtleLdmSUyN87ZoThsbS/ScucStWYPG3BzH/v1x6NUTjfmThwsFxwXz+ZHPORd1jppuNfms1md42Hjk6f0LjZR4uLBObWVEBoKJJVTqCP69oHjAS7cxoaHPzHYE7gghdEAS8O825Z+omwMaQnHU41X/cSvrMUmS9GBrYcLnbSuydWg9fNxs+HzbJZpM38/283fytC2HsYMDrp99ive2rRSpWZOoH34gpHkLErZuReh0j11bxr4My5sv59NanxIYHUiHrR1YdH4RGa/CAUQWdlDjAxj0N7y/V9299sJ6+OlNmO4DW4fDlR2v3KwpfYPiFuqqa1C36Wj6r+dqALk/Pf5xT4vjp366FUXpryjKSUVRTkZFFcITvCSpAFUsbssv79dkWZ/qFDE1YuivZ2g37zBHr+dt4wQzb29KzJuLx88/Y+zgwJ2Px3Kj0zskHTv+2HUaRUPncp3Z0m4L9d3rM+vMLDpv78zZyLN5ev9CQ1HAvRq0nauu/m43H0rUVLumVneHb71gZUc4vgjicuyVL/T07XpaAKQIIUYpijIIdcHdH0AG8DbwoxBiiF5vKLuepFdUYf2cZeoEG0/fYtqeq9y9n0oTHxfGNitPmaJ561sXOh33t28n8ocZ6oB348a4fDjmqQPe+8L38dWxr7iXdI/O5Tozwn8E1qYvb9/+M2nTIewIXP0Nru6C2Ovq4y6+UPZtKNsM3KsXmlP6DD1G4QQ4CCGuZn0/DHUQuwiwG5gshNCrVZFDULQEhvJoMHuWEOLJeXn/IYNCKgwK++csNSOTJX+HMv+vEJLStXSpXoKRTcpS1ObJcYbnoe+Ad1JGEnPOzOHXK7/iaO7IJzU/oYlHk5d/sDs70dfg6m71K+wI6LTqjrel31KDo/Sb6vcFxNBBYQukCiFyfyK8Ws4q1PEMJ+AeMBEwARBCLMiaHjsHdbuQZKCPEOLZCZBFBoVUGLwsn7PYpHTm/HmNFUdvYKzR8P4bXvSv7421ed5mSGljYoieO08d8DYzw6FPHxz69MHI6vENpQOjA5l0ZBJXYq/Q0L0h/6v5P9ys3PL03i+FlHj1aNfgPepXcgwoRuBR+1Frw6nMCx0QN1hQKIpijDoG0V4Isc1A9TMoGRRSYfCyfc7CYpKZuieIbefu4GhpyogmZehWwwMTo7zNkEoLDSVqxkwe/PYbRg4OOA0ahH2Xziimpg+v0eq0/HL5F+aenQvAsKrD6F6+O0aFpEsm3+ky4faprNbGb3Ava58pey81MMq+DSXrqsfB5iODzXoSQmhRf/vPNETFJMNYtmwZiqI8/LK0tMTT05P27duzdu1adP+ZifLvazUaDU5OTrRt25bAwMCH10yYMOGx6571ZWxsrNd1hw4d4tq1a489ZmRkhJubGz169OD27dt636++dVuxYgWKorBx48ZnltWtWzdsbGxISXnJNrYzMA/HIszuVpUtQ+pS2sWKz7YE0vSHA+y6EJGnGVJmXl64z5yB59o1mJUpw72vviKkZSsStm1/OEPKWGNMrwq92NR2EwFFA/juxHd039mdyzGXDXV7hZvGCErUgDc/U2dQjbwILaepLYqTS2BFO/jOC9a8B2dWQmJkgVZX366nb4EyQogO+V+l5/c6tiiWLVtGnz59WLduHe7u7qSlpREWFsaOHTtYt24djRo1Ytu2bVhYqIe0KIpC7969GTBgAFqtlvPnzzNx4kTMzc25cOECdnZ23Lp1i1u3bj18j61bt/LNN9+wceNG3NwedQ0oivLYD5Iff/yRZcuWceTIkcfqWKFCBe7du0eZMmWYMGECLVu2JC0tjSNHjjB58mQqVKjAkSNHMDbO+fwsfevm5eWFj48PDRo0YNOmTU+Uc//+fVxdXenWrRuLFy/W47+0/l7mz5kQgr+CIvlm5xWCIxPx97DjkxY+VPd0yHO5SYf+JnLaNNKuXMHMxweX0aOxrFf34diEEILfbvzGlONTiEuLo4dPDwZXGUwRkyKGuLWXT3oShB541Np4kDWXp3jAo9aGa2WDdFHp26JACJHjFzAIdX3DCWAC0A91VfbDL33Kya+vgIAAkZ1Lly5l+/zLaOnSpQIQwcHBTzy3fv16oSiKGDp06MPHADF+/PjHrlu5cqUAxKpVq576HosWLRKACA0NzbYu48ePF+pH6UnBwcECEEuXLn3s8UmTJglAnDhxItuynyW7ug0cOFCYmpqK6OjoJ5776aefBCD279+fq/fNzqvwOcvQZorVx2+K6l/+LkqO3S4++PmECL73IM/l6jIzRfzWrSK48ZviUrny4kav3iL5/PnHrolPjRcT/54oKi6rKJquayr2hxv+3+ilo9MJceecEPu+E2JhYyEm2gox0UaI78sJsXW4EJd3CJGWmOvigZNCj5+x+nZGzkVd+BaAeojRIuCnf30t0rMc6QXo2LEjbdu2ZdGiRSQnP/tQFn9/fwDCwsJeVNVeyHv36tWL9PR01qxZ88Rzy5cvx9PTkzfeeMPg7/sqMDbS0KW6B/s+asiHTctyOCSGt2ccYPymC0Q+yP1yKfUMjNZ479pJ0f/9j7SgIG6805lbI0eRfuMGALZmtkyqM4llzZZhbmzOkL1D+Gj/R0SnPOsU5teAoqi71zb4CD7YCx9ehbbz1Cm2F9bD6m7w+8R8r4a+QeGVw9eTE6elAtWiRQvS0tLIrkvuRtb/oKVKlXpBtXox712rVi3KlSvHihUrHnv85s2bHDx4kJ49e77aUzINoIipMUMbl2HfRw15r6YHa06E03DqPmb8cZWktNwfi6oxNcWhZw9K/b4Hp8GDSTxwgJCWrYiYNImMSLUfPqBoAOtar2NIlSHsDdtLm81tWHd1HTqhy6H014CVC1R9F7qsgI9DocdmqNY33982585hQOix4d9Ladc4uHuhYOvgWgmaTzF4sR4e6t46ERGP1ioKIdBqtWRmZnL+/Hk++ugjatWqRZs2bQz+/v+l0+nQarWkpaVx9OhRvvnmG7p06YKfn1++vF/Pnj0ZP348wcHBlClTBoAVK1YghKBnz5758p6vIicrMz5vW5Hedb2Y+tsVZvwRzMqjYYx6qwxdqpXAOJczpIysrHAePgz77t2InjefuLVrSdiyFYdePXHs1w9Ta2sG+g3kbc+3mXxkMpOPTGZ7yHYm1p6It538vRRQZ0SVavRC3uq5/pUVRamsKMrQrPOyXbMeK60oyiu4xPLlJrIGm//9m/PXX3+NiYkJ5ubm1KhRg6SkJLZu3YqJSd7mz+ujX79+mJiYYGVlRZMmTXB3d+fnn3/Ot/fr0aMHGo3msVbFihUrqFu3boG0oF52Xk6WzHs3gI2D6+DlVITxmy7SdMYB9gTezdseUk5OuH72KaV2bMe6USNiFvxIyFtNiVm2DF16Ol62Xix5ewmT60zmWvw1Om7ryJwzc0jLzNOSLul56TOQAZgB61CnyOqy/vTPem4jMEWfcvLrSw5mP2nhwoUCEAcOHBBCqIPZffv2FSdOnBAHDx4UkyZNEhqNRjRu3FjodLqnlmHIweyJEyeKEydOiH379olBgwYJ/t/emcdVWXQP/HsuICDuihsKmOZe+qqZ9rPM1x0XNJdwN31VLG2xxdwCzTLrbS9zTXPJNVRMRXPXhF7NzH1NxS0Vd0WuAvP747kSIMsF7r1s8/18ng/3zjPPzBkY7rlzzsw5oAYNGmT9gDMhW/PmzVWlSpVUfHy8Cg8PV4CaPn16pvtMj7w4z1IiPj5erTtwUTX772blM/Jn1fW7X9XvZ67ZpO3o/QfUmZcGqEPVqqvjzf6tri9fruJjY5VSSkVFR6mR20aq2nNqq/Yh7dX/Lv7PJn3mZ7CxM/sDoAXQByhD0uB9azHiPWlyEKtXr6mSD3cAACAASURBVMbNzY369esnlJUrV44GDRrQpEkTgoKCGDduHJs2bWLZsmV2l8fX15cGDRrQtGlTpkyZQq9evZg5cyZ79qSblyrT9OvXj1OnTrFjxw7mzZuHm5sb3bt3t1t/+QURoVWtsqx//Tk+6FybU1HRvDBlJ0Pn/86pqKxFTXWvXQvv72fh/f0snIoX5+K7ozjV+QXubN1KCbcSfPTsR0xrMY0H8Q8YsG4A434dx42YGzYamSY1rFUUPYCxSqkfgWvJ7p3CyHynySGEhIQQGhpKYGAgBQumvhd95MiRlC9fnvHjx2fJfJAZJk+ejKurK+PHj7dbH126dKFQoULMmjWLxYsX4+/vT9GiuTivcw7D2clEr6d92Pr287zRoipbj12h5WdbeW/lAW7FZC2kuMczz+C7dAlen31KfEwMZ4cEEtmnL/f27uUZr2dY7r+cAbUHsOrkKjqu6Miqk6scPofzExnJR5HakUkThmlKkw3s3buXiIgItm3bxvz58wkICKBbt260bNmSSZMmpfmsu7s7o0eP5uDBg2meZLYHXl5eBAYGEhoayt699gk9XbBgQbp27crcuXO5evUq/fr1s0s/+R0PV2dea2HskApoWJH5EWdo+8V2fstiSHMxmSji50fln1dR5r1xmE+f5nRAD84NH44p8iJv1H+Dxe0XU7FwRUbvGM2QX4Zw+uZp2wxKkwRrFcUpoHEq9xoCR20jjiajdOvWjcaNG9O6dWvGjBmD2Wxm0aJFhIWF4ZZC9rHkDBo0CB8fHyZOnOjwb2SjRo3Cw8OD999/32599OvXD6UUZcuWpVWrVuk/oMk0pQu7MbHTEywNfAZnJyFgRgSTw45wPzZr21qlQAFK9OxJlXVhlHp1OHd/3clf7Ttwcdx7PPagGHPbzmVUw1Hsi9qH/0p/3tn2DsevH7fRqDRgfQiPUcBoIBDDeX0X4/BdMYz0qMFKqa/tKGea5McQHpqch55n/3DHHMv7qw6xePdZansV4YsX/0WV0oVs0nbstWtETZ3K9YWLEJOJEn37UPI//+F6gQfMPTSXxUcWEx0bTbOKzRj85GBql3oko4HGgq3DjDsBC4DugBnD1HQPcAMWKaV6ZU3crKEVhSYnoOfZo4Qd+JtRIfu49yCOMX416N3Ix2aHHe+fO8eVr77i1qqfMRUpQqnBgyjeqxe3xcyCwwtYcHgBt+7f4pnyzzDoiUE0KJt+SKP8hk0VRaJGn8XY4VQauAqEKaW2ZlpKG6EVRe4nLi4uTdOXyWTCZMpa+Gt7o+dZyly6FcNbS/9k+/EomlXz5OOudfAsbDu3Zszhw1z+7HPubt+Oc/lylH7jDYq0a0d03D0WH13MDwd/4FrMNeqVrsfgJwfzTPln9Ml8C3ZRFDkVrShyP02aNOHXX39N9f7AgQOZOXOmAyXKOHqepU58vGJu+Gk+XHuEwq7OTO7yJC1qlrFpH3cjfuPyxx8Tc+gQbrVqUXrkO3g0bMi92HuEHA9h9oHZXIq+RK2StRj05CCaVWyGSXL2lw97Y2vT0x5gLrBQKXXJBvLZFK0ocj9Hjx7l9u3bqd739PTEx8fHgRJlHD3P0ufYpdu8tmgvhy/eoufT3oxtV4OCBayKJGQVj+Txbt6c0m++ietjlXgQ94DQk6HMOjCLs7fPUqVYFQY9MYjWvq3zT8KkZNhaUawFmlvebsBQGiuUlXmy7Y1WFJqcgJ5n1mGOjeOz9ceYvv0vfEt68MWLdalTsZhN+4iPieHaD3O5On26JY/3i5Qa9grOJUoQGx/LutPrmLFvBidvnsS7sDcDnxhIh8c64OJk/3A2OQmbm55EpDTQE+gN1ANuY+x4mq+U2pwFWbOMVhSanICeZxlj58ko3lzyJ5dvm3m9+eMMfb5ypoMMpkbs1atc+eYbbixZisndnZJDBlOib19Mrq7Eq3g2R25m+v7pHLp6iLIeZXmp1ku88PgLuDmnv7U8L2BXH4WI1MAI59ETqAicU0pZZRcQkTbAl4ATMFMp9VGy+97ADxhbb52Ad5VSa9JqUysKTU5Az7OMczP6AWNXHmDVnxeo71Ocz7vXxbuk7TPbmU+e5PJ/P+XO5s0Wh/cIirTzQ0wmlFL8euFXZuybwZ7LeyjpVpJ+tfrRvVp3PFw8bC5LTsLuzmwRcQO6AB8B5ZVS6Rr5LNtsjwEtgXMYGfN6KKUOJaozHfhDKfWdiNQE1iilfNNqVysKTU5Az7PMoZRi5d4LjFtxAAUEd6xFl3pedtmZdDcigksff4z50GHcatemzMh3KPjUUwn3d/+9m+n7phN+MZwiBYrQu0ZvetboSVHXvBn6xVpFkeF1noj8W0RmA5cwfBXngOFWPt4QOKGU+kspdR9YBPgnq6OAIpbXRYELGZVRo9HkHkSETv/yYu3rz1KzfBHeWvonr/y4h+t379u8L49Gjai0bBnlJ39EbFQUZ/r05eywYZhPnQKgQdkGTG81nYXtFlK/TH2m/DmF1j+15vPfP8/XmfasdWbXxvBN9MRIiXoGmA/MU0pZfVZeRLoCbZRS/7G87wM8rZQalqhOOWA9UBzwAFoopX5Pq129otDkBPQ8yzpx8Ypp207y2fpjlCxUgE+71aXJ46Xs0lf8vXv/OLzv3//H4V28eEKdY9ePMXPfTNadWYeLyYWuVbvSv1Z/ynqUtYtMjsbWK4p9wBAgDHheKfWYUuq9jCiJh3KlUJZcU/UA5iilKgB+wDyRRzc7i8hgEdktIruvXLmSQTE0Gk1OxMkkvPx8FVa88n8UcnWm96zfeP/nQ8Q8iLN5XyZ3d0oFDqHy+nUU69qF64sWGUmTZs4k3mwkRqpavCofN/2Y0E6h+FXyY/GRxbQNaUvwzmDO3jprc5lyKtauKLoBoUqpLKWVEpHGGHGhWlvejwJQSk1KVOcgxqrjrOX9X0AjpdTl1NrVKwpNTkDPM9ty734cH645zLyIM1QvW5gvAupSvWyR9B/MJOYTJwyH95YtuJQvj+eIERTxa4skighw4c4FZh+YTcjxEGJVLG0rteU/tf9DleJV7CaXPbHpikIptTQ1JSEiTUXkeyvl2gU8LiKVRKQAEACEJqsTieXMhmV3lRuglwzJmDNnDiKScHl4eODr60vnzp1ZsmQJ8fFJI3YmrmsymShVqhT+/v4cPHgwoc7YsWOT1EvtcnZ2tqrejh07OHHiRJIyJycnypUrR58+fTh//nyGx12hQgX69++fpCwuLo7evXvj5OTE7NmzAZg5cyYiwunTpzPchyZn4F7Aifc71WZ2/6eIumOm49e/MnP7X8TH2yeahGuVKlSc+h3es7/HVLQoF956i9MvBhCd6Eto+ULlGdNoDGFdwuhbsy+bIjfRObQzb2x+g6PX8m4Q7UwdiRSRKkBfjC2yPkA0MCC955RSsSIyDFiHsfX1e6XUQRGZgJGSLxR4E5ghIm9gmKX6q7wQZ8ROLF26lAoVKmA2m4mMjGT16tX06NGD6dOns2rVKtzd3RPq9u/fnyFDhhAbG8u+ffsICgqiTZs27N+/n2LFihEYGEj79u0T6oeGhjJp0iRCQkIoV65cQrmIJInLNG3aNObMmUN4eHgS2WrVqsWlS8ZB/rFjx9KuXTvMZjPh4eFMmDCBI0eOEB4ejrNz5k/mPnjwgF69ehESEsLcuXPp1Stb41Nq7ECz6qUJe/053v1pPxNXH2bz0ct82q0uZYva56yDR+PGVPppGTdDQ7ny+Rec6d2Hwi1b4DliBK6VKgHgWdCTNxu8ycDaA1lwZAELDi1gQ+QGWni3ILBOINVKVLOLbNmGNflSLR8KRYHBwA6MnNlxwB4M30URa9uxx6VzZidl2bJlSkTUsGHDEsoANWbMmCT15s+frwC1cOHCFPuwZc7s2bNnJykPDg5WgNq1a1eabSfHy8tL9evXTymllNlsVv7+/srFxUUtXbo0U7Lbkrw4z3IS8fHx6sffzqjqY9eqJ4PXqdX7Lti9z7joaHXlu+/UkX/VU4dq1VYX35+oHlx7ND/4TfNNNeWPKarxgsaq9pza6vVNr6sjV4/YXb6sgi1yZouISUT8RGQRcBGYipH29FtLldeVUtOUUrdsqbw0WaNLly74+/szY8YMoqOjU61Xr149ACIjIx0lms36jomJoVOnToSFhfHTTz/RtWtXW4qnyYGICD0aerP61Sb4lizIywv28OaSP7mdxbSraWE4vAMNh3eXLlz/8UdOtmrN1VmzEhzeAEUKFGFo3aGEdQ3j5Tov89vF3+i6qmueMUmluuYXkf8CvTBCiscAyzFOTG/AOOcwLLVncwuT/zeZI9eOZKsM1UtUZ2TDkTZv18/PjxUrVrB7926ee+65FOs8tN9XrlzZ5v2nR1b6jo6Opn379uzcuZPQ0FCduS6f8ZhnIZYNfYavNx7nm80n+N/pq3zevS4NfEvYrU/nUqUoNz6YEn16c+mTT7j8yX+5vuBHw+Hdzi/hcOBDhdGrZi8WHFrAvEPz8oRJKq0VxQgMJbEG8FZK9VJKrVdKxfPollZNDsPb2xuAixcvJpQppYiNjcVsNrNr1y7efvttGjVqRMeOHe0uT3x8PLGxsdy9e5eNGzcyadIkXnzxRerUqZPhtpYuXcrGjRuZOnWqVhL5FBcnEyNaVWNpoJGhufu0cD5df5QHcVlLu5oerlWq4D1tGt7fz8JUpMg/Du/fkx71SrzCGFpnaO5fYaRmkwJmAjeAeCAK+AZoqP7xV8QDz1lj37L3pX0Uj7J27VoFqMWLFyulDB9F8svX11ddvnw51T5s6aNIfj311FMqJibGusEmwsvLSzVq1EiVLFlS+fr6qsjIyCzJbkvy4jzLDdy6d1+9tWSv8hn5s2rzxTa169RVh/QbHxurrocsV8eea6oOVauuzr3xhrp/IWW/yU3zTfXtH9+qRgsa5SgfBln1USjj9HRZjBPZv2Pkyw4XkcPASPSqIkdz9qxxGCjxbqUBAwawa9cutm/fTnBwMJGRkQQEBKSZWc5WBAUFsWvXLrZs2cLQoUPZtWsXw4dbG/klKdWqVWP9+vXcuHGD5s2bJ1k1afIfhd1c+KRbHab1qc+N6Pt0nRrOW0v/JOpOlo59pYs4OVGscycqh62l1CuvcHvjJk629ePKlCnExyTNwFCkQBFervsyYV2MFUbExQi6rurKiC0jcsUKI01ntlIqRin1ozIOyFUERmPsdnoX45T1RyLS2xIgUJODWL16NW5ubtSvXz+hrFy5cjRo0IAmTZoQFBTEuHHj2LRpE8uWLbO7PL6+vjRo0ICmTZsyZcoUevXqxcyZM9mzZ0+m2qtXrx5hYWH8/fffNG/eHH06X9O6Vlk2vtmUoc9XZuXe8zT77xbmhp8mzk7nLh5icnfHc/gwKq9ZTaGmTYn66mv+ateeW+vXP/IlrKhr0SQKI/xCeK5QGFYHBVRKXVRKTVZK1QaeBqYAj2MEBtRf6XIQISEhhIaGEhgYSMGCqYdsHjlyJOXLl2f8+PEOWVUkZvLkybi6ujJ+/PhMt/H000+zZs0aIiMjadGiBdeuXbOhhJrcSMECzoxsU521rz3HkxWK8t7Kg3T8Zge/n7lu975dvLyo8OUXeM+Zg8nDg/OvvkbkSwOIOXbskbq5TWFkKkuIUmqXMgL5lQe6AlttKpXGavbu3UtERATbtm1j/vz5BAQE0K1bN1q2bMmkSZPSfNbd3Z3Ro0dz8OBBQkJCHCSxgZeXF4GBgYSGhrJ3795Mt9OkSRNCQ0M5fvw4rVq14ubNm0nur127lmXLliW5NmzYkFXxNTmcKqULMX/g03zT819E3THT5budvLPsT67a2RwF4NHoaSqF/ESZcWOJOXyYU51f4O+JHxCXbG5CUoURWCcw5yoMaxwZOf3Kz87sh5ebm5vy9vZWnTp1UkuWLFHx8fFJ6pPCgTuljENrPj4+qm7duo88Y88Dd0opdenSJeXh4aFeeOGFtAebiMQH7hITFhamXF1dVePGjdXt27cTZE/pqlOnjtX9ZYS8OM/yArdjHqgPVx9SlUetVk8Gr1Pzwk+r2Lj49B+0AQ+uXVMXgoPVoRo11dGnG6lrCxep+NjYVOvfiLmhvvnjmwSn9xub37Cr0xsrndmZTlyUk9BBATU5AT3PcjbHL91m3MoDRPx1jSe8ivJ+p9rUtXGu7tSIOXKESx98SPSuXbjWqEHZMaMp2CD1WHw3zTeZf3g+8w/N586DO7T0acmQJ4fY/ByG3TPc5SS0otDkBPQ8y/kopQj98wIfrD7MlTtmAp6qyDutq1Pco4BD+r4dFsaljz8h9uJFivj5Ufrtt3BJtDMxOSkpjMA6gVQtXtUmMmlFkQj9D5zziYuLS9OhbjKZMJky5VJzGHqe5R5uxzzgyw3Hmb3zNIXdnHmndXUCnqqIyWT79KvJib93j6szZnJ11iwwmSg1eBAlXnoJk1vqm0ftpTDslgpVo7EHTZs2xcXFJdVr8ODB2S2iJg9R2M2Fse1rsubVZ6lapjCjl++n85Rf2Xfuht37Nrm74/nqcB5bvZpCzz3HlS+/MrbT/vJLql+WiroW5ZW6rxDWJYwhTw4h/EI4XUK7MGLLCI5df3RXla3RKwpNjuDo0aPcvn071fuenp74+Pg4UKKMo+dZ7kQpxYq95/lg9RGu3jXTs6E3b7euRrGC9jdHAdyN+I1LH3yA+fhxCjZuRNnRo3F9/PE0n7lpvsm8Q/NYcHgBAdUDeK3ea5nqW5ueEqH/gTWOQM+z3M2tmAd8/ssxfth5mqLuLrzbtjrd6jvGHKViY7m+aDFXvv6a+Dt3KN6zJ57DXsGpaNE0n7tpvolJTBQuUDhT/WrTk0aj0WSAIm4uBHWoxc/Dn6WyZyFG/rSfLlN3cuD8o+cfbI04O1Oidy8qh62lWPduXF+wgJNt2nJ98RJUXOr5wou6Fs20ksgIWlFoNBpNImqWL8LSwMZ82q0OZ69F0/GbHby38gA3o+2X9+IhzsWLUy4oiEohP+FauTJ/BwVxqlu3R6LTOhqtKDQajSYZIkKX+hXY+Obz9Gnkw/yIM/z70y0s3X3Wbjm7E+NWvTre8+bi9dmnxF2/wZlevTn/5ls8+Ptvu/edElpRaDQaTSoUdXdhvH9tQoc1wadkQd5eto/u08I5dMH+ST1FhCJ+flRes5pSL7/M7Q0bONnWj6ipU5Nk13MEWlFoNBpNOtT2KsqywGf4uOuT/BV1l/Zfbyc49CA379nfHJVkO+2zz3Lliy/5q117bm/Y4LBgng5XFCLSRkSOisgJEXk3lTrdReSQiBwUkR8dLaNGo9Ekx2QSujeoyKY3m9LzaW9+CD9N80+3ErLnnEM+sAtU8KLCV1/iPWc2Jnc3zg0bztmBAzGfOGH3vh2qKETECfgWaAvUBHqISM1kdR4HRgH/p5SqBbzuSBlzC3PmzEFEEi4PDw98fX3p3LkzS5YsIT4+aUrIxHVNJhOlSpXC39+fgwcPJtQZO3ZsknqpXc7OzlbV27FjBydOnEhS5uTkRLly5ejTpw/nz5+3+e9lw4YNiAhbtmxJs15sbCwiwsSJExPKlixZwgsvvICPjw8FCxakevXqjBkzhjt37thcTk3upVjBAkzs9AShrzTBq7g7I5b8yYvTIjh2KfVzQLbEo1EjKi1fTpmxY7l34CA3V6ywe5/Odu8hKQ2BE0qpvwBEZBHgDxxKVGcQ8K1S6jqAUuqyg2XMVSxdupQKFSpgNpuJjIxk9erV9OjRg+nTp7Nq1Src3d0T6vbv358hQ4YQGxvLvn37CAoKok2bNuzfv59ixYoRGBhI+/btE+qHhoYyadIkQkJCkmTKE5Ek36CmTZvGnDlzCA8PTyJbrVq1uHTpEmAooXbt2mE2mwkPD2fChAkcOXKE8PBwnJ0dPQ3B2dmZ8PBwKlasmFD2ySefULlyZSZNmoSXlxd79uwhODiYrVu3sm3bthwfQkTjWJ6oUJTlQ59h8e6zTA47gt+X2xn03GO8+u/HcS/gZNe+H26nLdLOD3FxwMFAa0LM2urCyF0xM9H7PsA3yeqsAD4GfgUigDaptDUY2A3s9vb2TjOUbl4M/5xWzuxly5YpEVHDhg1LKCOFMOPz589XgFq4cGGKfdgzzHhwcLAC1K5du9JsO6P88ssvClCbN2/O8LMp5Q+fNWuWAtTWrVvTfT4vzjONdUTdjlEjFht5u5tM3qg2HbmU3SJZBVnNmW0nUjrimNy454yROe95oAcwU0QeiQWslJqulGqglGrg6elpc0FzM126dMHf358ZM2YQHR2dar169eoBEBkZ6SjRstx3bGwsH374ITVq1MDV1RVPT0/atm3LsWRZxO7evcvQoUMpWbIknp6e9O3bN0lSo5RMTynNo6eeegrALmYyTd6hZCFXPu1eh4WDGuHiZOKl2bt4ZcEeLt2KSf/hXICjFcU5jNzbD6kAXEihzkql1AOl1CngKIbi0GQAPz8/zGYzaYU2OX36NACVK1d2kFRZ77tr164EBQXRoUMHVq5cyYwZM6hWrRp/J9tfPnz4cAoUKMDChQsZO3YsS5YsYcSIERmWc+tWI3mjDs2hsYbGlUuy9rVnGdGyKr8cvkSLT7fyw0775+22N442Du8CHheRSsB5IADomazOCoyVxBwRKQVUBf6yhzB/f/gh5sNH7NG01bjWqE7Z0aNt3q63tzcAFy/+k85cKUVsbCxxcXHs27ePt99+m0aNGtGxY0eb95+c+Ph4YmNjMZvNREREMGnSJF588UXq1KljdRvr169n5cqVfPvtt7z88ssJ5Z06dXqkbrNmzfjyyy8BaNWqFYcPH2bevHnMmjXL6v7Onj1LcHAwbdq0oW7dulY/p8nfuDo78Wrzx+lQpzzjVhwgKPQgP+05x4edn6C2V9qxm3IqDl1RKKVigWHAOuAwsEQpdVBEJojIw0+rdcBVETkEbAbeVkpddaSceQFlcTaL/GPt+/DDD3FxccHNzY2GDRty9+5dQkNDcXFxsbs8AwcOxMXFhUKFCtGiRQsqVKjADz/8kKE21q9fj8lkYuDAgenWbdeuXZL3TzzxBNHR0URFRVnV161bt/D398fNzY3vv/8+Q3JqNACVSnkwb2BDvgyoy4Ub9+j4zQ4mrDrEHXNsdouWYRy+3UQptQZYk6zsvUSvFTDCctkVe3yTzymcPXsWIMlupQEDBjB06FBiYmLYuHEjEyZMICAgIGFLqT0JCgqiffv23L17l8WLF/Pdd98xfPhwpk+fbnUbV69exdPTE1dX13TrlihRIsn7h8/ExKRvM46OjqZDhw6cOXOG7du3J/kdajQZQUTwr+vF81VL8/G6I8zeeYq1By4S1KEWrWuVsfv/na1w/L5EjUNYvXo1bm5u1K9fP6GsXLlyNLDk6W3SpAlKKcaPH8+yZcvo1q2bXeXx9fVN6Ltp06bcunWLmTNnEhgYmODYTo9SpUoRFRWF2Wy2Sllkhvv379O5c2f++OMPNm7cSM2aNdN/SKNJh6IFXfig8xN0qV+B0SH7CZz/O82rl2a8fy0qFC+Y3eKli94YngcJCQkhNDSUwMBAChZMfRKOHDmS8uXLM378eIeFAnjI5MmTcXV1Zfz48VY/06pVK+Li4uxmCoqLiyMgIIDt27cTGhqasONJo7EV9byLs2p4E0b7VWfnyau0/Gwb07ae5EFcfPoPZyN6RZHL2bt3L1FRUdy/f5/IyEh+/vlnli5dSsuWLZk0aVKaz7q7uzN69GiGDRtGSEgIXbp0cZDU4OXlRWBgIF988QV79+61ylncsmVLOnXqxGuvvcaZM2do1qwZ9+/fZ8uWLXTq1Ilnn302SzIFBgayfPly3nvvPdzc3IiIiEi4V7FiRby8vLLUvkYD4OJkYvBzlfF7ohzBoQeZtPYIy/84zwedn6C+T/HsFi9F9Ioil9OtWzcaN25M69atGTNmDGazmUWLFhEWFoZbGsnaHzJo0CB8fHyYOHGiw1cVo0aNwsPDg/fff9/qZ5YsWcK4ceP46aef6NChAwMGDODo0aOULVs2y/KsXbsWgAkTJtC4ceMk1+zZs7PcvkaTmArFCzKjbwOm9q7PjegHdJ26k9HL9zsk70VG0alQNRoboeeZJrPcMcfy+S/HmP3rKUp4FGBc+5p0rFPe7s5unQpVo9FocgmFXJ0Z174mocOa4FXMndcW7aXPrP9xOupudosGaEWhySHExcURGxub6pU8Gq5Gkxep7VWUkJf/jwn+tfjz7A1afbGNrzYexxybet5sR6AVhSZH0LRpU1xcXFK9Bg8enN0iajQOwckk9G3sy4Y3m9KyZhk+++UYbb/cTvjJ7Dt3rHc9aXIEs2bN4vbt1OP568CPmvxGmSJufNuzHt3qX2bcygP0mBHBC/W8GONXg5KF7HOOKDW0otDkCKpVq5bdImg0OZLnq5Vm/etN+XrTcaZv+4tNRy4zqm11utWviMnkmJPd2vSk0Wg0ORz3Ak6806Y6a157lqqlCzPyp/0ETHdcVr18oyjywjZgTc5Fzy+NI6hapjCLBjfi4y5Pcuzybfy+3M7M7XYJrp2EfGF6cnFx4d69e2mGs9BossK9e/ccEoVXozGZhO5PVaR5jdJ8uOYIPiU97N5nvlAUpUuX5vz583h5eeHu7p5rIjZqcj5KKe7du8f58+cpU6ZMdoujyUc8zKrnCPKFoihSpAgAFy5c4MGDnHc8XpO7cXFxoUyZMgnzTKPJa+QLRQGGstD/yBqNRpNx8o0zW6PRaDSZQysKjUaj0aSJVhQajUajSROtKDQajUaTJlpRaDQajSZNtKLQaDQaTZrkiQx3InIFOJPJx0sBUTYUJzegx5w/0GPOH2RlzD5KqXRDM+cJRZEVRGS3NakA8xJ6zPkDPeb8gSPGrE1PGo1Go0kTrSg0Go1GkyZaUcD07BYgG9Bjzh/oMecP7D7mfO+j0Gg0Gk3a6BWFRqPRaNIk3ygKEWkjQtTzwAAACG1JREFUIkdF5ISIvJvCfVcRWWy5/5uI+DpeSttixZhHiMghEdknIhtFxCc75LQl6Y05Ub2uIqJEJNfvkLFmzCLS3fK3PigiPzpaRltjxdz2FpHNIvKHZX77ZYectkJEvheRyyJyIJX7IiJfWX4f+0Sknk0FUErl+QtwAk4CjwEFgD+BmsnqvAxMtbwOABZnt9wOGHMzoKDl9dD8MGZLvcLANiACaJDdcjvg7/w48AdQ3PK+dHbL7YAxTweGWl7XBE5nt9xZHPNzQD3gQCr3/YC1gACNgN9s2X9+WVE0BE4opf5SSt0HFgH+yer4Az9YXi8DmkvuToWX7piVUpuVUtGWtxFABQfLaGus+TsDvA98DMQ4Ujg7Yc2YBwHfKqWuAyilLjtYRltjzZgV8DABTVHgggPlszlKqW3AtTSq+ANzlUEEUExEytmq//yiKLyAs4nen7OUpVhHKRUL3ARKOkQ6+2DNmBMzEOMbSW4m3TGLyL+Aikqpnx0pmB2x5u9cFagqIr+KSISItHGYdPbBmjEHA71F5BywBhjuGNGyjYz+v2eI/JLhLqWVQfLtXtbUyU1YPR4R6Q00AJraVSL7k+aYRcQEfA70d5RADsCav7MzhvnpeYxV43YRqa2UumFn2eyFNWPuAcxRSn0qIo2BeZYxx9tfvGzBrp9f+WVFcQ6omOh9BR5diibUERFnjOVqWku9nI41Y0ZEWgBjgI5KKbODZLMX6Y25MFAb2CIipzFsuaG53KFt7dxeqZR6oJQ6BRzFUBy5FWvGPBBYAqCUCgfcMGIi5VWs+n/PLPlFUewCHheRSiJSAMNZHZqsTijQz/K6K7BJWbxEuZR0x2wxw0zDUBK53W4N6YxZKXVTKVVKKeWrlPLF8Mt0VErtzh5xbYI1c3sFxsYFRKQUhinqL4dKaVusGXMk0BxARGpgKIorDpXSsYQCfS27nxoBN5VSF23VeL4wPSmlYkVkGLAOY8fE90qpgyIyAditlAoFZmEsT09grCQCsk/irGPlmD8BCgFLLX77SKVUx2wTOotYOeY8hZVjXge0EpFDQBzwtlLqavZJnTWsHPObwAwReQPDBNM/N3/xE5GFGKbDUha/SxDgAqCUmorhh/EDTgDRwEs27T8X/+40Go1G4wDyi+lJo9FoNJlEKwqNRqPRpIlWFBqNRqNJE60oNBqNRpMmWlFoNBqNJk20otDkaESkvyXK68Prtoj8KSLDLAcjbdFHXREJFpEStmgvhfaViEy0YXvBIvLvFMrnWA4SajQ2RSsKTW6hG9AY6AL8D/gaeM9GbdfF2JduF0VhB4KARxQFRrDDzg6WRZMPyBcH7jR5gr1KqROW1+tFpArwOllQFiLiRMoxcmyCiLg6MiyKUuqko/rS5C/0ikKTW9kFFBaR0gAiMshikooRkSgRmZXclGQxAX0gIu+KyCngPkZU0dmWKscTmbh8LZcSkf7J2nneUv58orItIrJDRDpYkuWYMXKcJKoiY0TknIjcE5FtIlI3WbutRGSNiFwUkWgROSAib1oUWsIYLC/HJJI12HLvEdOTiJQTkbmW34nZktSmd7I6D817jURkgYjcEpELYiTCcbPmj6HJ2+gVhSa3UgkjHMUdEfkII2TDV8DbGOGVJwK1ReQZpVRcouf6Y8Q5egu4i5HQpwQwFsO8dc5S7yKQ0Xj+VS0yvG/pI3FQyb4Y8YeGAa7ABGCjiDyulHpY7zFgI4ZZLQYjom8w4Ak8zOLWGAgH5mDE6SKRzEkQEQ9gK1AcGI0Rhro3Rqiagkqp6ckemQcsBF6w9BMMXMcwdWnyM9mduUlf+krrwvhgV0A1jC82xYEhGEpiBeBref1esuf+z/Jcp0RlCiOipnsqfVRJVu7LP3GCEpc/byl/PlHZFiAeqJvCGBQQBXgka/sB8H4q4xbLeMdgfFibkrU3MYVn5pAokxuGUkoip6V8A3AZcEo2/vHJ6v0MHMvuOaCv7L+06UmTWziC8cF6DZgCLAAGAC0xTKgLRMT54QX8BtzCSCGZmDCl1D07yXhaKbU3lXtrlFJ3H75RSp3GiF7b+GGZxUw0TUTOYJjFHmCsjIoBpTMhz3PAeaXUlmTl8zFWKTWTla9O9n4/4J2JfjV5DG160uQWOmOYWG4DZ5RSMQAPfRQYUTNTInmWQpuFXk6BtNq+lEpZLUhIqhQKlMcw+RwB7gGdMFYVmfEVlEhFpr8T3U9M8vwrZgwzmSafoxWFJrdwQP2z6ykxD8Nlt8Iw0aR2/yEZCZf8MKd2gWTlqaXITavtMqmUnbe8rozhk+ijlJr/sIKIdLBCztS4hmGyS05Zy89cG2pc41i0otDkdn7B8A14K6V+yWQbD7ewuicrv2S5VztZebtM9OEnIh4PzU8i4ouRYe8jy/2Clp8PHj4gIi5ArxTaup+CrCmxFegmIv+nlPo1UXlPDB/F4YwMQJN/0YpCk6tRSp0UkcnANyJSDePDMQYjLWRLYKZSanM6zRyy/HxFRH7A+LDep5S6LyKLgYEicgwjhWg7DGd2RrmHcf7jEwxzzngMH8rnlvuHgTPAByISZ5HhjTTkbSciYRirqAtKqZTSXs4BXgNCRGQMhumuF8bvZYhKuhtMo0kV7czW5HqUUqOBwRjO2yXASmAkxofocSue/xPDL9AB2IFxRqO85fZrQIjl/mIMX8HwTIg5F8NZ/A3wA0ZazubKsjVWKXUfwx/xt6Xut8A2/llxJGYYxtbeVRZZB6cyrrtAU2C9pZ2VQB0M81byrbEaTaroDHcajUajSRO9otBoNBpNmmhFodFoNJo00YpCo9FoNGmiFYVGo9Fo0kQrCo1Go9GkiVYUGo1Go0kTrSg0Go1GkyZaUWg0Go0mTbSi0Gg0Gk2a/D9orydoVSSQOQAAAABJRU5ErkJggg==",
      "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAAEPCAYAAABcA4N7AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzs3XdYFMcbwPHvHL2IKKAiCKixJGo0dmOPvSJiN/aGUZP8Yow9iBqJMc0Ye8OS2FGxYYsFIxq7xooVsYBYEEFOyvz+OCVigVMPDnE+z7NPZHdu912DvOzOzDtCSomiKIqivIzG2AEoiqIo2ZtKFIqiKEq6VKJQFEVR0qUShaIoipIulSgURVGUdKlEoSiKoqRLJQpFURQlXSpRKIqiKOlSiUJRFEVJl6mxAzAER0dH6eHhYewwFEVR3iqHDh2KllI6ZdQuRyQKDw8PDh48aOwwFEVR3ipCiCv6tFOvnhRFUZR0qUShKIqipEslCkVRFCVdKlEoiqIo6VKJQlEURUmXShSKoihKunLE8FhFeRvFxMQQHR3No0ePjB2KksOYm5vj6OhI7ty5DXK+LE0UQoh5QHMgSkpZ+iVt6gC/AmZAtJSydmbFkxATRcRaP4q0m4jG0jazLqMoz0lISCAyMhJXV1esrKwQQhg7JCWHkFLy8OFDIiIisLCwwNLS8o3PmdWvngKAxi87KISwB6YBLaWUpYC2mRnMoR2rKXLhDyImVePk8QOZeSlFSePWrVs4OTlhbW2tkoRiUEIIrK2tcXR05NatWwY5Z5YmCinlbuBOOk06AYFSyvDH7aMyM56PPfuy9+PZ2Cbfw2NVMxbO/omo+wmZeUlFAXRPFLa26ilWyTy5cuUiIcEwP8+yW2d2cSCPEGKnEOKQEKJrZl5MCEGNRm2xGPg3d+1K0PXaWLb+1JVZO06jTUrOzEsr77ikpCRMTVUXoZJ5TE1NSUpKMsi5sluiMAUqAM2ARsBoIUTxFzUUQvQVQhwUQhx83cerFJnC8VvHsXF0w/XLv4gp14/OYjOVd3Sm28+r2HEmUx9olHeceuWkZCZDfn9lt0QRAQRLKeOklNHAbqDsixpKKWdJKStKKSs6OWVY/PCF1p5fS+eNnRmzdwyxyQnkbvUDtFtEaYtIZsZ/RcDCOfSY/w8Xbz14/TtSFEV5y2W3RLEWqCmEMBVCWANVgNOZdbHGhRvTo1QPVp9fTas1rdh5dSd80BJTn93kyudGgPkPVL48gya/7sR/02keaA3zGKcoOYkQIsPNw8NDr3Z16tQBoHv37mn2W1tbU758eebNm2fcm31HZfXw2CVAHcBRCBEB+KIbBouUcoaU8rQQIhg4DqQAc6SU/2ZWPJYaCwY4eNGoaSNG7x3NoL8G0cSjCUMrD8Whz3bY8DX9jy6mnv1lOu7qTeDhawxrXBKvj1zQaNRrA0UBCA0NTfO1l5cXZcuWZcyYMan7hBBIKdO0q1atGt27d6dfv36p++zs7FL/7OTkRFBQEACRkZFMnjyZXr16YWdnR5s2bTLhTpSXydJEIaXsqEebScCkLAiH+xs3cf2bb8jr3Zo/PpvCgqh1zDw+k9AboQytPJRmnr8j3KpSfOPXhOb1Y7T5YAav0LJo3xX8WpaibCH7rAhTUbK1qlWrpvnawsICR0fH5/a/iIuLy0vbmZubpzlWr149ChUqxJw5c1SiyGLZ7dVTlrKp/jF5u3Th3pq1XGnSnNY7ElhedwFuudwYHjKcgX8N5GaJBtBrK+YWVnx/fzhryh8l4k48nlP/5puVx7gVqzX2bSjKO8HW1pbixYsTHh5u7FDeOe90ojDNk4f8w4dRdNNGctWrx+0ZM5FtfZh8uxFDyw3mwM0DtFrbiuX3z5DSdweieGPKnfqB0KIBDPo4H6uPXOOTH3cyJ+Qiickpxr4dRcnRkpOTuXr1KkWLFjV2KO8cNZAbMHd1xeWnH8nbowdRkyZxa4I/Vd3cqN7/C76z/otx+8ax6dImxjT5Dne3qpht9WVwnlO0+3QGo0IF4zecZsk/4fi2KEWt4q83AktRAPzWneTU9ftGjeGDgnb4tihl1BieeDIPICoqigkTJhATE8OoUaOMHNW7551+oniWVelSuAXMp9CsmWgsLUkYPp6Rc2OZlKs7Z++cxXtdG+bb2ZLUNQgexVNoVUsCPjrH3G4VSU6RdJ33D70XHOTK7Thj34qivPWuXbuGmZkZZmZmuLi4MG3aNObNm0eVKlWMHdo7Rz1RPEMIgW2tWthUr07M2iBu/fYb7iPmsLBmNRbVhp8P/cxmh1L4dQygxLYJiLUDqPdRF2oM/J55+yOZ8lcYDX7eTZ9ahfmsznvYWKi/YkV/2eU3+ewgX758bNiwgZSUFC5cuMCoUaPo2bMnZcuWpWTJksYO752iniheQpiYYN/ai6LBm3Aa/BXJR07QYcJ+5h2pSPyNCDps/4zfyzTkUc2v4MgiLAIa078M7Pi6Ds0/dGbqjgt88tNO1h699tywQEVRMmZmZkbFihWpXLkyHTt2ZOPGjSQlJTF48GBjh/bOUYkiAxpLSxz79KHo1i3k7dIF2+2HmDj1AcOPurPw4Ezaxh7maItJEHMVZtUh/7Wt/Ny+HKv6f0y+XJZ8sfQobWeE8u+1GGPfiqK81UqUKMGAAQPYuHEjBw6oas9ZSSUKPT09QsquXn3KbDzL/LlWVAyJosexKUys3oV4h6Kw7FPYMooKrrasHVCdid5luBQdR4vf9zA88AS3H6jhtIryuoYNG4aNjQ1jx441dijvFJUoXtGTEVIeK1diW7IUbTbcY1aAJec3rKZ1HnNCy7aGvVNgQQs0D27SvpIbf31dh57VC7Pi4FXq/riT+X9fUsNpFeU15MuXj88//5z169dz5MgRY4fzzhA54f15xYoV5cGDB7P8ulJK4kJCiJr0I9qwMMJdLZhbO4mS5T7i6xN/YWdmBd5zoEgdAMIiYxm7/hQhYdEUy2fLhNZlqOSRN8vjVozv9OnTvP/++8YOQ8nhMvo+E0IcklJWzOg86oniDTwZIVV4zWqcJ0ygcKI9fn8kU3zmYfrburM9V25Y5AW7J0FKCsXy52Jhz8rM6lKBh4nJtJ8ZypTtYSSnvP3JWlGUnEslCgN4MkLqvc3BOA3+ivI3LBkx/S6ndzxkdP5SRO+cAH+2g/g7CCFoWKoAwV/WokXZgvy09Rxd5+0nKlatrKcoSvakEoUBPRkhVXzbNvJ0+ZS6/wq8f7/N/CuFWB+xHzmzFkQcAsDWwpRf25fjB+8POXTlLk0nhxASZpj1bRVFUQxJJYpMYJonDwVHjKRYcDBWn9Sm+d+JOC2zZcY5yfV5TeCf2SAlQgjaVSpE0MAa5LUxp+u8f/gh+AxJqqNbUZRsRCWKTGReqBAlfpuB+4pliKLu1NmRwrmNDmxcMJ7kFT1Bq1s5r3j+XKwdUIP2FQsxbecF2s/ax7V7D40cvaIoio5KFFnAusyHVFqxCavJEzCxsqbwdmt2TgvlwujK8O8qkBIrcxO+9/6QyR3KcebGfZpODmHrqUhjh64oiqISRVYRQuDRyIvqW/dz88s2WMZpeBQk2fO/YdyfWA9ungDAs5wLGz6vSaG8VvRZeBC/dSfRJiUbOXpFUd5lKlFkMY2pKXV9xlF8y1YOeH+AxS1TrgXc4HjPVjwK6Afxd/BwtGFV/4/p/rEH8/++TJvpoaoiraIoRqMShZE45XGh63erSFo2hW217Ui+ak7YD7u43KkKSVt+xUJIxrQsxcwuFbhyO45mv+0h6Nh1Y4etKMo7SCUKI6tWoj59pu5i/69d2V7OhNhzppz9agZR3SqS/O9mGpUqwMYvalI8vy2fLznC8MDjPHykXkUpipJ1VKLIBixNLfGpN5xm04KYM6wMe4truH1Qy7lOn3P784YU1F5nWb9q9K9TlCX/XKXV1L8Ji4w1dtiKkkZAQABCiNTNxsYGDw8PvLy8WL58OSkpaYd9P91Wo9Hg6OiIp6cnJ0+eTG0zatSoNO1etpmamurVbs+ePZw/fz7NPhMTE5ydnenSpQvXrl3T+371jW3RokUIIQgMDHzpuTp27IidnR0PH2bP0Y6q1lM2kyJTWHN+DcvXTcRzWyzlLkpMrFNwal0D+8G/svtqAl8tO0r8o2T8PEvRtoIrQghjh628opxY6ykgIIAePXqwYsUKXF1d0Wq1hIeHs2HDBlasWEHdunVZt24dVlZWgC5RdO/enX79+pGUlMTx48fx9fXF0tKSEydOYG9vT0REBBEREanXCAoKwt/fn8DAQJydnVP3CyHSrPsyc+ZMAgICCA0NTRNjqVKliIyMpFixYowaNYpmzZqh1WoJDQ1l7NixlCpVitDQUExNM15wTN/YChcuzPvvv0/t2rVZvXr1c+e5f/8+BQoUoGPHjsydO1ePv2n9GarWE1LKt36rUKGCzGmi46Pl8N3DZTu/D+Smuh/IUyVKyvNVSsqYOePkzbtxssPMUOk+dL38YslhGZuQaOxwlVd06tQpY4dgcPPnz5eADAsLe+7YypUrpRBCDhw4MHUfIEeOHJmm3eLFiyUglyxZ8sJrzJ49WwLy0qVL6cYycuRIqfvx9rywsDAJyPnz56fZP2bMGAnIAwcOpHvul0kvNh8fH2lubi6jo6OfOzZnzhwJyF27dr3WddOT0fcZcFDq8TNWvXrKphysHJhQcwJf9ZnH7wM9mOStIcpEcG3SH8R7fcws18v8r35xgo5dp8WUPZy8rhZGUrIvb29vPD09mT17NvHx8S9tV758eQDCw8OzKrQsuXa3bt149OgRy5Yte+7YwoUL8fDwoGbNmga/rqGoRJHNVXGuwirPQCq0/YyBfS2Y19yc+7EJRHzlh9dvPVlR3ZT4R0l4Td3LwtDLatlVJdtq2rQpWq2W9F4TX758GYCiRYtmUVRZc+2qVatSokQJFi1alGb/lStXCAkJoWvXrtn6FXLGL+IUo7MwsWBAuQE0KdyEcfnH0eP9A/Q4akn93VFYf/0lyyoVZ0rZ7ny79iR7z99mYpsPyW1lZuywldexaVjq5EujKVAGmnxv8NO6ubkBcOPGjdR9UkqSkpJITk7m+PHjDBkyhKpVq9KyZUuDX/9ZKSkpJCUlodVq2bdvH/7+/rRv356yZctmyvW6du3KyJEjCQsLo1ixYgAsWrQIKSVdu3bNlGsainqieIsUyV2EeY3m8W3t8SyvbkWvgZZc+NiShCNn6D13BEtvLOXw4XM0nRzC4fC7xg5XUdJ48rT79G/OEyZMwMzMDEtLSypXrkxcXBxBQUGYmWX+Lzq9evXCzMwMW1tb6tevj6urKwsWLMi063Xp0gWNRpPmqWLRokVUr17dKE9Qr0I9UbxlhBC0eq8VtV1r89PBnxhuvpaS1ZwYseU2uQ8cYIHmELtKVqdH9B0+a/ERfWoWQaPJvo+0yjMy4Tf57OLq1asAaUYE9ezZk/79+5OQkMD27dsZO3YsHTp0YNu2bZn+KsbX15fmzZsTFxfHsmXLmD59OoMGDWLWrFmZcr1ChQpRt25dFi9ejJ+fH/v37+fcuXN8/fXXmXI9Q1KJ4i2VxzIP42uMx/M9T8aGjqVr8xja1nfm0zXnqf1vCDXC9rH4Yj36nvVmYqfKONhaGDtk5R23YcMGLC0tqVChQuo+Z2dnKlbUjc6sUaMGUkr8/PxYuXIlbdu2zdR4PDw8Uq9du3Zt7t+/z5w5c/Dx8Unt2Da0bt260bVrV/bs2cPSpUuxtLSkXbt2mXItQ3rpqychRNdX2bIyaOU/lQpUYlXLVXxW7jPWWt/m00/zEda3IHYOD+h2ajP9pn3BDwP8CT2rKtEqxhMYGEhQUBA+Pj5YW1u/tN3QoUMpWLAgfn5+WT4wY+LEiVhYWODn55dp1/D29sbW1pa5c+eybNkyPD09yZ07d6Zdz1DSe6IIeObrJ//XxAv2ASw0REDKqzM3Mad/2f408WjC+H3jGZm0n7IDyzD6cAROO2Povn8ZUZ03s6RdH9p+1Q1TUxNjh6zkYEePHiU6OppHjx4RHh7O+vXrWbFiBQ0aNMDf3z/dz1pZWTFixAgGDhxIYGAg3t7eWRQ1uLi44OPjw6+//srRo0cpV66cwa9hbW1NmzZtWLBgAVJKunXrZvBrZIb0OrMLP7XVBCKAmUAd4P3H/50FXAVq6HMxIcQ8IUSUEOLfDNpVEkIkCyHa6HNeRccjtwezG85mQo0JhD+6R/viKQR+8zGO9RJwNblFuXmTCPmkCRFbdqhhtEqmadu2LdWqVaNRo0aMHDkSrVbL0qVLCQ4OxtLSMsPP9+nTB3d3d8aPH5/l36fDhw/HxsaGcePGZdo1unXrhpSSAgUK0LBhw0y7jiHpVcJDCLEGOCulHPqCYxOB4lJKLz3OUwt4ACyUUpZ+SRsTYCuQAMyTUq7M6Lw5qYSHocRoY/jl0C+sCluFi3UBRuDEh+t3EHnCjpR4DY9KlaXYyG+wzqR3sUr6cmIJDyX7MVQJD32Hx9ZD98P7RbY+Pp4hKeVu4E4GzQYBq4AoPWNTXiC3RW7GfDyGgMYBWJhZMyD+BOM6NsWypzP5y9/D9PxxrnTqzOU+fXn4VBE2RVGUZ+mbKLTAy7JOJeCRIYIRQrgAXsAMPdr2FUIcFEIcvHXrliEunyNVyF+BlS1W8vlHn7Mr+hgd8mrZ2LUdbp73yPNhHPf37+OydxsiPv8C7fnzxg5XUbKN5ORkkpKSXro9Ww03J9M3USwHxgghhgghPIQQVo//+w3gCzxfwOT1/AoMlVJmuOCClHKWlLKilLKik5OTgS6fM5mZmNHnwz6sbrmaD50+ZGLkX/SuUJWwBqUp1Tyc5FKmxOzaxcUWLbk+dCiPjFBnR1Gym9q1a2NmZvbSrW/fvsYOMcvoO49iMJAL8AeenhEkgT8fHzeEisDSxxNtHIGmQogkKeUaA53/nVbIrhAz6s9g8+XN/HDgBwaYR9Oqaiv6Wv2FQ7E4jl2uBMGbidmwEXtvbxz7+2BWoICxw1YUo5g7dy6xsS9f9+Vd+gVVr0QhpXwIdBFCjAOqAM7ADWC/lPKcoYKRUhZ+8mchRACwXiUJwxJC0LhwY2q41GDq0an8eeZPdhXzoNN9a/pahnLR3ZXE+JrcCwwkZvVq8nTsiEPfPpg6OBg7dEXJUiVKlDB2CNlGhq+ehBDmQohfhBCVpJTnpJSLpJQ/PP7vKyUJIcQSIBQoIYSIEEL0EkL4CCF8XvcGlNdja27L0MpDWdZ8Ga52hfjd4hod36/JbbsEiuddyqPuFcjVuCF3Fi3ifIOGRP36K8n37xs7bEVRjEDf4bHxQOPHo5ayHTU89s2kyBQCwwL55dAvxCXG8Um8A+MjDxGrKYCm8ii0wYeI3RSMxs4Oh549ydvlUzQ2NsYO+62mhscqWSGrh8ceAcro2VZ5y2iEhjbF27DOax0ti7Zkq1UUjYuUZoc5OIYOQFP+AYWXLsC6fHlu/for5xs24s6CBaRotcYOXVGULKBvohgMfC2EaC6y8+oayhvJa5mXsdXHsrDJQhxz5+O7AmZ4O5ch6XIgjzZ0pMDnzfBYugSLYsWI9P+eC40ac3fZcmRiorFDVxQlE+mbKFYADsBaIEEIcVUIEf7UdiXzQlSy2kf5PmJZ82V8XfFrrtkm4unmxhQra+TyziT/+xPuv/+AW8B8zPLn56avLxeaNScmKAiZnOGoZkVR3kL6Jort6GZLL0Q3HHbb431Ptr8yJTrFaMw0ZnQr1Y21rdZS170uSx2gnmsJjl7dhnZyBaytLuO+5E9cp09DY23N9W+GctHTk/tbtqg6UoqSw+jVmZ3dqc7szLfn2h7GhX7H9bgIqsZqmHA3nDwen2DacjIyV0FiN2/m1m9TeHTpEpalSuH05RfY1KiRrdcBNibVma1khazuzFbecTVcahDktQafD/tzIJcJDV3cWXzrINrfqyAOzcOuUSOKrAvCecIEku/d42qfvlz5tAvxBw4YO3QliwQEBCCESN1sbGzw8PDAy8uL5cuXP1fy4um2Go0GR0dHPD09OflU7bFRo0alafeyzdTUVK92e/bs4fz582n2mZiY4OzsTJcuXbh27dor37erqyvdu3dPsy85OZlPP/0UExMT5s+fD8CcOXMQQnD58uVXvoaxvdIKd0KIskAJ4LlawVJKtR5FDmdhYsGAjz6jedFmDN3px08mB1iu1fD9tuGUObES0fJ37Ft7kbt5M+6uXMnt6TO40qUrNtWr4/TlF1iVUQPn3gUrVqzA1dUVrVZLeHg4GzZsoGPHjsyaNYt169ZhZWWV2rZ79+7069ePpKQkjh8/jq+vL40bN+bEiRPY29vj4+ND8+bNU9sHBQXh7+9PYGBgmiVVhRBpXnnOnDmTgIAAQkND08RWqlQpIiN1i3iNGjWKZs2aodVqCQ0NZezYsZw5c4bQ0FBMTV9/8c/ExEQ6d+5MYGAgCxcupHPnzq99rmxDSpnhBtgDfwPJj7eUx9uTr5P1OU9mbRUqVJBK1kpJSZGBZzbI8gE1ZOn5peXoKe/Ju9/llzLkFymTEqWUUibHx8voOXPl2SpV5akSJWX4gAFSe/mykSPPHk6dOmXsEAxu/vz5EpBhYWHPHVu5cqUUQsiBAwem7gPkyJEj07RbvHixBOSSJUteeI3Zs2dLQF66dCndWEaOHCl1P96eFxYWJgE5f/78NPvHjBkjAXngwIF0z/0sFxcX2a1bNymllFqtVnp6ekozMzO5YsWK14rdkDL6PgMOSj1+xur76mkCulFPtdCtcOcFfAL8AVwEKr95ylLeJkIIvEo0ZVfHTVR28GK1rRWNC+Rjzb4fkHPqws0TaKyscOjVk6LbtuI4aCDx+/Zz0bMVdxYtRr5DlTcV3RKgnp6ezJ49m/j4+Je2e7JWdbgRClO+6bUTEhJo1aoVwcHBrFq1ijZtcs66a/o+XzUC/IB9j7+OkFIeAnYKIaYDXwBq3ex3kK25LXNbjGXreS+G7RzDaCfJSm00386vT/Eqg6DWEExsbXEaMAD7Nm24MXo0kd99R+y2bTh/9x3mri7GvoVsZeI/Ezlz54xRYyiZtyRDKz+3Rtkba9q0KWvWrOHgwYPUqlXrhW2evL8vWrSowa+fkTe5dnx8PM2bN2fv3r0EBQW9NSvX6UvfJwpn4KLUlf9OQFdJ9olAoJmhA1PeLg3e+4iQrispb9WXYya5aOucj59OzCZ+Rg0I3w+AWf78FJo5E+fx40j4918utWypm7CXA0beKRlzc3MD4MaNG6n7pJQkJSWh1Wo5cOAAQ4YMoWrVqrRs2TLT40lJSSEpKYm4uDi2b9+Ov78/7du3p2zZsq98rhUrVrB9+3ZmzJiR45IE6P9EcRNdPwXAFaAasPPx1+8ZOCblLWVtbsaCdoNYfawRviGTCLDfx8bkhwxd2ooGpbsg6n2LsLDFvk0bbKpV4/qoUdz09SV261acx49TJc0hU36Tzy6e/ELw9JDpCRMmMGHChNSvPTw82LFjB2ZmZpkeT69evejVq1fq15UqVWLBggWvda6qVasSFhaGr68vdevWpVChQoYKM1vQ94liD7rkALAI8BVCzBRCTAUmAZszIzjl7eRVtjibu/yGh3YokYkFGJzfkc+uBHJ1ZjW4/DcAZi4uuM2dS/5vRxN/6BAXW7TkXuBq9XSRg129ehUgzWilnj17cuDAAUJCQhgzZgzh4eF06NAhS74PfH19OXDgADt37qR///4cOHCAQYMGvda5SpQowZYtW7h37x716tVL89SUE+ibKPyA4Md/ngRMRfe6qSMQhG6da0VJ5ZzbijW9O9O76O9oI5sTamlHKzuYt7oDybt+gJQUhEZD3k6dKLJ2DRYlinNjxAgiPhtAYpRaLj0n2rBhA5aWllSoUCF1n7OzMxUrVqRGjRr4+voyevRo/vrrL1auXJnp8Xh4eFCxYkVq167NtGnT6Ny5M3PmzOHw4cOvdb7y5csTHBzMzZs3qVevHjlpiWa9EoWU8oKUMuTxnxOllIOllK5SyrxSyk5SytuZG6byNjLRCL6sX5I/2w3B6tYoHj14n1/y2tPjzGyuLm4JcdEAmLu54b5wIfmGDSVu714utWhJzPoN6ukiBwkMDCQoKAgfHx+sra1f2m7o0KEULFgQPz+/LP//P3HiRCwsLPDz83vtc1SpUoWNGzcSHh5O/fr1uXPnjgEjNB69EoUQomRmB6LkXBU98hI8sAWfOAzj4bV2/Gtui3fyJVbMr4W8vBcAodHg0L07hVevxszDnetff821L74kKYf8Q3uXHD16lH379rF7924WL15Mhw4daNu2LQ0aNMDf3z/dz1pZWTFixAhOnjxJYGBgFkWs4+Ligo+PD0FBQRw9evS1z1OjRg2CgoIICwujYcOGxMTEpDm+adMmVq5cmWbbtm3bm4afufSZbIFuct0NdAUBewNF9flcVm1qwt3bI/RCtKz36xpZYWojWTqgtOw/7T0ZtWO8lMnJqW1SEhPlrZmz5OnSZeTZah/LmM2bjRhx5sjJE+6ebJaWltLNzU22atVKLl++XKakpKRpzwsm3Empm7Tm7u4uy5Ur99xnMnPCnZRSRkZGShsbG9m6dev0b/YpT0+4e1pwcLC0sLCQ1apVk7Gxsamxv2grW7as3td7FYaacKfvCncNgLqPtwqACXANXdXYHcAOKWXWz5B5TBUFfLskJqewYO8lpv8zG5l3I9YyiZGmhWjSZglY501tl3DuHDeGDSfh1CnsmjenwKiRmNjbp3Pmt4cqCqhkhSwtCiil3CqlHCGlrAbkBVoAy4GywDx0s7MVRS9mJhp61yzKpr5jqGTxPSLRnm/kdYYsrEnMhf8q1lsWL47HsqU4DhrI/eBgLrZoSezOncYLXFHeUa9TPdYFcAPcAdfH+/41WETKOyNfLktmdmrKpIZrcI+rxlZLQeudAwle9xU8GXNvZobTgAEUXr4Mkzx5iPDpz/URI0mOjTVy9EpOl5ycTFJS0ku3Z6vh5mT6dmb3FEIsFkJcA06jK9kRBfgA+aSU5TIxRiWHq1o4H2v6zaCL8zhEijlD7mzlm1nViY7+722m5Qcf4LFyBQ79+hGzZg0XW7TkwZ6/jRi1ktPVrl25HpzOAAAgAElEQVQbMzOzl259+/Y1dohZRt8+ihQgHpgO/CylzFazSVQfRc4Rcfce4wK7s9f0Ai6JKXQqNIguDfulmc378Phxrg8bzqOLF7Fv3558Q4ZgYmtjxKhfneqjyP7Onj1LbDpPrk5OTri7u2dhRK/OUH0U+iaKn9B1ZH8I3AN2oevI/ktKeVrfoDOLShQ5z4pdM5lxfgrRJlAl4T2+bDmXDwo6pB5PSUjg1uTfuBMQgFnBgjhPmIBNlbeniLFKFEpWyOrO7MFSyvKAE9AX3Yin/sC/QogbQog/9AtbUfTTtnY/Vnlv4pMkO0KtLvDV+vqMDAzkgTYJAI2lJfmHfoP74kVgYkJ4t27c/G4CKQ8fGjlyRcl5XqkzW0p5V0oZCPwM/ILuqSI/0CETYlPecfb2hfil199MdKpHvKmWTTHf0mb6QFYfuZo6a9e6QgWKrFlNns6dubtoEZdaeRF/+IiRI1eUnEXfzuyCQohPhRBzhRCXgAvADHQVZSehyowrmUUImjb9ldW1f+PjRMm1PH/z275OtJ61jrM3de+PNdbWFBg9CreAAGRiIlc+/ZTISZNI0WqNHLyi5Az6PlFEAAvQTbZbA7QCHKSUlaSUQ6WUwel+WlHekEPR+kzpvJtxGmceWt7hqvko2gZ8j1/QSe4nJAJgU7UKhYOCsG/Thjtz53HJ25uHJ9TIbUV5U/omiraAk5SynJTyf1LKdVLK+5kZmKI8S9g40KpzMIGFO/KhNgHpHMSG8KHU/Xk9gYcjkFJiYmuD81g/Cs2eTUrsAy536EDU5MnIR4+MHb6ivLX07cxeJaVU1dkU49NoKFhnFHOaBPDNg2SSbS+jcR7PN5v+oN3MUE5d1/3+YluzBkXWBZG7RQtuT5/BpXbt0Z4/b+TgFeXtpHdnthDiIyFEoBAiWgiRJIQo/3j/BCFE48wLUVGep3H/mC7dQ1hu4kHhxAdYuS7mQvJ0mk/dypigk8Q8TMTEzo6C3/vjOm0qSVFRXPJuw90lS1T58kwSEBCAECJ1s7GxwcPDAy8vL5YvX/7cTOan22o0GhwdHfH09OTkyZOpbUaNGpWm3cs2U1NTvdrt2bOH8+fPp9lnYmKCs7MzXbp04dq1awb/e9m2bRtCCHZmUH4mKSkJIQTjx49P3bd8+XJat26Nu7s71tbWlCxZkpEjR/LgwQODx5kevZZCFULUALahq+n0JzDwqcMp6GZoZ9hPIYSYBzQHoqSUpV9wvDPwZC3IB0B/KeUxfWJU3kE2DhTtHMQfe35i1pHfmZ37KPmLX2LxsbasP36doY1L4l3elVyffILV2jJcHzGSm35jeRCyB+fx4zDNmzfjayivbMWKFbi6uqLVagkPD2fDhg107NiRWbNmsW7dOqysrFLbdu/enX79+pGUlMTx48fx9fWlcePGnDhxAnt7e3x8fGjevHlq+6CgIPz9/QkMDEyzUp4QIs0vADNnziQgIIDQ0NA0sZUqVYrIyEhAl4SaNWuGVqslNDSUsWPHcubMGUJDQzE11XeVaMMxNTUlNDQ0zTKqkyZNomjRovj7++Pi4sLhw4cZM2YMu3btYvfu3Wg0r1OF6TXoU2IW3VKoawGBLrmkAOUfH2sNhOt5nlpAeeDflxz/GMjz+M9NgP36nFeVGVfkpT3y+C8lZPPZJWXpgNKyxqxB0n3Yauk1dY88EXFPSillSnKyvL1gga58eY0aMjZkj9HCzcllxsPCwp47tnLlSimEkAMHDkzdxwvKjC9evFgCcsmSJS+8RmaWGR8zZowE5IEDB9I996vaunWrBOSOHTte+bNRUVHP7Zs7d64E5K5duzL8vKHKjOubjsoD0x+f+Nnn9mh0E/H0SUq7gZf2dUgp90op7z7+ch//FR1UlPR5VKdM7xCWmxWjU0ws98x3UPjDGVyKPUvL3/cwes2/xD5KJm/XrnisXIFJ7txc7d2bSP/vSVEd3ZnO29sbT09PZs+eTXx8/EvblS9fHoDw8KxfteB1r52UlMSECRN4//33sbCwwMnJiSZNmnDu3Lk07eLi4ujfvz8ODg44OTnRtWvXNIsavejVk5PT8z9aK1WqBJApr8leRt9EkQC8bP1CZyDmJcfeRC9gUyacV8mpbJ2w6rKG4WUHMOvmLUwSriGdJ1Ox3EH+2H+RBj/vYvPJm1iWKEHhlSvJ06kTdxYs4LLq6M4STZs2RavVkl65ncuXLwNQtGjRLIrqza/dpk0bfH19adGiBWvXrmX27NmUKFGCmzdvpmk3aNAgzM3NWbJkCaNGjWL58uV89dVXrxznrl27ALK0BIy+L+L2AF8KIdY+te/Jk0UvdDO0DUYIUffxeWuk06YvunIiuLm5GfLyyttMo4HaQ6jmVoXAVb3wt4b1ciUfVDzGgxuN6LdIS6NS+RnrWZoC347GpmYNbowcxSXvNuQfNhT7Dh3SFCDMajcnTEB7+ozRrg9g8X5JCowYYfDzPvl3euPGfzVFpZQkJSWRnJzM8ePHGTJkCFWrVqVly5YGv/6zUlJSSEpKQqvVsm/fPvz9/Wnfvj1ly5bV+xxbtmxh7dq1TJ06lc8++yx1f6tWrZ5rW7duXSZPngxAw4YNOX36NIsWLWLu3Ll6X+/q1auMGTOGxo0bU65c1hXt1veJYjS610/HHv9ZAt2EEDuAqsDrr0b+DCHEh8AcwFNKeftl7aSUs6SUFaWUFV/0eKa84wrXwq7fHvxtSvJL5C0S48K5net3Sn70J7suH6b+T7tYvO8KNrXrUGTtGqwrV+am31giBgxU63RnEvlkjZGnEvGECRMwMzPD0tKSypUrExcXR1BQEGZmZpkeT69evTAzM8PW1pb69evj6urKggULXukcW7ZsQaPR0KtXrwzbNmuWtoBFmTJliI+PJzo6Wq9r3b9/H09PTywtLZk3b94rxfmm9HqikFIeE0LUQleuYyS6Tu2BQAhQW0p51hDBCCHcgECgi5TyXEbtFSVdufJDlzXU3zWRWrt+YIVLcWaZX8HMbQp2yRUYvbEOa48Wx7/1hxSdOYO7ixcTNelHLnp6UtD/e2xrVM/ykDPjN/ns4urVqwBpRiv17NmT/v37k5CQwPbt2xk7diwdOnRIHVKamXx9fWnevDlxcXEsW7aM6dOnM2jQIGbNmqX3OW7fvo2TkxMWFhYZts37zCi7J59JSEjI8LPx8fG0aNGCK1euEBISkubvMCvoPQZMSnkYqCeEsES3HOo9KeXLe6VeQAixBKgDOAohIgBfwOzx+WcA3wIOwLTH3yRJUo8SuIryUhoTqDsCc5cKdF7Vh1Z3NSys1JaA67vJVfQIZ2Ir0XRqPQbUrEj/Tp9iXaUK1wYP5mrv3uTt1g2nwV+hMTc39l3kCBs2bMDS0pIKFSqk7nN2dqZiRd0/8Ro1aiClxM/Pj5UrV9K2bdtMjcfDwyP12rVr1+b+/fvMmTMHHx+f1I7tjDg6OhIdHY1Wq9UrWbyOR48e4eXlxZEjR9i+fTsffPBBplwnPRm+ehJCmAsh7gghWgJIKROklNdfNUk8/mxHKaWzlNJMSukqpZwrpZzxOEkgpewtpcwjdaVCyqkkoRhM8UbQdwc2NgXov3sOm1w96fx+J8xyH8aqyCSmHf+VJlOCOWnppDq6M0FgYCBBQUH4+Phgbf2ycTEwdOhQChYsiJ+fX5ZPjJw4cSIWFhb4+en/Jr1hw4YkJydn2qug5ORkOnToQEhICEFBQakjnrJaholCSvkISEI38klR3l4ORaH3NvjAk7w7JjL08knWNV1K86JNsHAIIcp+DB2XT2Dkpn+x/mYYrtOnqRndr+Ho0aPs27eP3bt3s3jxYjp06EDbtm1p0KAB/v7+6X7WysqKESNGcPLkSQIDA7MoYh0XFxd8fHwICgri6NGjen2mQYMGtGrVii+++IJhw4axefNm1q1bx+DBgwkJCXnjmHx8fFi9ejVDhgzB0tKSffv2pW7ZcXjsGqBNZgaiKFnCwhbazIcG4+D0OlyWduG7kj1Y1XIVNQtVxiLfZoLufE6dmRMIcSymOrpfQ9u2balWrRqNGjVi5MiRaLVali5dSnBwMJaWlhl+vk+fPri7uzN+/PgsT87Dhw/HxsaGcePG6f2Z5cuXM3r0aFatWkWLFi3o2bMnZ8+epUCBAm8cz6ZNuhkCY8eOpVq1amm2+fPnv/H59aXvUqhewG/AfnRJ4wbPTLyTUhp0iOyrUEuhKq/l4k5Y0QNSkqD1LCjRhKNRRxm/90fOxhwj5ZEDJS3aMqVFNyyDVhH1409o7HNT8Pvvsa3+Zh3dailUJStk6VKowCrABV25joXAVnS1n57+r6K8XYrUgX67IG9hWNIBdkygnOOHrPBcxG91f8fJJhfn5AwarfBmqmsu3JYt083o7tWbyO8nqhndyjtD3yeK2hm1kVLuMkhEr0E9UShvJPEhrP8Kjv0JxRrpni6s7EmRKSw4vpopR34nUURjnVwc34pfUH7NLu7++ScWJUvi8uMkLN5775UvqZ4osr/k5OR0X31pNJqsK8r3mrL0iUJKuSuj7RViV5TsxcwKWk2Dpj/Che0wuy5EnkIjNPQo682+TzfTuEB/4rnO0CMD6F3iMvwwmqTISNXRnYPVrl0bMzOzl259+/Y1dohZRq8niuxOPVEoBhO+D5Z3Be0D8PwdSrf+79DduwzYMJlLj9YjNI9oZFOHfhvvkRR6ANtPPnml0uXqiSL7O3v2LLGxsS897uTkhLu7exZG9OoM9UShEoWiPOv+DVjRDa7uh48HQb0xYPLf3NSgE+cYs3sKj6xDMBUw7MqHlF15FJNX6OhWiULJClndma0o7w47Z+i2Hir2gr1TYHFriPuv7FjLMsUJ6f0LzfJMJiGmHN+5H2VkN3PuW6Sojm4lR1KJQlFexNQcmv8MnlN1r6Nm1YbrR1IP21iYMrFVbZa2/pV890dyyuI9+naIYUclK+4EBHCpbbsMZ3TnhKd5Jfsy5PeXShSKkp6PPoWewSAlzG0ER/9Mc7hcIXuCB7RlUOnxxN0cyPTqhfi+jYY7V8M439qL23/++cJ/sGZmZjx8+DCr7kJ5Bz18+NBgVXhfKVEIITRCiNJCiNpCCBuDRKAo2Z1Led18i0KVYU1/2PA1JP33asnMRMOAuu8R7NOFUpph7LHozbAeLhx3SSZq7DhOt/Pi4TMlIfLly8e1a9eIj49XTxaKQUkpiY+P59q1a+TLl88g59S7M1sIMQBdtVeHx7sqSSkPCyHWAH9JKX8zSESvQXVmK1kiOQm2+ULo71CoKrRbALnSlmmQUrLiYATjN54k0fwwzaPX4rXzPnniIFeTJuQb/BXmrroVfu/fv09UVBSJiYnGuBslBzMzMyNfvnzY2dml286go56EEH2A6cA8YAuwHKj4OFEMBlpKKTOclJdZVKJQstSJlRA0CCzsoN1CcKvyXJNbsVr81p1k/b8XKFBwBc2O/IvnPwIzTMjbtQuO/fphksE/YkXJbIYe9fQV8JOUsi+w+pljZ4ASrxifory9yrTRVaE1s4KAZnBgjq4P4ylOuSz4vVN5FvWoQ+6kASws0YJBfUzYV8qc2/Pmc6FhI+4s/gOpniaUt4C+iaIwsPklx+IAe8OEoyhvifyloO8OKFoXNgyGtQMg8flK/DWLObHx81qMrzuAB9pB/FjfkmHdzYguaEfk+PFcbOlJ7F9/qX4KJVvTN1FEAx4vOVYCyLrC6IqSXVjlgY7LoNY3cPQPmNcI7l19rpmJRtC+khu7P+9B50KTuZCrOP1aXmNexw9ISkkm4rMBhHfrzsOTJ41wE4qSMX0TxTrgWyFEkaf2SSGEI/A/dKXHFeXdo9HAJyOhw59w+4JuvsXFF5c+s7EwZUSjCmzttIBi5h3Y5H6e9q21nGjfloSwMC63acv1ocNIvHkzi29CUdKnb2e2A7AXKIRuTYpaj78uCUQBH0spYzIxznSpzmwlW4gOg6Wd4XYYNBgL1QaCbu33F1p1cjfjD4wkUT4g350W+EeZkHvjKjAxIW+P7jj06o2JrRqFrmQeg9d6EkLkAr4EGgH5gNtAMPCLlPL+G8T6xlSiULINbaxursXpdVDaG1pOAfOX/7C//fA2Ppu/5kzMQRJjylIjoRX/u7QbzY6tmDg64vT5IOy9vREmJll4E8q7QhUFVBRjkRL2/ALbx0K+D6DpD+Be/aVPFykyhZnHZjP92DRkogNxVzvRx84e730rST5xDItixcj3zTfY1qyRxTei5HQqUSiKsZ3fDqv7QdwtKFheV4n2/ZZpKtE+7cDNAwzZ9Q33EmJIiGyJjKnEaLsoKm/9k+SICGxq1CDfN0OwLF48i29EyakMPeEuvfWwU4AY4BAwV0oZqXeUBqIShZJtJT7U1YcK/R3uXAR7d6g2QFdD6gWvpKIfRjM8ZDj7buwjv+Zjzp9qRAFLK8ZxBrcNS0l58AB7b2+cPh+EqZOTEW5IyUkMnSh2AMUBZ+ASEAnkRze/4sbjr98HHgC1pZSnXj/0V6cShZLtpSTD2Y26suVX94OlPVTqDZX7Qq78aZompyQz68Qsph+djrO1G+a3u3HisjXlcsOoO/uw2bQGjbk5Dn16k7d7dzRWVka6KeVtZ+hE0QL4FWgjpTzy1P4K6Mp5fIXuiWILcFZK6fW6gb8OlSiUt0r4ftj7G5zZACZmULaDboSUU9oCB/tv7Gfo7qHEJcbR0nUg2w64ceV2PC0dk+h/NhhCdmJaoABOX35B7pYtEdl8/WYl+zF0ojgG/CilXPSCY12BIVLKMkKIHo/bOTx3kkykEoXyVrp9QfdK6uifkJQAxZvo+jHcP07t+I5+GM3Q3UP55+Y/NC/SEreUzszYGUFsQiKDHGJp9vcKkk+fwvKDD8g3dCg2VSob+aaUt4mhE8VDoLWUctMLjjUBAqWUVkKIWsAWKaXl6wT9ulSiUN5qcdG6elH/zIL427qO7+qfQ8kWYGJKckoyM47PYOaxmRTJXYQxVSey7mAyC0MvY64BX+trlNv8J8k3b2L7ySfk+/prLIoUNvZdKW8BQyeK08ApKaX3C46tBkpKKd8XQrQGpkgpXV4n6NelEoWSI7yw43sgfNQZzG3Ye30vw0OG8zDpIaOrjqZM7k/4ftMZgk/exNVaMD7pJM4blpGi1ZKnfXscBw7ANE8eY9+Vko0ZOlF0BBYDJ4FV6GZj5wO8gdJAJynlUiHENKCAlLL1mwT/qlSiUHKUl3V8V+lHlAa+2f0NhyIP0bpYa4ZXHs7xq/F8t+EUxyJiqJwbht/ag+XmdWgsLcnbvTt5e3THxNbW2HelZEOZMTO7AeAHVADMgETgIOArpdz2uI0lkCylzNLaySpRKDlWmo5vcyjbnqQqnzHt2lZmn5hNsTzF+Kn2T7jn8mDd8ev8EHyWa/ce0tYxkV5hW5G7/sIkd24c+vQmT+fOaoSUkkamTbgTQmgARyBaSpnymvEZlEoUSo73go7vPSU/Yfi5RWiTtfhW86VZkWYkJCYz7+9LTNtxgUdJKQwrKvkkdA0PQ0IwcXLEsZ8P9u3aojE3N/YdKdlAtpyZLYSYBzQHoqSUpV9wXACTgaZAPNBdSnk4o/OqRKG8M57p+L7pUo5v8tpy5EE4bYq3YVjlYViYWHArVsu49acIOnad9/LZ8kPxFByWzSf+wAFMCzrjNGAAuT09EaYvniWuvBsy49WTOdAE3foTz45qklLKcXqcoxa6SXkLX5IomgKD0CWKKsBkKeXz60w+QyUK5Z3zKB6OLYHQ30m8c5Hfnd2YZwkl7IvxU91fcLdzB2DHmShGrfmXa/ce8mmVQnxuf4+4ab+TcOIE5h4eOA4aiF2TJmoOxjvK0J3ZBYE96BYvksCT6mapH5ZS6lXeUgjhAax/SaKYCeyUUi55/PVZoI6U8kZ651SJQnlnPdXxvTv6GCPyOZJkYs6YysNpXLIdAHHaJH7aco6AvZdwymWBX4tSVI86xa1fJ6MNC8OiRAmcvvgc27p1EemURVdyHkOvmT0JuAW4oUsSVYAiwHfA+cd/NgQX4OklwiIe73uOEKKvEOKgEOLgrVu3DHR5RXnLaEzg/RbQawu1OgaxwvID3nsYx5D94xi7vBnx8bexsTDl2xYfsPqz6uSxNsfnj8N8fT031ouWUvDHH5EJCUR8NoDL7TsQt3evWpZVeY6+iaIm8BNw/fHXKVLKy1LKb4GVwG8GiudFv8688LtWSjlLSllRSlnRSRVHUxRwq4JzxxXMb72OHhaFWBl/Be9ldTl4ZhUAZQvZs25QDb5pXIKdZ2/R4JcQ1jmWxmPdOpzHjyPp1i3Ce/YivFt34g8fyeBiyrtE30ThAFx/PMopDnh6Fs9fQB0DxROBbhW9J1z5LzkpiqIHM6cSfNVhI/PLDAKZTM99vkxc142ExIeYmWj4rM57bP6yFmVcczNqzb90mHeA6FqNKLo5mPwjR6K9eJErnToR3q8fCaeytL6nkk3pmygi0A2JBbgANHzqWGUgwUDxBAFdhU5VICaj/glFUV6sQoV+rPLaQDuRm8V3DtN2SU2ORewBwMPRhj96V+GHNh9yLvIBTSfv4bfdl7Hp2JH3tmzGafBXPDx6jEutvYn44ku0Fy4Y+W4UY9K3M3sG8FBK+T8hRH9gKrAN3aS7RsBMKeUAPc6zBN3ThyO60uS+6CbvIaWc8Xh47O9AY3TDY3tIKTPspVad2YqSjpQU9m0fxrfh64g0MaG7WxMG1P4OcxPdXIpnh9J+37oMFT3ykhwby535AdwJCCAlIYHcLVrgOHAA5oUKZXBB5W1h6FFPjkBeKeW5x18PAtoD1ujWzR4rpTTUU8UrU4lCUTL24Moeftz8GassJO+Z5WZ8g+mUciqTejzNUNqqbnzTuCR2lmYk3b3L7dlzuPvHH8jkZOzbeOPYvz9m+fOnczXlbWDoRJEbSJBSag0RnKGpRKEoekq4T8janox5cJLbJqb0KdmZvpUGY2ZiBjw/lHasZ2kalSoAQGJkFLdnzuDuipUIjYY8HTvi0LcPpnnzGvOOlDdgsEQhhDBF1wfhJaVcZ6D4DEolCkV5NTEH5zHxn+9ZZ2NBSWtnxtebQom8/y2cdOzqPYauOs6Zm7E0KpWfsZ6lyW+nm2f7KCKC6KnTiFm7Fo2lJXm6dcWhRw9M7OyMdTvKazL0E8U1oI+UcqMhgjM0lSgU5TVEn+ev1Z/iZ3Kf+yam9P+wHz3L9sNUoyvrkZicwuyQi0zeFoa5iYahTUrSqbIbGo1uFLv24kVuTZlC7KZgNHZ2OPTqRd5PO6OxeX4tcCV7MnSimAgUy+ry4fpSiUJRXlOSlrtbR/LdxUA229pQOndRvqvzM0Xs/5tDezk6jhGrT7D3wm0qeeTBv3UZ3suXK/V4wunT3Jr8Gw927sTEwQHHfn3J06EDQhUezPYMnSj6AyOAm8Ba4AbPTISTUs57vVDfnEoUivKGwrYSvHEA3+UyI97UjEHlv6DLB10x0egq80gpWXEogu82nObho2Q+q1uU/nWKYmH6X+We+CNHuDX5N+L37cPcw4P8I4ZjW6uWse5I0YOhE0VG5cSlvrWeMoNKFIpiALGRRAf2YmzcaXbYWPORYxnG1fRPLTAIuqG0Y9efYt0zQ2mf9mD3biIn+PPo8mVsa9cm//BhmHt4ZPHNKPowdKJwz6iNlPKKnrEZnEoUimIgKSnIvb+xfv+P+Oe1J9HUgi8rfkXHkh3RiP/m575sKO0T8tEj7ixaTPS0aaQ8eoRD92449PPBxFb1X2Qn2XI9isyiEoWiGFjEISIDezDGLJ491lZUzl+JsTXG4WL7X43O9IbSPpF06xZRP/9CzOrVmDo5ke/rwdi1aKHKmmcTmZIohBAfArXQ1X6aKaW8KYR4D4iUUsa+drRvSCUKRckECfeR6//H6sub+MHREWlmydeVhtCmWJs05cjTG0r7xMNjx7g5/jsSTpzAqlw58o8ciVWZ51YaULKYoV89WQCLgdboKrxKoJKU8rAQIhA4J6Uc9oYxvzaVKBQlk0gJx5ZyPXgI3+bNxX4LU6oXrM6Yj8dQwOa/p4dnh9J+1bA4Xaq6Y2ry35ODTEkhZs1aon7+meTbt8nt3Zp8//sfpg4OxrgzBcOvR/EdUB/oAuQnbTnwTejqPSmKktMIAeU6UrD3TmalODAy+g6Hr++j9Vov1pxfk7p2xZOqtMFf1qKcmz1+607RfMoe/rl0579TaTTYt/aiaPAm8vboQcyatVxo1JjbAQHIxERj3aGih1eZcDdBSjlVCGGCrhhgxcdPFPWBFVLKPOmfJfOoJwpFyQJJWtg+lqsHZjCqYCEOmyRTx7UO31b7Fifr/9aEkVIS/O9Nxq0/xfWYBLw+cmF4k5Lke+Z1lPbiRSL9vycuJATzokXJP3w4tjWqZ/VdvdMM/UThAJxO5xwW+gamKMpbytQCGn1HoXZLmB8dy5C7Dwi9FoLXWi82XtyY+nQhhKBJGWe2Da7NgLpF2XD8Bp/8tIs5IRdJTP5vpL1FkSIUmjUT1+nTkImJXO3dm6sDBvLo6tWXRaAYib6J4hJQ7SXHKgNnDROOoijZXvGGaPr/Tde8H7Li6lXcExMZGjKUwbsGcyfhv1dN1uamDGlUks3/q0WF/7d33+FRVtkDx78nDUiBACEQkCZFDCBVVkQUVFZXioqCWFdF0VUBBVkFVEJT+YnSBAVZRbHrWmi6AlIVVATpIF1DQiAJUtLL+f3xTkImkBBCMknI+TxPHmfeuXPnXsA5eW879asybuF2ekxdzdq9cdllRISgrl25eMF8agwZQsKaNezt3oPDkyaTmZBQEr0zZ1DQQPEe8KyI3A1k7ctXEekKPAWU2K5sY0wJCKoF93xJw2ue5939uxmcqCz/Yxm3fn0rSw4scSvaMCSAOQ9czqx723EyJZ1+s9Yy6KMNxBw/lZnAy8+PkAEP0+ibbwi68QbiZs5kz03dOfaWI9sAABxdSURBVDZ/geXwLgUKOkfhDXwA9AVScIaakoCKwMeqendxNvJsbI7CmBIU+Sv890F2JUQzsuGlbE+N529hf+PJtk/SIsR9CWxSagZvLN/Nmyv34uslDL6+CQ90aoivt/vvrInrNxAzfjzJW7dSqV07ao0cQcXwcE/2qlworn0UnXFWOIUCccC3qrqi0K0sIhYojClhycdhwVOkbfmcT+pfxqwKGRxNO0G3+t0Y2GYgDas0dCt+IC6B0fO38f2OwzQODWRMr+Zc2TjErYxmZPDXF19wZNJkMo4eJbhPH2o8OdjyXxQh25ltjPEsVdj4EXzzDAlpCbzXtCNz0o+QkpnKLY1v4dFWj7rtvQBYsi2G0Qu28md8Et0vC+O57pcSVqWSW5mM48eJnT6d+Pc/wCsggBoDB1L1zn6Ij48ne3dBKuoNd+tx5ik+UtWYImhfkbJAYUwpkhgPq16Fn98izkuY3fRvfJIciZd4cVezu+jfsj9VKlTJLp6clsHMFXuZsXw33l7CwGub0P+qhvj5uA9HpezeTcyLL5Lw4xoqNGlMzREjCOiY1xobUxBFHSi+Aa5zPV2CEzS+Ksk82TlZoDCmFDoWCctfgt8+5GDFIGY0asP8hH0E+gbyYMsHuavZXfj7+mcX/zM+kTELtrF4WwwX1whgdK/mdG5Sw61KVeXk0qXEvDyBtMhIgrp1I/SZZ/C7qE7uTzcFUORDTyISCtwF3AO0BU4AnwPvq+qy82jrebNAYUwpdmQnfD8Wts9nV1ANpjYIZ/nJfYRUCuHRyx6ld9Pe+HqdOnl22Y7DRMzfyoG4RP7RohbP9QinTrD7cFRmSgrx77xD7MxZkJlJ9f79qf7wQ3hVqpT7000+inWOQkQuxTnO4y6gLhCpqmc9iry4WKAwpgyIXAdLImD/KjZUr8fksLqsT/iTukF1GdhmIDc0uCH7KPPktAxmr9rL68t2AzDw2iY81LmhW6IkgLRDhzj8ykSOL1yIT1gYtUaOIOj66z3dszKr2CezRaQicBvwMlDbEhcZY85KFfZ8D0si0EObWBV2CVOqBfN7YjTNqjVjcNvBdKrdKft02sijiYxbsJ1vtx6iYUgAo3qG0+WS0NOqTVy3jkNjx5GycyeVe/ak1sgReAcHe7p3ZU6xBQoRuRbnbqI3EAj8DMxV1RmFaWhRsEBhTBmTmQnbvoTvx5EZv5dF9S7j9QAfDibH0r5me55s9yStarTKLr7i9yNEzNvKvtgEuoXX5IUe4dSt5u9WpaalETtzFrFvvolP1arUGjuGoC5dPNyxsqWoJ7Nb4MxN3AXUAQ7gHDs+V1V3nWdbz5sFCmPKqIw02DAXlk8g7eQhPmvUgZk+ScSnHuPautcyqO0gGgU3AiAlPYP/rN7HtKW7yVTl8a6NGXD1xVT0dR/MSNq6lehnh5OyaxdVevem5vBn8Q4KKonelXrFkTP7GPAZTnBYdf5NLDoWKIwp41IT4ac3YfVkElNPOHswMmNJykihV6NePNbqMcICwwCI+iuJ8Qu3s3BzNPWr+zOqZzjXNqvpVl1maiqxr08nbvZsfGrWJGzcWAI72cm0uRV1oOgDzFPVlKJoXFGzQGHMBSIxHn6YDD/N5CiZzG56BR+lHASgX7N+PNzyYapWdDIarN4Vy6h5W9hzJIHrmoUyqmdz6lV3H45K2riRqGeHk7pvH8H97qDmsGF4BVje7iwe25ktItcA/1TVB8+rovNggcKYC8zxKFgxAdbPJbqCPzMat2Ve4gEq+VTi/ub3c1/4ffj7+pOansk7P+xjytJdpGcqg65tzKPXNHLLrJeZnMyRKVOJnzMH3zp1CHtxPAEdOpRg50qP4l4e2xi4D2dSuz6QqKqB51xREbFAYcwFKnYXfD8Otn3FnqAQptZvzvcJ+6hWsRoDLhtA36Z98fX25dCxZMYs2MqizYdoV78qk/q2Pu3uIvHXX4kaPoK0P/6g6n33EvrUU+V+30VxbLirAtyBEyCy9s1vBGbiHO1xvJBtPW8WKIy5wB1cD0tHw97lbKxWl8m167Eu4U/qBNbh8daP0/3i7gjC179F8fxXW8hUZVSv5vRpd1H2UluAzMREDr/6Gkc/+AC/+vUJe/kl/Nu0KcGOlawiCRQi4gXciBMceuEcKx4FfAE8DnRV1ZXn2LAbgSmANzBbVV/O9Xo94F0g2FXmWVVdlF+dFiiMKSf2LIOlo9GoDfxYqwmTq1djR2I0Tas2ZXDbwXSu05mDfyUx9NON/LQvnhub1+LF3i2pFuDnVk3C2rVEjxhJ2qFDVH/wAUIGDsSrQvlL1HnegUJEJgJ34xwpngx8hfMFvgSoDMQDXc4lULjyWvwOdAMigV+AO1V1W44ys4ANqvqGiIQDi1S1QX71WqAwphxRhW1fw/djyYzbzf/qtmRaoB9/Jh+hXc12DGs/jGbVwpm9ai8Tv9tJsL8fE/u04pqm7udGZZw8yeEJ/8dfn32GX+NG1H7pZSq1bJHHh16YiiJn9hCcILEIqKeqd6vqd6qaCRR2BrwDsFtV96pqKvAxcHOuMooTiACq4NzBGGOMQwSa3wKP/YRXz6n84684vt7+KyMllH1Hd9FvYT9G/jCcXu38+erxTlT19+Wfb//MqK+3kJyWkV2Nd2AgYWPHUPetWWSeOMn+fv04PGUKmppagp0rnfILFG/jHPzXHdgpIq+LyPkuFagD5MycHum6llMEcI+IROIEqYHn+ZnGmAuRtw+0+ycMWo9vtzH0i9rNgr176F+9PYv3L6bnVz1ZcmgOHz7Smgc6NeDdNQfoMW01Ww4ec6smsHNnLp4/jyo9ehD3xpvs63sHyTt2lFCnSqc8A4WqPgTUwtmR/SvwKLBGRLYDz1C4uwo5w7Xc9dwJzFHVi4CbgLmuuRL3ikQGiMg6EVl35MiRQjTFGHNB8K0EnQbDE+sIqt+JJ9d9wXyfi7muTmdmb57NbfN7cWnTrcx5sB0nktO4dcYPzFi+m4zMU1893pUrU3vCy1w0YzrpsbHs69OX2DfeQNPTS7Bjpce5rHoK49SS2KzktWuBGcDnBclNISIdgQhVvcH1fDiAqr6Uo8xW4EZV/dP1fC9whaoezqtem6MwxgDOGVI/vQGLR0FgKJuvH8HEg4tZf3g9jao04pGWg5i3pjLfbImhQ4NqvNq31WlnRqUfPUrM2HEcX7SIii1aUPvll6jQuHEJdah4FcUchRtVjVbVCaraAvgbToBogpPEKLqA1fwCNBGRhiLiB/QD5uUq8weuJEmu48wrAnbLYIw5Oy8v6Pg4PLQEfCrS8suBzKnQlElXTyQtM41/rx5MeuhMhvUIYlv0cf4xZRVfrI8k5y/MPlWrUue1V6kzeRJpBw+y79bexM2ejWZk5PPBF7bz2pktIr5AT+A+Vb2lgO+5CZiMs/T1bVUdLyJjgHWqOs+10uktnJNpFfi3qn6XX512R2GMOU3KCVj0b9j4IdTrSNotM/j40A+8ufFNTqSeoFvdHuz5/Sp+2690vyyM8be0INjffRltemwsh0aP5sTiJVRq3Zqwl16kQsOGJdShouexIzxKAwsUxpg8bfoUFjwFXt7QaxrHGnVh5qaZfLTjI3zEhxaBt7Dql+aEBAQxsU8rrmoS4vZ2VeX4ggUcGjsOTU0ldMhTVL3nHsSrwAMypZYFCmOMyRK/Fz7vD1Hrod0DcMOL/JEcy+T1k1l8YDFVK4SQHnsDUZHN6X9VI4bdcMlpx5enxRwm+oXnSVixEv/LLyfsxfH41a1bQh0qGhYojDEmp/RUWDYOfpgCNS6F29+GmuGsj1nPxHUT2Ry7mSpe9Yne143GQW2YdEdrwmtXdqtCVTn2xRfEvPgSqkrNfw8j+I473I4JKUssUBhjzJnsXgpfPgopx+GG8dC+P5ko3+77linrpxCVEIVXUjjJMf9gaNfOPHTVxXh5uQeCtKgoop97joQf1xBw5ZWEjR+Hb1hYCXWo8CxQGGNMXk4ega8ehd1LoFkP6DUN/KuRkpHC+9ve561Nb5GQnkTq0Q5c5t+HKX07UzvY/aRZVeWvjz8m5pWJiJcXoUOHOHcXZWjuwgKFMcbkJzMT1s6AJREQGAq934IGTha8+OR4Zvw2g093fkZmpi/y13WMuuZRbm97+oqn1D//JPqFF0hcs5ZKbdsSNmZ0mdl3YYHCGGMKImoDfP4gHN0PVw+Dq//tHA8C7P1rL+PXvMLPh1eTmRZMi4r9eLP3Q1T1dz9pVlU59uVXHJ4wgYzEREIGDKD6IwPw8vM7wweWHhYojDGmoHLtuaD3WxB8akXTjwfXMGLFS8Sl7cMrtR5D2z3NfW27nlZNelwcMS++xPGFC/Fr1IiwMaPxb9fOkz05JxYojDHmXOXac0H4qcOtMzIzmLHuE2ZvmUGm9zEu8uvAtBufo3HV04ejTq5cSXREBOlR0QT3u4PQoUPxDgryZE8KxAKFMcYURtwe+G9/Z0jKtecCv1PnQcUlnuCRea+xI2keIhl0b3A7wzsOpEqFKm7VZCYkcGTqNOLnzsUnJISazz9H5W7dPN2bfFmgMMaYwkpPhe/Hwo9T3fZc5PTlpm1ErHqNjICfqegdwBNt/sXdl96Jr7evW7mkzZuJfv4FUnbsIKjb9dR87nl8a4Z6sjd5skBhjDHn6wx7LsixuS72ZAqD/ruIDSfn4hO4ixoVazP8iqe5vt71bpvwNC2NuDlziH19OuLrS+jTQwnu27fEl9JaoDDGmKJw8rATLPYsddtzkUVV+WZzNKOXfskJ/y/xrhhD82qtGHnFM7Ss0dKtqtQDB4geFUHi2rVUatfOWUrbqJGne5TNAoUxxhSVzExYOx2WjD5tz0WWpNQM3ljxO29t+Bjv6t8hPie5of6NDGn/FLUDa2eXy1pKGzNhApqYSPVHHqH6gIdLZCmtBQpjjClqB9c7E91H9zv7La4elr3nIkvk0UTGLtzAsphPqFB9NT5ecF/4vTx02UME+Z1a+XTaUtqxY/Bv29aj3bFAYYwxxSHlBCwaBhs/gnpXQu9Zbnsusvy4J5YXFvxAJP/FN3gDlf2CGdjmcW5vejs+XqeCS0kupbVAYYwxxWnjJ7BwiLPnoudUZ89FrlNk0zMy+fDnP5i4fCnpwfPw9t9L/aAGDLv8aa6+6OrsCW9nKe1U4ue+79GltBYojDGmuOXcc1GvI3QdAQ2vPq1YfEIqr363g0+3fUvFmt+C7xE61OrAsMuH0axas+xySZs3E/3c86Ts3OmRpbQWKIwxxhPSU2H9u7DqVTgRDQ06Q5fhp012A2yNOkbEvE38duwb/EO/R70S6dWoFwPbDKRmQE3AtZT2nTnETi/+pbQWKIwxxpPSkuHXObD6NTgZAw2vce4w6l3hVkxVWbApmvHf/MpRv2+pUP1HKnj7cH+L+3mg+QP4+zq7wD2xlNYChTHGlITURFj3NvwwGRKOQKNrocsIqHu5W7HE1HTeWL6HmT/+gm+Nb/EK3EhIpRoMbPMENze6GW8v72JfSmuBwhhjSlJqAvwy20m9mhgHTf7uDEnVcV8C+0dcIuMXbWPx3p+pXOcbMnz307RqU4a2H8qVta8Eim8prQUKY4wpDVJOws+znHOjko5C039A1+EQ1sqt2KpdR4iYv5UDSWuoUuc7UiWWq+pcxdB2Q2lc1UmEdHLFCqJHj3aW0t7Zj9AhQ85rKa0FCmOMKU2Sj8NPM2HNNEg+5hwH0mU41GqRXSQtI5O5aw4wack20gJW4l9zORkkc1uT23is9WOEVAo5bSltrYgIgq49PTdGQVigMMaY0ij5GKx9A9ZMdw4bDL8ZrnnW7XTa2JMpTPzfTj7ZsIMqtZahQWuo5FuR/i36c2/4vVT0qZi9lDb4ttuodt+9hWqKBQpjjCnNko7CmhlO0Eg9CS16wzXPQI1LsotsjjzGqHlb2HBoF6H1lpDou5FaAbUY1GYQ3S/ujqRngJcX4u1dqCZYoDDGmLIgMR5+nOYMS6UlQss+TsAIceYlVJWvf4vixUXbicvYRs0Gizmh+2levTlPt3+a9rXO+j2fJwsUxhhTliTEOhPeP78F6clw2R3OoYPVnb0TJ1PSmb5sN/9ZtQffKr9RufZiTmbE8XDLhxnUdlChPrKggaJks2YYY4xxBIRAtzEweCNc8Rhs/RJevxy+fhyO7iewgg/P3NiM757qQseafyd662D8E3oQmNny7HWfJwsUxhhTmgSGOtn0Bm+EDgNg02cwrR3MGwR//UGDkABm//Ny3rm/EwGJN5CeWK/Ym2RDT8YYU5odj4LVk5zjQVSh7b3QeShUuYjU9ExEwNe7cL/z29CTMcZcCCrXhptegUEbnCCxfi5MbQOLhuGXGFPoIHEuPB4oRORGEdkpIrtF5Nk8yvQVkW0islVEPvR0G40xptSpchH0mASD1kOrO53zpKa0gh9fL/aP9jl7kaIjIt7AdKAbEAn8IiLzVHVbjjJNgOFAJ1U9KiLFdxi7McaUNcH1oNdU6DwEVr7iPC9mHg0UQAdgt6ruBRCRj4GbgW05yjwMTFfVowCqetjDbTTGmNKvagO4ebpHPsrTQ091gD9zPI90XcupKdBURH4QkbUicuOZKhKRASKyTkTWHTlypJiaa4wxxtOBQs5wLfeyKx+gCdAFuBOYLSLBp71JdZaqtlfV9jVq1CjyhhpjjHF4OlBEAnVzPL8IiDpDma9VNU1V9wE7cQKHMcaYEuDpQPEL0EREGoqIH9APmJerzFdAVwARCcEZitrr0VYaY4zJ5tFAoarpwBPA/4DtwKequlVExohIL1ex/wFxIrINWAYMU9U4T7bTGGPMKbYz2xhjyinbmW2MMaZIWKAwxhiTrwti6ElEjgAHCvn2ECC2CJtTFlifywfrc/lwPn2ur6pn3V9wQQSK8yEi6woyRnchsT6XD9bn8sETfbahJ2OMMfmyQGGMMSZfFihgVkk3oARYn8sH63P5UOx9LvdzFMYYY/JndxTGGGPyVW4Cxdky64lIBRH5xPX6TyLSwPOtLFoF6PMQVybBTSKyVETql0Q7i1JBMii6yt0uIioiZX6FTHnMGlmAf9v1RGSZiGxw/fu+qSTaWVRE5G0ROSwiW/J4XURkquvPY5OItC3SBqjqBf8DeAN7gIsBP2AjEJ6rzGPAm67H/YBPSrrdHuhzV8Df9fhf5aHPrnJBwEpgLdC+pNvtgb/nJsAGoKrreWhJt9sDfZ4F/Mv1OBzYX9LtPs8+Xw20Bbbk8fpNwDc4qRyuAH4qys8vL3cU2Zn1VDUVyMqsl9PNwLuux58D14nImfJnlBVn7bOqLlPVRNfTtTjHvpdlBfl7BhgL/B+Q7MnGFZOC9PlCyxpZkD4rUNn1uAqnpzMoU1R1JRCfT5GbgffUsRYIFpGwovr88hIoCpJZL7uMOqfcHgOqe6R1xaMgfc6pP85vJGXZWfssIm2Auqq6wJMNK0ZFljWyDClInyOAe0QkElgEDPRM00rMuf7/fk48nTO7pBQks15BypQlBe6PiNwDtAeuKdYWFb98+ywiXsAk4H5PNcgDzjVr5EXAKhFpoap/FXPbiktB+nwnMEdVXxWRjsBcV58zi795JaJYv7/Kyx1FQTPr1QUQER+c29X8bvVKu4L0GRG5HhgJ9FLVFA+1rbicrc9BQAtguYjsxxnLnVfGJ7TLY9bIgvS5P/ApgKquASrinIl0oSrQ/++FVV4CRUEy680D/ul6fDvwvbpmicqos/bZNQwzEydIlPVxazhLn1X1mKqGqGoDVW2AMy/TS1XLcjKT8pg1siB9/gO4DkBELsUJFEc82krPmgfc51r9dAVwTFWji6rycjH0pKrpIpKVWc8beFtdmfWAdao6D/gPzu3pbpw7iX4l1+LzV8A+vwIEAp+55u3/UNVeeVZayhWwzxeUAvb5f8DfXVkjMyjjWSML2OehwFsi8hTOEMz9ZfkXPxH5CGfoMMQ17zIK8AVQ1Tdx5mFuAnYDicADRfr5ZfjPzhhjjAeUl6EnY4wxhWSBwhhjTL4sUBhjjMmXBQpjjDH5skBhjDEmXxYoTKkmIve7TnnN+jkhIhtF5AnXxsii+IzWIhIhItWKor4z1K8iMq4I64sQkWvPcH2OayOhMUXKAoUpK/oAHYHbgJ+BacALRVR3a5x16cUSKIrBKOC0QIFz2OGtHm6LKQfKxYY7c0H4TVV3ux5/JyKNgSc5j2AhIt6c+YycIiEiFTx5LIqq7vHUZ5nyxe4oTFn1CxAkIqEAIvKwa0gqWURiReQ/uYeSXENA40XkWRHZB6TinCr6jqvIrhxDXA1cPyoi9+eqp4vrepcc15aLyGoR6elKlpOCk+MkRxEZKSKRIpIkIitFpHWuev8uIotEJFpEEkVki4gMdQW07D64Ho7M0dYI12unDT2JSJiIvOf6M0lxJbW5J1eZrOG9K0TkAxE5LiJR4iTCqViQvwxzYbM7ClNWNcQ5juKkiLyMc2TDVGAYzvHK44AWInKlqmbkeN/9OOccPQ0k4CT0qQY8hzO8FekqFw2c63n+TV1tGOv6jJyHSt6Hc/7QE0AFYAywVESaqGpWuYuBpTjDask4J/pGADWArCxuHYE1wBycc7rI0WY3IhIArACqAiNwjqG+B+eoGn9VnZXrLXOBj4Ders+JAI7iDHWZ8qykMzfZj/3k94Pzxa7AJTi/2FQFHsEJEl8BDVyPX8j1vk6u992S45rinKhZKY/PaJzregNOnROU83oX1/UuOa4tBzKB1mfogwKxQECuutOAsXn0W1z9HYnzZe2Vq75xZ3jPHHJkcsMJSm7tdF1fAhwGvHP1f3SucguA30v634D9lPyPDT2ZsmIHzhdrPDAD+AB4EOiGM4T6gYj4ZP0APwHHcVJI5vStqiYVUxv3q+pveby2SFUTsp6o6n6c02s7Zl1zDRPNFJEDOMNiaTh3RsFAaCHaczVwUFWX57r+Ps5dSniu6wtzPd8M1CvE55oLjA09mbLiVpwhlhPAAVVNBsiao8A5NfNMcmcpLLKjl88gv7pj8rjWHLKTKs0DauMM+ewAkoBbcO4qCjNXUC2PNh3K8XpOufOvpOAMk5lyzgKFKSu26KlVTzllHZf9d5whmrxez3IuxyVn5dT2y3U9rxS5+dVdM49rB12PG+HMSdyrqu9nFRCRngVoZ17icYbscqvl+m+ZPWrceJYFClPWLcaZG6inqosLWUfWEtZKua7HuF5rket690J8xk0iEpA1/CQiDXAy7L3set3f9d+0rDeIiC9w9xnqSj1DW89kBdBHRDqp6g85rt+FM0ex/Vw6YMovCxSmTFPVPSIyAXhdRC7B+XJMxkkL2Q2YrarLzlLNNtd/HxeRd3G+rDepaqqIfAL0F5HfcVKIdseZzD5XSTj7P17BGc4ZjTOHMsn1+nbgADBeRDJcbXgqn/Z2F5Fvce6iolT1TGkv5wCDgS9EZCTO0N3dOH8uj6j7ajBj8mST2abMU9URwACcydtPga+BZ3C+RHcV4P0bceYFegKrcfZo1Ha9PBj4wvX6JzhzBQML0cz3cCaLXwfexUnLeZ26lsaqairOfMQhV9npwEpO3XHk9ATO0t75rrYOyKNfCcA1wHeuer4GWuEMb+VeGmtMnizDnTHGmHzZHYUxxph8WaAwxhiTLwsUxhhj8mWBwhhjTL4sUBhjjMmXBQpjjDH5skBhjDEmXxYojDHG5MsChTHGmHz9P3sRtHPlP/mrAAAAAElFTkSuQmCC",
      "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "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",
    "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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "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",
    "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",
    "\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
}
