{
 "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": 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  = 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=0.001\n",
    "    value_lr=0.01\n",
    "    train_iterations = 30\n",
    "    test_iterations = 30\n",
    "    out_folder = 'mcts_exploration/value_policy_exploration/exploration'\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=0.001)\n",
    "    parser.add_argument('--value_lr', help='Learning Rate Value', type=float, default=0.01)\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='mcts_exploration/value_policy_exploration/exploration')\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, \n",
    "        'train_iterations': train_iterations, \n",
    "        'test_iterations': test_iterations,} "
   ]
  },
  {
   "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",
      "instance 0, ep 3\n",
      "instance 0, ep 4\n",
      "instance 0, ep 5\n",
      "instance 0, ep 6\n",
      "instance 0, ep 7\n",
      "instance 0, ep 8\n",
      "instance 0, ep 9\n",
      "instance 0, ep 10\n",
      "instance 0, ep 11\n",
      "instance 0, ep 12\n",
      "instance 0, ep 13\n",
      "instance 0, ep 14\n",
      "instance 0, ep 15\n",
      "instance 0, ep 16\n",
      "instance 0, ep 17\n",
      "instance 0, ep 18\n",
      "instance 0, ep 19\n",
      "instance 0, ep 20\n",
      "instance 0, ep 21\n",
      "instance 0, ep 22\n",
      "instance 0, ep 23\n",
      "instance 0, ep 24\n",
      "instance 0, ep 25\n",
      "instance 0, ep 26\n",
      "instance 0, ep 27\n",
      "instance 0, ep 28\n",
      "instance 0, ep 29\n",
      "instance 0, ep 30\n",
      "instance 0, ep 31\n",
      "instance 0, ep 32\n",
      "instance 0, ep 33\n",
      "instance 0, ep 34\n",
      "instance 0, ep 35\n",
      "instance 0, ep 36\n",
      "instance 0, ep 37\n",
      "instance 0, ep 38\n",
      "instance 0, ep 39\n",
      "instance 0, ep 40\n",
      "instance 0, ep 41\n",
      "instance 0, ep 42\n",
      "instance 0, ep 43\n",
      "instance 0, ep 44\n",
      "instance 0, ep 45\n",
      "instance 0, ep 46\n",
      "instance 0, ep 47\n",
      "instance 0, ep 48\n",
      "instance 0, ep 49\n",
      "instance 0, ep 50\n",
      "instance 0, ep 51\n",
      "instance 0, ep 52\n",
      "instance 0, ep 53\n",
      "instance 0, ep 54\n",
      "instance 0, ep 55\n",
      "instance 0, ep 56\n",
      "instance 0, ep 57\n",
      "instance 0, ep 58\n",
      "instance 0, ep 59\n",
      "instance 0, ep 60\n",
      "instance 0, ep 61\n",
      "instance 0, ep 62\n",
      "instance 0, ep 63\n",
      "instance 0, ep 64\n",
      "instance 0, ep 65\n",
      "instance 0, ep 66\n",
      "instance 0, ep 67\n",
      "instance 0, ep 68\n",
      "instance 0, ep 69\n",
      "instance 0, ep 70\n",
      "instance 0, ep 71\n",
      "instance 0, ep 72\n",
      "instance 0, ep 73\n",
      "instance 0, ep 74\n",
      "instance 0, ep 75\n",
      "instance 0, ep 76\n",
      "instance 0, ep 77\n",
      "instance 0, ep 78\n",
      "instance 0, ep 79\n",
      "instance 0, ep 80\n",
      "instance 0, ep 81\n",
      "instance 0, ep 82\n",
      "instance 0, ep 83\n",
      "instance 0, ep 84\n",
      "instance 0, ep 85\n",
      "instance 0, ep 86\n",
      "instance 0, ep 87\n",
      "instance 0, ep 88\n",
      "instance 0, ep 89\n",
      "instance 0, ep 90\n",
      "instance 0, ep 91\n",
      "instance 0, ep 92\n",
      "instance 0, ep 93\n",
      "instance 0, ep 94\n",
      "instance 0, ep 95\n",
      "instance 0, ep 96\n",
      "instance 0, ep 97\n",
      "instance 0, ep 98\n",
      "instance 0, ep 99\n",
      "Took 44.5260751247406 time for inference and 138.6474642753601 time for training\n",
      "6.703803364966309\n"
     ]
    }
   ],
   "source": [
    "policy = full_mcts_policy \n",
    "name = \"mcts\"\n",
    "\n",
    "train_iterations = 30\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": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "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": 20,
   "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": 21,
   "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(policy_loss_1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "results['policy_loss'] = policy_loss_1\n",
    "results['value_loss'] = value_loss_1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Ground Truth Comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "policy_network, value_network = memory[0][-5], memory[0][-9]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1481277/2068906370.py:3: DeprecationWarning: elementwise comparison failed; this will raise an error in the future.\n",
      "  if match_probability != []:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.572463035583496 5.5637628118638025\n",
      "6.0989580154418945 6.111224759882095\n",
      "5.711530685424805 5.743086256515368\n",
      "6.265198707580566 6.269306050584771\n",
      "5.929128646850586 5.97113389725618\n",
      "6.388731956481934 6.372652697456274\n",
      "6.130236625671387 6.1292141504491555\n",
      "6.526082992553711 6.5305795237318325\n",
      "5.973400115966797 5.983692305458811\n",
      "6.379582405090332 6.377912573006219\n",
      "6.116389274597168 6.1417725529233635\n",
      "6.513043403625488 6.535839394362425\n",
      "6.278968811035156 6.2923696724268225\n",
      "6.61063289642334 6.603670059591434\n",
      "6.419536590576172 6.450295972546369\n",
      "6.756422996520996 6.761517034089479\n"
     ]
    }
   ],
   "source": [
    "if volunteers_per_arm * n_arms <= 4:\n",
    "    match_probability = simulator.match_probability_list \n",
    "    if match_probability != []:\n",
    "        match_probability = np.array(match_probability)[simulator.agent_idx]\n",
    "    true_transitions = simulator.transitions\n",
    "    discount = simulator.discount \n",
    "    budget = simulator.budget \n",
    "\n",
    "    Q_vals = arm_value_iteration_exponential(true_transitions,discount,budget,simulator.volunteers_per_arm,\n",
    "                    reward_function='combined',lamb=lamb,\n",
    "                    match_probability_list=match_probability)\n",
    "\n",
    "    N = volunteers_per_arm*n_arms \n",
    "    error_max_action = []\n",
    "    error_overall = []\n",
    "    for s in range(2**(volunteers_per_arm*n_arms)):\n",
    "        state = [int(j) for j in bin(s)[2:].zfill(N)]\n",
    "        max_q_val = np.max(Q_vals[s])\n",
    "        max_action = np.argmax(Q_vals[s])\n",
    "        action = [int(j) for j in bin(max_action)[2:].zfill(N)]\n",
    "        predicted_q_val = value_network(torch.Tensor([state+action])).item() \n",
    "        error_max_action.append((predicted_q_val-max_q_val)**2)\n",
    "\n",
    "        print(predicted_q_val,max_q_val)\n",
    "\n",
    "        for a in range(2**(volunteers_per_arm*n_arms)):\n",
    "            action = [int(j) for j in bin(a)[2:].zfill(N)]\n",
    "            predicted_q_val = value_network(torch.Tensor([state+action])).item()\n",
    "            actual_q_val = Q_vals[s][a]\n",
    "            error_overall.append((predicted_q_val-actual_q_val)**2)\n",
    "    \n",
    "    results['value_error_max_action'] = error_max_action\n",
    "    results['value_error_overall'] = error_overall     \n",
    "        "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Monotonicity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Value Function monotonicity \n",
    "num_trials = 100\n",
    "num_not_monotonic = 0 \n",
    "avg_diff = []\n",
    "\n",
    "for i in range(num_trials):\n",
    "    random_state = [random.randint(0,1) for i in range(n_arms*volunteers_per_arm)]\n",
    "    while sum(random_state) == n_arms*volunteers_per_arm:\n",
    "        random_state = [random.randint(0,1) for i in range(n_arms*volunteers_per_arm)]\n",
    "    choices = [i for i in range(n_arms*volunteers_per_arm) if random_state[i] == 0]\n",
    "    random_arm = random.choice(choices) \n",
    "    random_action = [random.randint(0,1) for i in range(n_arms*volunteers_per_arm)]\n",
    "    \n",
    "    value_without = value_network(torch.Tensor(random_state+random_action)).item() \n",
    "    random_state[random_arm] = 1\n",
    "    value_with = value_network(torch.Tensor(random_state+random_action)).item() \n",
    "    if value_with < value_without:\n",
    "        num_not_monotonic += 1\n",
    "    avg_diff.append(value_with-value_without)\n",
    "\n",
    "results['num_not_monotonic'] = num_not_monotonic\n",
    "results['avg_monotonic_value_diff'] = avg_diff "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Policy Predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "avg_probabilities = []\n",
    "num_trials = 100\n",
    "\n",
    "for i in range(num_trials):\n",
    "    random_probs = policy_network(torch.Tensor(get_policy_network_input_many_state(simulator,np.array([[random.randint(0,1) for i in range(n_arms*volunteers_per_arm)]]),contextual=False)))\n",
    "    random_probs = random_probs.detach().numpy().flatten().tolist()\n",
    "    avg_probabilities.append(random_probs)\n",
    "results['policy_predictions_random'] = avg_probabilities"
   ]
  },
  {
   "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
}
