{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Semi Synthetic Experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Analyze the performance of various algorithms to solve the joint matching + activity task, when the number of volunteers is large and structured"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import random \n",
    "import matplotlib.pyplot as plt\n",
    "import json \n",
    "import argparse \n",
    "import sys\n",
    "import secrets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr0/home/naveenr/miniconda3/envs/food/lib/python3.8/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from rmab.simulator import RMABSimulator\n",
    "from rmab.omniscient_policies import *\n",
    "from rmab.fr_dynamics import get_all_transitions\n",
    "from rmab.mcts_policies import *\n",
    "from rmab.utils import get_save_path, delete_duplicate_results, create_prob_distro\n",
    "import resource"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.cuda.set_per_process_memory_fraction(0.5)\n",
    "torch.set_num_threads(1)\n",
    "resource.setrlimit(resource.RLIMIT_AS, (30 * 1024 * 1024 * 1024, -1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "is_jupyter = 'ipykernel' in sys.modules"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "if is_jupyter: \n",
    "    seed        = 42\n",
    "    n_arms      = 2\n",
    "    volunteers_per_arm = 2\n",
    "    budget      = 3\n",
    "    discount    = 0.9\n",
    "    alpha       = 3 \n",
    "    n_episodes  = 100\n",
    "    episode_len = 20 \n",
    "    n_epochs    = 1 \n",
    "    save_with_date = False \n",
    "    TIME_PER_RUN = 0.01 * 1000\n",
    "    lamb = 0.5\n",
    "    prob_distro = 'uniform'\n",
    "    policy_lr=5e-3\n",
    "    value_lr=1e-4\n",
    "    train_iterations = 30\n",
    "    test_iterations = 30\n",
    "    out_folder = 'real_data_mcts'\n",
    "else:\n",
    "    parser = argparse.ArgumentParser()\n",
    "    parser.add_argument('--n_arms',         '-N', help='num beneficiaries (arms)', type=int, default=2)\n",
    "    parser.add_argument('--volunteers_per_arm',         '-V', help='volunteers per arm', type=int, default=5)\n",
    "    parser.add_argument('--episode_len',    '-H', help='episode length', type=int, default=20)\n",
    "    parser.add_argument('--n_episodes',     '-T', help='num episodes', type=int, default=200)\n",
    "    parser.add_argument('--budget',         '-B', help='budget', type=int, default=3)\n",
    "    parser.add_argument('--n_epochs',       '-E', help='number of epochs (num_repeats)', type=int, default=1)\n",
    "    parser.add_argument('--discount',       '-d', help='discount factor', type=float, default=0.9)\n",
    "    parser.add_argument('--alpha',          '-a', help='alpha: for conf radius', type=float, default=3)\n",
    "    parser.add_argument('--lamb',          '-l', help='lambda for matching-engagement tradeoff', type=float, default=0.5)\n",
    "    parser.add_argument('--seed',           '-s', help='random seed', type=int, default=42)\n",
    "    parser.add_argument('--prob_distro',           '-p', help='which prob distro [uniform,uniform_small,uniform_large,normal]', type=str, default='uniform')\n",
    "    parser.add_argument('--time_per_run',      '-t', help='time per MCTS run', type=float, default=.01*1000)\n",
    "    parser.add_argument('--policy_lr', help='Learning Rate Policy', type=float, default=5e-3)\n",
    "    parser.add_argument('--value_lr', help='Learning Rate Value', type=float, default=1e-4)\n",
    "    parser.add_argument('--train_iterations', help='Number of MCTS train iterations', type=int, default=30)\n",
    "    parser.add_argument('--test_iterations', help='Number of MCTS test iterations', type=int, default=30)\n",
    "    parser.add_argument('--out_folder', help='Which folder to write results to', type=str, default='real_data_mcts')\n",
    "\n",
    "    parser.add_argument('--use_date', action='store_true')\n",
    "\n",
    "    args = parser.parse_args()\n",
    "\n",
    "    n_arms      = args.n_arms\n",
    "    volunteers_per_arm = args.volunteers_per_arm\n",
    "    budget      = args.budget\n",
    "    discount    = args.discount\n",
    "    alpha       = args.alpha \n",
    "    seed        = args.seed\n",
    "    n_episodes  = args.n_episodes\n",
    "    episode_len = args.episode_len\n",
    "    n_epochs    = args.n_epochs\n",
    "    lamb = args.lamb\n",
    "    save_with_date = args.use_date\n",
    "    TIME_PER_RUN = args.time_per_run\n",
    "    prob_distro = args.prob_distro\n",
    "    policy_lr = args.policy_lr \n",
    "    value_lr = args.value_lr \n",
    "    out_folder = args.out_folder\n",
    "    train_iterations = args.train_iterations \n",
    "    test_iterations = args.test_iterations \n",
    "\n",
    "save_name = secrets.token_hex(4)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_states = 2\n",
    "n_actions = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_population_size = 100 # number of random arms to generate\n",
    "all_transitions = get_all_transitions(all_population_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "match_probabilities_by_seed = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_environment(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "\n",
    "    all_features = np.arange(all_population_size)\n",
    "    match_probabilities = []\n",
    "\n",
    "    if seed in match_probabilities_by_seed:\n",
    "        match_probabilities = match_probabilities_by_seed[seed]\n",
    "    simulator = RMABSimulator(all_population_size, all_features, all_transitions,\n",
    "                n_arms, volunteers_per_arm, episode_len, n_epochs, n_episodes, budget, discount,number_states=n_states, reward_style='match',match_probability_list=match_probabilities,TIME_PER_RUN=TIME_PER_RUN,contextual=True)\n",
    "\n",
    "    return simulator "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_multi_seed(seed_list,policy,is_mcts=False,per_epoch_function=None,train_iterations=0,test_iterations=0,test_length=500):\n",
    "    memories = []\n",
    "    scores = {\n",
    "        'reward': [],\n",
    "        'time': [], \n",
    "        'match': [], \n",
    "        'active_rate': [],\n",
    "    }\n",
    "\n",
    "    for seed in seed_list:\n",
    "        simulator = create_environment(seed)\n",
    "        if is_mcts:\n",
    "            simulator.mcts_train_iterations = train_iterations\n",
    "            simulator.mcts_test_iterations = test_iterations\n",
    "            simulator.policy_lr = policy_lr\n",
    "            simulator.value_lr = value_lr\n",
    "\n",
    "        if is_mcts:\n",
    "            match, active_rate, memory = run_heterogenous_policy(simulator, n_episodes, n_epochs, discount,policy,seed,lamb=lamb,should_train=True,test_T=test_length,get_memory=True,per_epoch_function=per_epoch_function)\n",
    "        else:\n",
    "            match, active_rate = run_heterogenous_policy(simulator, n_episodes, n_epochs, discount,policy,seed,lamb=lamb,should_train=True,test_T=test_length,per_epoch_function=per_epoch_function)\n",
    "        time_whittle = simulator.time_taken\n",
    "        discounted_reward = get_discounted_reward(match,active_rate,discount,lamb)\n",
    "        scores['reward'].append(discounted_reward)\n",
    "        scores['time'].append(time_whittle)\n",
    "        scores['match'].append(np.mean(match))\n",
    "        scores['active_rate'].append(np.mean(active_rate))\n",
    "        if is_mcts:\n",
    "            memories.append(memory)\n",
    "\n",
    "    return scores, memories, simulator"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "results = {}\n",
    "results['parameters'] = {'seed'      : seed,\n",
    "        'n_arms'    : n_arms,\n",
    "        'volunteers_per_arm': volunteers_per_arm, \n",
    "        'budget'    : budget,\n",
    "        'discount'  : discount, \n",
    "        'alpha'     : alpha, \n",
    "        'n_episodes': n_episodes, \n",
    "        'episode_len': episode_len, \n",
    "        'n_epochs'  : n_epochs, \n",
    "        'lamb': lamb,\n",
    "        'time_per_run': TIME_PER_RUN, \n",
    "        'prob_distro': prob_distro, \n",
    "        'policy_lr': policy_lr, \n",
    "        'value_lr': value_lr} "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Index Policies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed_list = [seed]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "acting should always be good! 0.000 < 0.044\n",
      "acting should always be good! 0.000 < 0.162\n",
      "acting should always be good! 0.108 < 0.183\n",
      "good start state should always be good! 0.380 < 0.508\n",
      "good start state should always be good! 0.506 < 0.760\n",
      "cohort [83 53]\n",
      "instance 0, ep 1\n",
      "instance 0, ep 2\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[14], line 4\u001b[0m\n\u001b[1;32m      1\u001b[0m policy \u001b[38;5;241m=\u001b[39m full_mcts_policy_contextual \n\u001b[1;32m      2\u001b[0m name \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mmcts\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m----> 4\u001b[0m rewards, memory, simulator \u001b[38;5;241m=\u001b[39m \u001b[43mrun_multi_seed\u001b[49m\u001b[43m(\u001b[49m\u001b[43mseed_list\u001b[49m\u001b[43m,\u001b[49m\u001b[43mpolicy\u001b[49m\u001b[43m,\u001b[49m\u001b[43mis_mcts\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43mtrain_iterations\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtrain_iterations\u001b[49m\u001b[43m,\u001b[49m\u001b[43mtest_iterations\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtest_iterations\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      5\u001b[0m results[\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m_reward\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(name)] \u001b[38;5;241m=\u001b[39m rewards[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mreward\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m      6\u001b[0m results[\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m_match\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(name)] \u001b[38;5;241m=\u001b[39m  rewards[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmatch\u001b[39m\u001b[38;5;124m'\u001b[39m] \n",
      "Cell \u001b[0;32mIn[11], line 19\u001b[0m, in \u001b[0;36mrun_multi_seed\u001b[0;34m(seed_list, policy, is_mcts, per_epoch_function, train_iterations, test_iterations, test_length)\u001b[0m\n\u001b[1;32m     16\u001b[0m     simulator\u001b[38;5;241m.\u001b[39mvalue_lr \u001b[38;5;241m=\u001b[39m value_lr\n\u001b[1;32m     18\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m is_mcts:\n\u001b[0;32m---> 19\u001b[0m     match, active_rate, memory \u001b[38;5;241m=\u001b[39m \u001b[43mrun_heterogenous_policy\u001b[49m\u001b[43m(\u001b[49m\u001b[43msimulator\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mn_episodes\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mn_epochs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdiscount\u001b[49m\u001b[43m,\u001b[49m\u001b[43mpolicy\u001b[49m\u001b[43m,\u001b[49m\u001b[43mseed\u001b[49m\u001b[43m,\u001b[49m\u001b[43mlamb\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mlamb\u001b[49m\u001b[43m,\u001b[49m\u001b[43mshould_train\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43mtest_T\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtest_length\u001b[49m\u001b[43m,\u001b[49m\u001b[43mget_memory\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43mper_epoch_function\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mper_epoch_function\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     20\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     21\u001b[0m     match, active_rate \u001b[38;5;241m=\u001b[39m run_heterogenous_policy(simulator, n_episodes, n_epochs, discount,policy,seed,lamb\u001b[38;5;241m=\u001b[39mlamb,should_train\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m,test_T\u001b[38;5;241m=\u001b[39mtest_length,per_epoch_function\u001b[38;5;241m=\u001b[39mper_epoch_function)\n",
      "File \u001b[0;32m~/projects/food_rescue_rmab/rmab/omniscient_policies.py:996\u001b[0m, in \u001b[0;36mrun_heterogenous_policy\u001b[0;34m(env, n_episodes, n_epochs, discount, policy, seed, per_epoch_function, lamb, get_memory, should_train, test_T)\u001b[0m\n\u001b[1;32m    993\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    994\u001b[0m     all_active_rate[epoch,t] \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msum(state)\u001b[38;5;241m/\u001b[39m\u001b[38;5;28mlen\u001b[39m(state)\n\u001b[0;32m--> 996\u001b[0m action,memory \u001b[38;5;241m=\u001b[39m \u001b[43mpolicy\u001b[49m\u001b[43m(\u001b[49m\u001b[43menv\u001b[49m\u001b[43m,\u001b[49m\u001b[43mstate\u001b[49m\u001b[43m,\u001b[49m\u001b[43mbudget\u001b[49m\u001b[43m,\u001b[49m\u001b[43mlamb\u001b[49m\u001b[43m,\u001b[49m\u001b[43mmemory\u001b[49m\u001b[43m,\u001b[49m\u001b[43mper_epoch_results\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    997\u001b[0m next_state, reward, done, _ \u001b[38;5;241m=\u001b[39m env\u001b[38;5;241m.\u001b[39mstep(action)\n\u001b[1;32m    999\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m done \u001b[38;5;129;01mand\u001b[39;00m t\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m<\u001b[39m T: env\u001b[38;5;241m.\u001b[39mreset()\n",
      "File \u001b[0;32m~/projects/food_rescue_rmab/rmab/mcts_policies.py:404\u001b[0m, in \u001b[0;36mfull_mcts_policy_contextual\u001b[0;34m(env, state, budget, lamb, memory, per_epoch_results)\u001b[0m\n\u001b[1;32m    403\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mfull_mcts_policy_contextual\u001b[39m(env,state,budget,lamb,memory,per_epoch_results):\n\u001b[0;32m--> 404\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfull_mcts_policy\u001b[49m\u001b[43m(\u001b[49m\u001b[43menv\u001b[49m\u001b[43m,\u001b[49m\u001b[43mstate\u001b[49m\u001b[43m,\u001b[49m\u001b[43mbudget\u001b[49m\u001b[43m,\u001b[49m\u001b[43mlamb\u001b[49m\u001b[43m,\u001b[49m\u001b[43mmemory\u001b[49m\u001b[43m,\u001b[49m\u001b[43mper_epoch_results\u001b[49m\u001b[43m,\u001b[49m\u001b[43mcontextual\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43mgroup_setup\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mnone\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/projects/food_rescue_rmab/rmab/mcts_policies.py:596\u001b[0m, in \u001b[0;36mfull_mcts_policy\u001b[0;34m(env, state, budget, lamb, memory, per_epoch_results, contextual, group_setup, run_ucb, use_whittle)\u001b[0m\n\u001b[1;32m    594\u001b[0m should_break \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mFalse\u001b[39;00m \n\u001b[1;32m    595\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(scores_current_combo) \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m:\n\u001b[0;32m--> 596\u001b[0m     current_value \u001b[38;5;241m=\u001b[39m \u001b[43mget_total_value\u001b[49m\u001b[43m(\u001b[49m\u001b[43menv\u001b[49m\u001b[43m,\u001b[49m\u001b[43mall_match_probs\u001b[49m\u001b[43m,\u001b[49m\u001b[43mbest_group_arms\u001b[49m\u001b[43m,\u001b[49m\u001b[43mstate\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    597\u001b[0m \u001b[43m                                    \u001b[49m\u001b[43mgroup_indices\u001b[49m\u001b[43m,\u001b[49m\u001b[43mvalue_network\u001b[49m\u001b[43m,\u001b[49m\u001b[43mpolicy_network\u001b[49m\u001b[43m,\u001b[49m\u001b[43mlamb\u001b[49m\u001b[43m,\u001b[49m\u001b[43mnum_future_samples\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m25\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43mcontextual\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcontextual\u001b[49m\u001b[43m,\u001b[49m\u001b[43mmemoizer\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mmemoizer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    598\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m arm \u001b[38;5;129;01min\u001b[39;00m scores_current_combo:\n\u001b[1;32m    599\u001b[0m         new_group_index \u001b[38;5;241m=\u001b[39m deepcopy(group_indices)\n",
      "File \u001b[0;32m~/projects/food_rescue_rmab/rmab/mcts_policies.py:170\u001b[0m, in \u001b[0;36mget_total_value\u001b[0;34m(env, all_match_probs, best_group_arms, state, group_indices, value_network, policy_network, lamb, num_future_samples, weighted, contextual, memoizer)\u001b[0m\n\u001b[1;32m    167\u001b[0m samples \u001b[38;5;241m=\u001b[39m samples \u001b[38;5;241m<\u001b[39m probs \n\u001b[1;32m    168\u001b[0m samples \u001b[38;5;241m=\u001b[39m samples\u001b[38;5;241m.\u001b[39mastype(\u001b[38;5;28mfloat\u001b[39m)\n\u001b[0;32m--> 170\u001b[0m future_actions \u001b[38;5;241m=\u001b[39m \u001b[43mget_action_state\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpolicy_network\u001b[49m\u001b[43m,\u001b[49m\u001b[43msamples\u001b[49m\u001b[43m,\u001b[49m\u001b[43menv\u001b[49m\u001b[43m,\u001b[49m\u001b[43mcontextual\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcontextual\u001b[49m\u001b[43m,\u001b[49m\u001b[43mmemoizer\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mmemoizer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    172\u001b[0m future_actions \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mTensor(future_actions)\n\u001b[1;32m    173\u001b[0m future_states \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mTensor(samples)\n",
      "File \u001b[0;32m~/projects/food_rescue_rmab/rmab/mcts_policies.py:373\u001b[0m, in \u001b[0;36mget_action_state\u001b[0;34m(policy_network, state_list, env, contextual, memoizer)\u001b[0m\n\u001b[1;32m    362\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"Given a state, find the best action using the policy network\u001b[39;00m\n\u001b[1;32m    363\u001b[0m \u001b[38;5;124;03m\u001b[39;00m\n\u001b[1;32m    364\u001b[0m \u001b[38;5;124;03mArguments: \u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    368\u001b[0m \u001b[38;5;124;03m\u001b[39;00m\n\u001b[1;32m    369\u001b[0m \u001b[38;5;124;03mReturns: Numpy array, 0-1 action for each agent\"\"\"\u001b[39;00m\n\u001b[1;32m    371\u001b[0m x_points \u001b[38;5;241m=\u001b[39m get_policy_network_input_many_state(env,np\u001b[38;5;241m.\u001b[39marray(state_list),contextual\u001b[38;5;241m=\u001b[39mcontextual,memoizer\u001b[38;5;241m=\u001b[39mmemoizer)\n\u001b[0;32m--> 373\u001b[0m policy_network_predictions \u001b[38;5;241m=\u001b[39m policy_network(\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mTensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx_points\u001b[49m\u001b[43m)\u001b[49m)\u001b[38;5;241m.\u001b[39mdetach() \n\u001b[1;32m    374\u001b[0m policy_network_predictions \u001b[38;5;241m=\u001b[39m policy_network_predictions\u001b[38;5;241m.\u001b[39mnumpy()\n\u001b[1;32m    376\u001b[0m action \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mzeros(np\u001b[38;5;241m.\u001b[39marray(state_list)\u001b[38;5;241m.\u001b[39mshape, dtype\u001b[38;5;241m=\u001b[39mnp\u001b[38;5;241m.\u001b[39mint8)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "policy = full_mcts_policy_contextual \n",
    "name = \"mcts\"\n",
    "\n",
    "rewards, memory, simulator = run_multi_seed(seed_list,policy,is_mcts=True,train_iterations=train_iterations,test_iterations=test_iterations)\n",
    "results['{}_reward'.format(name)] = rewards['reward']\n",
    "results['{}_match'.format(name)] =  rewards['match'] \n",
    "results['{}_active'.format(name)] = rewards['active_rate']\n",
    "results['{}_time'.format(name)] =  rewards['time']\n",
    "print(np.mean(rewards['reward']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "if is_jupyter:\n",
    "    def plot_sliding_window(data):\n",
    "        return [np.mean(data[i:i+100]) for i in range(len(data)-100)]\n",
    "    policy_loss_1 = memory[0][-6]\n",
    "    value_loss_1 = memory[0][-10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGdCAYAAAAxCSikAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/OQEPoAAAACXBIWXMAAA9hAAAPYQGoP6dpAABCEUlEQVR4nO3deXxU5d3///dk3yckIQmBLGyyCAKyxKAV1FSwtIraitQCpVZvrQsWv6hYl/5u641dtFi1ovZW27pAvVWKSrEYFLFEkF0QAdkSCUkIITvZZq7fHzEDIwEyyWTOJHk9H495PIYz15z5XIeQeXOd61zHZowxAgAA8GMBVhcAAABwNgQWAADg9wgsAADA7xFYAACA3yOwAAAAv0dgAQAAfo/AAgAA/B6BBQAA+L0gqwvwBqfTqYKCAkVHR8tms1ldDgAAaAVjjCorK5WSkqKAgDOPoXSJwFJQUKDU1FSrywAAAG2Qn5+vPn36nLFNlwgs0dHRkpo6HBMTY3E1AACgNSoqKpSamur6Hj+TLhFYmk8DxcTEEFgAAOhkWjOdg0m3AADA7xFYAACA3yOwAAAAv0dgAQAAfo/AAgAA/B6BBQAA+D0CCwAA8HsEFgAA4PcILAAAwO8RWAAAgN8jsAAAAL9HYAEAAH6PwHIGtQ0OLVi+U/e//bkcTmN1OQAAdFsEljOw2aTnPt6n19blqaqu0epyAADotggsZxAaFKiQwKZDRGABAMA6BJaziA4LkiRV1jZYXAkAAN0XgeUsor4JLFW1jLAAAGAVAstZRIU2j7AQWAAAsAqB5Sxcp4SYwwIAgGUILGcRFRosiVNCAABYicByFjFMugUAwHIElrNwTbrllBAAAJYhsJzFicuaCSwAAFiFwHIWzXNYCCwAAFinTYHlmWeeUUZGhsLCwpSZman169eftu2OHTt07bXXKiMjQzabTQsXLmz3Pn0pijksAABYzuPAsmTJEs2dO1cPP/ywNm3apBEjRmjSpEkqLi5usX1NTY369eunxx57TMnJyV7Zpy81T7qtrmeEBQAAq3gcWJ544gnddNNNmj17toYOHapFixYpIiJCL774Yovtx44dq9///ve6/vrrFRoa6pV9+lLzwnFc1gwAgHU8Ciz19fXauHGjsrOzT+wgIEDZ2dnKzc1tUwFt2WddXZ0qKircHh0lMpSF4wAAsJpHgaWkpEQOh0NJSUlu25OSklRYWNimAtqyzwULFshut7seqampbfrs1mgeYakmsAAAYJlOeZXQ/PnzVV5e7nrk5+d32GdFc/NDAAAsF+RJ44SEBAUGBqqoqMhte1FR0Wkn1HbEPkNDQ087H8bbXCMs9Q7VNjgUFhzok88FAAAneDTCEhISotGjRysnJ8e1zel0KicnR1lZWW0qoCP26U09IkLUyx4mSfp49xGLqwEAoHvyaIRFkubOnatZs2ZpzJgxGjdunBYuXKjq6mrNnj1bkjRz5kz17t1bCxYskNQ0qfaLL75wPT906JC2bNmiqKgoDRgwoFX7tFJAgE3npth1uLxWR6rqrC4HAIBuyePAMm3aNB05ckQPPfSQCgsLNXLkSK1YscI1aTYvL08BAScGbgoKCjRq1CjXn//whz/oD3/4gyZMmKCPPvqoVfu0Wkx402GqOM48FgAArGAzxhiri2iviooK2e12lZeXKyYmxuv7//WyHXp57QH9YmJ/3TN5sNf3DwBAd+TJ93envErI15pXu61geX4AACxBYGmFmHBugAgAgJUILK3QvBZLxXFGWAAAsAKBpRWiwxhhAQDASgSWVoghsAAAYCkCSytEM+kWAABLEVhagUm3AABYi8DSCs2XNVfVNarR4bS4GgAAuh8CSyvYvxlhkaQKRlkAAPA5AksrBAUGKPqbuzaX1dRbXA0AAN0PgaWVmuexlLEWCwAAPkdgaaXYiKbAUl5DYAEAwNcILK3UHFjKjnNKCAAAXyOwtFJseIgkRlgAALACgaWV7BHMYQEAwCoEllaKbZ50ywgLAAA+R2BpJdekW0ZYAADwOQJLKzXPYWEdFgAAfI/A0krMYQEAwDoEllZqXp6fU0IAAPgegaWVWDgOAADrEFhaKTqsKbBUcvNDAAB8jsDSSqFBTYeq3uGUMcbiagAA6F4ILK0UEnTiUNU1Oi2sBACA7ofA0kqhJwWWegeBBQAAXyKwtFJI4EkjLA0EFgAAfInA0ko2m811WogRFgAAfIvA4oHm00J1DQ6LKwEAoHshsHgglBEWAAAsQWDxQGhQoCTmsAAA4GsEFg+4TglxWTMAAD5FYPFA86TbylqW5wcAwJcILB4YkBglSfrkqxKLKwEAoHshsHhgdHoPSVJxRZ3FlQAA0L0QWDxgD2+6AWIFp4QAAPApAosHmgNL+XECCwAAvkRg8QCBBQAAaxBYPBDTfEqIwAIAgE8RWDxwYg5Lo4wxFlcDAED3QWDxQHNgcTiNquoaLa4GAIDug8DigbDgQNficcxjAQDAdwgsHooJa57HwggLAAC+QmDxkD08SBIjLAAA+BKBxUNc2gwAgO8RWDwUw2q3AAD4HIHFQ3bWYgEAwOcILB7ilBAAAL5HYPEQIywAAPgegcVDzZc1M8ICAIDvEFg8xCkhAAB8j8DioRgCCwAAPkdg8VDMNwvHVdSy0i0AAL5CYPEQp4QAAPA9AouHCCwAAPgegcVDzXNY6hudqm1wWFwNAADdA4HFQ1EhQQqwNT1nLRYAAHyDwOKhgAAbVwoBAOBjBJY2YB4LAAC+RWBpg+bVbrljMwAAvkFgaQNGWAAA8C0CSxu4AksNgQUAAF8gsLQBq90CAOBbbQoszzzzjDIyMhQWFqbMzEytX7/+jO3feOMNDR48WGFhYRo+fLiWL1/u9npVVZVuv/129enTR+Hh4Ro6dKgWLVrUltJ8gquEAADwLY8Dy5IlSzR37lw9/PDD2rRpk0aMGKFJkyapuLi4xfZr167V9OnTdeONN2rz5s2aOnWqpk6dqu3bt7vazJ07VytWrNArr7yinTt36q677tLtt9+uZcuWtb1nHYg5LAAA+JbHgeWJJ57QTTfdpNmzZ7tGQiIiIvTiiy+22P7JJ5/U5MmTNW/ePA0ZMkSPPPKIzj//fD399NOuNmvXrtWsWbM0ceJEZWRk6Oabb9aIESPOOnJjlebAwsJxAAD4hkeBpb6+Xhs3blR2dvaJHQQEKDs7W7m5uS2+Jzc31629JE2aNMmt/fjx47Vs2TIdOnRIxhh9+OGH2r17ty6//PIW91lXV6eKigq3hy81X9bMCAsAAL7hUWApKSmRw+FQUlKS2/akpCQVFha2+J7CwsKztn/qqac0dOhQ9enTRyEhIZo8ebKeeeYZXXzxxS3uc8GCBbLb7a5HamqqJ91oN04JAQDgW35xldBTTz2lTz/9VMuWLdPGjRv1+OOP67bbbtMHH3zQYvv58+ervLzc9cjPz/dpvXGRIZKkkqp6n34uAADdVZAnjRMSEhQYGKiioiK37UVFRUpOTm7xPcnJyWdsf/z4cd1///16++23NWXKFEnSeeedpy1btugPf/jDKaeTJCk0NFShoaGelO5VKbHhkqSSqjrVNjgUFhxoWS0AAHQHHo2whISEaPTo0crJyXFtczqdysnJUVZWVovvycrKcmsvSStXrnS1b2hoUENDgwIC3EsJDAyU0+n0pDyf6RERrPBvQsrh8lqLqwEAoOvzaIRFaroEedasWRozZozGjRunhQsXqrq6WrNnz5YkzZw5U71799aCBQskSXPmzNGECRP0+OOPa8qUKVq8eLE2bNig559/XpIUExOjCRMmaN68eQoPD1d6erpWr16tv/3tb3riiSe82FXvsdlsSowJ1cGjNSqpqlPfhEirSwIAoEvzOLBMmzZNR44c0UMPPaTCwkKNHDlSK1ascE2szcvLcxstGT9+vF577TU98MADuv/++zVw4EAtXbpUw4YNc7VZvHix5s+frxtuuEGlpaVKT0/Xo48+qltuucULXewYsREhOni0RseqmccCAEBHsxljjNVFtFdFRYXsdrvKy8sVExPjk8/86Uvr9dGuI/rdtefpurG+vUoJAICuwJPvb7+4Sqgz6hHRdKXQsRpGWAAA6GgEljaKjWhai+UYd2wGAKDDEVjaKO6bEZYyRlgAAOhwBJY2io3klBAAAL5CYGmjHs2nhKo5JQQAQEcjsLQRk24BAPAdAksbMekWAADfIbC0UY+TJt12gaVsAADwawSWNmoOLI1Oo6q6RourAQCgayOwtFF4SKDCgpsOXxmnhQAA6FAElnZg4i0AAL5BYGmH2G8CSyk3QAQAoEMRWNqheS0WTgkBANCxCCztwCkhAAB8g8DSDqzFAgCAbxBY2iEukhsgAgDgCwSWdoh1nRJihAUAgI5EYGmHE5NuGWEBAKAjEVjaoQeXNQMA4BMElnaI5bJmAAB8gsDSDlzWDACAbxBY2qE5sNTUO1TX6LC4GgAAui4CSztEhwUpMMAmiXksAAB0JAJLOwQE2BQREihJ+uvagxZXAwBA10Vgaae6BqckadHqvRZXAgBA10Vgaac7Lh1gdQkAAHR5BJZ2+v6IFElS5DenhgAAgPcRWNopPqrpSqHqeodqG7hSCACAjkBgaafo0CAFBzZdKXSUK4UAAOgQBJZ2stlsio8MlSSVVhFYAADoCAQWL4iLbDotVFJdZ3ElAAB0TQQWL2iex8IICwAAHYPA4gUJUU2nhP780VcWVwIAQNdEYPGCkMCmw7j3SLXKuXMzAABeR2DxgoraEyGlsKLWwkoAAOiaCCxekD0kyfX8cPlxCysBAKBrIrB4wdRRvV3PixhhAQDA6wgsXhAYYNP1Y1MlSYfLCSwAAHgbgcVLkmLCJDHCAgBARyCweElzYDlSyeJxAAB4G4HFSyK+uVtzbYPT4koAAOh6CCxeEhrUdCi5YzMAAN5HYPGSsOBvRlgaCSwAAHgbgcVLmkdY6jglBACA1xFYvCSUERYAADoMgcVLwoIZYQEAoKMQWLwkNKj5KiFGWAAA8DYCi5e4RlgaGWEBAMDbCCxe0jzCUtfolNNpLK4GAICuhcDiJfbwYAUG2CRJxax2CwCAVxFYvCQkKEDp8RGSpD3FlRZXAwBA10Jg8aL0uKbAUlB23OJKAADoWggsXpQQFSpJKqmqt7gSAAC6FgKLF8W7AgtzWAAA8CYCixclRIVIkl76zwEdq2aUBQAAbyGweFHzKSFJemrVVxZWAgBA10Jg8aKTA0teaY2FlQAA0LUQWLwoOizI9Zwl+gEA8B4CixelfnNZsyTV1DdaWAkAAF0LgcWL4iJD9D9XD5ckHS6vtbgaAAC6DgKLl2UPSZQkFVXUqtHBjRABAPAGAouXJUSFKjjQJqeRirinEAAAXtGmwPLMM88oIyNDYWFhyszM1Pr168/Y/o033tDgwYMVFham4cOHa/ny5ae02blzp6688krZ7XZFRkZq7NixysvLa0t5lgoIsCnZHiZJOswS/QAAeIXHgWXJkiWaO3euHn74YW3atEkjRozQpEmTVFxc3GL7tWvXavr06brxxhu1efNmTZ06VVOnTtX27dtdbfbu3auLLrpIgwcP1kcffaRt27bpwQcfVFhYWNt7ZqFe9nBJUgHzWAAA8AqbMcZ48obMzEyNHTtWTz/9tCTJ6XQqNTVVd9xxh+67775T2k+bNk3V1dV69913XdsuuOACjRw5UosWLZIkXX/99QoODtbf//73NnWioqJCdrtd5eXliomJadM+vOmXS7bo7c2HdN8Vg3XLhP5WlwMAgF/y5PvboxGW+vp6bdy4UdnZ2Sd2EBCg7Oxs5ebmtvie3Nxct/aSNGnSJFd7p9Op9957T+ecc44mTZqkxMREZWZmaunSpaeto66uThUVFW4Pf9KLU0IAAHiVR4GlpKREDodDSUlJbtuTkpJUWFjY4nsKCwvP2L64uFhVVVV67LHHNHnyZP373//W1VdfrWuuuUarV69ucZ8LFiyQ3W53PVJTUz3pRodLiW06JbRuf6nFlQAA0DVYfpWQ09l06e9VV12lX/7ylxo5cqTuu+8+ff/733edMvq2+fPnq7y83PXIz8/3ZclnlRLbNMLyZWGl9h6psrgaAAA6P48CS0JCggIDA1VUVOS2vaioSMnJyS2+Jzk5+YztExISFBQUpKFDh7q1GTJkyGmvEgoNDVVMTIzbw5+kxUW6nufsLDpDSwAA0BoeBZaQkBCNHj1aOTk5rm1Op1M5OTnKyspq8T1ZWVlu7SVp5cqVrvYhISEaO3asdu3a5dZm9+7dSk9P96Q8vzEgMUrJMU2jLF8fYx4LAADtFXT2Ju7mzp2rWbNmacyYMRo3bpwWLlyo6upqzZ49W5I0c+ZM9e7dWwsWLJAkzZkzRxMmTNDjjz+uKVOmaPHixdqwYYOef/551z7nzZunadOm6eKLL9Yll1yiFStW6J133tFHH33knV5a4Off6avfvLdT5ccbrC4FAIBOz+PAMm3aNB05ckQPPfSQCgsLNXLkSK1YscI1sTYvL08BAScGbsaPH6/XXntNDzzwgO6//34NHDhQS5cu1bBhw1xtrr76ai1atEgLFizQnXfeqUGDBunNN9/URRdd5IUuWiMmLFiS9M8tBXriupEKDLBZXBEAAJ2Xx+uw+CN/W4dFklZsP6xbXtkkSXr8RyN07eg+FlcEAIB/6bB1WNB6jc4TOXDnYf9aJwYAgM6GwNJBhqXYXc8PV7BEPwAA7UFg6SAZCZGac9lASVLe0RqLqwEAoHMjsHSgycOa1popYIl+AADahcDSgZrvKXS0ul61DQ6LqwEAoPMisHQge3iwQoOaDnFxRZ3F1QAA0HkRWDqQzWZzjbLsP1ptcTUAAHReBJYOlvxNYJn14npV1zVaXA0AAJ0TgaWDxUeGup5vziuzrhAAADoxAksHCw0+cYhtrM4PAECbEFg62MDEaNdzboQIAEDbEFg62E/HZ7ieH6upt64QAAA6MQJLBwsPCdT1Y1MlSUcqubQZAIC2ILD4QGpchCQpr5Ql+gEAaAsCiw+kfRNY9hRVWVwJAACdE4HFB8ZmxEmSPj9UrsJy7twMAICnCCw+kGwP0+j0HpKkVV8WW1wNAACdD4HFR8Z8E1j+tf2wxZUAAND5EFh8ZEBilCRpzZ4SlugHAMBDBBYfmTws2fU8/xhXCwEA4AkCi49EhwVraK8YSdLhMibeAgDgCQKLD6XENt25uaD8uMWVAADQuRBYfCguMkSSVFbDPYUAAPAEgcWHekQ0BZZj1dxTCAAATxBYfCi2ObAwwgIAgEcILD7UIyJYklRazU0QAQDwBIHFh/r04CaIAAC0BYHFh/onRkqSDh6tUYPDaXE1AAB0HgQWH0qMDlOATWp0Gh2rYeItAACtRWDxocAA24mJt9VMvAUAoLUILD52YuItIywAALQWgcXHXGuxcEoIAIBWI7D4WFpc05VCXx6usLgSAAA6DwKLj43rGydJWre/1OJKAADoPAgsPtYcWNYfKNWBkmqLqwEAoHMgsPhY34RIDesdI2Ok/+wtsbocAAA6BQKLj9lsNo1JbxplyTvKircAALQGgcUCGfFNE28PElgAAGgVAosF0uOblug/cJQ5LAAAtAaBxQJp8SdugmiMsbgaAAD8H4HFAn16hCvAJtXUO1RSxQJyAACcDYHFAqFBgeplD5ckHeS0EAAAZ0VgsUg6E28BAGg1AotFmifeHiwlsAAAcDYEFoucGGHhlBAAAGdDYLFIehynhAAAaC0Ci0WaL23O55QQAABnRWCxSFJMmCSptKZejQ6nxdUAAODfCCwWiQ0Pls0mGSOVHW+wuhwAAPwagcUiQYEBsocHS5KOVbN4HAAAZ0JgsVBcRIgk6UhVncWVAADg3wgsFmq+tHnvES5tBgDgTAgsFhrcK0aStG7fUYsrAQDAvxFYLHTFsGRJ0sovilTX6LC4GgAA/BeBxULDe9uVEBWiukanPtlTYnU5AAD4LQKLhWw2m64a2VuS9H8bv7a4GgAA/BeBxWLfP6+XJOlT5rEAAHBaBBaLDU6Okc0mHatp0FEubwYAoEUEFouFhwSqT49wSdKe4iqLqwEAwD8RWPzAgJ5RkqSvCCwAALSIwOIHBiQ2BZa9RwgsAAC0hMDiB9LiIyVJ+aXHLa4EAAD/1KbA8swzzygjI0NhYWHKzMzU+vXrz9j+jTfe0ODBgxUWFqbhw4dr+fLlp217yy23yGazaeHChW0prVNKi2taoj+/tMbiSgAA8E8eB5YlS5Zo7ty5evjhh7Vp0yaNGDFCkyZNUnFxcYvt165dq+nTp+vGG2/U5s2bNXXqVE2dOlXbt28/pe3bb7+tTz/9VCkpKZ73pBNrDix5pTUyxlhcDQAA/sfjwPLEE0/opptu0uzZszV06FAtWrRIERERevHFF1ts/+STT2ry5MmaN2+ehgwZokceeUTnn3++nn76abd2hw4d0h133KFXX31VwcHBbetNJ9U7Nlw2m3S8waEjlVzaDADAt3kUWOrr67Vx40ZlZ2ef2EFAgLKzs5Wbm9vie3Jzc93aS9KkSZPc2judTs2YMUPz5s3Tueeee9Y66urqVFFR4fbozEKCAtQ7tunS5v0l3LkZAIBv8yiwlJSUyOFwKCkpyW17UlKSCgsLW3xPYWHhWdv/9re/VVBQkO68885W1bFgwQLZ7XbXIzU11ZNu+KWB31wp9NA/d1hcCQAA/sfyq4Q2btyoJ598Ui+//LJsNlur3jN//nyVl5e7Hvn5+R1cZce7+JyekqRdRZUqKONqIQAATuZRYElISFBgYKCKiorcthcVFSk5ObnF9yQnJ5+x/Zo1a1RcXKy0tDQFBQUpKChIBw8e1N13362MjIwW9xkaGqqYmBi3R2c3+8K+rhVvtx8qV3FlrUpYqh8AAEkeBpaQkBCNHj1aOTk5rm1Op1M5OTnKyspq8T1ZWVlu7SVp5cqVrvYzZszQtm3btGXLFtcjJSVF8+bN0/vvv+9pfzq1cRlxkqSb/75R4x7N0eV//FiNDqfFVQEAYL0gT98wd+5czZo1S2PGjNG4ceO0cOFCVVdXa/bs2ZKkmTNnqnfv3lqwYIEkac6cOZowYYIef/xxTZkyRYsXL9aGDRv0/PPPS5Li4+MVHx/v9hnBwcFKTk7WoEGD2tu/TmVIrxhp8yHXn0ur63Wkqk697OEWVgUAgPU8DizTpk3TkSNH9NBDD6mwsFAjR47UihUrXBNr8/LyFBBwYuBm/Pjxeu211/TAAw/o/vvv18CBA7V06VINGzbMe73oIs5Pjz1l2zV/XqsVcy6WPaJ7XeoNAMDJbKYLrFRWUVEhu92u8vLyTj2fxRijvvNPXQX4/11+jm6/dKAFFQEA0HE8+f62/CohnGCz2bT+/ssUFeo+8NXg6PSZEgCAdiGw+JnEmDBt//8muSbgSlJ4SKCFFQEAYD0Ci5+ae/k5rueVtQ0WVgIAgPUILH7qgn7x+nFmmiTp62MsJAcA6N4ILH6sf8+m5fr/uaVAR1lEDgDQjRFY/NiVI1LUyx4mSbrn/7ZZXA0AANYhsPixntGhunJkiiQp58tiff51ucUVAQBgDQKLn7t+bJrreV5pjYWVAABgHQKLn+ubEKkLBzTduoCrhQAA3RWBpROIjwyVJP3h37strgQAAGsQWDqBzfnHJEklVXXafoh5LACA7ofA0gn8YuIA1/NPviqxsBIAAKxBYOkEfjS6j6ac10uS9MkeAgsAoPshsHQCQYEBmnNZ092aP/mqRAePVltcEQAAvkVg6STOSYrWOUlNK9/uPVJlcTUAAPgWgaUTSY+PlCQd4t5CAIBuJsjqAtB6Kd8s03+orFYvfrJffROaAszYvnGKCuWvEgDQdfEt14n0iAyRJC1avddt+5UjUvSn6aOsKAkAAJ/glFAnYg8PbnH7yi+KVNfo8HE1AAD4DoGlE2l0mBa3H29waP3+Uh9XAwCA7xBYOpGI0EDX8ytHpLi9truIK4cAAF0Xc1g6kWvP76PVu47oksGJ+t7wXvru0CSt2XNE/9jwtfK5kzMAoAtjhKUTCQsO1PMzx2j6uDTZw4P1gxEpGp3eQ5L08toD2nm4wuIKAQDoGASWTm50epzr+ePczRkA0EURWDq5AYlRunxokiRpw8FSOZwtT8wFAKAzI7B0AX++4XzFhAWprKZBj/97l9XlAADgdQSWLiAoMED/NaG/JOm5j/eptLre4ooAAPAuAksXcdslAzQ4OVoOp9F/v7NDxnBqCADQdRBYupAfZ6ZJkpZuKdCOAq4YAgB0HQSWLuQnmemu50cq6yysBAAA7yKwdCEBATZdOCBeklR2nHksAICug8DSxcSGN93RubymweJKAADwHgJLFxPzzR2dy44TWAAAXQeBpYtJjQuXJC38YI9+vWyHxdUAAOAdBJYu5upRvV3PX157QBsOlFpYDQAA3kFg6WJ62cM1b9Ig159/uChXH+4qVnVdo4VVAQDQPgSWLui2SwbozVuzXH+e/dJnuu65XO4zBADotAgsXdTo9Dj1iAh2/XlHQYWKK2strAgAgLYjsHRh7935Hd07ebAiQwIlSYfLCSwAgM6JwNKFpcSG69aJ/TUoOVqSdM2f1yrvaI3FVQEA4DkCSzdw6eBE1/OLf/+hVn1ZZGE1AAB4jsDSDdx+6UAt+slo159v/ttG5rMAADoVAks3MencJP1iYn9JUqPTaGt+ucUVAQDQegSWbsJms+meyYNdp4dKq7mbMwCg8yCwdDNxkU03Ryyp4m7OAIDOg8DSzcR/E1iOfhNYjlbVaclnefqquMrKsgAAOKMgqwuAb/XvGSVJ+mBnkaJCA/WnVV9JktLjI7Tq7okKDLBZWR4AAC1ihKWbufzcJElSXmmNK6xI0sGjNXpz09dWlQUAwBkRWLqZ2IgQ9Y4Nb/G1e/5vmw6VHfdxRQAAnB2BpRta9JPROj8tVm/emqWcuyfokanDXK9d+Ngq/XrZDgurAwDgVDZjTKe/hW9FRYXsdrvKy8sVExNjdTmdjjFGd7y+We9uO+zatuz2C3Ven1jrigIAdHmefH8zwgLZbDY9/ePztenB77q27TxcYWFFAAC4I7DAJS4yRNPGpEqSiitYWA4A4D8ILHCTGBMqSVq0eq/FlQAAcAKBBW4GJzedQ6yud6i0mtVwAQD+gcACN98bnqzQoKYfiz+u3G1xNQAANCGwwI3NZtNPL8yQJG08eMzaYgAA+AaBBaeYcUG6JGl3UaUaHU6LqwEAgMCCFqTYwxUSGKBGp9Hh8lqrywEAgMCCUwUE2NQnrmn5/vzSGourAQCAwILTSI4JkyQVV7IeCwDAegQWtCgsOFCSdNeSLdYWAgCA2hhYnnnmGWVkZCgsLEyZmZlav379Gdu/8cYbGjx4sMLCwjR8+HAtX77c9VpDQ4PuvfdeDR8+XJGRkUpJSdHMmTNVUFDQltLgJUerToyscFoIAGA1jwPLkiVLNHfuXD388MPatGmTRowYoUmTJqm4uLjF9mvXrtX06dN14403avPmzZo6daqmTp2q7du3S5Jqamq0adMmPfjgg9q0aZPeeust7dq1S1deeWX7eoZ2+dWUoa7ne4orLawEAIA23K05MzNTY8eO1dNPPy1JcjqdSk1N1R133KH77rvvlPbTpk1TdXW13n33Xde2Cy64QCNHjtSiRYta/IzPPvtM48aN08GDB5WWlnbWmrhbc8f42cufadWXxXrsmuG6ftzZ/x4AAPBEh92tub6+Xhs3blR2dvaJHQQEKDs7W7m5uS2+Jzc31629JE2aNOm07SWpvLxcNptNsbGxLb5eV1eniooKtwe8L+mb+woVcSNEAIDFPAosJSUlcjgcSkpKctuelJSkwsLCFt9TWFjoUfva2lrde++9mj59+mnT1oIFC2S3212P1NRUT7qBVkqPj5Qkbf26zNpCAADdnl9dJdTQ0KDrrrtOxhg9++yzp203f/58lZeXux75+fk+rLL7uGRQoiRp1ZfFemDp5zpe71BNfaMkyek0uvP1zXrsX19aWSIAoJsI8qRxQkKCAgMDVVRU5La9qKhIycnJLb4nOTm5Ve2bw8rBgwe1atWqM57LCg0NVWhoqCelow3OSYpyPX/l0zy98mmeJOnnF/XV5GHJWra16UqumVnp6hkdqkCbTQEBNktqBQB0bR6NsISEhGj06NHKyclxbXM6ncrJyVFWVlaL78nKynJrL0krV650a98cVvbs2aMPPvhA8fHxnpSFDmKz2fSLif1P2f6XT/brh4tOzEEa/9gqDfzVvzTyv/+tf2zIl8Pp0TxuAADOyuNTQnPnztULL7ygv/71r9q5c6duvfVWVVdXa/bs2ZKkmTNnav78+a72c+bM0YoVK/T444/ryy+/1K9//Wtt2LBBt99+u6SmsPLDH/5QGzZs0KuvviqHw6HCwkIVFhaqvr7eS91EW9152UD991XntqptRW2j7vm/bep//3L9etkO1TY4zti+pKpO72wt0PH6M7cDAMCjU0JS02XKR44c0UMPPaTCwkKNHDlSK1ascE2szcvLU0DAiRw0fvx4vfbaa3rggQd0//33a+DAgVq6dKmGDRsmSTp06JCWLVsmSRo5cqTbZ3344YeaOHFiG7sGbwgLDtTMrAxtyS/TW5sOtfp9L689oAaHU49ePfy0be5avEWffFUiSXr3jos0rLe93fUCALomj9dh8Uesw9LxjDEqqmgaEXl0+U5J0qq7J2jJZ/kKCLCpuKJOb276+pT3rbnnEqXGRZyyvaiiVpn/c+JU4a0T++veyYPdPm9zfpn6xkeqR2RIB/QIAGA1T76/CSzw2I6CcgXYbBrSy/1Y55fWqPx4g/r1jNT0F9Zpa36ZekQE6+1fXKiMhEjVNjj00n8OaPnnh/X5ofJT9hsREqiRqbEa3seud7YUqKC8ViNTY3XbJQO083CFUmLDde35vWWzMbEXALoCAgsstzW/TFc98x9J0sRBPRUUEKAPdhad0m58/3jtLqpUSVXr5ivdM3mQfjFxgFdrBQBYo8NWugVaa0RqrB67pmn+yke7jrQYVn6cmaaXZo/VO3dcpN9eO1zp8SdOHY1J79Hift/ZerhjCgYA+DVGWNBhdhVWatLCj922vXlrlob3jlXZ8XolRoed8p6DR6tVU+/Q4ORorfqyWG9tPqQJ5/TUmxu/1rr9pZKkIb1itOCa4RqZGuuLbgAAOginhOAXGh1OXfHkGu0prpIkPXn9SF01sneb9mWM0a2vbNKKHSdu6fCbqcP0kwvSz/re2gaHQgIDWNQOAPwMgQV+w+E0+uxAqc7rY1dEiMdX0bsxxuj5j/dpwUm3A3hp9ljXLQRasuFAqWa+uF4XDUjQ8zPHtOvzAQDexRwW+I3AAJsu6Bff7rAiNa28+18T+uvOS09Muj3b2jB/WvWVauod+vcXRfrLmn3trgHeU1XX6Lo3FQCcTfu/RQAf+/nF/bSzsFIrvyjSO1sLNOOCdI3rG3dKu4Ky49pwoNT159+8t1Pj+sbpvD6xPqwWzRxOo9fX56m0ul7GSH/8YLd62cN0+6UDdPHAnurTI1w2m01Op3GdvjPG6H8/2a/Q4EDNaMXpPwBdF6eE0Ckdq67XqEdWum174roRumJYL4WHBKqqrlHDHn6/xfeO6GNXfFSo5lw2UCO6+MTd5n/evli75u3NX+vTvaX65XfP0Y6CcoWHBGp8/wRJ0lfFVZqzeLN2FFSccR8hgQGKCQ/S94b30tHqer237cRVYeP7x+vg0Rr991Xn6rIhSR3aFwC+wRwWdAtjfrOyVeu3/HHaCIUEBuquJZvV4Djx4z6ub5yW3HzBWb/Ml20t0Asf79N/TeinSecmq7K2UXuKKjUoOVobDhzTyLRYJUT5393Ddx6u0BVPrtF3BiZo2thUDUyM1qDk6A75rC8LKzR54ZpTtsdFhujhHwzVnMVbXNtS7GGy2Ww6VHa8zZ+39aHLZY8IbvP7rWKMkTFiAjjwDQILuoWPdhXr77kHlfNl8WnbXDY4Uc/ccL7CggNV1+jQX9bs18IPdruCy5j0HnrjlizZbDbtPFyh/3xVoomDEpVsD9Ox6npFhwVp5H+fGMnpHRve4hftT8dn6PpxqRqUFG3pSry1DQ59dqBUL6zZr493H3F7zR4erHX3X6aw4MAW37vkszwFBwbomvP7ePSZB0qqNfEPH7Wq7eM/GqFrRzft3xijT/eVKj4qRPuOVOl37+9SfmmNfnBeihzGKCIkUKXV9Xp/R5GCAmwakBilLwsrXfsa1zdOCVEhKq6oU9+ESN3/vSF+cxuHspp6/e79XRre267D5bWqa3Toq6Iq5XxZrKAAm7L6x+v3PxyhZPupl/YD3QmBBd1KQdlx/TX3gJ5bfWJS7Z2XDdSPRvdp8T5Gxhj9/K8bXEHn43mX6MNdxXp42Y5213JBvzi9ftPZR23ao7C8VjHhQadMZC6qqNUPF61VfumZRy6uHJGi3157nvaXVOs3732htXuPKijApkZn06+C0ek9NPncZF07uo/iIkP0r88Pq6SqTjOyMlz7+OxAqf6yZp/e3+G+IODCaSO1o6BcDqcUHGjTcx+f+Dv5yQVp+s3U098M0xgjp2maqP3t7ZV1jYoJC9Ztr21yO030bVse+q5iI5pCy6LVe7V4fZ4KymtlDw/WPZMG6UdjUs94bFqrorZBW/PLdNGABNffdXVdo27862f6dF/pWd7dZMYF6Xpk6rAWX6ttcJw2WAJdCYEF3Y4xRoUVtVqzp0QXD+x51v+5Op1G/e5f3ur9j8uI088uytDfcg9q7d6junBAvH7+nX6qON6gd7YeVnVdo3L3HXW1PycpSndeNlDfPy+lzX1yOI2cxqiqtlGxEcEqrKjVj19Yp/0l1eplD9OSm7NUXd/02vZDFfr1sh2njP7cd8Vg3fydfnp0+U797yf7Pfr84ECbEqJCdbi8VpL05q3jlRgdqhv+sk55pTWntL90cKL+d9YY1xe4MUZ//mivvj52XKlx4bp+bJri2jkCcqy6Xt/94+rTngqccUG6ahsc2l9SrQ0Hj7m9Zg8P1taHL5cxRruLqlRV16h+CZEqqqzV4GT33xv7jlTpna2Hta+kSk4j3fydfurXM1K/XLJFq3cfUV2jU1LT33NMWLBKq+u1r6T6tHX3iAjWNef3UVRokEqq6vTqujxJ0tSRKRrW267iyjpFhAQqISpU7+8o1Jo9JRre2660+AhNOKenrmtF0Gp0OLWrqFKDk2NOCX3e0OBwatmWAk0Y1NMvT4F2Jk6n0ZIN+YoKDdLEQT0VHdb5Tm96C4EFaIW/5x7Qg/88MarSr2ekfv/D8/TvHUX6/FC51u5tCiBDesXo5dljlRTTFIKOVdcrNiL4lFGUm/+2Qf/+wn3E4f27Lm7TvJHqukZ9709rdPBoUzDo0yNc8ZEh2vr1qTeN/La/zByjEamxsocHKyQowFXzvW9uO6W+ZlOG99KMrHQ99M/t2l1U1WKbAJv03aFJp4yqjEiN1bCUGP36ynMVHNjxKyU0OpxqcBjVO5yyhwfL4TS67rlcbfxWQGn2z9sudN3XKjQoQA98f6geXLrdrc0lg3pKalqdOTEmTJ8fKpfD2fZfjS/9dKyG9bZrd1Gl4qNC3AJRaXW9sp9YrdLq1t0/S5IW/eR8hYcE6XcrvtScywbq4nN66lhNvdbsKdFr6/JUWF6rwopaV/t377hIw3rbz7rf7YfKZQ8PVmpchFbvPqI3N36tiJBA/frKcxUUYNOcJVtUXFEre3iI2+01osOCFBRg0x+njdTEM6yD1F0VV9bqxU8OaP3+o0qLi1BGQqTKahpUVlOvXrHhevajvW7tR6TGKrNvnF5fl6fePcJ17+TBumRw9ziuBBaglQ4erVZ1nUP9ekaeMgR/uPy4osOCFRXauqv/GxxOPbXqK33wRZG+ONx0NUxQgE13ZQ/U7ZcOlCSVH2/QrsJK5ZXW6NN9R+U0RlGhQbr90gGuWxXU1Dfq/rc+19ItBS1+zunm0QzrHaNHrhqmUWkt34dJahr1OFbToOWfH9YDS7dr+rg0TTo3SRPO6ek2MrJmT4leWLNPa/aUtLifC/rF6fmZYxTjJ/8zrGt06NI/rD7luPx/V56rWeMzdO//bdOSDfle+7ye0aEamBilhKhQFVfWuk4DvXnreI0+zX2wTlZT36iVXxTpL2v2q6SqTuP6xml3UZUaHU4N6RWj8/rYte3rci3b2vLPwNlEhwXpH/+Vdcod1Zu9ufFrvbBmn2tOkM0mtfWboH/PSI3vn6BzkqM1Jr2HhvSKkcNptHZvifYdqdaMC9K7zSTjQ2XHtXDlbr2x8et276t/z0j93y3j/WZeVkchsAAW236oXI++t9N1mujZG87XF4cr9NSqr9q8z+8MTND1Y9P0veHJ+uJwhWIjQpQQFaJP95XqeL1DEwf17JB5D8WVtXri37u1+LOmL/yLBiToqemj/O4X6db8Mr27rUBXj+qjgrLj2l1cqZu+00/BgQFqcDh15+ub9a/tTbd2sNma5vJ8Z2BP/eerEq3fX6rQ4ADtO9J0WuetX4zXqNRY7SmuktMY/XHlbpVU1evnF/XVFcN7nfLZtQ0OVRxvUGKMdyfR7jxcoXvf3KZtZxlZO12InZWVruyhSRqd3kOPvrdT/9xSoKo6zxfri48MkT0iWIOSovVlYaUuH5rkNj/pZD8YkaK80hptzS9zbfuvi/tpbEacsoc2XY5e19h0u4zmkLyrsFJPf/iVvigo19AUu0anxcqo6QapoUH+N5enpr5RL689oA0HjqnB4dSD3x+qh/+5w+20sNQ0atsjIkQHSqo1YVBPNTqMdhVWqsHh1I8z05TZN16/ee8L133SxqT3kD082O1CgtCgANcpyP49I/X8zDHq3zPKd53tYAQWwA8YY/Rff9942tMwZ2IPD9bkc5P14A+G6khlnRodTg1M6phLklur0eFUUWWdeseGW1pHWxljdPc/turA0Wr9YuIA15fnyUqq6hQTduJUmr+orG1Qg8PI4TTae6RK+45Ua+nmQ7p1Yn/XqYMvCiqUbA/T4s/y9LsVu1q13z9NH6XzTjp1lBYXoVfX5+nPH36l6rpGvfyzcRraK6bFILw1v0z/742trnuFtUbP6FClx0Vow8FjGpUWq9svGaCH/nnq3KtmESGBWnPPJap3OPU/y79UUnSofjVliKVX4hljdPtrm/Xe5y1P/g4NCtBFAxJ0/5QhSu0R0aqfpU15x2SM0ej0OBlj9GTOHi38YM9p2//swr6aOKinLj6npzYeLFVdg1Pnp/folBO1CSyAn3h13UH96u0T8yX6JUTqV1OGaOKgRBljdOBojXpGh2rHoXL9adUerd9fqld/foEy+8Z1m2F0eF9tg0OTFn7smgN1sp9ckKbqOoduyEzTmIxTV4j2lMNptLuoUmHBgfp/b2zVwaM1GpvRQ5OHJevg0Ro9sXJ3q/f1wJQh2njwmGskrCXJMWH61ZQh+sGItk9ob6ttX5fpqVVfaeU3/wkZmRqrLSeNJI3oY9eiGaPVy96+UG+M0YrthXru431KjYvQO604NRgSGKBrR/fW/O8N8ZtTta1BYAH8RHlNg657Lle7iip12eBE/e9Px1pdErqJRodTXxyuUO/YcP1n71ENSY62bJTOGKNX1+Xpjyt3yx4efMoVVZcOTnRbedoYo+c+3qfHTrrR6bf9aHQf9YgM0d7iKpVU1emHY1I1NqOHBiY29bGu0dHue5i9v6NQL3y8T3uKq1R+vMHttebL0qvrGvVVcZWG9bZ3yNVZzRzOphHbkyc/n85zM0Zr0rnJkqQdBeXacahChRW1So4J094jVfrsQKkuPqen7rx0YIv/MSqrqddf1uzX54fK9d2hSbpiWLLiO+jKMAIL4EccTqNtX5dpQGJUt758EWhW2+DQ3iNV2ppfrqq6Bt14Ub8Wv+wPlx/Xy/85oCOVdcoemqRGp9Gdr29u9edcPjRJlw5OVO8e4UqPi1Rto0O7Cis1pFe0QoMC9dHuI9p3pEpjM+LUr2ek62quHQXlmv78p6qobXm+z5UjUvTHaSM7NKCcjjFGq3cf0fs7itS/Z6SG9orRuSl2/XDRWrfTc9PGpKqituGMo1Vj0ntowjk99fjK3RqQGKXrx6aq3uFs8ZTiiNRYPf6jERqQ6N35MwQWAECXVFpdrz/l7FFVXaOO1ztU2+A442rXrRUcaNMrN2YqMSZMl5y0cvOPM9P0/fN66ccvrJMkvXJjpi4amNDuz+sIi9fn6b63Pj/t6yNTYxUcaNNnB1peAuDbekQ0LRtwcnDb+vDlsod77z9eBBYAQLdhTNO6PL9fsUuFFbW65vze+uvag1p90u0pQoMCVO9wenT59qKfnK/Jw5quClv1ZZEOldXqJ5lplk76PZujVXWa/fJnrivLRqbG6pWfZ56yPMM7Wwv0+vo8bc4r0/EGhxKiQhUdFqTkmDBNHNRTU87rpT49mlYKf39HoX77ry/V4HRqzT2XerVeAgsAACcxxqiu0akGh1N/yz2o5JgwTR6WrLc3H9LXx47rhTX7XIsFDk6O1tzvnqPLv5kH0hm9t+2wXlt/UHdeOlCZ/eK9ss+a+sZ2zwv6NgILAAAeyC+t0Qtr9ml8/3h9d2iyJfNTuiNPvr+9G5UAAOiEUuMi9N9XtXwzSvgH/1odCQAAoAUEFgAA4PcILAAAwO8RWAAAgN8jsAAAAL9HYAEAAH6PwAIAAPwegQUAAPg9AgsAAPB7BBYAAOD3CCwAAMDvEVgAAIDfI7AAAAC/1yXu1myMkdR0m2oAANA5NH9vN3+Pn0mXCCyVlZWSpNTUVIsrAQAAnqqsrJTdbj9jG5tpTazxc06nUwUFBYqOjpbNZvPqvisqKpSamqr8/HzFxMR4dd+dQXfvv8Qx6O79lzgG3b3/Esego/pvjFFlZaVSUlIUEHDmWSpdYoQlICBAffr06dDPiImJ6ZY/pM26e/8ljkF377/EMeju/Zc4Bh3R/7ONrDRj0i0AAPB7BBYAAOD3CCxnERoaqocfflihoaFWl2KJ7t5/iWPQ3fsvcQy6e/8ljoE/9L9LTLoFAABdGyMsAADA7xFYAACA3yOwAAAAv0dgAQAAfo/AchbPPPOMMjIyFBYWpszMTK1fv97qktptwYIFGjt2rKKjo5WYmKipU6dq165dbm1qa2t12223KT4+XlFRUbr22mtVVFTk1iYvL09TpkxRRESEEhMTNW/ePDU2NvqyK17z2GOPyWaz6a677nJt6+rH4NChQ/rJT36i+Ph4hYeHa/jw4dqwYYPrdWOMHnroIfXq1Uvh4eHKzs7Wnj173PZRWlqqG264QTExMYqNjdWNN96oqqoqX3elTRwOhx588EH17dtX4eHh6t+/vx555BG3e5p0pWPw8ccf6wc/+IFSUlJks9m0dOlSt9e91ddt27bpO9/5jsLCwpSamqrf/e53Hd21VjvTMWhoaNC9996r4cOHKzIyUikpKZo5c6YKCgrc9tGZj8HZfgZOdsstt8hms2nhwoVu2y3tv8FpLV682ISEhJgXX3zR7Nixw9x0000mNjbWFBUVWV1au0yaNMm89NJLZvv27WbLli3me9/7nklLSzNVVVWuNrfccotJTU01OTk5ZsOGDeaCCy4w48ePd73e2Nhohg0bZrKzs83mzZvN8uXLTUJCgpk/f74VXWqX9evXm4yMDHPeeeeZOXPmuLZ35WNQWlpq0tPTzU9/+lOzbt06s2/fPvP++++br776ytXmscceM3a73SxdutRs3brVXHnllaZv377m+PHjrjaTJ082I0aMMJ9++qlZs2aNGTBggJk+fboVXfLYo48+auLj4827775r9u/fb9544w0TFRVlnnzySVebrnQMli9fbn71q1+Zt956y0gyb7/9ttvr3uhreXm5SUpKMjfccIPZvn27ef311014eLh57rnnfNXNMzrTMSgrKzPZ2dlmyZIl5ssvvzS5ublm3LhxZvTo0W776MzH4Gw/A83eeustM2LECJOSkmL++Mc/ur1mZf8JLGcwbtw4c9ttt7n+7HA4TEpKilmwYIGFVXlfcXGxkWRWr15tjGn6hxscHGzeeOMNV5udO3caSSY3N9cY0/SDHxAQYAoLC11tnn32WRMTE2Pq6up824F2qKysNAMHDjQrV640EyZMcAWWrn4M7r33XnPRRRed9nWn02mSk5PN73//e9e2srIyExoaal5//XVjjDFffPGFkWQ+++wzV5t//etfxmazmUOHDnVc8V4yZcoU87Of/cxt2zXXXGNuuOEGY0zXPgbf/rLyVl///Oc/mx49erj9/N97771m0KBBHdwjz53pC7vZ+vXrjSRz8OBBY0zXOgan6//XX39tevfubbZv327S09PdAovV/eeU0GnU19dr48aNys7O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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "if is_jupyter:  \n",
    "    plt.plot(plot_sliding_window(value_loss_1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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YgLEz88WVElYCRERkfUxjNiB/gEemKvfwfd4ToXE1RAREVkXw4idmDM6FABwOo+dWImIyLEwjNgJQ/OznPJaNj8jIiKHwjBiJ0J9db1G6hq1KKlukLgaIiIi62EYsRNKZycMDPIAAPzFfiNERORAGEbsyJSYQADAIxuOQKvlpRoiInIMDCN2xNetud/I7yfzJayEiIjIehhG7Ehto0b8/GQe96khIiLHwDBiR25L6C9+frGsRsJKiIiIrIdhxI4MCPTA6htHAQAultVKXA0REZF1MIzYmcEqTwBADsMIERE5CIYROxPhp2t+lq+uQ5OGO/gSEZH9YxixM0GeSiic5NBoBeRV1EldDhERUbcxjNgZuVyGMH031pxyXqohIiL7xzBihwyXajiJlYiIHAHDiB0K93UDwOW9RETkGBhG7FCEny6McEUNERE5AoYROxThbxgZYRghIiL7xzBih8J99XNGynmZhoiI7B/DiB0yXKbJK6+Dhrv3EhGRnWMYsUMqb1conOVo0gqcxEpERHaPYcQOOclliA70AAA899NJiashIiLqHoYROxXkpQSgawtPRERkzxhG7NTz140EAJzIVeOhrw+jpqFJ4oqIiIi6hmHETvXzd0egp2505KejuXgj6ZzEFREREXUNw4idkstliOvvK36dmlMhXTFERETdwDBix0J93KQugYiIqNsYRuzYDWPDxc+LKxskrISIiKjrGEbsWGykL7b+4xIAQHpxNcqqGUiIiMj+MIzYuYFBnujn744GjRYpGaVSl0NERGQxhhE7J5fLMCrCBwBwoagayWklbBFPRER2pUthZN26dYiKioKrqysSEhKQkpLS5rHr16/HtGnT4OfnBz8/PyQmJrZ7PFku0k+3cd7Lm09j3vq9eGXLaYkrIiIi6jyLw8jGjRuxbNkyrFq1CocOHUJsbCxmz56NwsJCs8fv2LED8+bNw/bt25GcnIzIyEhcfvnlyMnJ6XbxpGPYOM/g/Z0XcDirTKJqiIiILCMTBMGiMf2EhASMHz8eb7/9NgBAq9UiMjISDz30EJ588skOH6/RaODn54e3334bCxcu7NT3VKvV8PHxQUVFBby9vS0pt0/YebYIiz42HW2aFB2Ar++dKFFFREREnX//tmhkpKGhAQcPHkRiYmLzE8jlSExMRHJycqeeo6amBo2NjfD392/zmPr6eqjV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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "if is_jupyter:\n",
    "    plt.plot(plot_sliding_window(policy_loss_1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Write Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_path = get_save_path(out_folder,save_name,seed,use_date=save_with_date)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "delete_duplicate_results(out_folder,\"\",results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "json.dump(results,open('../../results/'+save_path,'w'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "food",
   "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.18"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
