{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "d479fbdb-1592-4328-ad2d-943b77db62e1",
   "metadata": {},
   "source": [
    "# GUMDPs: Policy optimization in the finite trials regime"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ef6e0cd1-edd4-4f03-8568-c3a2bb481526",
   "metadata": {},
   "source": [
    "Notebook containing the experiments for the MountainCar environment."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "a7627910-bf1f-4428-8fbd-eeda8c78bfd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# A valid Gurobi license is needed (https://www.gurobi.com/).\n",
    "# GUROBI_OPTIONS = {\n",
    "#    \"WLSACCESSID\": ,\n",
    "#    \"WLSSECRET\": ,\n",
    "#    \"LICENSEID\": ,\n",
    "#}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67846214-0895-468a-b937-0dd903edf0c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import math\n",
    "import json\n",
    "import itertools\n",
    "import numpy as np\n",
    "import matplotlib\n",
    "import cvxpy as cp\n",
    "from itertools import product\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "\n",
    "from envs.envs_gym import get_gym_env, MOUNTAINCAR_D_BETA_CONTINUOUS\n",
    "\n",
    "import seaborn as sns\n",
    "sns.set_style(\"dark\")\n",
    "\n",
    "matplotlib.rcParams['text.usetex'] =  True\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{pifont} \\usepackage{amsfonts}')\n",
    "matplotlib.rcParams.update({'font.size': 16})\n",
    "\n",
    "sns.set_palette(\"colorblind\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f8bcda2-f6d2-47fb-8262-bfcaba0747d5",
   "metadata": {},
   "source": [
    "#### Auxiliary functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a3b6a0b3-42fc-4f8c-9ae1-6d0baf31c668",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_trajectory(env, policy, traj_length):\n",
    "    # Args:\n",
    "    # env - environment.\n",
    "    # policy - policy specification (np.array).\n",
    "    # traj_length - length of the sampled trajectory.\n",
    "\n",
    "    states = []\n",
    "    actions = []\n",
    "\n",
    "    s_discrete, s_continuous = env.reset()\n",
    "\n",
    "    for t in range(traj_length):\n",
    "        states.append(s_discrete)\n",
    "\n",
    "        a = np.random.choice(range(env.num_actions), p=policy[s_discrete])\n",
    "        actions.append(a)\n",
    "\n",
    "        s_discrete, _, _, _, s_continuous = env.step(s_continuous, a)\n",
    "\n",
    "    return states, actions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7e7aab59-70ed-4322-a766-37f262644a3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def estimate_d_pi_from_trajectory(env, trajectory_states, trajectory_actions, gamma):\n",
    "\n",
    "    nS = env.num_states\n",
    "    nA = env.num_actions\n",
    "\n",
    "    d_hats = []\n",
    "    d_hat = np.zeros((nS,nA))\n",
    "    for t in range(len(trajectory_states)):\n",
    "        s_t = trajectory_states[t]\n",
    "        a_t = trajectory_actions[t]\n",
    "        \n",
    "        d_hat[s_t,a_t] += gamma**t * 1\n",
    "\n",
    "        d_hats.append(((1 - gamma)/(1 - gamma**(t+1))) * d_hat)\n",
    "        \n",
    "    return np.array(d_hats)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "80767f85-5f33-426e-ac4d-3752cf8211c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def estimate_f_d_pi_from_samples(env, obj_f, gamma, policy, N, K, max_traj_length, flatten=False):\n",
    "    \n",
    "    nS = env.num_states\n",
    "    nA = env.num_actions\n",
    "\n",
    "    f_estimated_list = []\n",
    "    for n in range(N):\n",
    "\n",
    "        # Compute d_hat from K sampled trajectories.\n",
    "        d_hat = np.zeros((max_traj_length,nS,nA))\n",
    "        for k in range(K):\n",
    "            traj_states, traj_actions = sample_trajectory(env, policy, traj_length=max_traj_length)\n",
    "            d_hat += estimate_d_pi_from_trajectory(env, traj_states, traj_actions, gamma)\n",
    "        d_hat = d_hat / K\n",
    "\n",
    "        # Compute f(d_hat), d_hat.shape = [max_traj_length, nS, nA].\n",
    "        if not flatten:\n",
    "            f_d_hat = np.array([obj_f(x) for x in d_hat])\n",
    "        else:\n",
    "            f_d_hat = np.array([obj_f(x.flatten()) for x in d_hat])\n",
    "\n",
    "        f_estimated_list.append(f_d_hat)\n",
    "\n",
    "    return np.array(f_estimated_list) # [N, max_traj_length]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "809d3eb9-3fc2-49f4-bac3-2249400399b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mean_ci(samples: np.ndarray, num_resamples: int=25_000):\n",
    "    # Point estimation.\n",
    "    point_estimate = np.mean(samples)\n",
    "    # Confidence interval estimation.\n",
    "    resampled = np.random.choice(samples,\n",
    "                                size=(len(samples), num_resamples),\n",
    "                                replace=True)\n",
    "    point_estimations = np.mean(resampled, axis=0)\n",
    "    confidence_interval = [np.percentile(point_estimations, 5),\n",
    "                           np.percentile(point_estimations, 95)]\n",
    "    return confidence_interval"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "efd9a240-c9f8-4683-85b1-faeba34a59d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def construct_random_policy(nS, nA):\n",
    "    pol = np.ones((nS, nA))\n",
    "    return pol / np.sum(pol, axis=1, keepdims=True)\n",
    "# print(construct_random_policy(nS=5, nA=3))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e8f65e11-a20e-441b-9730-97dd357e462a",
   "metadata": {},
   "source": [
    "#### Infinite trials solver"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "88167e05-4da9-4d5c-985c-dc0cb2fb71b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def build_transition_matrix(env, num_samples=2_000):\n",
    "    \n",
    "    nS = env.num_states\n",
    "    nA = env.num_actions\n",
    "    P = np.zeros((nA, nS, nS))\n",
    "    \n",
    "    for action in range(nA):\n",
    "        for state in range(nS):\n",
    "\n",
    "            count_next_states = np.zeros(nS)\n",
    "            for _ in range(num_samples):\n",
    "                continuous_state = env._get_continuous_state(state)\n",
    "                new_state, _, _, _, _  = env.step(continuous_state, action)\n",
    "                count_next_states[new_state] += 1\n",
    "            P[action,state,:] = count_next_states / np.sum(count_next_states)\n",
    "\n",
    "    return P\n",
    "\n",
    "def build_initial_states_distribution(env, num_samples=2_000):\n",
    "    \n",
    "    nS = env.num_states\n",
    "\n",
    "    count_initial_states = np.zeros(nS)\n",
    "    for _ in range(num_samples):\n",
    "        initial_state, _ = env.reset()\n",
    "        count_initial_states[initial_state] += 1\n",
    "    p_0 = count_initial_states / np.sum(count_initial_states)\n",
    "\n",
    "    return p_0\n",
    "    \n",
    "# env, obj_f = get_gym_env(\"pendulum_entropy\")\n",
    "# print(\"env.num_states\", env.num_states)\n",
    "# print(\"env.num_actions\", env.num_actions)  \n",
    "# P_sampled = build_transition_matrix(env)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f2a07214-7cd0-48e9-9549-052a9370b80b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_cvx_opt_problem(env, obj_f, gamma):\n",
    "\n",
    "    nS = env.num_states\n",
    "    nA = env.num_actions\n",
    "\n",
    "    print('Building transition matrix and initial states distribution...')\n",
    "    P_matrix = build_transition_matrix(env)\n",
    "    p_0 = build_initial_states_distribution(env)\n",
    "    print(\"P_matrix.shape\", P_matrix.shape)\n",
    "    print(\"p_0.shape\", p_0.shape)\n",
    "    \n",
    "    x = cp.Variable((nS, nA))\n",
    "    \n",
    "    constraints = []\n",
    "    for s in range(nS):\n",
    "        lhs = cp.sum(x[s, :])\n",
    "        rhs = (1 - gamma) * p_0[s] + gamma * sum(\n",
    "            cp.sum(cp.multiply(P_matrix[a][:, s], x[:, a])) for a in range(nA)\n",
    "        )\n",
    "        constraints.append(lhs == rhs)\n",
    "    constraints.append(x >= 0.0)\n",
    "\n",
    "    obj = obj_f(x)\n",
    "    \n",
    "    prob = cp.Problem(obj, constraints)\n",
    "    prob.solve()\n",
    "\n",
    "    # x.value[x.value < 0.0] = 1e-8 # TODO.\n",
    "    # x.value += 1e-05 # TODO\n",
    "    \n",
    "    # print(\"status:\", prob.status)\n",
    "    # print(\"optimal value\", prob.value)\n",
    "    # print(\"optimal var\", x.value)\n",
    "\n",
    "    opt_policy = x.value / np.sum(x.value, axis=1, keepdims=True)\n",
    "\n",
    "    return prob.value, opt_policy"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2bcf07af-4a04-4262-aa4e-d6e324d41b37",
   "metadata": {},
   "source": [
    "#### Plotting functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2c065c43-b2d2-4722-846e-411c78f212e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_2(DATA_TO_PLOT, mdp_name):\n",
    "\n",
    "    plt.figure(figsize=(5.0, 4.0))\n",
    "    \n",
    "    # Plot f(\\hat{d}) of \\pi_random.\n",
    "    random_policy_f_data = DATA_TO_PLOT[\"random_policy_f\"][:,-1]\n",
    "    cis = mean_ci(random_policy_f_data)\n",
    "    errors = np.array([np.mean(random_policy_f_data) - cis[0], cis[1] - np.mean(random_policy_f_data)]).reshape(-1,1)\n",
    "    plt.errorbar(1, np.mean(random_policy_f_data), yerr=errors, capsize=3, fmt='o')\n",
    "\n",
    "    print(\"pi_rand\", np.mean(random_policy_f_data), \"ci_low:\", np.mean(random_policy_f_data) - cis[0], \"ci_up:\", cis[1] - np.mean(random_policy_f_data))\n",
    "\n",
    "    # Plot f(\\hat{d}) of \\pi_\\infty^*.\n",
    "    infinite_trials_policy_f_data = DATA_TO_PLOT[\"infinite_trials_f\"][:,-1]\n",
    "    cis = mean_ci(infinite_trials_policy_f_data)\n",
    "    errors = np.array([np.mean(infinite_trials_policy_f_data) - cis[0], cis[1] - np.mean(infinite_trials_policy_f_data)]).reshape(-1,1)\n",
    "    plt.errorbar(2, np.mean(infinite_trials_policy_f_data), yerr=errors, capsize=3, fmt='o')\n",
    "\n",
    "    print(\"pi_infinity\", np.mean(infinite_trials_policy_f_data), \"ci_low:\", np.mean(infinite_trials_policy_f_data) - cis[0], \"ci_up:\", cis[1] - np.mean(infinite_trials_policy_f_data))\n",
    "    \n",
    "    # Plot f(\\hat{d}) of MCTS policy.\n",
    "    mcts_data = DATA_TO_PLOT[\"mcts_planner\"]\n",
    "    cis = mean_ci(mcts_data)\n",
    "    errors = np.array([round(np.mean(mcts_data) - cis[0],4), round(cis[1] - np.mean(mcts_data),4)]).reshape(-1,1)\n",
    "    plt.errorbar(3, np.mean(mcts_data), yerr=errors, capsize=3, fmt='o')\n",
    "\n",
    "    print(\"pi_mcts\", np.mean(mcts_data), \"ci_low:\", np.mean(mcts_data) - cis[0], \"ci_up:\", cis[1] - np.mean(mcts_data))\n",
    "    \n",
    "    # ax.set_ylim([-1.5,-0.2])\n",
    "    plt.xticks([1,2,3], [r\"$\\pi = \\pi_{Random}$\", r\"$\\pi = \\pi_\\infty^*$\", r\"$\\pi = \\pi^*_{MCTS}$\"])\n",
    "    plt.grid()\n",
    "    #plt.legend()\n",
    "\n",
    "    plt.ylabel(r'$F_{1,H}(\\pi)$')\n",
    "\n",
    "    os.makedirs(\"figs/\", exist_ok=True)\n",
    "    plt.savefig(f'figs/{mdp_name}_plot2.pdf', bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "98b00acd-e3a3-4308-af54-63f815735f9a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_3(DATA_TO_PLOT, mdp_name):\n",
    "\n",
    "    plt.figure(figsize=(5.0, 4.0))\n",
    "    # fig.tight_layout()\n",
    "    \n",
    "    # Plot f(\\hat{d}) of \\pi_random.\n",
    "    random_policy_f_data = DATA_TO_PLOT[\"random_policy_f\"][:,-1]\n",
    "    plt.violinplot(random_policy_f_data, [1], widths=0.3,\n",
    "                       showmeans=False, showmedians=True, showextrema=True)\n",
    "    \n",
    "    # Plot f(\\hat{d}) of \\pi_\\infty^*.\n",
    "    infinite_trials_policy_f_data = DATA_TO_PLOT[\"infinite_trials_f\"][:,-1]\n",
    "    plt.violinplot(infinite_trials_policy_f_data, [2], widths=0.3,\n",
    "                      showmeans=False, showmedians=True, showextrema=True)\n",
    "\n",
    "    # Plot f(\\hat{d}) of MCTS policy.\n",
    "    mcts_data = DATA_TO_PLOT[\"mcts_planner\"]\n",
    "    plt.violinplot(mcts_data, [3], widths=0.3,\n",
    "                       showmeans=False, showmedians=True, showextrema=True)\n",
    "    \n",
    "    #ax.set_ylim([-0.01,1.01])\n",
    "    # ax.set_title(r\"$\\gamma = $ \" + str(gamma_val))\n",
    "    #ax.set_xlabel(r'$H$')\n",
    "\n",
    "    plt.grid()\n",
    "    #ax.legend()\n",
    "    plt.xticks([1,2,3], [r\"$\\pi = \\pi_{Random}$\", r\"$\\pi = \\pi_\\infty^*$\", r\"$\\pi = \\pi^*_{MCTS}$\"])\n",
    "\n",
    "    plt.ylabel(r'$F_{1,H}(\\pi)$')\n",
    "    \n",
    "    os.makedirs(\"figs/\", exist_ok=True)\n",
    "    plt.savefig(f'figs/{mdp_name}_plot3.pdf', bbox_inches='tight', pad_inches=0)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "21efa11e-f63b-4b30-a54d-f13d1a2a112a",
   "metadata": {},
   "source": [
    "## Imitation learning"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f4add7d7-3cdb-4933-9786-a00ebadf4d91",
   "metadata": {},
   "source": [
    "#### The objective function is $f(d) = \\| d - d_\\beta\\|_2^2, \\quad d_\\beta \\in \\Delta(\\mathcal{S} \\times \\mathcal{A})$"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ef5501af-d26c-4c12-bd30-cfd2bb8ec861",
   "metadata": {},
   "source": [
    "#### Mountaincar environment (continuous)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "df31f360-443f-4c5b-9170-0a900992de46",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_random_policy_objective_imitation_learning(env, obj_f, mcts_plan_path, data_folder_path=\"data/\"):\n",
    "\n",
    "    # Load MCTS planner data and MDP.\n",
    "    with open(data_folder_path + mcts_plan_path + \"/exp_data.json\", 'r') as f:\n",
    "        mcts_plan_data = json.load(f)\n",
    "        mcts_plan_data = json.loads(mcts_plan_data)\n",
    "    f.close()\n",
    "\n",
    "    # Extract parameters.\n",
    "    N = int(mcts_plan_data[\"config\"][\"N\"])\n",
    "    max_traj_length = int(mcts_plan_data[\"config\"][\"H\"])\n",
    "    K = 1 # Single trial setting (K=1).\n",
    "    gamma = mcts_plan_data[\"config\"][\"gamma\"]\n",
    "    print(\"N\", N)\n",
    "    print(\"Max. traj. length:\", max_traj_length)\n",
    "    print(\"Gamma:\", gamma)\n",
    "\n",
    "    # Compute random policy finite trials objective value.\n",
    "    random_policy = construct_random_policy(nS=env.num_states, nA=env.num_actions)\n",
    "    random_policy_f_estimated = estimate_f_d_pi_from_samples(env, obj_f, gamma, random_policy,\n",
    "                                                             N=N, K=K, max_traj_length=max_traj_length, flatten=False)\n",
    "\n",
    "    return np.array(random_policy_f_estimated) # [N,H]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "55880960-0b3c-4df3-8a1c-98de6459c5ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_mcts_data_imitation_learning(mcts_plan_path, data_folder_path=\"data/\"):\n",
    "\n",
    "    # Load MCTS planner data and MDP.\n",
    "    with open(data_folder_path + mcts_plan_path + \"/exp_data.json\", 'r') as f:\n",
    "        mcts_plan_data = json.load(f)\n",
    "        mcts_plan_data = json.loads(mcts_plan_data)\n",
    "    f.close()\n",
    "\n",
    "    return np.array(mcts_plan_data[\"f_vals\"]) # [N]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "4f0c8614-05b5-4c46-9994-209819cd260b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "\n",
    "def solve_gurobi_opt_problem_imitation_learning(env, gamma, d_beta):\n",
    "\n",
    "    nS = env.num_states\n",
    "    nA = env.num_actions\n",
    "\n",
    "    print('Building transition matrix and initial states distribution...')\n",
    "    P_matrix = build_transition_matrix(env)\n",
    "    p_0 = build_initial_states_distribution(env)\n",
    "    print(\"P_matrix.shape\", P_matrix.shape)\n",
    "    print(\"p_0.shape\", p_0.shape)\n",
    "    \n",
    "    with gp.Env(params=GUROBI_OPTIONS) as guroby_env, gp.Model(env=guroby_env) as m:\n",
    "    \n",
    "        x = m.addVars(nS, nA, lb=0.0, name=\"x\")\n",
    "    \n",
    "        for s in range(nS):\n",
    "            lhs = gp.quicksum(x[s, a] for a in range(nA))\n",
    "            \n",
    "            rhs = (1 - gamma) * p_0[s]\n",
    "            \n",
    "            for a in range(nA):\n",
    "                rhs += gamma * gp.quicksum(P_matrix[a][s_prime, s] * x[s_prime, a] for s_prime in range(nS))\n",
    "            \n",
    "            m.addConstr(lhs == rhs, name=f\"flow_state_{s}\")\n",
    "    \n",
    "        quad_expr = gp.QuadExpr()\n",
    "        for s in range(nS):\n",
    "            for a in range(nA):\n",
    "                quad_expr.add(x[s, a] * x[s, a] - 2 * d_beta[s, a] * x[s, a])    \n",
    "            \n",
    "        # Set the objective. Change GRB.MAXIMIZE to GRB.MINIMIZE if needed.\n",
    "        m.setObjective(quad_expr, GRB.MINIMIZE)\n",
    "        \n",
    "        m.optimize()\n",
    "\n",
    "        # Check if the optimization succeeded.\n",
    "        if m.status != GRB.OPTIMAL:\n",
    "            raise Exception(\"Model did not solve optimally.\")\n",
    "    \n",
    "        # Extract the solution.\n",
    "        x_opt = np.zeros((nS, nA))\n",
    "        for s in range(nS):\n",
    "            for a in range(nA):\n",
    "                x_opt[s, a] = x[s, a].X\n",
    "\n",
    "        obj_val = m.ObjVal\n",
    "\n",
    "    opt_policy = x_opt / np.sum(x_opt, axis=1, keepdims=True)\n",
    "\n",
    "    # row_sum = np.sum(x_opt, axis=1, keepdims=True)\n",
    "    # opt_policy = np.divide(x_opt, row_sum, out=np.zeros_like(x_opt), where=row_sum != 0)\n",
    "    \n",
    "    return obj_val, opt_policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a0e82b1c-76af-4313-95d2-a73c222e8ccf",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_infinite_trials_objective_imitation_learning(env, obj_f, d_beta, mcts_plan_path, data_folder_path=\"data/\"):\n",
    "\n",
    "    # Load MCTS planner data and MDP.\n",
    "    with open(data_folder_path + mcts_plan_path + \"/exp_data.json\", 'r') as f:\n",
    "        mcts_plan_data = json.load(f)\n",
    "        mcts_plan_data = json.loads(mcts_plan_data)\n",
    "    f.close()\n",
    "\n",
    "    # Extract parameters.\n",
    "    N = int(mcts_plan_data[\"config\"][\"N\"])\n",
    "    max_traj_length = int(mcts_plan_data[\"config\"][\"H\"])\n",
    "    K = 1 # Single trial setting (K=1).\n",
    "    gamma = mcts_plan_data[\"config\"][\"gamma\"]\n",
    "    print(\"N\", N)\n",
    "    print(\"Max. traj. length:\", max_traj_length)\n",
    "    print(\"Gamma:\", gamma)\n",
    "    \n",
    "    x_star, opt_policy_infinite_trials = solve_gurobi_opt_problem_imitation_learning(env, gamma, d_beta)\n",
    "    # print(\"np.sum(opt_policy_infinite_trials)\", np.sum(opt_policy_infinite_trials))\n",
    "    # print(\"opt_policy_infinite_trials[np.where(opt_policy_infinite_trials < 0.0)]\", opt_policy_infinite_trials[np.where(opt_policy_infinite_trials < 0.0)])\n",
    "    infinite_trials_f_estimated = estimate_f_d_pi_from_samples(env, obj_f, gamma, opt_policy_infinite_trials,\n",
    "                                                            N=N, K=K, max_traj_length=max_traj_length, flatten=False)\n",
    "\n",
    "    return np.array(infinite_trials_f_estimated) # [N,H]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f446c30-3d8a-4b10-b078-05ccdc2d08de",
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_steps = [10,20,50,100,500,1_000,2_000,3_000,4_000]\n",
    "mcts_planner_data = ['mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-22-35-07', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-22-35-17', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-22-35-39', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-22-36-46', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-22-39-02', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-22-53-49', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-23-25-18', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-30-00-33-07', 'mountain_car_continuous_imitation_learning_mcts_gamma_0.9_2025-04-29-16-56-22']\n",
    "\n",
    "env, obj_f = get_gym_env(\"mountain_car_continuous_imitation_learning\")\n",
    "\n",
    "exp_idx_to_plot = -1\n",
    "mcts_data_path = mcts_planner_data[exp_idx_to_plot]\n",
    "\n",
    "# Load distribution to imitate.\n",
    "with open(\"data/\" + MOUNTAINCAR_D_BETA_CONTINUOUS + \"/train_data.json\", 'r') as f:\n",
    "    ql_data = json.load(f)\n",
    "    ql_data = json.loads(ql_data)\n",
    "f.close()\n",
    "imitation_learning_d_beta = np.array(ql_data[\"estimated_d_pi\"])\n",
    "\n",
    "data_to_plot = {}\n",
    "data_to_plot[\"random_policy_f\"] = compute_random_policy_objective_imitation_learning(env, obj_f, mcts_data_path)\n",
    "data_to_plot[\"mcts_planner\"] = load_mcts_data_imitation_learning(mcts_data_path)\n",
    "data_to_plot[\"infinite_trials_f\"] = compute_infinite_trials_objective_imitation_learning(env, obj_f, imitation_learning_d_beta, mcts_data_path)\n",
    "# print(data_to_plot)\n",
    "print(\"Random policy:\", data_to_plot[\"random_policy_f\"][:,-1])\n",
    "print(\"Infinite trials policy:\", data_to_plot[\"infinite_trials_f\"][:,-1])\n",
    "print(\"MCTS planner:\", data_to_plot[\"mcts_planner\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "e0c15b5c-1f08-45bd-ab76-7164833047d3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pi_rand 0.1786984098215929 ci_low: 0.03889044802619229 ci_up: 0.040853116355808405\n",
      "pi_infinity 0.06538797344293193 ci_low: 0.013572382653567222 ci_up: 0.015756554043875173\n",
      "pi_mcts 0.035875588806530835 ci_low: 0.010988176762198085 ci_up: 0.012558103163929565\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_2(data_to_plot, mdp_name=f\"mountaincar_continuous_env_imitation_learning_exp_steps_{exp_steps[exp_idx_to_plot]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "5133ba5b-3850-41eb-84a4-51de60cb7933",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_3(data_to_plot, mdp_name=f\"mountaincar_continuous_env_imitation_learning_exp_steps_{exp_steps[exp_idx_to_plot]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "26d49833-1706-47ad-a94b-48b8a346db62",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAegAAAF+CAYAAABJb4lSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABuJUlEQVR4nO3deXxU9b0//tc5s08ySxb2DItIgCS0tgUtsa0oUQL+Wmt6K/fbVRS0yxXbW6hdJPcW7SbYW/R+61W0eLtY461Y/V4lqCitTVygdoFAQCGQSdiyzL6dOed8fn9MZkjIOpNZzpl5Px8Pbq+znDn5JHPe57O93xxjjIEQQgghisLn+gQIIYQQMhwFaEIIIUSBKEATQgghCkQBmhBCCFEgCtCEEEKIAlGAJoQQQhSIAjQhhBCiQBSgCSGEEAWiAE0IIYQokDbXJ5Dv+vp8SCVXG8cBZWWWlN9PxkdtnFnUvplF7Zt56Wjj+DFSQQE6wxjDpL48k30/GR+1cWZR+2YWtW/m5aqNaYibEEIIUSAK0IQQQogCUYAmhBBCFIgCNCGEEKJAFKAJIYQQBaIATQghhCgQBWhCCCFEgWgfNCEFSJIkyLKU0c/gOCAcDiMaFWifbgZQ+2bepW3M8xpoNJqsfT4FaEIKiCBE4Pe7IQjhrHxefz8PWZaz8lmFiNo38y5tY73eiOJiO/R6Q8Y/mwI0IQVCFKNwuS5Ao9HCZiuDVqsDwGX0MzUaDpJE3btMofbNvIttzCCKUQQCPrhcF1BWNn3gO5Q5FKAJKRA+nxs8z6O0dBp4PjvLT7RaHqJIPbxMofbNvMFtrNMZYDCY0dd3Fn6/G3b7lIx+Ni0SU7jeoABvRMz1aRCVY4xBEMIwmYqyFpwJyUc8z8NoLEIkEgbL8OQ/fVMVri8ooCcg5Po0iMpJkgjGZOh0mZ83IyTf6fUGMCZDkjLbeaIhboVjDIjSIhAySfE7feo9EzJ58e8R9aAJohKDTPsoSFpkdlEYIYUhO98jCtAqIEgyIrQQhBBCCgoFaIXTa3hEZQZBogBNCCGFhOagVUBmDDKNcBOSMfX118Lv96GychF++cvfjPlan8+H1auvBQCsWLES99//01Ffe+xYO3796104ePAd+P0+FBdbMHPmLCxdeiVuuqkBs2ZV4NixdmzZck/S5/zMM88P+e8DB97Gb3/732hvPwq/35f4nM9//suYNasi6eOP5cCBt/HNb34d9933E1x7bV1aj00uogCtAhSbCcmO48fb0d3dNWZAe+21VyZ0rN/+9r/xyCMPY+bMWfjUp27GrFkV6O7uwsGD7+Cpp36FxYurMGtWBWbOnIUVK1Ym3mez2QAA+/a9guPH27FixUosXlwFAPB4PENeE/eLXzyEp576FSorF+FTn7oZNpsNR48ewQsvPIcXXngOf/7zwaTagSgDBWgVYIyCNCGZNnPmLJw50439+/fh85//8qive/753aisXITjx9tHfc0DD/wQL7zwHJYuvRI///kvhj1/4MDbWLQoFnQtFgu+9rWNw17T3d2F48fbcdNNDVi27KpRP+vAgbfx1FO/wqc+dTO+/e3vD3nO5/PhhRd2j/peomw0B60CDCzjy/kJKXTFxRasWLESzz8/ekDz+Xw4frwdK1deP+prjh1rHzM4A8CyZVfBYrFM+pwBJM730uAMxIL/WDcbRNkoQKsA9aAJyY6VK6/HmTPdOHZs5N5xvDc6eEj6Uj/96f0AgK9+dXivOBP8fl9WPodkHwVolaAONCGZF1/w9Pzzz474/PPP78bSpVeOOkcdH5aurFyEhQsXZew8B4sPf//2t/+dlc8j2UMBWg2oB00yjDGGgCCp7l8mpn5WrFiJ1157ddjj3d1dOHOmGzfd1DDqew8efAcAsHTplWk/r9HEe/OPPPIwvvGNr+H553eju7sr6eMcO9aO2277Ag4ceBuvv/4qbrvtC/jYx5YmHpuI55/fjdtu+wLq669Fff21uPfee4ady4EDb+OWW27CsWPtidfHP+fSkYtkXhv3wAM/xC233DTq5x871p445rFj7fjGN76G+vprk2ip7KFFYmpBXWiSIYwxfPK3f8WBbm+uTyVpV86y4oXPfwgcl77MTitXXo/9+/fhwIG3hyzOis/1jrWtKB4M0r2taSyzZlXgiSd+gy1b7sHBg+8kbhIqKxfhppsaxryhGMzr9eD48XZs2fIdLFq0GCtXXo9FixbjhReewze/+XX8x3/833EXq/32t/89ZNX5I488jNtv/yL+539eGDLnfuZMN3760/thtVpx000N6O7uwlNP/Qp33/1VNDe/PuS4E32tz+fD7bd/AV6vF1/84q0oLrbg+ed3D/t8r9eDM2e6cfDg24lV9tddp8ytYhSgVYCBUQ+aZBQlAL3o4jD37iEB6YUXnhtz7jmXFi5chGeeeR7HjrVj376XcfDgOzh+vB3btv0Ix44dHXEB2Wiuu65uyOuvvbYO3/zm1/Hb3/73mAF62bKrhu3NnjmzArff/gW88MLuYYvV/H7fsD3nTz31q2E3RhN97SOPPIQzZ7rR1PSHxA3STTc14JZbbhrx8x955GF87nNfGnEFvVJQgFYBxqgDTTKH4zi88PkPIRhNf7a6TNcrNuv4tPae41asWIn9+/cl/vvYsXb4/b4xV28DF3vOqQwxp8PChRfnvuMJUF544Tlce23dmMF16DEWD/nvZcuuwtKlV+LgwXfg8/mSWn0eP5eR2uPSnn281z3SoreJvHbwDdTgz1u69Eo8//zwAF1ZuUjRwRmgAK0KDDQHTTKL4zgU6TVpP65Wy0Pk1dc/v+mmBuzfvw+vv/4qrr22Ds8//yyKiy3jZs2Kzz2PtUc6WxYuXIT77vspbr/9C3j99VcnHKBHsmzZVTh48B2cOdM95uK3+L7ro0eP4Pjxdni9o0+bFBdPPNCP99r4fPT+/fuG3FiNZbybLSWgAK0StA+akOxZtuwqFBdbsG/fK7j22jq89tqrE5qnjGcGO3jwHRw71p61ldyjiX/+mTPdGf+sePrP4mILvvjFW3HTTQ2wWm24/fYvjPh6q9U64WNP9LXJpB6dOXPWhD8/V2gVt0pQqQxCsuu66+oSi8X8fh9uuukzE3rffffFcnM/8shDmTy9BJ9v9H3Q8ecqKyd3oxBfxT3WDceWLd/BzJmz0Nz8Oj7/+S9j2bKrsnaDEv+cia42VwsK0CohU7UMQrIqHpAfeeRhFBdbJhxsFi6M5cM+ePAd3HvvyEUwuru78Prrw7dypeL227+AX/xi5JuBeBGOlStvmPDxLp0vfv31V3Hw4DvjLpCLFxsZLJsB81OfuhkvvPDciPPdo23JUjoa4lYJWsdNSHYtXLgIM2fOwvHj7fjc576U1Hu//e3vY9asCjzyyMO45ZabcNNNDYl51AMH3sb+/fuwYsXKtFSCKi624KmnfoUXXngOixYtRmXlIvj9vsSc8Ve/eldSPdmnnvoV/H4fli27CgcOvI0XXngOxcUWfPWrd435vqVLr8T+/ftw7733YOXK6xPFOrLl29/+Ptrbj2Lt2k/jc5/7EhYvrsKZM93Yty9W3GS8KmVKRAFaJWgKmpDs27z5ezhw4O0J7yUe7POf/zKWLr0Kv/71Lvz6108mVhxXVi7CV796V9pyZP/yl7/BgQNv4/nnd+P48XYcPPgOiostWLRoMe6776dJDzNv3vw9dHd34ZFHHobX68WKFStxzz33jrt6+777footW+7B/v37EtnUdux4BD/96f1Z2xf+y1/+Br/4xUOJimHxSmFf/OK6rHx+unGMVh9lVG+vL6XgynFAebkF7xw/j1OuEObYTbis1Jz+Eyxg8TZO9XekJtGogL6+sygrmwGdTp+1z830NqtCl872jS/y2rz5eyndkOSrkdo4me9T/DqTCpqDVgk53yMIIYSQIShAqwStESOEkMJCAVolaJEYIYQUFgrQKkEj3IQQUlhoFbdK0BA3ISSTli27Cn/+88FcnwYZhHrQKsBxHAVoQggpMBSgVYADzUETQkihoQCtBrEITQUzCCGkgKhiDnrnzp1wu92w2+1wOp2ora1FfX19Ro6xbt06VFVVYc2aNaiurobT6cTTTz8Nn8+HrVu3putHSkq8WB8b9P8Tkpps3uQxSDIDAwNHf7kkr2Tne6T4AN3Y2AiHw4HNmzcnHlu3bh08Hg/Wrl2b9mN4PB48/vjjePzxxxOP1dbWYteuXZP8SSaHYWAlN13nSAp4PjZYJkkSdLrsfGZUYpBlGRxj0PGxtRSE5ANJEgFc/F5liqIDdFtbG5qamnDs2LEhj2/atAkNDQ0TCtDJHqOiogKrV6/GoUOH4HA4cPXVV6O2tnbyP8wkcOBiAZr60CRFGo0WWq0ewaAfBoMp48FSlGUIkgyNhocoyeDAQ6ehv12ifowxBIMBaLV6aDSZDaGKDtBNTU2orq4e9nj8sebm5nGHupM9ht1ux4YNGyZz2mnHcTT/TCavqMgKj6cXLlcPzOaigYtL+oOmJDMIsgwwBp7TQpIkhEQGUcNDm+EeR6GRZQ6SRNeGTLrYxgySJCIYDEAQQrDZyjP+2YoO0K2traiqqhrxOavVitbW1nEDdDqOoQSJIW5CUmQyFQEAAgEv3O7ejHwGY4AoM8iMgec48BoOssQSN5haDQ+eOtJpw/M8ZJmKkWTSpW2s1ephs5Unvk+ZpOgAHV/MNRKbzYbDhw9n7BhtbW04fPgwampqRuyBT1SqI4nx93EckOh0cKkfjww3uI0LhdlcBLO5CJIkpv3CLsoyur1h9AdFlJi10ICDxWaCzxMCA+AJi9CDh8NmhFmnSetnF6qSkiK4XIFcn0ZeG9zGPM8nPaw9meuLYgO01+sd83mr1Trua1I5htvtxrZt23D11Vdj7dq1aG1tRUNDA3bs2AGHwzGxkx+krCy1MmNxdnsRgrwGJq0GZWXFMGjpwpZuk/0dkdgUzKn+EIQwj7mluiFD2fZyQ+x/GUOPX0BIp0PFlCL6W06TGTOMuT6FvJerNlZsgM6VeGCOq62txerVq7Fu3Tq8+uqrSR+vry/1etBlZRa43QF4fQJCGg49Bg5GuqilTbyNU/0dkYvO+cLocIVgM+rgG1jhygGwlxTB7QokNqVoGEOHOwifN4i5dhN0GpqTThX9/WZeOto4foxUKDZAW63WMZ8fr3ec6jFGWhleW1uL7du3T2hR2qUYm9zccfy9jAED625Imk32d1To+oICTrsjKNJrodfwF9tyYGhv8PoJDhxKTTpc8AvQcBxm20zQ0KT0pNDfb+blqo1Ve/vq8XjGDcDpOkZ8aLu1tXVSnzdZ9B0kSuOLiOj0hKHTcBOeV9bwsSB9zifgjC9MOxQIGYWiA7TVaoXb7R7xOa/Xi5qamrQeY+PGjWhoaBj1WKMdJ9Ni26zoLpkoSygq4bQ7BFFisBqSG4zTaXjYjFp0ecI4749k6AwJUTdFB+jVq1ejq6tr1OcnkkAkmWMcOXIENptt2Gs8Hg8AYMmSJeN+XqawQf+XkFyLSjI6PWH4IxJKTKnNlBm0PIoNWnR6wugNCmk+Q0LUT9EBur6+Hm1tbcPmiuNDzRMJ0MkcY9WqVSOm9GxubgYw8vx0NsRm6Bj1oIkiSDJDlzeMvlAUpWbdpLKSmXUa6DU8TrvDcIejaTxLQtRP0QG6trYWq1atwqOPPjrk8Z07d2LHjh3D5o/r6upQV1eX8jHuvPNONDY2DnldW1sbHnvssRE/L1viqT4JyTXGGM76IzjnE1Bm0qZlgZfFoAXAcNodhj8iTv4kCckTHFPBCo2JVqJqaGiAzWYbsRc80WN4vV5s374dFosFTqcTQCxwp5qspLc39W1W5eUWvHP8PHqDUUgyQ/XU4oGLGUmHeBun+jsqRBcCAjr6g7AYtDBox76/57iLSR4m0r59QQFmnRbzS00wUSKTcdHfb+alo43jx0jpvWoI0GqWzgBdNbU46cU4ZHR0gUuOOxzF+31B6DU8ivTjB9BkAzRjDH3BKOwmLeaVmKGnPdJjor/fzMt1gKZvgApwiF286F6K5EpAEHHaHQbHYULBORUcx6HUrENfUITTHYJIOaZJgaMArRYczUOT3IiIMk65w4iIEuzGzBaT5jkOZWYdzgcFdHsikOmmlBQwCtAqQtcqkm2iLKPTE4I3EkWpKbPBOU7Lcygx6nDGH8E5X4RGjkjOREQZgRwuXKQArRIcR7ugSXbJjKHbE0FPQECpST+p7VTJ0mt4WA0aOD1h9ARp+xXJvmBUwsn+IM56wzk7BwrQasFAPQmSVed9EZzxR1Bi0kGbg3zZRq0GJp0Gp10h9IcoSJPsCQgiTvaHcD4g5LRjREuCVYTCM8mW3qAApzcMi16T09XURXoNJJnhtDsELc/RLgaScb6IiA5XCGFRytiCyImiHrRKUHAm2eKNiOh0h6HX8IrYj2w1aiFKDKddIQQEKdenQ/KYOxzFif4gIqKMMrMeua6zRgFaRWiEm2RaMCrhtCsEiTFFJcUpMWkRiErodIcQEWn7FUm/vqCAE/2xv/1Sc3YWRI6HArRKcKBeNMksQZLR6Q4hEJVQYlROcAZie6TLzDq4I1Gc9oQQlShIk/TpCQjocIXAc8j4VsJkUIBWDao3STJHkhmc7hD6QyLKJlkAI1N4jkOZSY/egIAubxiSTN8HMjmMMZz3R9DhCkKnUd4aBwrQasEoUQnJDMYYzvjCuBCIosysBa/A4Byn4TmUmnQ45xNwxhemnQ0kZYwxnPVFcMoVglGrQbFeWcEZoACtHhx1oElm9AQEdHsjsBm10PLKvyToNDxsRi26PGGc80VyfTpEhWQWK5l62h1CsUGT89Xao1H+t5EkUHwm6eYKRXHaHYZZpxm3OpWSGLQ8ig1aOL1h9AaFXJ8OUZHYdE4YXd4IbEYdjFplBmeA9kGrBseB8hKTtPJHRJx2h6DhM1cAI5PMuoE90q7YHmklLe4hyhSVZHR5wzjrj6DEqFN8xTRlnx1J4EABmqRPWJRwyh2GIMmwqTiwWQxagANOu8Pw5zBnMlE+QZJxyh3CWV8EZSblB2eAArSq0KJVkg5RSY4FNCF7BTAyyW7UJW44QlFKZEKGC4sSOlwh9AaiKDPrVbHWAqAArRoc7YQmaSAzhjPeCPqC2S+AkUllJh0CgohOTwgC7ZEmgwSjEjr6Q+gPCSgz5yavfKooQKsFB1D9ejIZjDGcGyiAUWrSQaOiC9V4OI5DqVmH/qAIpzsEkb4sBBeLXnjCIsrNetX9zVOAVgkOAF1yyGT0BqNwesOwGjTQqWD+LVn8QJA+HxTQ7YnQmo0C54vEgnMwKqK8SKfo/f2joVXcKsFxVG6SpM4TjqLTE4ZRyyt6W8lkaXkOJUYdzvgj0Gk4zLAY8mYYn0ycJxxFhyuEqMRQZtbn+nRSln+30Xkqtoo712dB1CggSDjtjmXdUmK2pHTTa3hYDRo4PWH0BGiPdKHpD0Vxoj8EUVZO0YtUUYBWCQ4cGC0SI0mKiLECGMGohJI8WLE9UUatBiadBqfdYfSHork+HZIlPQEBJ/uD4IC8+HunAK0WtEiMJEmSGbo8IbjDsQIYhaZIr4GW53DaHYKX9kjnNcYYLvgj6HCFYkUvFFaNLVUUoFWCFomRZDDG0O0L43xQQKlZnQtk0sFq1EIcyDYWEGiPdD6KF73ocIVg1PJ5NY1DAVolKNUnScZ5fwTdnjDsBnXt+8yEEqMWgaiETncIYZGCdD4ZXPSiSK/cohepogBNSJ7pCwro9ERQbNCqqgBGpnAchzKzDu5IbCV7lBKZ5AVJZnB6Lha9MOnyKzgDFKBVgwMHMNpqRcbmi4jo9ISh4zmY8/CClSqe41Bm0qM3IKDLG4ZEWyJUTZRldHpC6PaGYTfm741ofv5UeYqBkn2S0YWiEk67QxAlljeLZNJJw8d60ud8As74wnSzq1KCJOOUK1b0olQlRS9Slb8/WZ6Jr/GhawoZSVSS0ekJIyBIKDFRcB6NludhM2rR5QnjnC+S69MhSYqIMjpcIVwIxope5GNGvMHy+6fLI/FSGbQXmlwqvlCmLxRFiUlHmbPGYdDyKDZo4fSG0RukRCZqEYpK6HAF4QpFUW4qjMWPdKutEhwHMJlRD5oMEd9ics4noNSkVV0xgFwx6zSQBrZfaXkOdhXXxC4EAUHCKXcIvrCIMpXm1U4F9aBVIpZJjOagyVA9wSi6PGHYjNq8H+5LN4tBC3CI1camRCaK5Y+IONkfhD+i3qIXqaJvtIpQ75kM5g5H4XSHYNJp8nYVa6bZjTpERAmn3GGEorRHWmk84ShOuEIIiRLKzIU3fUPfapXguIE5aArSBLE6t6fdYYBD3iVnyLZSk26gPUMQaI+0YrgGil5EJRllZn3BBWeAArS6MEaLxAgiooxT7jDCUYnmTtOAG6gj7QqJ6HSHIFLS+5zrDeZX0YtUUYBWicQqborPBS2eoMEXKcwCGJnCDwTpC0EB3Z4IpdXNkXjRi5P9IWj4/Cl6kSoK0CrBcbHgTJeNwiUzhm5PBD0BgbZTZYCW51Bi1OGMP4KzvgglMskyxhjO+SI45Y4VvbAYCjs4AxSgVYSjHnSBO++L4Iw/gpIC2QOaC3oND6tBgy5PGD0B2iOdLTJjOOOL4LQnDLMu/4pepIpuUVTi4uWYInQh6g0KcHrDsOg1eZ3aUAmMWg0kObb9SqvhUVrAc6DZIMmxRDtnfBHYqMDLEBSgVSI2mkmJSgqRNyKi0x2GTsPnZcUeJSrSDyQycccSmVhpuDUjRFmG0xPGOZ8Au0lLN5+XoNZQiYupPkkhCUYlnHaFIMmMgkSWWY1aiAPZxgIC7ZFOt6gk4/RA0YsSCs4johZRCY7jqPdcYARJRqc7RAUwcqjUpEMwGkszGRYpSKdLRJTR4Q7hfIEUvUgVtYrKUIwuDJLM0OUJoX8g9zCt2M6dMrMO3kgUnZ4wopTIZNLiRS/6g4VT9CJVFKBVhDFGWz8KAGMMZ3xhnPdHUWbSFlTuYSXiOA5lJj16AwK6vGFIMn0HUxUQJJx0heAOR1Fm1lFxl3FQgFYTjqMedAHoCQjo9kZgM2qh5ekrqgQankOZWYdzPgFnfGG6UU6BPyKiwxWELyKi3KynG88JoG+/ytB1Ib+5QrGhVDMVwFAcLc/DZtSiyxPGOV8k16ejKt6IiJOuEIJRCeUFWPQiVbTyRGUoPucvfyRWsIGnAhiKZdDyKDZo4fTG9khPKdLn+pQUzxWK4pQ7BFFmKDNTeyWDbtFVhANoaC1PhQdKHgqSDBsVwFC0+OhGpzs2l0pGFy96wRijhC8poACtMhSe80+sAEYYPiFKFzGVKNZrAS6WbcwfEXN9Oop0ISCgY6DoBd10poYCtMpQBzq/xAtg9AYElJkKs+atWtmNOkQGRj5CUdojHccYw1lvGB2uIAxU9GJSKECrDMXn/BGv3nPGH0GpibacqFGpSYeAEFs7INAeaSp6kWYUoAnJkd5gNFEAgzIpqRM3UEfaFRLR6Q5BlAs3SMeLXnR6wrAYNDBT3vhJo6uCqjAa484TnnBsO5WBCmCoHj8QpC8EBXR7IpAL8DsqyjK6PGF0e2IVqYxa+ptOBwrQasIoUUk+CAgSOt2xZBc0P5cftDyHEqMOZ/wRnPVFCmq3RbzoRbc/jBITlYtMJ2pJNeGoA612iQIYUQkltGI7r+g1PKwGDbo8YfQEhFyfTlZERBmn4kUvTDqaqkkzun1XGYrP6iXJDE53CO6wiPIiCs75yKjVQJJj26+0Gj6vt82FRQmn3SH0B0WUU17tjKAArSIch4Kc38oHjDF0+8I4HxBQRnmI81qRXgNJZjjlCkHLc3lZxzsYldDhCsEXiaK8iP6eM4XGI1SEAwVotTrvj6DbE4bdSOX1CoHVqIXEGE67YvW884k/IuJkPxW9yAYK0CrCgQNVulOf/lAUnZ4IivS0gKaQlJp0CEYlnHKHEBbzI0jHi14EqOhFVtDVQk04ysWtNr6BAhg6nqOkDQWozKyDNxLFaXcYUZUnMnGHozjRH0REklFupqx32UABWkVixTJyfRZkokJRKXFhthrzbx6SjI/jOJSZ9OgLCujyhiGpdAisLyjgRH8IMhW9yKq0XTX8fj/cbjd8Ph8cDgeKi4vTdWgyiLrvwQtHVIoVwPALUZRTib2CpuE5lJl1OOcToOU5VFiNqup9XggIOO0KQavhYDVQcM6mlAO03+9HU1MTWltb0draCmDo8CvHcbBaraipqUF9fT0++9nPTv5sCxyt4lYHmcVSHvYFBRoKJAAALc/DZtSiyxOGluMww2rM9SmNizGG8/4IOj1hGLWUVzsXkg7QXV1d2LZtG9566y189KMfxapVq/Ctb30LDocDFosl8Tqfzwen04nDhw/j0KFDeOyxx1BdXY1NmzahoqIirT9EoaB60MrHGMNZXwTn/AIVwCBDxCs7Ob2xPdJTipQ7shL/O+70hFGkp7zauZJUgH7mmWfw9NNP4ytf+Qp27Ngx5mstFguqqqpQVVWFW265BQDQ3NyMxsZGXH311bj99ttTP+sCxYFSfSpdTzCKLk8YVgMVwCDDmXQaSIyh0x2CTsPBrsA6yZLMcMYXRpc3AqtBQ3m1c2jCV5Dt27fD5/Nh9+7duOGGG1L6sPr6evzyl7+ExWLBgw8+mNIxChoHFHCxHMVzh6NwukMw6ni6qJFRFeu1ABfLNuaPiLk+nSHiRS+6qOiFIkyoB33kyBGsWbMGVVVVafnQW265BUeOHMHRo0exePHitByzEHBQ9iIxmTHIjEHLF17PMV4AA9zABZiQMdiNOvQFBZxyhzG/1KSIimZRSYbTE8K5QGx6hkaAcm9CV5J0BeZUj7lz50643W7Y7XY4nU7U1taivr4+qc+bzDEaGhqwe/fupD4vE5S+SOyCP4KeQBTTivWwm3TQF8gXPCLKOO0OIRSVUK7geUWiLKUmHXoDUZx2h3BZqTmn3xdBiv0N9wQElJl1BXmTrUSTvtX3+/0Z3VLV2NgIh8OBzZs3Jx5bt24dPB4P1q5dm/FjNDY2oq2tLbWTn6Q/nejDD/e9jy9dMRMlJh04KHfBUViUcM4vQJBkvO8KotivxbRiPUryPFCLsoxOTwgeKoBBksRxHMqKYkG60x3C3BJTTgJjrOhFGP3BKMrMekpFqyCT/mtYtmwZurq60nEuw7S1taGpqQkbNmwY8vimTZvQ2NiY8WO0tbXh8OHDyZ10Gj361mm8cqIfbzk9Fx9kylzJ3R+MIijKKDXpMNWsh8wYTvQH0d4TwDlfGILKsyiNhDGGbm8EPUEBpWYd5SQmSeM5DqVmHS4EBXR7IlkfIQtGJXT0h+AKxXvO9DesJJMO0Iwx+Hy+dJzLME1NTaiurh72ePyx5ubmjB7jpZdewurVqyd6umkX/7KEBuXxZVBeyclQVML5gIBinQYcx4HjOFgMWkwt0oOB4aQrhKMDgToi5k+gPueL4Iw3jBIqgEEmQctzKDHqcMYfwVlfJGs34AFBxMn+EDwREWVmPW0JVKC0jKdkKhFDa2vrqHumrVZrIkFKJo6xc+dO3HnnnRM/2Qww6mK/nnhQ47iBAK2wCN0bFBCOysMSGXAch2J9LFBjIFC39wZw1qv+QN0XFOD0hlFs0Ob1ED7JDr2Gh9WgQZcnjJ6AkPHP80VEnOgPIRiN1XKm0R9lSsty0//6r//CkiVLhiQr8fl8aGlpSQwRP/vss0kfN76YayQ2m21Cw8+pHKOtrQ0OhwNWqzW5Ex5Bqn/3HIdEcgBBYuA4QMMDksTAwBSTnSoYldAbjMJq1Iz6s8Z71MV6DYJRGac8IfQEo5hapEOpWZ+zCk/x8022KX0REZ2eMPRanrIrjYEb/L/K+HNVNJNOA5kBnZ4wtBoOZeOkiE3179cdjuKUK4SoxGhR4zgSf8OT+PudzHvTEqDvvPNOVFRU4PDhw2hra0NnZye6urrgdrvhcDiwZs2apI/p9XrHfN5qtY77mlSP8dJLLw1ZUDYZZWWW8V80ivjWC07Lo6SkCIIoIyhIKCkthlEB2zIA4FRfEMYiCdOthgm9vhSxaZGAIKE/IiISZZhu1KC8yJCznymZ31FQENHVE0Cx1UQXtwmylxTl+hRUowSAOxSFB8D0IiNsEyhMkczfb28ggv6ACIvVhBLKET8uZoiNZkzmOj4ZaQnQHMfBYrFg+fLlWL58eToOmTPpHtru6/OlNCTNcRcDtDcgwOUKQJRleMMSLug5RaTeCwgS2nv8MOl4uFzJJ1wwMAZvSMCZHh/MOh5Ti/QoNeuylhyB42JfvIn+jgRJxklXEO5gbMW2S4hm/iRVjEMsOLtdAcWtm1C6/lAUf/GGML/UPOooTbJ/vz0BAafdIWh4DlaDFq4I/f2OxxOKrWxP9ToOXPw9pSItAfp3v/sdampqsHz58rTl2R5veHm83nEqx0jn0HYcY6nPGccDdESSwVgs1afMWGyYWwG5MHr8AqKSDLtRl+LPGLvRMOs0CAgSOtxhnPMLmJblQD2R35EkM3R5wugLiphi1gHgFLcWQHEGhvaUuG5C6UqMOvQGBHS4QphfahrzuzDe3y9jLFaRyh2CQcujWK+l38cExZtpMtfxyUjLZf6f//mfUVxcjObmZrS2tsJqteLqq69Oa8C+lMfjgcPhSOsx0jm0nQ6D56CB2JYMmQGSAr5d/oiInqCQtvJzRfpYtZyAIOGUJ4zzASHWozbpcp5libFYbuJzPgFlZi0tqCFZUWbWoSco4LSbw2UlppQye8WLXjg9YZh0VJFKbSYdoK1WKzweDxYvXoz169dj/fr1OHLkCJ5++mls2bIFs2fPxoYNG1IqN2m1WuF2u0d8zuv1oqamJm3HaG5uxpEjR4btjY4vIos/vmnTprT2sMdiumQVNxC7o8t1zXfGGHqCAkSZpX2B1+BA3ekO40JAwJQiPcpyGKh7AgK6vRHYjFrKsESyhuM4lJn06A1FoddwmG0zJbUVSmYM3d5wrHiLkfJqq9GkA/SGDRuwZ88efPSjH008VlVVha1bt2LTpk1oampCc3NzSgF69erVY67UHm11dirHqK+vHzH1ZzyT2NatWydwxuk1eIg7jkPue9B+QUJPIAqrIXPj7PFAHYxKcLrDuOAXMKVIhzKzPqvz765QFJ2eMMw6Tc5Wm6tVfzCKABcCLRFLnYbnUGbS4pxPgIbn4LAaJ7SDIz4lc8Yfgc2oo79dlZr0b23Dhg1wOBwjVqeyWq3YsGEDnnjiiZSOXV9fj7a2tmFzxfG9yxMJ0Ok4Rq6YEkPcQ/cMyznsQjPGcMEfS6aQjS+9WafB1GI9dBoOXZ4I2nsCcHpCCEal8d88SQEhtp2K50BDg0k6fN6PW5r+gRseewsPvdWJUBZ+X/lKy/OwGbXo9oRxzhcZ9/VRKZZ+ttsfht2opeCsYmn5za1fvx633HIL/H5/Og6XUFtbi1WrVuHRRx8d8vjOnTuxY8eOYUPNdXV1qKurm9QxLjXa8Hg2mAeCgnBJUo9cDnF7IyL6QlHYjNldpRYP1HoNh25v5gN1WJRwyh1GRJRgU2DNXiU7dN6Hb+xpRyAqQWbA7/5xDl989jDe6fKM/2YyIoOWh8WghdM7diITQZJxyh3CWV8EZXmeB78QcEyJiZ0vMdFKVA0NDbDZbNi1a1fKx4hrampCS0sL9u7dCyCWGrSmpibpoe7e3tS3WbX7BHzi/7ZipsWA3//zBwHEMljNsBjgsJmSP+gkMcbwfn8QroGtB7kUikrwCSL0Gk1s6NukT7qXy3FAebll2O9IlGV0uELoDQqYYtYrJimMGvztrA+b9h5DMCrjwzMsuPWqOfjhK8dxfiCorFlQjrs+6qCbnhT5BRGixDC/zIwSk27I3+/gohellFc7LdzhKObPtKOEY5PaZlVento2qwkFaKfTiWeeeQbf+ta3UvqQkTz44INYs2ZN3teDnkyAPh2WsOznb6DMrMP/+/yHAMT2R5abdJhXak7zmY7PHY7iWG8AdgUtlhocqMvNOpSbJx6oRwrQMmNwusPo9oVRTvmJk/LuGS827T2OsChj6UwrttUvwIwpVnSd9+LRA134fdt5MAB2oxbfrJ2DustK6eYnBe5wFFqex+WlJsydVYLeXh8CgoTTrhDckSjKTPR3my65DtATuso6HA6sXr0at99+O7q7u1P6oLiuri7cfvvtqK2tzfvgPFmJbVaDhrg1HBDNwRi3zBjO+wXw4BQTnIHYPP3UIgOMWg5nfWG09/hx2h1CQEg+cQowUADDH0GJSUcXuSQc7PbgW82x4HzlLCu2rapMrBou0mvwzdo5ePRTVZhXYoI7LOLfXjuBzXuP45x//DlVMpTdqENkYAomKIjwx4tehEW6qcwzSQ1xe71efOMb3wDHcVi/fn1SWcPefPNNPP300/D7/fj3f//3Se9hVovJ9KD9vAaX/WgfDBoOr9+2DEAsD7ROw6N6auZqcI/EFYr1nktMyh46C4tSrI14HuVmPcqLdCjSjzxffmkPujco4ER/EEU6Tc73XqvJ210e3PPycQgSw0crbPjx9Qtg0PLgOKCkpAguVyDxHYhKMn7z97N48q9nEJUZzDoeX1nmQEPVVNpfngTGGPqCUcybYcP5Pj+CgoQys45GJNIs1z3olOag48H2zTffhMPhQG1tLex2O6xWK2w2GzweD7xeL9xuN1pbW3HkyBFUVVXhjjvuwKpVq1I6UbWaTICWDHrM+MHLAICW9cvAcRwCggQOQM204qx9GSWZ4b2+AHyChNIJ5AZWgokE6sEB2hMW8V5fEBoOsGRw+1i+ecvpxndeeQ+CxFDrsOFH1y9ILEwaKUDHnXKF8JM3OvCP87GFpTVTi/HdT8zDvJLsr61QKwYGUaeD3xeC3aCl4JwBqgzQg+3duxeHDh2C0+mEz+eD0+mExWKBw+GAzWZLpAAtlB7zpSYToPXFRtjvjdWrfn3dUhi0PEJRCRIDqqcWZW2ouS8o4HhvAKVmvaJ7zyOJiDJ8EREansMUsx5lZh2KBwJw/IvTedaN93uDCEuyam5AlKCl043vvfIeojLDx+fYcd/Ky4esGh4rQAOxaZM/HL2AX7zjRDAqQ8tz+PIVM/HFK2bQ6uMJGK99yeTlOkBPuquwatWqgusVZ8vgYdaIKMOg5cFzHARJhiQD2djeKMmxuWe9llddcAZi21MMWj0iooyzvgh6ggLKzDpMMethMWohiDI63SEEohLKzRScJ+qN0y58/9X3IcoMK+aW4AfXzU86FSXPcWiomoarZ9uxveU0WjrdeOLdbrx2sh/f+cRcLJmWmwpChCgF3aYqmE7DQzMwbBXPJsZzsZ6HnKVbZlc4Ck9EhGWUeVy1MGh5TCmOZSE77xdwtCeADlcQp1xB9IdEmr9Lwh87+vG9V2LB+bp5pdi6MvngPNi0YgMeuGEB7rtuPkpMWnS4Q/jKC0fxs5ZTCAiU4IQULgrQCmfQDgRoMR6gYwUzshGgRVnGOZ8Ag4bLm5WhBi2PKUWxrVjn/QLOesNUACMJr53sx7373ofEGOrml+Lfr5uflqkWjuOwcn4ZfvdPH8CNleVgAH5/5AK+8PtDaOl0T/r4hKhRWgP0m2++mc7DESCRpi8sXtqDzvxn94dE+CJiXi6aigfqGVajoraNKdkrJ/rwb6+9D4kBqy4vQ+OK+Wmf9rAatfj+NZdhx5qFmGkx4HxAwOa9x9H42vvoD1H9YlJY0npliue3JuljHAjQ8SFujuPAkPmCGVFJxgV/BMaBeW9S2Pa+34sfvH4CEotlA7v3mssyuiZh2SwbfvNPNfjcB6aD54BXT/Tjc//zD+w53gsVJD8kJC3SGqB37tyJz3zmM3jwwQfx1ltvpfPQBcugGV5ykkNs8VYmuUJReCMiig20H7jQvXS8B1tfPwmZAZ9cOAXfu2ZeVqY8jFoN/uWq2Xj8pmosKDPDG5Fw3x9P4ht7juGMlxKckPyX1gBdVVWF6upqtLS04NZbb8XixYsTAfvNN99MFNNItbpVIYr3oAdXA8p0TWhBknHOL8Cs01DvucD977Ee/PCPHWAAblo0Bfd8fG7W/yYWTSnCE5+uwleXVUCv4XCg24svPHsIv/vHWYi5Lo5OSAaldXLxzjvvHLLlqrW1Fdu3b0dLSwt27twJjuMS+6Fvv/32dH503iob2PrTO2j+jcvwIrH+oAC/IGJqUW4LYpDc+sPRC3jgz6cAAA1VU/GvtXNydsOm5Xl88YqZWDGvFD99owPvnvXh4bedeOVEP777iXlYUJb93PSEZFpae9CX7oeura3FmjVrsHv3brS3t+PZZ5/FZz/7WXg8VHZuoqYWGQAAF/wXS8xxPDLWc4iIMs4HoijSa2jbUQHbfeR8Ijh/tnoavpXD4DyYw2bEwzcuwnc/Pg/Feg3aewO47bk2/NcB55BpIELyQVp70EePHh1WAGPwRb6qqgpVVVV04U9CvBd7YVANWB4cRDkzF6O+oIAA9Z4L2v8cPof/eLMTALC2Zho2fnS2or6zHMfhk4umYPlsG37Wehr7O1z41d/O4vWT/fjOJ+bhQzPGrvFOiFqktQf90ksvDXtspBWXlHls4qYVjxCgeSAqpb8HHRYlXAgIKNZTXt9C9fShi8H58x+YrrjgPFi5WY8f1S3Aj+suR7lZB6c3gq//bzt++kYHfJHUqpkRoiRpX8V9++2344knnkB7ezsAjPjlLtS83KkYrQediQDdF4wiGJUnXE+Z5Jen/nEWD70VC85fumIGvnalQ7HBebBr5pXit/+0BJ9eNAUA8Hx7Dz7/+0P4Y0d/js+MkMlJ+yruWbNm4emnn8anP/1pLF68GE1NTcO2XdEq7ombGu9B+4XEaATPA2KaF4kFoxLO+wVYaFtVQfrV387gP992AgDWfWgm7lxaoYrgHGcxaPHtj8/D//3/FmG2zYjeYBTfffV9fO+V99Az6OaWEDXJ2Cpun8+HlpYWHD58eMgq7qqqKvh8PlrFPUHxHnRIlOETJFgNsbSUjMX2QqdrP2pfUIAgybAZae650Ox6txs7/9INAFj/kVm47cOzcnxGqfvQDCv+u6EGT/71DH7z97PYf8qFg2e8+PpVDnxq4RRV3XQQktYAPXhu2WKxoL6+HvX19YnHWltb0dLSgt///vfp/Ni8ZtTysBo08EYk9ASEgQANCHKsYIYGk7/gBAQJFwJRFNPQdkFhjOGJd7vxy3fPAADuXFqBL39oZo7PavIMWh53LqvAystK8eM3OnC0J4CfvnEKL7/fh3s+Nhez7VRzmqhDVpMs19bWora2FiUlJdn8WNUrN+vhjYRw3i9gfqk5VjBDliExhnQUSOwNCIhKEuxGQxqORtSAMYadf+nGk3+NBeevXenAFz44I8dnlV6Xl5nx2Keq8D9t5/HYwS789awPX9p9GLd9eBY+94HplIOdKF5O/kJpFXdy4nWK4wvF4hWtpDTstAoIInqCAqwGqoVcKBhj+K8DXYngfNdV+Rec4zQ8h39eMh2/+cwSXDnLCkGK/ey3P3cER3v8uT49QsaUkwBNq7iTU37JSm6eA2SwtBQNuBAQIEosUTWL5DfGGP7vO078+u9nAQDfWD4b/+cD+RmcB5tpNeA/Vi/ElhWXwWrQ4L3+IDY8fwQPv9U5JI0uIUqS9avyM888g6uuugovv/wynnnmGRw9ejTbp6A6U+I9aP/FHjRjk69o5YuI6A1EYTXmXzlJMhxjDA+91Ymn/nEOAPCt2jm4pWZ6js8qeziOw+oF5Xjqsx/ADfPLIDPgd4fO4YvPHsY7XZTdkChP1gN0TU0NNmzYgBtuuAG33HILiouLs30KqlNuHr4XOlZyMvVjMsbQE4hAZtR7LgSMMfxH62k0HT4PAPj2x+biM9XTcnxWuVFq0uHfr5uP7asqMa1IjzO+CL6x5xju338SnjDVnCYxEVFGe08gpyMsWe86xdN9xtFw9/gunYOOm0zBDJ8goTcoUu+5AMiM4cGW03ju6AVwAL7z8Xn45EBSj0JWO9uO3/zTEjx6sAvPtp3HS+/14s0uN765fA5WXlZKW7IKUECQ8KbTjf0dLrzpdCMkyritP4SfXDc/J+dDV2cViM9Bnx9IVsJxHHgAcooFMxhjOO+PAGDQa6j3nM9kxvDAn0/hhfYecAC+d8083FhJwTmuSK/Bv9bOwfXzS/GTP51ChzuExtdOYO/7fdh09RxMK6adDfnOGxHRctqN10/1450uD4RBQ5NTzDp8fF5pzs4tJwF6pKIaZHTxHnREkuGLSLAatZMa4vZGRPSHorAZ6P4sn0kyw0/e6MCLx3vBc8C911yG+gXluT4tRVoyzYInG6rx67+fxZN/PYOWTjf+etaLry5z4OaqqYqo5EXSxxWK4k+nXdjf4cLBbu+Q9TwVVgNWzCvFinklmFGsx+WzShCbVMy+nFyhW1tbKUAnQa/hYTdq4Q6LOB8QYDXGkpVEU9hnJTOGc34BHAAd9Z7zliQz/OhPJ7HnvT7wHNC4Yj5uuLws16elaDoNj9s+PAvXzivFT97owKHzfjzYehovn+jDdz4+D/NKKMGJmvUEBPzxlAv7O/rxt3M+DB6AnFdiwrXzSrBibinml5oS0xvuHK9JSGuAfvDBByf0ur1791KqzyRNLdLDHRZxwR/BgrJYspJUakJ7wiLcoSjsJuo95ytRZrh//0m8fKIPGg7492vnY+V8Cs4TNa/EhEc+uRjPHb2AR95x4tB5P27dfRhfumImvnjFDJoWUpGzvghe7+jH/g4XDl8Yuu99YbkZK+bGespzFJpdLq1XacYYnE4nbDZbOg9LECuacbwviAuB2B0dzwHRJGtCy4zhQiACnucoi1KeEmWGH7x+AvtO9kPDcdi6cj6uzeEcmlrxHIfPVE3Dx2bbsb3lNFo63Xji3W68drIf3/nEXCyZZsn1KZJRnHaHsL/Dhf2n+nGsNzjkuZqpxVgx0FOeaVX++oKkAvTRo0dhsVhQUVEx4vNr167FkSNHxs0U9vjjjyfzsQQXi2acD0QAYKAHndwx3GERrpCIEhNlDctHoizj3147gdc7XNDyHO5feTk+MZfS6k7GtGIDHrhhAfad7MfPWk+jwx3CV144is9UT8OdSyuoNKsCMMZwoj+E/af68XqHCx2uUOI5ngOumG7BinmluGZuCaYUqasYUFIB+uabbwbHcVi1ahUcDgfsdvuQoWqHw4Gurq5xj1NbW5v8mRa4eIDuGZzuc6BgxkQWsEgyw3lfBFqegzZNFbCIckQlGY2vncAfT7mg4zn8qO5yXD2HgnM6cByHuvllWDbLioffduKl4734fdt5vHHKhU0fm4urZ9tzfYoFhzGGo72BWE+5ox9d3kjiOQ3HYeksK1bMK8HH55SgVMUdkqSHuF9++eUx9y4vX7583GMM3gdNJmZa8cWtVkDszlBMIkC7w1G4IyLKVPzHSkYmSDLuffV9/LnTDb2Gw4/qFqCWgkba2Yw63HvNZbhhfhke+PMpnPFFsHnvcVw/vxR3L5+j6kCgBjJjOHTej/0d/dh/ypW4FgKAXsPhygobrp1biqvn2GHNkx0qSf0UVVVVlFgkR6YOy8fNQWYMkgyMlwhMlGWc8wvQa7i01Y8myhARZXzv1ffwptMDvYbDT65fgI867Lk+rbx2ZYUNv/5MDZ54txtPHzqHV0704+0uD+7+6BzULyijBCdpJMoMfzvrxesdLvzplAt9oYurqk1aHssddqyYV4LlDnteTjckFaApOOfOlMQQdxSMMWj42B3lRPJxu0IivBExsZ+a5IeIKOO7r7yHt7o8MGh4PLBqAZbNogWa2WDSafAvV83GystiCU7e6w/ivj+eRPP7vbjnY/NUsQBJqaKSjAPdXuzv6Mcbp93wRMTEc8V6Da6ebceKeaX4aIUt79MUJxWgL70z9Pl8aGpqgtPpRE1NDZYvXz7qAjIyOfHhs4gkIyTKMGh4yGz8ilZRScZ5fwRGDU/JFvJIWJRwz8vv4UC3F0Ytj22rKvGRmdZcn1bBWTylGE/cXIWn/nEOv3y3Gwe6vfjCs4ew4SOzcEvNdBqxmqCIKOMtpxuvn3Kh5bQbgUH5r20GLT4xtwQr5pVg6UxrQeVvmNRAvcViwfr16+H1enHllVfi6quvRlVVFdasWUOJSNLMpOVh0PCISDL6Q1FUWI2xmtDjdKBdYRG+iITyIuo954tQVMK3X34PfznjhUnLY3t9JT40g4Jzrmh5Hl+6YmYiwclfz/rw8NtOvHqyH9/9+DxcXmbO9SkqUkCQ0Op0Y39HP950ehAetC2l3KyLBeW5pbhihqVgF7amZSbdarWitrYWP//5z2Gx0P7ATOA4DqUmLc76BbgGAjRDbHX2aARJxnlfBEYd9Z7zRTAqYfPe4/jrWR/MOh4/q1+ID0yn75wSOGxGPHzjIvzvsR7859tOHO0JYN1zbfj8B6dj3Ydm5f1w7ER4IyL+PJBi853uoXmvpxXrsWJuCa6dV4qaacV0zUKSAdrpdKK7uxuzZs0a9pzFYqHgnGElJt1AgI7PybAxK1q5QlH4oiKmmtW194+MLCBI2NR8DH8/70eRToOfra6khBkKw3McPrVoKmpn2/Gz1tPY3+HCr/52Fvs7XLjn43MLcqSjPxTFnwZSbP7ljG/IuhnHoLzXi8qLaIHdJZIK0G1tbairq0v0mGtraxPzzna7fdT3UXGM9IjPQ/cPrGTkwI06xB0RZZz3CyjSaeiPPg8EBAnf3HMMhy/4UazX4OerF6JqKtVSV6pysx4/qluAP3b048HW0+j0hPH1/23HTYum4OtXOVCsz49tQKPpCQiJ7VB/vyTv9WUlJqyYF+spX1ZiouvTGJJexb18+XK0trZiz5492LNnDziOg9UauyscbaHY008/jR/84AfpO+sCFc8A5opvNWAYdZFYf1CAXxAT27OIevkiIv61+RjaLgRgMWiwY/UiLJpSlOvTIhNwzbxSfHimFb94x4nn23vwfHsPWjrd+FbtHFyTZylYz3gjA9m8+tF2ITDkuUXl5lhPeW4JZis077USJb0PeuvWrQBiK7hbWlrQ2tqKN998E06nE1u2bEkE7ME97IlkFyPjKxkocBEP0ByPEQtmhEUJ5wMCivVaujtVOW9ExDdeOob23gCsBg12rFmEheUUnNXEYtDino/Pww2Xl+Enf+qA0xvBd199HyvmluBfr56DchVPQZ1yh/DHUfJeL5lWjBVzS7BiXilmWGjbWSqSCtCbNm1K/P8WiwX19fWor68HMDxgD+5hk/RI9KDDsTloHtyIJSf7g1EERRnTqPesap5wFHe/dAzH+4KwG7XYsWYRFtCKYNX60AwrfvWZJdj112789u/nsP+UCwfPePEvVznwyYVTVHGtHJL3+qQLHe7hea+vnVeKT6gw77USpS1RyWgB+6WXXsIrr7wyubMkAIbPQfM8EL2kBx2KDvSedfmXVaeQuMNR3P3iMbzXHwvOD9+4CPNLKTirnUHL4yvLHFh5WRl+/KcOtPcG8JM3TuHl9/twz8fnwWEz5voUhxkr77WW57B05sW811SIJ70ytlJhcMC+++67M/UxBaXEOHQOmuc4iJesEusNCghHZUwtprtXteoPRXH3S+040R9CqUmHh29chHklNG+XTxaUmfHYTVX4n8Pn8NjBbrx71ocvPnsIt314Fj73gek5Lwc7Xt7rqypsWDGvFB+bbYclT/JeK1FWWpZShKZH6cAcdLwHreE4iAPZxDiOQzAqoScQhcVAvWe16g9GcdeL7ehwh1Bu1uGhGxdhLi2qyUtansP/+cAMfGJuCR748ykc6Pbivw50Yd9AgpNsLwQcL+917Ww7VswtwfLZdphphC4rshKgB89dk9TFh4+8EQmiLIPjAJnF/mm42NaGiCTBZqQFGWrUGxRw14vtOO0OY0qRDv9542JFDnmS9JplNeLnqxei+b0+7HjrNN7rC2L982345yXTsf4js2DUZi4YCpKMg2Pkvf7YQN7rqwog77US0diEitiMWvADQdkVEmE1aCHKMiTGEBYk9AaEnJZZ6/KGMb1Yn/PhOTXqCcSCc6cnjGlFejz8/y1ChZWCc6HgOA6rK8txlcOGHW+exisn+vHUP84lEpykswhKWJTwttMzYt5ru1GLj88pwbXzSvCRAst7rUQUoFWE5zjYjTr0h6JwhaOwGbWQZQZJZugNRCHKLKN326NhjOEX73Tht/84i8oyM358/QLaVpGE8/4I/uXFdnR7I5herMd/3riYqiEVqFKTDj+47nLccLkb2wdqTt/90jGsqSzHxqtmw2pM7ZI9Xt7rawa2Q31weuHmvVYiCtAqU2rSoj8URX8wistKzJBYLJFFT1DIyWINxhgePRgLzgBwvC+I255rww+um48rK6j04XjO+iK468V2nPFFMNNiwMM3LqKbG4KrZ9txxT8twaMHnHj2yAW8dLwXbzrd+ObyOVh5WemEtmSNlfd6erEeK+aV4tp5JaieSnmvlYoCtMrE5qFDcIVFaDiAgcEVjvWeczFH9MS73fjV32LBef1HZuHPp91o7w3gX5uP4c6lFfjCB2eoYn9nLpzxRvAvLx7FOb+AWdZYcJ5eTMGZxBTpNfjXq+fi+stjW7JOucNofO0EXn6/D9+6eg6mj3AjN1be69k2I1bMi1WIWlhupu+lClCAVpnBW604joMsM3jCEmwpDn1Nxi/f7cYv3z0DALj7o7Oxdsl0fP4DM7C95RRePN6LRw504WhvAN//xGUo0tOqz8G6vGHc9WI7zvsFOKwGPHzjYtoaR0a0ZJoFTzbU4Nd/O4v//tsZ/LnTjXfPevG1Kx247ep5uBAQsP/kyHmv55easGJurBgF5b1WHwrQKnNpuk+G2DCzPsuLOZ786xk8/pduAMC/XOXA2iXTAcQSMXzvE/NQPbU4Uc3nlKsNP75+AebQdiEAgNMTC84XAgJmD5QopKxLZCx6DY/bPzIL111Wih//qQOHL/ixveU0fv33czjvjwx57aLyokQxCtoFoG4UoFXmYsEMMfHf2V7U8eu/ncFjB2P51b+6rAKf+8CMIc9zHIdPL56K+aUmfP/V93HKHcbtf2jDlhXzcc3ckqyeq9Kcdodw14vt6A1GMdceC85lKs7FTLJrXokJ//WpxXjuyAU8csCJ8/4IOAzkvZ5XimvmltAahjxCAVplLk33me2e81P/OItHDsSC8x1LK/DFK2aO+tol0yzYdXM17t13An8/58N3X3kPX75iJtZ/ZBY0BbhS9JQrFpz7QlFcVmLCQzcuSvw+CZkonuPwmepp+MS8EjiDIuYUaVFmopu8fESb3FTmYsGM6DivTL+mQ+fwn287AQC3f3gWbv3Q6ME5rsysx8M3LsRnq6cBAP77b2ewee9xeMPiOO/MLyf7g/j6i0fRF4ri8lITHqbgTCZpapEedZVTVF0Ni4yNArTKXJruM1t+33YeO97qBACs+9BM3P6RWRN+r5bn8c3aOWhccRkMGh5vdXlw2x/a8F5fcPw354H3+4L4lxfb4QqJWFBmxsM3LqKiAoSQcVGAVpnBc9CMDa8FnQm7j5zHz1pPAwC+dMUMrE8iOA9Wv6Acj960GDOK9Tjji+CO54/g5fd703mqinO8L4C7XmyHOyxiUbkZD69ZBJuRgjMhZHwUoFUmvs1KlBl8gjTOqyfv+fYL2N4SC86f/8B03Lm0YlJbNSrLirDr5hpcVWFDRJLx76+fxM/fPA1RHl7XWu2O9caCsyciompKEXasWZRyJihCSOGhAK0yBi2PooFKMq4MD3P/77Ee/PSNUwCAtTXT8LUrHWnZR2k1arF9VSW+PLDA7JnD57HxxWPoD2Z/Xj1TjvT4sfHFdvgiEqqnFuHnaxZSWT5CSFIoQKtQNuahXzregx//qQMA8Nnqadj40dlpTXKg4TncuawCP667HGYdj7+d8+HW5w7j8Hl/2j4jVw6f9+PuF4/BJ0j4wLRi/Hz1IhTrKTgTQpJDAVqFLt0LnW7N7/Xih3/sAAPQUDUV31ie3uA82DXzSvH4p6sxx25EbzCKr/3vUfzh6IWsza+n26HzPnxjTzsCUQlXTLfgZ6sXUhY1QkhKKECrUKnpYrrPdHvlRB/u/+NJMACfXjQF/1o7J+PpAefaTXj8pmqsmFsCUWZ44M+n8JM3TiEiqmte+m9nffjmnmMIRmV8eIYFD9ZXUmF7QkjKKECrUKb2Qr92sh9bXz8BmQGfXDgFmz42N2tVbor0Gvyw7nJ8ZVkFeA74f8d68NX/dxTnLkljqFTvnvHiX5tjwXnZLCu211fCRMGZEDIJFKBVKJ6PO52LqvZ39OPfXnsfEgPWVJbjno9nLzjHcRyHL10xEw/WL4TVoEF7bwC3PdeGv5zxZvU8knWw24NvNR9HWJRx5SwrHrihMid1uQkh+YUCtApd7EGnZw76T6dc2LLvBCQG1F9ehu9+fF5O68NeVWHDrptrUFlmhjss4hsvteN3/ziryHnpt7s82LT3OCKSjOUOG356Q2VOyn4SQvIPXUlUKL4XOh2ruFtOu3DvvvchMYYb5pfh+9dcpog82TMsBjz6qSrUX14GiQEPv+1E42snEIpmfu/3RL3ldOOel49DkBiunm3Hj69fQMGZEJI2qtj7sXPnTrjdbtjtdjidTtTW1qK+vj4jx/B6vXj00Udht9vhdrtx5MgR1NbWYsOGDen6cSYtXYvE3nS68b1X34coM6y8rBT3rlBGcI4zaHlsWXEZqqcW4+dvdmLfyX50uEL4yfULUJHjMnotnW5875X3EJUZPj7HjvtXXg5dlguXEELym+IDdGNjIxwOBzZv3px4bN26dfB4PFi7dm1aj+H1erF9+3Zs3bp1yGMrV67EoUOH8NBDD6XhJ5q8izWhUx/ifsvpxncHAsy180rwb9fOz3rZyongBir3LCgz4/uvvo+TrhBu+0Mb/u3a+bh6tj0n5/TGaRe+P3Bjs2JeCbZeNx9anoIzISS9FH1VaWtrQ1NT07De66ZNm9DY2Jj2Y+zZswdNTU1obW1NPGa1WrF8+XLs3bsXTqczxZ8kveI96EBUSmkr0oFuD77zynsQJIZr5pbgB9cpMzgP9oHpFvzy5mosmVYMvyBh897jeOIv3ZCzPC/9x45+fO+Vi6MOFJwJIZmi6CtLU1MTqqurhz0ef6y5uTmtx6ipqYHVah32WrvdDiDWm1aCYr0GuoGAmuxWq7+c8eLbe2PB+WOz7aoKMFOK9PjPGxehoWoqAOCJd7txz8vvwRfJTunK1072J+brr59fOjDqoI62I4Soj6KvLq2traioqBjxOavVOqSnm45jVFdX48CBA6itrR12DIfDMWKgzwWO4xIruZNZKPbXs15sHlhxXOuw4f469c2b6jQ8Nl09F9+/Zh70Gg4tnW7c/oc2nOjPbOnKV070Jbah1V9ehsYVyh91IISom6Kvzk6nM9F7vZTNZsPhw4czfozm5mZ4PB7s2LFj3M/KpmTnof9+zodNA3t1P1phww/rFkCvsuA82I2VU/Bfn6zCtGI9urwRbHj+CF490ZeRz9r7fi9+8HpsG9qNleWKWelOCMlvil0kNt5wstVqHfc1qR7D6XSiubkZhw4dgs/nw759+0Yc+p6IVLcTx9/HcRf/DTZ4Jfd4n3HovA/faj6G0EAijR/fsADGPNgOtHhqEZ5sqMaWfSdwsNuLxtdO4GhvAF+70jGh3i03+H9HefmLx3vww/2xvOSfWjQlJwlc1Goi7UtSR+2beYk2nkT7Tua9ig3QueRwOLBhwwZ4vV40NTWhoaEBO3bsSGmIu6zMMqlzsduLIOkFlJj1Qx6fZjMBTg/CHIeSkqJR3//3Mx58c89xBKMyPjrHjkc+84G8SkFZAuDJz30IO/7UgZ1vd+J3/ziHDk8YP/tUNUovabPR2Edpv2f/cTYRnP/5iplovKGSgnMKRmtfkh7UvpnDDAKAyV/HU6XYAD1ej3UiC7Ymewyr1YoNGzbA6XSioaEBr776KhwOx7ifO1hfnw+pLDTmuNgfhdsdgDsYBRcZOtdcrIkFiu6+AFyuwIjHONrjx8YXjyEgSPjwDAt+dN18hP1hhJM/HcW77YPTMdeix/37T+Kt027c/MsD+PENl2PxlOJR38MhdnFzuwK49Ff0h6MXErWw/6l6KjYumwWPO7Pz3PlmrPYlk0ftm3meUBRlZn3K13Hg4rU8Faod5/R4PCkPOyd7jHhCk23btiX9GYyl/m+s99uNF+egR3q+vSeAu188Br8g4YPTLXhgVSw/9GTOR+n/rh0oXTnbZsT5gICvvHAU/6+9Z/T3xH9Hl7Tzs23nE8H5lppp+ObyOQC4nP98qvs3SvvSP2pf1fxLw3WcxQ+SAkUHaKvVCrfbPeJzXq8XNTU1aT1GQ0MD1q1bN+x1NpsNAHDkyJHxTzqDGGMICLFUl6VjrOI+3hfAxpfa4RMkLJlWjO2rCqfs4bwSEx7/dBU+NscOQWL40Z868MAbHRCkie0X/5/D57C95TQA4P8smY67P5q5WtiEEDIWRQfo1atXo6ura9TnL90ONdljtLW1jZiMxOPxAACqqqrG/bxMCokyXCEBoiyPWnLyRH8Qd794DL6IhOqpRfhZ/UIU6QsjOMcV67X4yfULsOEjs8AB+EN7D77+v0fRExDGfN/Th87hP97sBAB84YMz8C9XOSg4E0JyRtEBur6+Hm1tbcPmiuN7lycSoJM5Rm1tLXbv3j3sGC0tLQCANWvWJPcDpJnMGHQaHpI8cg/6ZH8Qd73YDk9ExOIpRfiP1YUXnON4jsO6D8/C9vpKWPQatF0I4NbnDuOvZ0ded/DUP87iobdiwfnLV8zEV5dVUHAmhOSUogN0bW0tVq1ahUcffXTI4zt37sSOHTuGzR/X1dWhrq4u5WNs3boV995775Bg7nQ68fjjj2Pt2rVJF+hIN1kG9BoeoswS+6A9YRGSzHDKFcJdL7XDHRaxqNyMn69eiGK9YtcAZs1yhx1P3FyNy0tNcIVEbHzxGJ45fA6DS1f+6m9n8J9vx0ZObvvwTNyxdBYFZ0JIznFMiUV2LzHRSlQNDQ2w2WzYtWtXyseIF8ywWCzw+XxwOp2TCs69vamv4i4vt+Cd4+fRF4yixKSDKxSFXsNDkhnMeg0+8cQBAMAjn1yMe199H32hKBaUmfHwmkWwGik4DxaKSvjpG6fw8kAykxsuL8N3PzEXf3ivHzve6AAAbPjILKz78KxcnmZe4TigpKQILldgUgtlyMiofTPPHY5i/kw7SjiWchvHr+UpvVcNAVrN0hmg+4ICLHot/IKEUrMOq3/1LjwRESYtj5Ao4/JSEx6+cRFsA/WiyVCMMTzTdh7/+VYnJAaUm3XoDcamCL6yrAJfumJmjs8wv1AAySxq38zLdYBW9BA3GUpmgE7DQRr4S4kPc4dEGZeVmLBjDQXnsXAch7U10/HQjYtQYtImgvPXr3JQcCaEKA6Ng6oMx3GJvXlTivQ45Q5jnt00EHQoOE/Eh2ZYsevTNdj5ly5cfXk5rq2wUg+EEKI4FKBVZvDSpds+PAtzbEZ8+UMzE6u6ycRMLdbj3hWXJYYISfrF9u2LCIsSNBwHDcfR4jtCkkABWmV0Gh48F9ty9cHpFnxwem5yxBIyFlFmcIUFTDcZIEgMUVGGxBgYGDjGQaPhoOWH/qM854QMRQFaZQwaDlqOgyQz8Bq6oBHlCUYl+AUJU4v0qJ5ugdvAQxAZRFlGVGYQJYawKCEUlSHIDEFBgsgYZBYbIeI4QMdz0PI8tDwHzUAAJ6TQUIBWCUlm4DlAr+Wh4TmIMkOBZO8kKsEYgyssggMw12bENIsBZr0WQQ0PHQ8Aw/9gJZkhKsuISmwgeMuISDJC0dj/hkUZoswgyTLAceCARMDWDep909A5yUcUoFVCZgw8x0GviQVoiVY1EQWJSjJcIREWgxYOmwE2o25CdXA1PAcNr8FI2/YZiwXtWPAeCOIDQTs0ELgjgoSozMAAcIh9R7SDet/xHjghakQBWiVkhsTFx6Dh4RfEXJ8SIQAAvyAiKEiYbjFgpsUIgzY9uzc5joNewyGWrXZ471scCNqiHA/kseAdFiUIIrvY+x64meWAYfPe1PsmSkYBWuF4LlbyTGYMGp4DzwEGLQ93mHrQJLdkxuAKRaHlecwvK0K5WZfVhV6xXvLo5xYL3nKiFy5IMkJRCeGB+fB4AAcAsItD55pBwZt63ySXKEArHMdxYAMLaHgO0HAcjFoe8sSqJxKSERFRhjscRalJhwqrEcUGZV1KeI6DQcvBMEIuJsYu9rrFgZ63KMcWrgWFWEAPiTIkWYY0aOHa8N435XkimaWsbxUZRjuQmERiDEaeB8fF7uoZRz1okhvesIioLKPCZsSMYgN0GnUFKo7joNNwoy6yjC9cEwcWrsWHz4NRCWFRhiAxBAUZEhNj28YwtNdN28ZIulCAVjgNz4GxeKnJ2BdeFx/3VphgVILMGFXRylOSzNAfjMKk12C+3YxSky4v52/jC9dGujoOXrh26baxYDT237RtjKQLXUkVjuMAsFipyXhPJf4ll2SmiDmyqCTDHRKh18YqbQUgFWwd6nwVFiV4wiLKi/SosBphLtA9fuMtXEt125iOp4VrZDgK0ArHcRzAxYa4dQPBOHaHH6sLncsAzRiDNyJCkBimFOkw3WKELxLFKXcYOk1sSxhRN8YYPBERkgzMsZswvdigiJtCpZrstrGwIEGkbWNkAAVohRvoQIMDSwyL6Qa+rLncCx2KSvBGRFgNWsyxGxLDnSYdj4jI0O0LY0qRnubhVEyUZfSHorDotagoNcJOldImJZltY0Ji4dro28Z4DmAGHYKClEjcQj3v/EIBWuFiMTm2FIUf1IPW8hyiUvaXcosygzsUhZbnMMduwpQi/ZCeMs9xmGk1ICRK6AtGMaVIn/VzJJMXECQEohKmmvWYZTPCqC3MIe1sSmbbmCDFhs+NJj2CvjCCggRBkhOLSA0aPrYQjoK2qlGAVjhuoAIQG0hUEmfQcAhFs9eDZozBJ0iIiDLKzDrMKDaMurVGp+HhsJkQkYLwhKNUo1pFZMbgDongOWCe3YipxQYaBVGAkbaNcRxQXl6MEk5GeGCOOyLKsZsrQRoUtAENz8Og4aHXcKpbdV/IKEArHM8BbGA16ODaGEadBlIompVziO15FVGs12B+qRllE0hIUaTXYLbNiPf6gghFJZgKdFGRmgiSDFdYhM2ghcNmhFVhe5vJyHiOg0mnGfIdkxlDRBwetP2ChKgUpaCtEvQNVDhu4F88SUmcfmD7VSZJMoM7HAUHDhU2A6YVGZJK41hi0sFhNeCUJxybI6OLgGL5IiLCooxZxQbMsBpogZ/KjRa0Y/u4hwdtURYBMGh5HnoK2opBAVrh4j1Vnrs4Bw0M7I/O4Of6BRHBqIxSkxYzLKn3pqZZDAhLMs76BEwpym4qSDI+SY6l69RrecwvNaPcnJ97m0nsGmLWaYZskbs0aPsiIkJRmYK2QlCAVrh475nnuCE9aJ2Gj63wZiytF9SIKMMbEWHSDQxnm3ST2tbBcxxmWY0IR2W4QlGUmWnRmFJERBnuSBRlA+k6iyjBTMG5NGhPKzaMGbSjsjiwo4SCdjbQN1LhYsE3ViRj8PdAMxCwJQZo0xCfZcbgDotgjGFGsQFTi/VpmzfWa3jMtsfmo+Nbs0huecJRiDKDw2rEDIuB8kqThJGCtiSzxHy2IFHQzha6Uiocx12cfx7ag76YTWyyaQNj81AiSow6zLAaYDNo0z7MWaSPLTw60R9EWJRo206OiDKDKyTArNNibokRJcb0/65J/tHwHMz8+EE7SEE7rShAKxzPDQxzX7KfMZ6YQJQZDCkeOyrJ8IRjKTovKzGhvEif0Z5UmVmPsCij0x2G1kzVgLItGJXgj0iJdJ20sp5MRipBmx94HwXtiaEArXAcYoFZd0kvOZ4CMCwmn6xEHkjRKQ6k6JxWbMxa7uzpxQaEoxIuBKKYUkQLkrKBMQZXWAQHYO7A3mZKF0kyYbygHRHlxALUkYK2QUs37oNRgFY4nosNc+s1wy+oRi0Pf1RK6njBqARfRITVoMO8EkPWhzg1PIcKmwlhiaGfFo1lXFSS4QqJsBi0cNgMlDSGZN2lQRsYHrR9QmxO2xuWIDIRHAO0GgraFKAVjhtYwT3SUJBhoHrURIhy7EKt0/CYO5CiM1fDSwYtn0hi4ovEggdJv4AgIRiVMN2ix0yLMak97IRk0qVBe/pA0B68etw7sDd/cNDWaTno+MIJ2nRlVDiei63gHmkhmFbDj7sXmjEGX0RCWIzNPc60GBSxncYykK3qZH8Qeo1MwSONZBYbndDxF9cW0P5zonQankORXoOigUIi0y0UtHN/pSZjiqf4HOkCe+m89KXCogRPRIJFp8GC8iKUmpSVKKTcrENYNMDpDaOM11MR+zSIpWWNosSog8NmHDVfOiFqMFbQjkgyhDGCdnwhmpqDNn17FY4bGN4eaVGPlucGcnUPTVYiDqTo1HAcHFYDpiaZojNbOI7DTIsRYVFGX1BAuVlPi8YmwRsRIYgyZlmNmGkx0ApZkpfGC9qRqASfICGUB0GbArQKFOk0MIxwsdXysb3Rosyg03BgjME/8IdZatJhpsWg+PldDc/BYTMiIsYKNZSaaBFTsiQ5NqRt0mkwvyyW/Y1udEghGRK0TTrMQGzdTUSMLUYLR6XEtTERtBHLJxEL2rwiR/CUffUmAICZVuOIj2v5gWQljEEWY3uazfr0pOjMJqNWg9l2E97rDSAgSFnb8pUPYtMYIspM+oF0ndR2hAAD9bX1SARtYPSg7QmLkBgbFrRzjQK0imn52F5oV0iEXsNjpsWAaRa9KrN0WQ1aOOwmnOwPQstzihySVxLGGDwREZIMzLGZMK04s0lmCMkHyQZtUU4+z0Razzenn04mheM4mLQ8dGYdZlgMsGYgRWc2TTHrEIoa0O0No9ysV80IQLaJsoz+UBTFOi0qSowooWkBQlI2etCWIcgM0ywGCP5wbs4tJ59K0ma23RTL050HwYzjOMyyGhAWZfQHoyinTGPDBAQJgaiEqWY9ZtmMqhwtIUTpYkGbRzEHWI069FKAJqlQwjxJOml5Hg6bEYIowx0WqXc4gDEGV0gEzwHzBtJ1KmnLHCEk/fLr6k7yglmngcMeWxgXEJJLZZqPBEnGhWAUZn1sP/t0i5GCMyEFgAI0USS7UYcKqwHBqARByu1CjVzyRUR4wiJmFRuwoMxMtbQJKSAUoIliTS02YEaxAa5QFDKbWM7xfCHJDL0BAQzA/FIzZtuNeTedQQgZG92OE8XiOQ4zrQaERAl9wSimFBVG5at4us5SUyxdpxJypxNCso+++UTRdBoeDpsJESkITzia9+USvWERUVmGw2bEDIuB9jYTUsDo208Ur0ivwWybEaIMhJKsf60W4sCQtobncHlZESqsRgrOhBQ4ugIQVSgx6eCwGuATJETzbNFYKCqhPxhFqVmHy8vMKKVc2oQQ0BA3UZFpFgPCkoyzPgFTipRVOjMVjDG4wyIYA+bYjZhWbMiLhDOEkPSgAE1Ug+c4zLIaEY7KcIWiKDOrd9FYVJLhComwGLRw2Ax5P7dOCEkeDXETVdFr+MSWI29EzPXppCQgSHCFRUy36LGgzEzBmRAyIgrQRHWK9Fo4bEZEJRlhUT2LxmTG0BcUEJUZ5peYMMduoqpdhJBR0RA3UaUysx5hUUanOwytmVP8iuf43uYSow4VNiMslBGMEDIOukoQ1ZpebEA4KuFCIIopCq585Y2IEEQZs6yxvc2UEYwQMhF0pSCqpeE5VNhMsBq16A9Fc306w0gyQ09AAAdgfpkZs22UrpMQMnF0tSCqZtDymG2LJfXwKWjRWFiU0BsSUGLSYUFZEcrNesX28AkhykQBmqhebKuSERFRRkTMbRKT2N7mKAKCjDk2E+aXmlCk1+T0nAgh6kRz0CQvlJt1CIsGOL1hlPF6aHOQ8EOUZfSHoijWaVFRYkSJibZPEUJSRwGa5AWO4zDDYkBYlNEXFLI+pBwQJASiEqaa9ZhpNcKko14zIWRyKECTvKHl+cRQtyssojQLPVjGGFwhETwHzLMbMbXYoPoUpIQQZaA5aJJXjFoNZttN4BHr1WZSVJJxIRCFWa/BgvIiTLcYKTgTQtKGAjTJO1aDFg67CcGoBCFDla/8gghXKIqZFgMWlJlhpcQjhJA0owBN8tIUsw4zLAa4QlFIMkvbcePpOmUGzC8rwhw77W0mhGQG3faTvMRxHGZZY4vG+oNRlKch01g8XWepSQeHzYgiPX19CCGZQ1cYkrfii8YEUYYnIsI+iapR3rAIQZbhsBkxvdgAHfWaCSEZRlcZktfMOg0cdiMYS23RmCgz9PgF8DyHy0vNqLAaKTgTQrKCrjQk79mNOlRYDUkvGgtFJfQHoygr0mFBmRlllK6TEJJFNMRNCsLUYgMiIkO3P4IpZt2Y26Fi6TpFMAbMsRsxrdgATQ4ykxFCChsFaFIQeI7DTKsBIVFCXzCKKUX6EV8nyjJcIRHFeg0qbMZJzVsTQshkUIAmBUOn4eGwmRCRgvCEo7Bfkmksnq5zWpEOM61GGLWUrpMQkjs0B00KSpFeg9k2I0Q5NscMXNzbHJUZ5peYMLfETMGZEJJzFKBJwSkx6eCwGuCNSAgIInoCUVj0WlSWmSmXNiFEMVQxxL1z50643W7Y7XY4nU7U1taivr4+I8fwer149NFH4fP54HQ64fF4cMcddyT9eUTZplkMiMgygoKEmRYDZlgMlBGMEKIoig/QjY2NcDgc2Lx5c+KxdevWwePxYO3atWk9htfrxfbt27Fp0yZYrVYAQFtbGxoaGrBq1So89NBDafqpSK7xHIcKqxFGiwliIAyAes2EEGVRdJehra0NTU1N2LBhw5DHN23ahMbGxrQf49FHHx0SnAGguroamzZtwt69e9Ha2priT0KUSKfhUUJ7mwkhCqXoAN3U1ITq6uphj8cfa25uTusx9u7di4aGhmGvra2tnfDnEUIIIemg6ADd2tqKioqKEZ+zWq0T6tEmcwyHwwGPxzPi6wDA7XZP4KwJIYSQyVN0gHY6nbDb7SM+Z7PZcPjw4bQeY9euXThw4MCw17W1tQEAlixZMv5JE0IIIWmg2EViXq93zOetVuu4r0nHMYDYMLnVap3worTBUp3ejL+Ppkczh9o4s6h9M4vaN/PS0caTea9iA7RStLa2orW1FTt27BiyeGyiysosk/r8yb6fjI/aOLOofTOL2jfzctXGig3Q4wXDifR803GMu+++G1u3bk15H3Rfnw+MJf8+jov9UaT6fjI+auPMovbNLGrfzEtHG8ePkQrFBujxeDweOByOjB5j48aNuOOOO1Ia2o5jDJP68kz2/WR81MaZRe2bWdS+mZerNlb0IjGr1Trqymmv14uampqMHWPbtm1YsmTJsP3ThBBCSDYoOkCvXr0aXV1doz4f35+c7mM0NTXBbrcPC85NTU3jfh4hhBCSDooO0PX19Whraxs2VxzfuzyRAJ3sMVpbW+H1ekfsOU9kzpoQQghJB0XPQdfW1mLVqlV49NFHh+TR3rlz54irquvq6gAAr776akrHcDqdaGxsRG1tLbZt2wYA8Pl8iedom1V+oTbOLGrfzKL2zbxcb7PiGFP+8oKJVqJqaGiAzWbDrl27UjpGXV0dnE7nqOexe/fuEdOGEkIIIemmigBNCCGEFBpFz0ETQgghhYoCNCGEEKJAFKAJIYQQBaIATQghhCgQBWhCCCFEgShAE0IIIQpEAZoQQghRIArQhBBCiAJRgCaEEEIUSNG5uAvVRFObFiKv14t7770Xa9asGbNNkmnDTL1WbbxeLx599FH4fD44nU54PB7ccccdWW+3fG5j4GI72+12uN1uHDlyBLW1taOWtqV2nryGhgbs3r17xOcU3b6MKMqWLVvYY489NuSxW2+9lT399NM5OiNluOuuu9iWLVvYli1bWGVlJduzZ8+or02mDTP1WrXxeDxsy5YtzOPxJB47fPgwq6ysZHfdddew11Mbpybezpc+tnTpUmrnDIlfM0Z7TsntSwFaQeIXxIk+Xog6OzvHDNDJtGGmXqtGDzzwwJDgHPfYY4+xyspK1tLSkniM2jh1Tz/99LD2ZCx2A1pZWck6OzsTj1E7T97hw4fZzTffnNTPq6T2pTloBWlqahqxWlb8sebm5myfkuok04aZeq0a7d27Fw0NDcMej9dLz0a75XsbA0BNTc2wMrkAYLfbAQytOU/tPHkvvfQSVq9ePeJzamhfCtAK0traioqKihGfs1qtaG1tzfIZqU8ybZip16qRw+GAx+MZ9ng8mLjd7sRj1Mapq66uxoEDBxI3PnGtra1wOBxDLuzUzpOzc+dO3HnnnaM+r4b2pQCtIE6nM3EnfSmbzYbDhw9n94RUKJk2zNRr1WjXrl04cODAsMfb2toAAEuWLEk8Rm2cXs3NzfB4PNixY8eQx6mdU9fW1gaHwzHiaEWcGtqXVnErxOChrZFYrdZxX1PokmnDTL023zQ1NcFqtWLt2rUAqI3Txel0orm5GYcOHYLP58O+ffuGBBNq58l56aWXsHnz5lGfV0v7Ug+aEDKi1tZWtLa24r777huzJ0KS53A4sGHDBtx///2ora1FQ0NDYrSCTM54Q9tqQgFaIca7AObDXW2mJdOGmXptPrn77ruxdevWIXs3qY3Ty2q1YsOGDYkg7XQ6E4+Phdp5ZBMZ2gbU074UoFXC4/FQL2aSkmnDTL1WLTZu3Ig77rgjMbQ9UdTGqYnfBG3btm1Cr6d2HtlLL72UlmQrSmlfmoNWEKvVOmS17GBerxc1NTXZPSEVSqYNM/Vatdu2bRuWLFkyamYrauPUNTQ0wGazYdeuXUMet9lsAIAjR44kHqN2Tk5zczOOHDmCxsbGIY/HF2XFH9+0aROsVqsq2pcCtIKsXr16zBV+l27NIMMl04aZeq2aNTU1wW63DwvOTU1Nid40tXHq4kOwl4pvcauqqko8Ru2cnPr6+hF7z42NjWhra8PWrVuHPK6G9qUhbgWpr69HW1vbsHmK+L45tX5xsimZNszUa9WqtbUVXq93xJ7z4J+b2jh1tbW1I+aEbmlpAQCsWbMm8Ri1c2apon2TyjtGMu6uu+5iDzzwwJDHbr311jFzTxeSeLq8sXLaJtOGmXqt2nR2drKVK1eyLVu2sAceeIA98MADidznI/2M1Map6ezsZHfdddeQtKrx9LWX5uhmjNo5HeJpVEd7TsntyzHG2MTDOcmGQqoyM1Hbtm2D0+nEkSNH4HQ6YbVasXz5ctjt9mFDV4DCK9QoUF1dXWIF8Uh27949LH0htXFqvF4vtm/fDovFkqgctnbtWqoalmZNTU1oaWnB3r17AcSyuNXU1Ay7Xii5fSlAE0IIIQpEc9CEEEKIAlGAJoQQQhSIAjQhhBCiQBSgCSGEEAWiAE0IIYQoEAVoQgghRIEoQBNCCCEKRAGaEEIIUSAqlkFIGixcuHDc16xatQoPPfRQFs6GEJIPKEATkiZWqxWbNm0a9fmRqhipXVNTExobG7Fp06ZRy1MSQlJDAZqQNLHZbImSjIUkmQL0hJCJo1zchKTBwoUL4XA48Oqrr+b6VMgY1q1bB4/HM2LJR0KUhhaJEUIIIQpEAZoQQghRIArQhGTZzp07sXDhQjQ1NQ17bt26dVi4cGGiNnNbWxsaGhrQ2tqK5uZmNDQ0YOHChYnHLtXU1ISGhgYsW7YMy5Ytw8aNG4fVeW5tbUVdXR3a2toSr48fs62tbchrvV4vNm7ciGXLlmHhwoVYtmwZGhsbE8dsbW3FwoUL0dzcPOLPOfjYI/28yZzLeMY618bGRixcuBCtra1oa2vDwoULE59zqcbGRtTV1Y3afsn8TsZrP0LGQnPQhKTBRLZZHTt2LPH/b9y4EXv37sXu3btRXV0NIBbQtm/fjl27dqG2thZALICtW7cOVqsVNTU1qK2thdPpTAS7S1/b2NiIVatWYcmSJQCA7du3w+PxYN++fYnFXPFjVldXw2azob6+Hp2dnXj88cdhtVpx4MCBxHnW1dUBADZs2ACbzZb47B07dqC6ujpxrB07dgwpRh8PsOvXr8fs2bMTAfjSrWbJnMt4xjpXq9WaCNQAsHXrVgCxhX3x9vd6vWhoaIDH48Edd9wBq9WKpqYmOJ3OEdtvIr+T8dqPkDExQsikVVZWsqVLl7I9e/aM+u9SN998M1u6dCnzeDyspaWFVVZWsscee2zIa+KPb9myZcTHb7311jHP6/Dhw8OOG3/vypUrh7z2gQceYJWVlaylpYUxxlhnZyerrKwc8dwvPdbg12zZsoVVVlayzs7OIa/ds2fPsNdO9FzGM5FzZSzW5jfffPOIz4123itXrhyx/cb7nUz0nAgZDW2zIiRN4j3AiXryySexcuVK3HrrrXA6nVi1atWoe4kv7W3V1taitrYWra2t8Hq9o251ir9vpCHVS7eExXvdXq838fMAsWHz6urqCe/jbmpqwtq1a4e9vr6+HtXV1di+ffuwdhrvXMaT6rleet6rVq0CMLS9amtr0dTUNOx3M97vJB3nRAobzUETkiNWqxVPPvkk2traYLPZks4yFh9GHRxMvF4vdu7ciY0bNybmUcf6/PHOb/369Yl54tHmZAeLzxuPNnxbU1Mz4vsnu5c6lXMdLH7ee/fuRV1d3ZB/8WHuiRj8O5nsORFCAZqQHDp8+DCA2AV9shfu1tZWLFu2DI899hiWLFmCrVu34sknnxz19fEe3lg2b96M3bt3Y/369XA4HIkANtoCLo/HM+bx3G53yucynmTPdSQ7duzAsWPHRvyXq3MihYuGuAnJkba2NjQ2NmLr1q2JlcGDFyONJ75iON5bvfvuuzOSLKW6unrIUHm8VxlfaDVYTU0NAKClpWXErGpHjhzJ6FBvMud66fuAWJsmM01xqUt/J5M5J0KoB01IDni9Xtx6661YtWoV1q5di61bt8Jms+HWW28d8fWdnZ1D/ru5uRmtra2JOdP4Mauqqoa8bqStWMmc46VzwA6HI7EieiRWqxWrVq3C3r17h/US40PFmcjZPdFztdlso85rr127dtTh7JF6vOP9TlJpP0IGox40IWni8Xiwc+fOMV8TD0633nrrsHnnXbt2oa6uLtGrHuzxxx+Hz+dLLEJqamqC1WrF5s2bE6+pra3F3r17sXHjRqxZswaHDh3CM888k/LPc/jwYaxbty6xbctqtaKlpQVer3fMnOP3338/jhw5goaGhsQ2q5aWFuzduxe1tbUZyVc+0XN1OBxobW3Ftm3bYLfb0dTUlBhx2Lp1Kw4fPoy6ujqsX78eS5YsgdPpxJ49ewBgWHrQ8X4nqbYfIXEUoAlJE6/Xi+3bt4/6vNVqxYYNG9DY2Ii2trZhF3yHw4EdO3YkhqoH9zS3bt2Kzs7OxL7mVatW4f777x8yHB5/7969e3HkyBFUVVXhySefxJYtW1IaVq6trcWmTZuwZ88evPnmm/B6vaiurh6253mkn/PVV1/Ftm3bsHfvXjidTlRXV2Pr1q0ZC0wTPdcNGzagtbUVzzzzDBwOx7Dz2b17N7Zt24Y333wTjz/+OBwOB1atWoU777xz2GeO9ztJtf0IiaNEJYQoWDwpRiaDG0kO/U5IttAcNCGEEKJAFKAJIYQQBaIATQghhCgQBWhCCCFEgWiRGCGEEKJA1IMmhBBCFIgCNCGEEKJAFKAJIYQQBaIATQghhCgQBWhCCCFEgShAE0IIIQpEAZoQQghRIArQhBBCiAL9/8vq4zEsfshJAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5.0, 4.0))\n",
    "\n",
    "ys_mcts_planner = []\n",
    "mcts_planner_cis = []\n",
    "\n",
    "for mcts_data_path in mcts_planner_data:\n",
    "    y_vals = load_mcts_data_imitation_learning(mcts_data_path)\n",
    "    ys_mcts_planner.append(np.mean(y_vals))\n",
    "\n",
    "    cis = mean_ci(y_vals)\n",
    "    mcts_planner_cis.append(np.array(cis))\n",
    "\n",
    "mcts_planner_cis = np.array(mcts_planner_cis)\n",
    "\n",
    "p = plt.plot(exp_steps, ys_mcts_planner, label=\"MCTS planner\")\n",
    "plt.fill_between(exp_steps, mcts_planner_cis[:,0], mcts_planner_cis[:,1], color=p[0].get_color(), alpha=0.15)\n",
    "\n",
    "plt.ylabel(r'$F_{1,H}(\\pi)$')\n",
    "plt.xlabel('Expansion steps')\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "\n",
    "# plt.ylim(-2.0, -1.5)\n",
    "\n",
    "os.makedirs(\"figs/\", exist_ok=True)\n",
    "plt.savefig(f'figs/mountaincar_continuous_imitation_learning.pdf', bbox_inches='tight', pad_inches=0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a5170cec-b1b4-4e98-8d7a-83b167661098",
   "metadata": {},
   "source": [
    "## Entropy maximization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "0178a0a9-628d-41db-b8fd-68a853e70eff",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_mcts_data_entropy(env, mcts_plan_path, data_folder_path=\"data/\"):\n",
    "\n",
    "    # Load MCTS planner data and MDP.\n",
    "    with open(data_folder_path + mcts_plan_path + \"/exp_data.json\", 'r') as f:\n",
    "        mcts_plan_data = json.load(f)\n",
    "        mcts_plan_data = json.loads(mcts_plan_data)\n",
    "    f.close()\n",
    "\n",
    "    return np.array(mcts_plan_data[\"f_vals\"]) # [N]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "7c6c7130-ce66-4a13-aeb9-3b07b76981fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_random_policy_objective_entropy(env, obj_f, mcts_plan_path, data_folder_path=\"data/\"):\n",
    "\n",
    "    # Load MCTS planner data and MDP.\n",
    "    with open(data_folder_path + mcts_plan_path + \"/exp_data.json\", 'r') as f:\n",
    "        mcts_plan_data = json.load(f)\n",
    "        mcts_plan_data = json.loads(mcts_plan_data)\n",
    "    f.close()\n",
    "\n",
    "    # Extract parameters.\n",
    "    N = int(mcts_plan_data[\"config\"][\"N\"])\n",
    "    max_traj_length = int(mcts_plan_data[\"config\"][\"H\"])\n",
    "    K = 1 # Single trial setting (K=1).\n",
    "    gamma = mcts_plan_data[\"config\"][\"gamma\"]\n",
    "    print(\"N\", N)\n",
    "    print(\"Max. traj. length:\", max_traj_length)\n",
    "    print(\"Gamma:\", gamma)\n",
    "\n",
    "    # Compute random policy finite trials objective value.\n",
    "    random_policy = construct_random_policy(nS=env.num_states, nA=env.num_actions)\n",
    "    random_policy_f_estimated = estimate_f_d_pi_from_samples(env, obj_f, gamma, random_policy,\n",
    "                                                             N=N, K=K, max_traj_length=max_traj_length, flatten=True)\n",
    "\n",
    "    return np.array(random_policy_f_estimated) # [N,H]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "311a26d3-3c41-41bc-9564-4e39ed17f238",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_cvx_opt_problem(env, obj_f, gamma):\n",
    "\n",
    "    nS = env.num_states\n",
    "    nA = env.num_actions\n",
    "\n",
    "    print('Building transition matrix and initial states distribution...')\n",
    "    P_matrix = build_transition_matrix(env)\n",
    "    p_0 = build_initial_states_distribution(env)\n",
    "    print(\"P_matrix.shape\", P_matrix.shape)\n",
    "    print(\"p_0.shape\", p_0.shape)\n",
    "    \n",
    "    x = cp.Variable((nS, nA))\n",
    "    \n",
    "    constraints = []\n",
    "    for s in range(nS):\n",
    "        lhs = cp.sum(x[s, :])\n",
    "        rhs = (1 - gamma) * p_0[s] + gamma * sum(\n",
    "            cp.sum(cp.multiply(P_matrix[a][:, s], x[:, a])) for a in range(nA)\n",
    "        )\n",
    "        constraints.append(lhs == rhs)\n",
    "    constraints.append(x >= 0.0)\n",
    "\n",
    "    obj = obj_f(x)\n",
    "    \n",
    "    prob = cp.Problem(obj, constraints)\n",
    "    prob.solve()\n",
    "\n",
    "    # x.value[x.value < 0.0] = 1e-8 # TODO.\n",
    "    # x.value += 1e-05 # TODO\n",
    "    \n",
    "    # print(\"status:\", prob.status)\n",
    "    # print(\"optimal value\", prob.value)\n",
    "    # print(\"optimal var\", x.value)\n",
    "\n",
    "    opt_policy = x.value / np.sum(x.value, axis=1, keepdims=True)\n",
    "\n",
    "    return prob.value, opt_policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "15081683-a9b1-4177-8634-31ea0dd68864",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_infinite_trials_objective_entropy(env, obj_f, mcts_plan_path, data_folder_path=\"data/\"):\n",
    "\n",
    "    # Load MCTS planner data and MDP.\n",
    "    with open(data_folder_path + mcts_plan_path + \"/exp_data.json\", 'r') as f:\n",
    "        mcts_plan_data = json.load(f)\n",
    "        mcts_plan_data = json.loads(mcts_plan_data)\n",
    "    f.close()\n",
    "\n",
    "    # Extract parameters.\n",
    "    N = int(mcts_plan_data[\"config\"][\"N\"])\n",
    "    max_traj_length = int(mcts_plan_data[\"config\"][\"H\"])\n",
    "    K = 1 # Single trial setting (K=1).\n",
    "    gamma = mcts_plan_data[\"config\"][\"gamma\"]\n",
    "    print(\"N\", N)\n",
    "    print(\"Max. traj. length:\", max_traj_length)\n",
    "    print(\"Gamma:\", gamma)\n",
    "    \n",
    "    # Define objective function.\n",
    "    cvx_obj_f = lambda x: cp.Minimize(-cp.sum(cp.entr(x))) # (Minus) entropy function.\n",
    "    x_star, opt_policy_infinite_trials = solve_cvx_opt_problem(env, cvx_obj_f, gamma)\n",
    "    # print(\"np.sum(opt_policy_infinite_trials)\", np.sum(opt_policy_infinite_trials))\n",
    "    # print(\"opt_policy_infinite_trials[np.where(opt_policy_infinite_trials < 0.0)]\", opt_policy_infinite_trials[np.where(opt_policy_infinite_trials < 0.0)])\n",
    "    infinite_trials_f_estimated = estimate_f_d_pi_from_samples(env, obj_f, gamma, opt_policy_infinite_trials,\n",
    "                                                            N=N, K=K, max_traj_length=max_traj_length, flatten=True)\n",
    "\n",
    "    return np.array(infinite_trials_f_estimated) # [N,H]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "f2e33dcf-de4e-4377-b48b-9e60a4aba88c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "N 10\n",
      "Max. traj. length: 200\n",
      "Gamma: 0.9\n",
      "N 10\n",
      "Max. traj. length: 200\n",
      "Gamma: 0.9\n",
      "Building transition matrix and initial states distribution...\n",
      "P_matrix.shape (3, 100, 100)\n",
      "p_0.shape (100,)\n",
      "Random policy: [0.77763647 0.75443395 0.69331767 0.69554891 0.72219439 0.6826802\n",
      " 0.6762019  0.77722562 0.65222852 0.75100382]\n",
      "Infinite trials policy: [0.61014348 0.68323027 0.7284172  0.70757416 0.78225593 0.67394812\n",
      " 0.76663131 0.62499967 0.65034984 0.75721828]\n",
      "MCTS planner: [0.5915997  0.63689355 0.63697344 0.63873943 0.55242298 0.58892935\n",
      " 0.63686235 0.6318645  0.57784154 0.63927744]\n"
     ]
    }
   ],
   "source": [
    "exp_steps = [10,20,50,100,500,1_000,2_000,3_000,4_000]\n",
    "mcts_planner_data = ['mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-22-37-26', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-22-37-39', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-22-38-06', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-22-39-19', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-22-42-08', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-22-58-49', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-29-23-34-47', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-30-00-48-58', 'mountain_car_continuous_entropy_mcts_gamma_0.9_2025-04-30-02-46-31']\n",
    "\n",
    "env, obj_f = get_gym_env(\"mountain_car_continuous_entropy\")\n",
    "\n",
    "exp_idx_to_plot = -1\n",
    "mcts_data_path = mcts_planner_data[exp_idx_to_plot]\n",
    "data_to_plot = {}\n",
    "data_to_plot[\"random_policy_f\"] = compute_random_policy_objective_entropy(env, obj_f, mcts_data_path)\n",
    "data_to_plot[\"mcts_planner\"] = load_mcts_data_entropy(env, mcts_data_path)\n",
    "data_to_plot[\"infinite_trials_f\"] = compute_infinite_trials_objective_entropy(env, obj_f, mcts_data_path)\n",
    "# print(data_to_plot)\n",
    "print(\"Random policy:\", data_to_plot[\"random_policy_f\"][:,-1])\n",
    "print(\"Infinite trials policy:\", data_to_plot[\"infinite_trials_f\"][:,-1])\n",
    "print(\"MCTS planner:\", data_to_plot[\"mcts_planner\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "11f33851-f5f5-4e34-8a53-93ac5dd3e642",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pi_rand 0.7182471427717412 ci_low: 0.02203782465601578 ci_up: 0.021996276976258722\n",
      "pi_infinity 0.6984768255098983 ci_low: 0.029422526259788917 ci_up: 0.029868507709653103\n",
      "pi_mcts 0.6131404280777936 ci_low: 0.016455718321834234 ci_up: 0.01492077311101403\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_2(data_to_plot, mdp_name=f\"mountaincar_continuous_env_entropy_exp_steps_{exp_steps[exp_idx_to_plot]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "47b3f168-2951-4f5f-bce6-10cdedc55c8f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_3(data_to_plot, mdp_name=f\"mountaincar_continuous_env_entropy_exp_steps_{exp_steps[exp_idx_to_plot]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "f04cfb96-3e31-4cd5-a6ce-4abb0f24b752",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5.0, 4.0))\n",
    "\n",
    "ys_mcts_planner = []\n",
    "mcts_planner_cis = []\n",
    "\n",
    "for mcts_data_path in mcts_planner_data:\n",
    "    y_vals = load_mcts_data_entropy(env, mcts_data_path)\n",
    "    ys_mcts_planner.append(np.mean(y_vals))\n",
    "\n",
    "    cis = mean_ci(y_vals)\n",
    "    mcts_planner_cis.append(np.array(cis))\n",
    "\n",
    "mcts_planner_cis = np.array(mcts_planner_cis)\n",
    "\n",
    "p = plt.plot(exp_steps, ys_mcts_planner, label=\"MCTS planner\")\n",
    "plt.fill_between(exp_steps, mcts_planner_cis[:,0], mcts_planner_cis[:,1], color=p[0].get_color(), alpha=0.15)\n",
    "\n",
    "plt.ylabel(r'$F_{1,H}(\\pi)$')\n",
    "plt.xlabel('Expansion steps')\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "\n",
    "# plt.ylim(-2.0, -1.5)\n",
    "\n",
    "os.makedirs(\"figs/\", exist_ok=True)\n",
    "plt.savefig(f'figs/mountaincar_continuous_entropy.pdf', bbox_inches='tight', pad_inches=0)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
