{
 "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": 6,
   "metadata": {},
   "outputs": [],
   "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": 7,
   "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": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "is_jupyter = 'ipykernel' in sys.modules"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "if is_jupyter: \n",
    "    seed        = 43\n",
    "    n_arms      = 2\n",
    "    volunteers_per_arm = 2\n",
    "    budget      = 3\n",
    "    discount    = 0.9\n",
    "    alpha       = 3 \n",
    "    n_episodes  = 200\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 = 'semi_synthetic_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='semi_synthetic_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": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_states = 2\n",
    "n_actions = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_environment(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "\n",
    "    if prob_distro == 'uniform':\n",
    "        match_probabilities = [np.random.random() for i in range(all_population_size * volunteers_per_arm)] \n",
    "    elif prob_distro == 'uniform_small':\n",
    "        match_probabilities = [np.random.random()/4 for i in range(all_population_size * volunteers_per_arm)] \n",
    "    elif prob_distro == 'uniform_large':\n",
    "        match_probabilities = [np.random.random()/4+0.75 for i in range(all_population_size * volunteers_per_arm)] \n",
    "    elif prob_distro == 'normal':\n",
    "        match_probabilities = [np.clip(np.random.normal(0.25, 0.1),0,1) for i in range(all_population_size * volunteers_per_arm)] \n",
    "\n",
    "    all_features = np.arange(all_population_size)\n",
    "    match_probabilities = create_prob_distro(prob_distro,all_population_size*volunteers_per_arm)\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)\n",
    "\n",
    "    return simulator "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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": 14,
   "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": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed_list = [seed]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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 [26 66]\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[16], line 4\u001b[0m\n\u001b[1;32m      1\u001b[0m policy \u001b[38;5;241m=\u001b[39m full_mcts_policy \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[13], 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:627\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    624\u001b[0m     should_random \u001b[38;5;241m=\u001b[39m random\u001b[38;5;241m.\u001b[39mrandom() \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m epsilon_func(n)\n\u001b[1;32m    626\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m should_random:\n\u001b[0;32m--> 627\u001b[0m     selected_index, memoizer \u001b[38;5;241m=\u001b[39m \u001b[43mget_random_index\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[43mpolicy_by_group\u001b[49m\u001b[43m,\u001b[49m\u001b[43mgroup_indices\u001b[49m\u001b[43m,\u001b[49m\u001b[43mnum_epochs\u001b[49m\u001b[43m,\u001b[49m\u001b[43mlamb\u001b[49m\u001b[43m,\u001b[49m\u001b[43mmemoizer\u001b[49m\u001b[43m,\u001b[49m\u001b[43mstate\u001b[49m\u001b[43m,\u001b[49m\u001b[43mbudget\u001b[49m\u001b[43m,\u001b[49m\u001b[43mstate_WI\u001b[49m\u001b[43m,\u001b[49m\u001b[43mrandomness_boost\u001b[49m\u001b[43m,\u001b[49m\u001b[43muse_whittle\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43muse_whittle\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    628\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    629\u001b[0m     selected_index \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mmax\u001b[39m(UCB_by_arm, key\u001b[38;5;241m=\u001b[39mUCB_by_arm\u001b[38;5;241m.\u001b[39mget)\n",
      "File \u001b[0;32m~/projects/food_rescue_rmab/rmab/mcts_policies.py:97\u001b[0m, in \u001b[0;36mget_random_index\u001b[0;34m(env, all_match_probs, best_group_arms, policy_by_group, group_indices, num_epochs, lamb, memoizer, state, budget, state_WI, randomness_boost, use_whittle)\u001b[0m\n\u001b[1;32m     95\u001b[0m         prob \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m (\u001b[38;5;241m1\u001b[39m\u001b[38;5;241m-\u001b[39mfraction_policy)\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m2\u001b[39m\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m1\u001b[39m\u001b[38;5;241m/\u001b[39m(\u001b[38;5;28mlen\u001b[39m(score_by_group_policy))\n\u001b[1;32m     96\u001b[0m     weighted_probabilities\u001b[38;5;241m.\u001b[39mappend(prob)\n\u001b[0;32m---> 97\u001b[0m weighted_probabilities \u001b[38;5;241m=\u001b[39m \u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43marray\u001b[49m\u001b[43m(\u001b[49m\u001b[43mweighted_probabilities\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m/\u001b[39;49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msum\u001b[49m\u001b[43m(\u001b[49m\u001b[43mweighted_probabilities\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     99\u001b[0m \u001b[38;5;66;03m# With some fixed probability, pick randomly \u001b[39;00m\n\u001b[1;32m    100\u001b[0m random_prob \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0.3\u001b[39m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "policy = full_mcts_policy \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": 14,
   "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][-5]\n",
    "    value_loss_1 = memory[0][-9]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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o4QEwbGfg3379glOTk7CP//5T+HMmTPCN998I7i5uQlff/21eMySJUsEb29v4ZdffhEOHz4sTJ061eQw11GjRgl79+4Vdu/eLQwYMMAmh/Sact999wm9evUShzX/+OOPgp+fn/DCCy+IxzjSc1BWViYcPHhQOHjwoABAePfdd4WDBw+KI2A64lpLSkqEgIAAYdasWcLRo0eFdevWCW5ubjYxpFcQmn8O1Gq1cOuttwq9e/cW0tPTjd4bDUe82PNz0NJroLHGo4QEwbrXz8DSgg8++EDo06ePIJfLhZiYGGHPnj3WLlK7ATD58/nnn4vHVFVVCY8//rjg4+MjuLm5Cbfddptw6dIlo/NcuHBBuOGGGwRXV1fBz89PeO6554Ta2touvpqO0ziwOPpz8OuvvwrDhg0TXFxchIiICOHf//630X6tViu89tprQkBAgODi4iJMmjRJOHXqlNExxcXFwsyZMwUPDw/By8tLSExMFMrKyrryMtpMpVIJzzzzjNCnTx9BoVAI4eHhwiuvvGL04eRIz8G2bdtM/t3fd999giB03LUeOnRIGDdunODi4iL06tVLWLJkSVddYouaew7Onz9v9r1x27Zt4jns+Tlo6TXQmKnAYs3rlwiCwbSORERERDaIfViIiIjI5jGwEBERkc1jYCEiIiKbx8BCRERENo+BhYiIiGweAwsRERHZPAYWIiIisnkMLERERGTzGFiIiIjI5jGwEBERkc1jYCEiIiKbx8BCRERENu//AdvfYqsxf0LuAAAAAElFTkSuQmCC",
      "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
}
