{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json \n",
    "from pathlib import Path\n",
    "from collections import Counter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# read json\n",
    "results_dir = './results'\n",
    "model_name = \"Llama-3.3-70B-Instruct\"\n",
    "agent_type = \"debate\"\n",
    "n_agents = 2\n",
    "level = \"level_0\"\n",
    "\n",
    "filename = Path(results_dir) / model_name / agent_type / str(n_agents) / f'result_{level}.json'\n",
    "with open(filename, 'r') as f:\n",
    "    data = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(data['1.0'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['total', 'success', 'failed', 'alpha', 'noop_count', 'action_history', 'action_success_history', 'prompt_history', 'all_tasks', 'all_orders_list', 'order_times', 'acomplished_task_list', 'task_interval', 'task_lifetime', 'max_num_tasks', 'dish_completion', 'all_orders_lifetime'])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "i = '1.0'\n",
    "data[i].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n"
     ]
    }
   ],
   "source": [
    "print(data[i]['task_interval'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All tasks ['salmonMeatcake']\n",
      "Acomplished Tasks:  ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "Orders:  [['salmonMeatcake'], ['salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake'], ['salmonMeatcake', 'salmonMeatcake']]\n",
      "All order lifetime:  [[7], [6], [5, 8], [4, 7], [3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [4, 7], [3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [4, 7], [3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [4, 7], [3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [2, 5, 8], [1, 4, 7], [0, 3, 6], [5, 8]]\n",
      "Order Times:  [False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True, False, False, True]\n",
      "Dish completion:  [False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, True]\n"
     ]
    }
   ],
   "source": [
    "print('All tasks', data[i]['all_tasks'])\n",
    "print('Acomplished Tasks: ', data[i]['acomplished_task_list'])\n",
    "print('Orders: ', data[i]['all_orders_list'])\n",
    "print('All order lifetime: ', data[i]['all_orders_lifetime'])\n",
    "print('Order Times: ', data[i]['order_times'])\n",
    "print('Dish completion: ', data[i]['dish_completion'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "i Order Time Complete Current_List\n",
      "1 False False False ['salmonMeatcake']\n",
      "2 False False False ['salmonMeatcake']\n",
      "3 True False False ['salmonMeatcake', 'salmonMeatcake']\n",
      "4 False False False ['salmonMeatcake', 'salmonMeatcake']\n",
      "5 False False False ['salmonMeatcake', 'salmonMeatcake']\n",
      "6 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "7 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "8 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "9 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "10 False True False ['salmonMeatcake', 'salmonMeatcake']\n",
      "11 False False False ['salmonMeatcake', 'salmonMeatcake']\n",
      "12 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "13 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "14 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "15 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "16 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "17 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "18 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "19 False True False ['salmonMeatcake', 'salmonMeatcake']\n",
      "20 False False False ['salmonMeatcake', 'salmonMeatcake']\n",
      "21 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "22 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "23 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "24 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "25 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "26 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "27 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "28 False True False ['salmonMeatcake', 'salmonMeatcake']\n",
      "29 False False False ['salmonMeatcake', 'salmonMeatcake']\n",
      "30 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "31 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "32 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "33 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "34 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "35 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "36 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "37 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "38 False True False ['salmonMeatcake', 'salmonMeatcake']\n",
      "39 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "40 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "41 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "42 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "43 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "44 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "45 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "46 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "47 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "48 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "49 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "50 False True False ['salmonMeatcake', 'salmonMeatcake']\n",
      "51 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "52 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "53 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "54 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "55 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "56 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "57 True False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "58 False False False ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "59 False False True ['salmonMeatcake', 'salmonMeatcake', 'salmonMeatcake']\n",
      "60 True True False ['salmonMeatcake', 'salmonMeatcake']\n"
     ]
    }
   ],
   "source": [
    "print('i Order Time Complete Current_List')\n",
    "for j, order in enumerate(data[i]['all_orders_list']):\n",
    "    lifetime_end = any([e == 0 for e in data[i]['all_orders_lifetime'][j]])\n",
    "    print(j+1, data[i]['order_times'][j], data[i]['dish_completion'][j], lifetime_end, order)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Acomplished tasks:  Counter({'salmonMeatcake': 6})\n"
     ]
    },
    {
     "ename": "KeyError",
     "evalue": "'all_orders'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[8], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mAcomplished tasks: \u001b[39m\u001b[38;5;124m'\u001b[39m, Counter(data[i][\u001b[38;5;124m'\u001b[39m\u001b[38;5;124macomplished_task_list\u001b[39m\u001b[38;5;124m'\u001b[39m])) \n\u001b[0;32m----> 2\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mAll orders: \u001b[39m\u001b[38;5;124m'\u001b[39m, Counter(\u001b[43mdata\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mall_orders\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m))\n",
      "\u001b[0;31mKeyError\u001b[0m: 'all_orders'"
     ]
    }
   ],
   "source": [
    "print('Acomplished tasks: ', Counter(data[i]['acomplished_task_list'])) \n",
    "print('All orders: ', Counter(data[i]['all_orders']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tau: 1.0 | total: 63 | success: 14 | failed: 40\n"
     ]
    }
   ],
   "source": [
    "for i in data.keys():\n",
    "    print(f\"tau: {i} | total: {data[i]['total']} | success: {data[i]['success']} | failed: {data[i]['failed']}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cos_metric: 0.2962962962962963\n"
     ]
    }
   ],
   "source": [
    "sum_i = [int(data[i]['success']) / (int(data[i]['success']) + int(data[i]['failed'])) for i in data.keys()]\n",
    "cos_metric = sum(sum_i) / len(sum_i)\n",
    "print(f\"cos_metric: {cos_metric}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "history = [('user', \"The available actions are :\\n1) goto: goto a tool location \\n2) get: get some object from a tool \\n3) put: put some object into a tool \\n4) activate: activate the tool to cook all ingredients inside the tool into a different tools \\n5) noop: not performing any actions \\nSometimes the system will give you error messages. Please consider these error messages when executing actions.  \\nYou need to specify action for all of the agents, **except human**. They all have different agent numbers. Do not assign actions to the same agent more than once. \\n\\nWhen the tools reach its capacity, you need to take stuff out. Otherwise, you cannot put items inside.\\nWhen you are holding objects, you cannot get any more objects. \\nWhen you are holding objects, you cannot activate tools. \\nAfer you cooked a required dish, you need to put it into the servingtable. \\nYou can only pick up objects from the tool location, if you are located at the tool location. \\nWhen you activate any tools, make sure all the items inside the tool are respecting the recipes. Otherwise, you will cook waste. Avoid waste at all cost. \\n*** You should mix salad in the mixer. To make salad you should chop veggies first. *** \\n*** If the tool is occupied, indicated by the occupy() predicate, you cannot get objects from it or put objects into it. *** \\n*** The food orders are keep coming. You should finish as many dishes as possible and finish every dish as soon as possible. Please deliver the order to the serveringtable when it is finished. *** \\n*** The dish will expire after the lifetime reaches 0 and it's not at the serveringtable. Please avoid this. *** Here are the recipes: \\n\\nCook porkMeatcake at: \\n -- location: blender \\n -- with ingredients:     pork,     flour, \\nCook salmonMeatcake at: \\n -- location: blender \\n -- with ingredients:     salmon,     flour, \\nThe following objects are available: \\n --1) flour \\n --2) salmonMeatcake \\n --3) pork \\n --4) porkMeatcake \\n --5) salmon \\nThe objecsts are cooked using tools or are just base ingredients. \\nAmong them, the following are base ingredients: \\n --1) flour \\n --2) pork \\n --3) salmon \\nYou can only obtain base ingredients from the storage initially.  \\nAdditional rules: \\nYou can place up to infinite item into the storage0 \\nYou can place up to infinite item into the storage0 \\nYou can place up to infinite item into the servingtable0 \\nYou can place up to infinite item into the servingtable0 \\nYou can place up to 5 item into the blender0 \\nYou can place up to 5 item into the blender0 \\n** Only ** the following tools are available: \\nstorage0, servingtable0, blender0, You cannot pick up these tools. You can only use those tools at the corresponding location.\\n\\n\\n\"), ('user', 'There are 2 agents available, so you can execute 2 actions at a time.\\nThis is an example you can use as a reference for a different level.\\n\\n-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 17\\ncurrent game step: 0\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, servingtable0)\\nhold(agent0, None)\\nat(agent1, servingtable0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, None)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'goto_agent0_storage0\\ngoto_agent1_storage0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 16\\ncurrent game step: 1\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, storage0)\\nhold(agent0, None)\\nat(agent1, storage0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, None)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'get_agent0_flour_storage0\\nget_agent1_pork_storage0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 15\\ncurrent game step: 2\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, storage0)\\nhold(agent0, flour)\\nat(agent1, storage0)\\nhold(agent1, pork)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, None)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'goto_agent0_blender0\\ngoto_agent1_blender0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 14\\ncurrent game step: 3\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, blender0)\\nhold(agent0, flour)\\nat(agent1, blender0)\\nhold(agent1, pork)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, None)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'put_agent0_blender0\\nput_agent1_blender0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 13\\ncurrent game step: 4\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, blender0)\\nhold(agent0, None)\\nat(agent1, blender0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, flour&pork)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'goto_agent0_storage0\\nactivate_agent1_blender0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 12\\ncurrent game step: 5\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, storage0)\\nhold(agent0, None)\\nat(agent1, blender0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, porkMeatcake)\\noccupy(blender0)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'get_agent0_flour_storage0\\nnoop_agent1\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 11\\ncurrent game step: 6\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, storage0)\\nhold(agent0, flour)\\nat(agent1, blender0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, porkMeatcake)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'goto_agent0_blender0\\nget_agent1_blender0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 10\\n    name: porkMeatcake lifetime: 17\\ncurrent game step: 7\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, blender0)\\nhold(agent0, flour)\\nat(agent1, blender0)\\nhold(agent1, porkMeatcake)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, None)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'put_agent0_blender0\\ngoto_agent1_servingtable0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 9\\n    name: porkMeatcake lifetime: 16\\ncurrent game step: 8\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, blender0)\\nhold(agent0, None)\\nat(agent1, servingtable0)\\nhold(agent1, porkMeatcake)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, flour)\\n\\n-accomplished task:\\n\\n-action:\\n'), ('assistant', 'goto_agent0_storage0\\nput_agent1_servingtable0\\n'), ('user', '-game state:\\ncurrent game level: level_1\\ncurrent dishes:\\n    name: porkMeatcake lifetime: 15\\ncurrent game step: 9\\nmaximum game steps: 30\\n\\n-agent state:\\nat(agent0, storage0)\\nhold(agent0, None)\\nat(agent1, servingtable0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, flour)\\n\\n-accomplished task:\\nporkMeatcake,\\n\\n-action:\\n'), ('assistant', 'get_agent0_pork_storage0\\ngoto_agent1_blender0\\n'), ('user', 'In this game, There are 2 agents available and no human, so you should control all the 2 agents, and plan 2 actions at a time.\\n'), ('user', '-execution error messages:\\n  --  []\\n-execution suggestions:\\n  --  []\\n-game state:\\ncurrent game level: level_0\\ncurrent dishes:\\n    name: salmonMeatcake lifetime: 8\\ncurrent game step: 0\\nmaximum game steps: 60\\n\\n-agent state:\\nat(agent0, servingtable0)\\nhold(agent0, None)\\nat(agent1, servingtable0)\\nhold(agent1, None)\\n\\n-kitchen state:\\ninside(storage0, None)\\ninside(servingtable0, None)\\ninside(blender0, None)\\n\\n-accomplished task:\\n\\n\\n-action:\\n'), ('assistant', 'goto_agent0_storage0\\ngoto_agent1_storage0\\n')]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "user :  The available actions are :\n",
      "1) goto: goto a tool location \n",
      "2) get: get some object from a tool \n",
      "3) put: put some object into a tool \n",
      "4) activate: activate the tool to cook all ingredients inside the tool into a different tools \n",
      "5) noop: not performing any actions \n",
      "Sometimes the system will give you error messages. Please consider these error messages when executing actions.  \n",
      "You need to specify action for all of the agents, **except human**. They all have different agent numbers. Do not assign actions to the same agent more than once. \n",
      "\n",
      "When the tools reach its capacity, you need to take stuff out. Otherwise, you cannot put items inside.\n",
      "When you are holding objects, you cannot get any more objects. \n",
      "When you are holding objects, you cannot activate tools. \n",
      "Afer you cooked a required dish, you need to put it into the servingtable. \n",
      "You can only pick up objects from the tool location, if you are located at the tool location. \n",
      "When you activate any tools, make sure all the items inside the tool are respecting the recipes. Otherwise, you will cook waste. Avoid waste at all cost. \n",
      "*** You should mix salad in the mixer. To make salad you should chop veggies first. *** \n",
      "*** If the tool is occupied, indicated by the occupy() predicate, you cannot get objects from it or put objects into it. *** \n",
      "*** The food orders are keep coming. You should finish as many dishes as possible and finish every dish as soon as possible. Please deliver the order to the serveringtable when it is finished. *** \n",
      "*** The dish will expire after the lifetime reaches 0 and it's not at the serveringtable. Please avoid this. *** Here are the recipes: \n",
      "\n",
      "Cook porkMeatcake at: \n",
      " -- location: blender \n",
      " -- with ingredients:     pork,     flour, \n",
      "Cook salmonMeatcake at: \n",
      " -- location: blender \n",
      " -- with ingredients:     salmon,     flour, \n",
      "The following objects are available: \n",
      " --1) flour \n",
      " --2) salmonMeatcake \n",
      " --3) pork \n",
      " --4) porkMeatcake \n",
      " --5) salmon \n",
      "The objecsts are cooked using tools or are just base ingredients. \n",
      "Among them, the following are base ingredients: \n",
      " --1) flour \n",
      " --2) pork \n",
      " --3) salmon \n",
      "You can only obtain base ingredients from the storage initially.  \n",
      "Additional rules: \n",
      "You can place up to infinite item into the storage0 \n",
      "You can place up to infinite item into the storage0 \n",
      "You can place up to infinite item into the servingtable0 \n",
      "You can place up to infinite item into the servingtable0 \n",
      "You can place up to 5 item into the blender0 \n",
      "You can place up to 5 item into the blender0 \n",
      "** Only ** the following tools are available: \n",
      "storage0, servingtable0, blender0, You cannot pick up these tools. You can only use those tools at the corresponding location.\n",
      "\n",
      "\n",
      "\n",
      "------------\n",
      "user :  There are 2 agents available, so you can execute 2 actions at a time.\n",
      "This is an example you can use as a reference for a different level.\n",
      "\n",
      "-game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 17\n",
      "current game step: 0\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, servingtable0)\n",
      "hold(agent0, None)\n",
      "at(agent1, servingtable0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, None)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  goto_agent0_storage0\n",
      "goto_agent1_storage0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 16\n",
      "current game step: 1\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, storage0)\n",
      "hold(agent0, None)\n",
      "at(agent1, storage0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, None)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  get_agent0_flour_storage0\n",
      "get_agent1_pork_storage0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 15\n",
      "current game step: 2\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, storage0)\n",
      "hold(agent0, flour)\n",
      "at(agent1, storage0)\n",
      "hold(agent1, pork)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, None)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  goto_agent0_blender0\n",
      "goto_agent1_blender0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 14\n",
      "current game step: 3\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, blender0)\n",
      "hold(agent0, flour)\n",
      "at(agent1, blender0)\n",
      "hold(agent1, pork)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, None)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  put_agent0_blender0\n",
      "put_agent1_blender0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 13\n",
      "current game step: 4\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, blender0)\n",
      "hold(agent0, None)\n",
      "at(agent1, blender0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, flour&pork)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  goto_agent0_storage0\n",
      "activate_agent1_blender0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 12\n",
      "current game step: 5\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, storage0)\n",
      "hold(agent0, None)\n",
      "at(agent1, blender0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, porkMeatcake)\n",
      "occupy(blender0)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  get_agent0_flour_storage0\n",
      "noop_agent1\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 11\n",
      "current game step: 6\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, storage0)\n",
      "hold(agent0, flour)\n",
      "at(agent1, blender0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, porkMeatcake)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  goto_agent0_blender0\n",
      "get_agent1_blender0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 10\n",
      "    name: porkMeatcake lifetime: 17\n",
      "current game step: 7\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, blender0)\n",
      "hold(agent0, flour)\n",
      "at(agent1, blender0)\n",
      "hold(agent1, porkMeatcake)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, None)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  put_agent0_blender0\n",
      "goto_agent1_servingtable0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 9\n",
      "    name: porkMeatcake lifetime: 16\n",
      "current game step: 8\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, blender0)\n",
      "hold(agent0, None)\n",
      "at(agent1, servingtable0)\n",
      "hold(agent1, porkMeatcake)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, flour)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  goto_agent0_storage0\n",
      "put_agent1_servingtable0\n",
      "\n",
      "------------\n",
      "user :  -game state:\n",
      "current game level: level_1\n",
      "current dishes:\n",
      "    name: porkMeatcake lifetime: 15\n",
      "current game step: 9\n",
      "maximum game steps: 30\n",
      "\n",
      "-agent state:\n",
      "at(agent0, storage0)\n",
      "hold(agent0, None)\n",
      "at(agent1, servingtable0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, flour)\n",
      "\n",
      "-accomplished task:\n",
      "porkMeatcake,\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  get_agent0_pork_storage0\n",
      "goto_agent1_blender0\n",
      "\n",
      "------------\n",
      "user :  In this game, There are 2 agents available and no human, so you should control all the 2 agents, and plan 2 actions at a time.\n",
      "\n",
      "------------\n",
      "user :  -execution error messages:\n",
      "  --  []\n",
      "-execution suggestions:\n",
      "  --  []\n",
      "-game state:\n",
      "current game level: level_0\n",
      "current dishes:\n",
      "    name: salmonMeatcake lifetime: 8\n",
      "current game step: 0\n",
      "maximum game steps: 60\n",
      "\n",
      "-agent state:\n",
      "at(agent0, servingtable0)\n",
      "hold(agent0, None)\n",
      "at(agent1, servingtable0)\n",
      "hold(agent1, None)\n",
      "\n",
      "-kitchen state:\n",
      "inside(storage0, None)\n",
      "inside(servingtable0, None)\n",
      "inside(blender0, None)\n",
      "\n",
      "-accomplished task:\n",
      "\n",
      "\n",
      "-action:\n",
      "\n",
      "------------\n",
      "assistant :  goto_agent0_storage0\n",
      "goto_agent1_storage0\n",
      "\n",
      "------------\n"
     ]
    }
   ],
   "source": [
    "for a in history:\n",
    "    print(a[0], ': ', a[1])\n",
    "    print('-'*12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "import re\n",
    "def extract_actions(text):\n",
    "    # List of action types\n",
    "    action_types = [\"noop\", \"goto\", \"put\", \"activate\", \"get\"]\n",
    "    \n",
    "    # Pattern for the actions\n",
    "    pattern = r'\\b(' + '|'.join(action_types) + r')(_?\\w+)?\\b'\n",
    "    matches = re.findall(pattern, text)\n",
    "    \n",
    "    # Extracting just the full action names from the returned tuples\n",
    "    combined_matches = [action + suffix for action, suffix in matches]\n",
    "\n",
    "    return combined_matches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['goto_agent0_storage0']"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extract_actions(\"goto_agent0_storage0\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Level 0:  Counter({'salmonMeatcake': 4})\n",
      "Level 1:  Counter({'lambMeatcake': 1, 'salmonMeatcake': 1, 'lobsterMeatcake': 1})\n",
      "Level 2:  Counter({'tunaSashimi': 1, 'salmonSashimi': 1})\n",
      "Level 3:  Counter()\n",
      "Level 4:  Counter({'lettuceSalad': 1, 'tomatoCucumberSalad': 1})\n",
      "Level 5:  Counter()\n",
      "Level 6:  Counter({'hawaiianPizza': 1})\n",
      "Level 7:  Counter({'onionPotatoLeekSoup': 1, 'onionPotatoCarrotSoup': 1, 'onionBroccoliCheeseSoup': 1})\n",
      "Level 8:  Counter({'beefDumpling': 1})\n",
      "Level 9:  Counter({'MaxJr': 1})\n",
      "Level 10:  Counter()\n",
      "Level 11:  Counter()\n",
      "Level 12:  Counter({'smashedPotato': 1, 'potatoSalad': 1})\n"
     ]
    }
   ],
   "source": [
    "n_levels = 13\n",
    "alpha = str(1.0)\n",
    "\n",
    "for level in range(n_levels):\n",
    "    \n",
    "    filename = f'./result_level_{level}_1_Llama-3.3-70B-Instruct.json'\n",
    "    with open(filename, 'r') as f:\n",
    "        data = json.load(f)\n",
    "\n",
    "    print(f\"Level {level}: \", Counter(data[alpha]['acomplished_task_list']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "\n",
    "random_number = random.uniform(0, 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "nums = []\n",
    "for i in range(10000):\n",
    "    nums.append(random.uniform(0,100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1027.,  977.,  990.,  984.,  996., 1050.,  983.,  972.,  986.,\n",
       "        1035.]),\n",
       " array([3.43188322e-03, 1.00020336e+01, 2.00006352e+01, 2.99992369e+01,\n",
       "        3.99978386e+01, 4.99964402e+01, 5.99950419e+01, 6.99936436e+01,\n",
       "        7.99922452e+01, 8.99908469e+01, 9.99894486e+01]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.hist(nums)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "from openai import OpenAI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "api_key = os.getenv(\"AVIOR_API_KEY\") # Not support yet\n",
    "api_base = \"http://avior.mlfoundry.com/live-inference/v1\"\n",
    "client = OpenAI(\n",
    "    api_key=api_key,\n",
    "    base_url=api_base\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = \"meta-llama/Llama-3.1-70B-Instruct\"\n",
    "\n",
    "messages = [\n",
    "    {\"role\": \"system\", \"content\": \"You are a helpful AI assistant\"},\n",
    "    {\"role\": \"user\", \"content\": \"Who are you?\"}\n",
    "]\n",
    "\n",
    "response = client.chat.completions.create(\n",
    "                model=model,\n",
    "                messages=messages,\n",
    "                temperature=.9,\n",
    "                max_tokens=250,\n",
    "                # stop=stop\n",
    "            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ChatCompletion(id='b79fc45cbb0544fd9905308946ca399b', choices=[Choice(finish_reason='stop', index=0, logprobs=None, message=ChatCompletionMessage(content=\"I'm an artificial intelligence model designed to assist and communicate with users in a helpful and informative way. I don't have a personal name, but I'm here to provide information, answer questions, and engage in conversation to the best of my abilities. I'm constantly learning and improving my knowledge base, so I can offer more accurate and helpful responses over time.\\n\\nI can assist with a wide range of topics, from science and history to entertainment and culture. I can also help with tasks such as generating text, summarizing articles, and offering suggestions and ideas.\\n\\nMy goal is to provide helpful and accurate information, and to engage in productive and respectful conversations. If you have any questions or topics you'd like to discuss, I'm here to help!\", refusal=None, role='assistant', audio=None, function_call=None, tool_calls=None), matched_stop=128009)], created=1740721739, model='meta-llama/Llama-3.1-70B-Instruct', object='chat.completion', service_tier=None, system_fingerprint=None, usage=CompletionUsage(completion_tokens=151, prompt_tokens=45, total_tokens=196, completion_tokens_details=None, prompt_tokens_details=None))\n"
     ]
    }
   ],
   "source": [
    "print(response)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "filename = '/data2/aamayuelasfernandez/economies-of-mind/experiment1/results/Llama-3.1-70B-Instruct/orchestrator/5/result_level_0_1000.json'\n",
    "\n",
    "with open(filename, 'r') as f:\n",
    "    data = json.load(f)\n",
    "\n",
    "data = data['1.0'][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "predictions = data['predictions']\n",
    "success_matrix = data['success_matrix']\n",
    "\n",
    "success_matrix_normalized = []\n",
    "for agent_matrix in success_matrix: \n",
    "    success_matrix_normalized.append({k: v / 100 for k, v in agent_matrix.items()})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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deqEmJgYyOVyzT5r165FeHg4evToAbFYjCFDhuCbb74x6LkRERERERE9yegFN8LDwxEeHl7mffv373/mY1euXFlqm0gkwuzZszF79uxyH+fo6Ih169bpEyYREREREdELMdo1X0RERERERKaEyRcREREREVEVYPJFRERERERUBZh8ERERERERVQEmX0RERERERFWAyRcREREREVEVYPJFRERERERUBZh8ERERERERVQEmX0RERERERFWAyRcREREREVEVYPJFRERERERUBZh8ERERERERVQEmX2RwyVkPce5OlrHDICIiIiKqVsyMHQDVDvdyCrDrbAp2nLmLvxMfAAA2TnwZQQ3qGDkyIiIiIqLqgckXVVhGXiF2nUvGjtPJOHrjPlSC9v1X7uUy+SIiIiIieoTJF+klK1+JPy6kYMeZZBy+mo7iJzKu1l72GODnjr+u3cfeS/eQpygyYqRERERERNULky96roeFxfjjfAq2n76LA1fSoCx+nHC18LBFfz8P9Pdzh5ejJQAgKSMfAJDL5IuIiIiISIPJFz3XhF/+waGr6ZrbTVxt0N/PHf383NHA2brU/taykpcVky8iIiIioseYfNFznb6VCQB4q5MPhrX1QmNXm2fub6VOvgqYfBERERERqTH5omfKUxQh59EI1tSejTWJ1bOoR77yCpl8ERERERGpcZ0veqaU7AIAgI3MTKfEC3hy2mFxpcVFRERERFTTMPmiZ0rNKkm+XO3kOj/m8bRDZaXERERERERUEzH5omdSj3y52eqefNnIH0075MgXEREREZEGky96JnXy5apH8mXFaodERERERKUw+aJnUk87dLOT6fwYa5kEAJMvIiIiIqInMfmiZ0rO0n/aobXMHEBJpURBEJ6zNxERERGRaWDyRc+UWqFphyUjX0UqAYoiVaXERURERERU0zD5omfSFNzQp9qh9HFJek49JCIiIiIqweSLylVUrEJajgKAftMOxWIRrKQlo195TL6IiIiIiAAw+aJnSM8thEoAJGIR6ljrXnADeFzxMKeAyRcREREREcDki55BPeXQxUYGiVik12OtNWt9MfkiIiIiIgKYfNEzpGTpX2xDzZprfRERERERaWHyReVSVzrU53ovNSZfRERERETamHxRuSpS6VBNfc1XnqLYoDEREREREdVUTL6oXKkGmXaoNGhMREREREQ1FZMvKtfjkS/9Kh0CTyZfHPkiIiIiIgKYfNEzqJOviox8qacd5rLUPBERERERACZf9AzqaYcVKbhhw1LzRERERERamHxRmXIKlMgrLJkyWKGCG1IJACC3kMkXERERERHA5IvKoS4zbyM3g6XUTO/Hc9ohEREREZE2Jl9UppQsBYCKTTkEOO2QiIiIiOhpTL6oTC+yxhfwxMgXky8iIiIiIgBMvqgcqS9Q6RB4stQ8ky8iIiIiIqAaJF9LliyBt7c35HI5goKCcOzYsXL33bZtGwIDA2Fvbw8rKyv4+/tj9erVWvuIRKIyf/79739r9vH29i51//z58yvtHGuilBeodAg8Tr447ZCIiIiIqIT+lRQMaOPGjYiIiEB0dDSCgoKwePFihIaGIiEhAS4uLqX2d3R0xCeffIKmTZtCKpVix44dCAsLg4uLC0JDQwEAycnJWo/ZtWsX3nzzTQwZMkRr++zZszFhwgTNbRsbm0o4w5pLs8YXpx0SERERERmEUZOvRYsWYcKECQgLCwMAREdHY+fOnVi+fDmmT59eav+uXbtq3X7//fexatUqHDp0SJN8ubm5ae3z66+/olu3bmjQoIHWdhsbm1L70mPqaYcVHvl6VHBDWSxAUVQMmZnEYLEREREREdVERku+CgsLcfz4cURGRmq2icVihISEID4+/rmPFwQBe/fuRUJCAhYsWFDmPqmpqdi5cydWrVpV6r758+djzpw5qFevHkaNGoWpU6fCzKz8p0OhUEChUGhuZ2dnAwCUSiWUSuVz461M6uMbMg71tEMnS7MKtSsVCZrfH+QWoI6V1GCxmaLK6GOqftjPtR/72DSwn2s/9rFp0KefdX0tGC35Sk9PR3FxMVxdXbW2u7q64tKlS+U+LisrC56enlAoFJBIJPj+++/Rs2fPMvddtWoVbGxsMHjwYK3tU6ZMQZs2beDo6Ii//voLkZGRSE5OxqJFi8o9blRUFGbNmlVq++7du2FpafmsU60ysbGxBmmnWADSciQARDj39yEkna5YO1KxBIUqEXb+sQdOFRtAo6cYqo+pemM/137sY9PAfq792MemQZd+zs/P16kto047rAgbGxucOnUKubm5iIuLQ0REBBo0aFBqSiIALF++HKNHj4Zcrv2Xf0REhOZ3Pz8/SKVSTJo0CVFRUZDJZGUeNzIyUutx2dnZ8PLyQq9evWBra2uYk6sgpVKJ2NhY9OzZE+bm5i/cXnJWAYQjB2AmFmHYwD4Qi0UVamfu2f1Iyy1E2/bBaObOa+pehKH7mKon9nPtxz42Dezn2o99bBr06Wf1rLjnMVry5eTkBIlEgtTUVK3tqampz7wWSywWo2HDhgAAf39/XLx4EVFRUaWSr4MHDyIhIQEbN258bixBQUEoKipCYmIimjRpUuY+MpmszMTM3Ny82rzpDBXL/fxcAICLjQwyWcWnC1rLzZGWW4iCYlSb56imq06vN6o87Ofaj31sGtjPtR/72DTo0s+6vg6MVmpeKpUiICAAcXFxmm0qlQpxcXFo3769zu2oVCqta7HUfv75ZwQEBKB169bPbePUqVMQi8VlVlg0RakvWOlQjeXmiYiIiIgeM+q0w4iICIwbNw6BgYFo164dFi9ejLy8PE31w7Fjx8LT0xNRUVEASq67CgwMhK+vLxQKBX7//XesXr0aS5cu1Wo3Ozsbmzdvxn/+859Sx4yPj8fRo0fRrVs32NjYID4+HlOnTsXrr78OBweHyj/pGuBF1/hSs5KVVDjMYfJFRERERGTc5Gv48OFIS0vDjBkzkJKSAn9/f8TExGiKcCQlJUEsfjw4l5eXh3feeQe3b9+GhYUFmjZtijVr1mD48OFa7W7YsAGCIGDkyJGljimTybBhwwZ8/vnnUCgU8PHxwdSpU7Wu5zJ1KdklI4muL5h8ceSLiIiIiOgxoxfcCA8PR3h4eJn37d+/X+v23LlzMXfu3Oe2OXHiREycOLHM+9q0aYMjR47oHacp0azxxWmHREREREQGY7Rrvqj6Mty0w5LkK6eAyRcREREREZMvKkVTcONFpx3KOfJFRERERKTG5Iu0CIKAFENNO5SWJF+5TL6IiIiIiJh8kbYcRRHyC4sBGG7aIZMvIiIiIiImX/SU1EfXe9nKzWAhlbxQW5x2SERERET0GJMv0mKoKYfA42qHHPkiIiIiImLyRU9RVzp80WIbwJPJV/ELt0VEREREVNMx+SIt6kqH7gYY+Xp8zZfyhdsiIiIiIqrpmHyRFs20QwOOfOVx5IuIiIiIiMkXaUvJUgAAXA1xzZec13wREREREakx+SItqYYc+Xq0zldhkQqFRaoXbo+IiIiIqCZj8kVa1NMODVFww0r2uFQ9y80TERERkalj8kUaymIV0nNLph0aotS8mUQMuXnJS4xTD4mIiIjI1DH5Io20HAUEATCXiOBoKTVIm1zri4iIiIioBJMv0lBPOXSxkUMsFhmkzccVD5l8EREREZFpY/JFGuoFlg0x5VBNvdZXDpMvIiIiIjJxTL5IQ5N8GaDYhhpHvoiIiIiISjD5Io1UA1Y6VNNc81XA5IuIiIiITBuTL9JQX/PlZiczWJtWLLhBRERERASAyRc9QT3t0KAjX3L1tMNig7VJRERERFQTMfkiDfW0w8q45itXoTRYm0RERERENRGTLwIACILwxLTDyki+OPJFRERERKaNyRcBALIfFqFAqQJg2GmHvOaLiIiIiKgEky8C8LjYhr2lOeTmEoO1ay0raYul5omIiIjI1DH5IgBPVDo04KgXAFjLzAFw5IuIiIiIiMkXAQBSK6HSIQBYPRr54jpfRERERGTqmHwRgMob+bJRl5ovZPJFRERERKaNyRcBeJx8uRqw0iHwuOAGr/kiIiIiIlPH5IsAPJ52aOiRLytpSfKVw2mHRERERGTimHwRgCemHdrJDNquetqhokgFZbHKoG0TEREREdUkTL4IAJCaXVkFN8w0v3PqIRERERGZMiZfhMIiFdJzCwEYftqhuUQMmVnJy4zl5omIiIjIlDH5ItzLKRn1kkrEcLSSGrx9a03RjWKDt01EREREVFMw+SLNlEMXWxlEIpHB21dPPcxVKA3eNhERERFRTcHki5CSpQBg+CmHataa5IsjX0RERERkuph8UaWt8aWmSb5Ybp6IiIiITBiTL9JMO6yskS8rmQQAqx0SERERkWlj8kVIqaQFltWs5eYAWO2QiIiIiEwbky+qgmmHJSNfTL6IiIiIyJQx+aJKn3b4uNQ8ky8iIiIiMl1MvkycIAiVPu1QXWo+h8kXEREREZkwJl8mLuuhEooiFYCSdb4qA0e+iIiIiIiYfJk89fVeDpbmkJtLKuUYTL6IiIiIiKpB8rVkyRJ4e3tDLpcjKCgIx44dK3ffbdu2ITAwEPb29rCysoK/vz9Wr16ttc/48eMhEom0fnr37q21T0ZGBkaPHg1bW1vY29vjzTffRG5ubqWcX3WnnnLoWklTDoEnph1ynS8iIiIiMmFGTb42btyIiIgIzJw5EydOnEDr1q0RGhqKe/fulbm/o6MjPvnkE8THx+PMmTMICwtDWFgY/vjjD639evfujeTkZM3P+vXrte4fPXo0zp8/j9jYWOzYsQMHDhzAxIkTK+08qzNNsY1KqnQIANbyRyNfhUy+iIiIiMh0GTX5WrRoESZMmICwsDA0b94c0dHRsLS0xPLly8vcv2vXrhg0aBCaNWsGX19fvP/++/Dz88OhQ4e09pPJZHBzc9P8ODg4aO67ePEiYmJi8NNPPyEoKAidOnXCt99+iw0bNuDu3buVer7VUUqWAkDlFdsAHk87zOXIFxERERGZMDNjHbiwsBDHjx9HZGSkZptYLEZISAji4+Of+3hBELB3714kJCRgwYIFWvft378fLi4ucHBwQPfu3TF37lzUqVMHABAfHw97e3sEBgZq9g8JCYFYLMbRo0cxaNCgMo+nUCigUCg0t7OzswEASqUSSqVS9xOvBOrjVySOu5n5AABna/NKOw/ZoxQ/V1Fk9OeqpnqRPqaag/1c+7GPTQP7ufZjH5sGffpZ19eC0ZKv9PR0FBcXw9XVVWu7q6srLl26VO7jsrKy4OnpCYVCAYlEgu+//x49e/bU3N+7d28MHjwYPj4+uHbtGv7v//4Pffr0QXx8PCQSCVJSUuDi4qLVppmZGRwdHZGSklLucaOiojBr1qxS23fv3g1LS0tdT7tSxcbG6v2Ys1fFAMS4d/MKfv/9suGDAnC/AADMkJ2vwO+//14pxzAVFeljqnnYz7Uf+9g0sJ9rP/axadCln/Pz83Vqy2jJV0XZ2Njg1KlTyM3NRVxcHCIiItCgQQN07doVADBixAjNvq1atYKfnx98fX2xf/9+9OjRo8LHjYyMREREhOZ2dnY2vLy80KtXL9ja2la4XUNQKpWIjY1Fz549YW5urtdjo2/EA8hBSMdAdG3sXCnxZeQVYvbJ/ShUidArtDfMJEav81LjvEgfU83Bfq792Memgf1c+7GPTYM+/ayeFfc8Rku+nJycIJFIkJqaqrU9NTUVbm5u5T5OLBajYcOGAAB/f39cvHgRUVFRmuTraQ0aNICTkxOuXr2KHj16wM3NrVRBj6KiImRkZDzzuDKZDDJZ6XWwzM3Nq82briKx3MspmUrp6WBdaedhb/042SoUxLCoJs9XTVSdXm9UedjPtR/72DSwn2s/9rFp0KWfdX0dGG0IQiqVIiAgAHFxcZptKpUKcXFxaN++vc7tqFQqrWuxnnb79m3cv38f7u7uAID27dsjMzMTx48f1+yzd+9eqFQqBAUFVeBMai5FUTHu5xUCqNxqhzIzCaSPRrtyudYXEREREZkoo047jIiIwLhx4xAYGIh27dph8eLFyMvLQ1hYGABg7Nix8PT0RFRUFICS664CAwPh6+sLhaLk+qHVq1dj6dKlAIDc3FzMmjULQ4YMgZubG65du4aPP/4YDRs2RGhoKACgWbNm6N27NyZMmIDo6GgolUqEh4djxIgR8PDwMM4TYST3skuSVqmZGA6WlfutjZVMgsJ8FRdaJiIiIiKTZdTka/jw4UhLS8OMGTOQkpICf39/xMTEaIpwJCUlQSx+PDiXl5eHd955B7dv34aFhQWaNm2KNWvWYPjw4QAAiUSCM2fOYNWqVcjMzISHhwd69eqFOXPmaE0ZXLt2LcLDw9GjRw+IxWIMGTIE33zzTdWefDWgWePLVg6RSFSpx7KWm+FBvpIjX0RERERksoxecCM8PBzh4eFl3rd//36t23PnzsXcuXPLbcvCwqLUgstlcXR0xLp16/SKszZKeSL5qmxWUq71RURERESmjWXnTFhKVkny5VqJ13up2chLki9OOyQiIiIiU8Xky4Q9nnZYuoqjoVnJSpKvHCZfRERERGSimHyZsJRHBTdcq2LaoYwjX0RERERk2ph8mbDUR9MOK7PMvJoNky8iIiIiMnFMvkxYcvZDAFVUcIPTDomIiIjIxDH5MlGCICC1CqcdWnPki4iIiIhMHJMvE/UgX4nCIhWAqk2+WGqeiIiIiEwVky8TpS4zX8dKCqlZ5b8M1NMOcxXFlX4sIiIiIqLqiMmXiVKXma+KUS8AsOY6X0RERERk4ph8maiU7KqrdAgA1jIJACCXyRcRERERmSgmXyZKPe2wyka+ZOYAOPJFRERERKaLyZeJUk87rIoy8wBg9Wjki6XmiYiIiMhUMfkyUY+nHcqq5HgsNU9EREREpo7Jl4mq+mmHJclXfmExilVClRyTiIiIiKg6YfJlolKruOCGutQ8AOQVcvSLiIiIiEwPky8TVKAsxoN8JYCqu+ZLZiaGuUQEgFMPiYiIiMg0MfkyQfeyFQBKEiI7C/MqOaZIJHq80HIBky8iIiIiMj1MvkzQk2t8iUSiKjuulfRR8sWRLyIiIiIyQUy+TJA6+aqqYhtqNnJ1xcPiKj0uEREREVF1wOSrFth1LgXZhbrvn5pVtWt8qWmmHSqUVXpcIiIiIqLqwOz5u1B1dvtBPqZsPAMRJNj14B8M8PdEaAs3OFpJy31MShVXOlR7nHxx5IuIiIiITA+TrxouI68Qfp62OHMnG39dz8Bf1zPw6f/OoWNDJ/T3c0doC7dSRTWMNu1QU3CDI19EREREZHqYfNVwfnXtsfXtl/HLtt/x0KkZfj+XigvJ2ThwOQ0HLqfh0/+eQ+fGTujv54GQ5q6wlpkZcdqhBACQV8iRLyIiIiIyPUy+agknOdC3sw/CezTG9bRc7DiTjB1n7uJyai72XLyHPRfvQWYmRrcmLriWlgsAcLOTVWmM1rKSEThWOyQiIiIiU8TkqxZq4GyNKT0aYUqPRricmoMdp+9ix5lkXE/PQ8z5FM1+VT3t0PrRyBfX+SIiIiIiU8Tkq5Zr7GqDiF5NMLVnY1xMzsGOM3cRcz4F9R0t4WFnUaWxqAtu5HHki4iIiIhMEJMvEyESidDcwxbNPWzxce+mRonBWs5FlomIiIjIdHGdL6oy1jImX0RERERkuph8UZWx5rRDIiIiIjJhTL6oyqiv+cph8kVEREREJojJF1UZjnwRERERkSlj8kVV5nHyxUWWiYiIiMj0MPmiKmP1RMENlUowcjRERERERFWLyRdVGRv545UN8pUc/SIiIiIi08Lki6qMzEwMiVgEAMgt4HVfRERERGRamHxRlRGJRLCSSgBwrS8iIiIiMj1MvqhK2cjNAbDiIRERERGZHiZfVKWsZBz5IiIiIiLTxOSLqpT1ExUPiYiIiIhMCZMvqlKacvMsuEFEREREJobJF1UpzULLhUy+iIiIiMi0MPmiKsVph0RERERkqph8UZXitEMiIiIiMlVGT76WLFkCb29vyOVyBAUF4dixY+Xuu23bNgQGBsLe3h5WVlbw9/fH6tWrNfcrlUpMmzYNrVq1gpWVFTw8PDB27FjcvXtXqx1vb2+IRCKtn/nz51faOdJjNvJH0w458kVEREREJsaoydfGjRsRERGBmTNn4sSJE2jdujVCQ0Nx7969Mvd3dHTEJ598gvj4eJw5cwZhYWEICwvDH3/8AQDIz8/HiRMn8Nlnn+HEiRPYtm0bEhISMHDgwFJtzZ49G8nJyZqf9957r1LPlUqoR75ymHwRERERkYkxM+bBFy1ahAkTJiAsLAwAEB0djZ07d2L58uWYPn16qf27du2qdfv999/HqlWrcOjQIYSGhsLOzg6xsbFa+3z33Xdo164dkpKSUK9ePc12GxsbuLm5Gf6k6JnUyRdHvoiIiIjI1Bgt+SosLMTx48cRGRmp2SYWixESEoL4+PjnPl4QBOzduxcJCQlYsGBBuftlZWVBJBLB3t5ea/v8+fMxZ84c1KtXD6NGjcLUqVNhZlb+06FQKKBQKDS3s7OzAZRMdVQqlc+NtzKpj2/sOHRhYSYCAOQUGP95q0lqUh9TxbGfaz/2sWlgP9d+7GPToE8/6/paMFrylZ6ejuLiYri6umptd3V1xaVLl8p9XFZWFjw9PaFQKCCRSPD999+jZ8+eZe5bUFCAadOmYeTIkbC1tdVsnzJlCtq0aQNHR0f89ddfiIyMRHJyMhYtWlTucaOiojBr1qxS23fv3g1LS8vnnW6VeHrUrzq6lCECIMGd1Pv4/fffjR1OjVMT+pheHPu59mMfmwb2c+3HPjYNuvRzfn6+Tm0ZddphRdjY2ODUqVPIzc1FXFwcIiIi0KBBg1JTEpVKJYYNGwZBELB06VKt+yIiIjS/+/n5QSqVYtKkSYiKioJMJivzuJGRkVqPy87OhpeXF3r16qWV2BmDUqlEbGwsevbsCXNzc6PG8jx1bmTgp4R/YGZhjb59Oxo7nBqjJvUxVRz7ufZjH5sG9nPtxz42Dfr0s3pW3PMYLflycnKCRCJBamqq1vbU1NRnXoslFovRsGFDAIC/vz8uXryIqKgoreRLnXjdvHkTe/fufW5yFBQUhKKiIiQmJqJJkyZl7iOTycpMzMzNzavNm646xVIeO0s5ACBPUVztY62OakIf04tjP9d+7GPTwH6u/djHpkGXftb1dWC0aodSqRQBAQGIi4vTbFOpVIiLi0P79u11bkelUmldi6VOvK5cuYI9e/agTp06z23j1KlTEIvFcHFx0e8kSG9WMgkAFtwgIiIiItNj1GmHERERGDduHAIDA9GuXTssXrwYeXl5muqHY8eOhaenJ6KiogCUXHcVGBgIX19fKBQK/P7771i9erVmWqFSqcTQoUNx4sQJ7NixA8XFxUhJSQFQUqZeKpUiPj4eR48eRbdu3WBjY4P4+HhMnToVr7/+OhwcHIzzRJgQ60frfOUWFkEQBIhEIiNHRERERERUNYyafA0fPhxpaWmYMWMGUlJS4O/vj5iYGE0RjqSkJIjFjwfn8vLy8M477+D27duwsLBA06ZNsWbNGgwfPhwAcOfOHfz2228ASqYkPmnfvn3o2rUrZDIZNmzYgM8//xwKhQI+Pj6YOnWq1vVcVHmsH5WaFwQgv7BYU3qeiIiIiKi2M/pfvuHh4QgPDy/zvv3792vdnjt3LubOnVtuW97e3hAE4ZnHa9OmDY4cOaJ3nGQYFuYSiEWASiiZesjki4iIiIhMhdGu+SLTJBKJNAlXDq/7IiIiIiITwuSLqpx66iGLbhARERGRKWHyRVVOnXzlMvkiIiIiIhPC5IuqnHraYW4Bky8iIiIiMh1MvqjKaaYdFjL5IiIiIiLTweSLqpw1R76IiIiIyARVKPnKzMzETz/9hMjISGRkZAAATpw4gTt37hg0OKqdNNMOFcVGjoSIiIiIqOrovcjSmTNnEBISAjs7OyQmJmLChAlwdHTEtm3bkJSUhF9++aUy4qRaxEbOaodEREREZHr0HvmKiIjA+PHjceXKFcjlcs32vn374sCBAwYNjmonK5kEAKsdEhEREZFp0Tv5+vvvvzFp0qRS2z09PZGSkmKQoKh2s2KpeSIiIiIyQXonXzKZDNnZ2aW2X758Gc7OzgYJimo3GxbcICIiIiITpHfyNXDgQMyePRtKpRIAIBKJkJSUhGnTpmHIkCEGD5BqHyuWmiciIiIiE6R38vWf//wHubm5cHFxwcOHD9GlSxc0bNgQNjY2mDdvXmXESLWMNacdEhEREZEJ0rvaoZ2dHWJjY3H48GGcPn0aubm5aNOmDUJCQiojPqqFuM4XEREREZkivZMvtY4dO6Jjx46GjIVMhGbaIUe+iIiIiMiE6D3tcMqUKfjmm29Kbf/uu+/wr3/9yxAxUS1n/WidrxwmX0RERERkQvROvrZu3VrmiFeHDh2wZcsWgwRFtZv1EyNfgiAYORoiIiIioqqhd/J1//592NnZldpua2uL9PR0gwRFtZs6+VIJQIFSZeRoiIiIiIiqht7JV8OGDRETE1Nq+65du9CgQQODBEW1m6VUApGo5PcchdK4wRARERERVRG9C25EREQgPDwcaWlp6N69OwAgLi4O//nPf7B48WJDx0e1kEgkgpXUDLmKIuQpigEbY0dERERERFT59E6+3njjDSgUCsybNw9z5swBAHh7e2Pp0qUYO3aswQOk2slaVpJ8sdw8EREREZmKCpWanzx5MiZPnoy0tDRYWFjA2tra0HFRLWclkwDgQstEREREZDoqvM4XADg7OxsqDjIx1nJzAFzri4iIiIhMh94FN1JTUzFmzBh4eHjAzMwMEolE64dIF9Yc+SIiIiIiE6P3yNf48eORlJSEzz77DO7u7hCpy9YR6cFKWvLSY/JFRERERKZC7+Tr0KFDOHjwIPz9/SshHDIV1vLHCy0TEREREZkCvacdenl5QRCEyoiFTIh6oWWOfBERERGRqdA7+Vq8eDGmT5+OxMTESgiHTAWTLyIiIiIyNXpPOxw+fDjy8/Ph6+sLS0tLmJuba92fkZFhsOCo9rJSJ19c54uIiIiITITeydfixYsrIQwyNeqRr7xCJl9EREREZBr0Tr7GjRtXGXGQiXk87bDYyJEQEREREVUNva/5AoBr167h008/xciRI3Hv3j0AwK5du3D+/HmDBke11+Nph0ojR0JEREREVDX0Tr7+/PNPtGrVCkePHsW2bduQm5sLADh9+jRmzpxp8ACpdrLRlJrnyBcRERERmQa9k6/p06dj7ty5iI2NhVQq1Wzv3r07jhw5YtDgqPayYrVDIiIiIjIxeidfZ8+exaBBg0ptd3FxQXp6ukGCotrPWiYBwOSLiIiIiEyH3smXvb09kpOTS20/efIkPD09DRIU1X7WspIlCvIURVy0m4iIiIhMgt7J14gRIzBt2jSkpKRAJBJBpVLh8OHD+PDDDzF27NjKiJFqIatHI19FKgGKIpWRoyEiIiIiqnx6J19ffPEFmjZtCi8vL+Tm5qJ58+bo3LkzOnTogE8//bQyYqRayEr6eJUDTj0kIiIiIlOg1zpfgiAgJSUF33zzDWbMmIGzZ88iNzcXL730Eho1alRZMVItJBaLYCWVIK+wGLkFRXCylhk7JCIiIiKiSqV38tWwYUOcP38ejRo1gpeXV2XFRSbASmZWknxx5IuIiIiITIBe0w7FYjEaNWqE+/fvV1Y8ZEKsNWt9MfkiIiIiotpP72u+5s+fj48++gjnzp2rjHjIhFhzrS8iIiIiMiF6TTsEgLFjxyI/Px+tW7eGVCqFhYWF1v0ZGRkGC45qNyZfRERERGRK9E6+Fi9ebNAAlixZgn//+99ISUlB69at8e2336Jdu3Zl7rtt2zZ88cUXuHr1KpRKJRo1aoQPPvgAY8aM0ewjCAJmzpyJZcuWITMzEx07dsTSpUu1CoJkZGTgvffew/bt2yEWizFkyBB8/fXXsLa2Nui50bNZMfkiIiIiIhOid/I1btw4gx1848aNiIiIQHR0NIKCgrB48WKEhoYiISEBLi4upfZ3dHTEJ598gqZNm0IqlWLHjh0ICwuDi4sLQkNDAQBffvklvvnmG6xatQo+Pj747LPPEBoaigsXLkAulwMARo8ejeTkZMTGxkKpVCIsLAwTJ07EunXrDHZu9HzqkS9e80VEREREpkDva74A4Nq1a/j0008xcuRI3Lt3DwCwa9cunD9/Xq92Fi1ahAkTJiAsLAzNmzdHdHQ0LC0tsXz58jL379q1KwYNGoRmzZrB19cX77//Pvz8/HDo0CEAJaNeixcvxqeffopXXnkFfn5++OWXX3D37l3873//AwBcvHgRMTEx+OmnnxAUFIROnTrh22+/xYYNG3D37t2KPB1UQY+nHRYbORIiIiIiosqn98jXn3/+iT59+qBjx444cOAA5s2bBxcXF5w+fRo///wztmzZolM7hYWFOH78OCIjIzXbxGIxQkJCEB8f/9zHC4KAvXv3IiEhAQsWLAAA3LhxAykpKQgJCdHsZ2dnh6CgIMTHx2PEiBGIj4+Hvb09AgMDNfuEhIRALBbj6NGjGDRoUJnHUygUUCgUmtvZ2dkAAKVSCaVSqdM5Vxb18Y0dh74szEUAgOx8RY2LvarV1D4m/bCfaz/2sWlgP9d+7GPToE8/6/pa0Dv5mj59OubOnYuIiAjY2Nhotnfv3h3fffedzu2kp6ejuLgYrq6uWttdXV1x6dKlch+XlZUFT09PKBQKSCQSfP/99+jZsycAICUlRdPG022q70tJSSk1pdHMzAyOjo6afcoSFRWFWbNmldq+e/duWFpaPuNMq05sbKyxQ9DLndsiABJcupaI33+/buxwaoSa1sdUMezn2o99bBrYz7Uf+9g06NLP+fn5OrWld/J19uzZMq+NcnFxQXp6ur7N6c3GxganTp1Cbm4u4uLiEBERgQYNGqBr166VetzIyEhERERobmdnZ8PLywu9evWCra1tpR77eZRKJWJjY9GzZ0+Ym5sbNRZ9pB9Jws5bl+Dg7I6+fVsbO5xqrab2MemH/Vz7sY9NA/u59mMfmwZ9+lk9K+559E6+7O3tkZycDB8fH63tJ0+ehKenp87tODk5QSKRIDU1VWt7amoq3Nzcyn2cWCxGw4YNAQD+/v64ePEioqKi0LVrV83jUlNT4e7urtWmv78/AMDNzU1znZpaUVERMjIynnlcmUwGmUxWaru5uXm1edNVp1h0YWshBQDkK1U1Km5jqml9TBXDfq792Memgf1c+7GPTYMu/azr60DvghsjRozAtGnTkJKSApFIBJVKhcOHD+PDDz/E2LFjdW5HKpUiICAAcXFxmm0qlQpxcXFo3769zu2oVCrNtVg+Pj5wc3PTajM7OxtHjx7VtNm+fXtkZmbi+PHjmn327t0LlUqFoKAgnY9LL85GzmqHRERERGQ69B75+uKLL/Duu+/Cy8sLxcXFaN68OYqLizFq1Ch8+umnerUVERGBcePGITAwEO3atcPixYuRl5eHsLAwACULOnt6eiIqKgpAyXVXgYGB8PX1hUKhwO+//47Vq1dj6dKlAACRSIR//etfmDt3Lho1aqQpNe/h4YFXX30VANCsWTP07t0bEyZMQHR0NJRKJcLDwzFixAh4eHjo+3TQC+A6X0RERERkSnRKvrKzszXXNUmlUixbtgwzZszA2bNnkZubi5deeklrEWNdDR8+HGlpaZgxYwZSUlLg7++PmJgYTcGMpKQkiMWPB+fy8vLwzjvv4Pbt27CwsEDTpk2xZs0aDB8+XLPPxx9/jLy8PEycOBGZmZno1KkTYmJiNGt8AcDatWsRHh6OHj16aBZZ/uabb/SOn17MiyRfGXmFcLA0h0gkMnRYRERERESVQqfky8HBAcnJyXBxcUH37t2xbds2eHl5wcvL64UDCA8PR3h4eJn37d+/X+v23LlzMXfu3Ge2JxKJMHv2bMyePbvcfRwdHbmgcjVgU8Hka8+FVLz1yz/o3cIN34x8CVKzCi1XR0RERERUpXT6q9Xa2hr3798HUJIQcU0DMgT1yJe+13z9eKCkLH3M+RS8s/Y4FEVcpJmIiIiIqj+dRr5CQkLQrVs3NGvWDAAwaNAgSKXSMvfdu3ev4aKjWs36UcENZbEARVExZGaS5z7mcmoOjiVmQCIWwUwswp6L9/D26uNY+noA5ObPfzwRERERkbHolHytWbMGq1atwrVr1/Dnn3+iRYsW1WZhYaq5rKSPX365BUWQWT8/eVp3NAkAENLMBWNe9sZbv/yNfQlpmLT6OH4YwwSMiIiIiKovnZIvpVKJt99+GwDwzz//YMGCBbC3t6/MuMgESMQiWJhL8FBZjDxFMepYP3v/h4XF2HriNgBgVFB9dGrkhOXj2+LNlf/gz8tpmPDLP/hxTCAspEzAiIiIiKj60emaLwcHB83CxKwuR4aknnqYo3j+dYTbz9xFTkERvBwtENzQCQDQwdcJK8LawlIqwcEr6Xhz1d94WMhrwIiIiIio+tG74Maff/7JghtkMNaaohvPT5jWPppyOKpdfYjFj78EeLlBHax6ox2spBL8de0+wlYeQ34h1w4jIiIioupF74IbgiCw4AYZjLWOFQ/P3cnC6VuZMJeI8Fpg3VL3t/V2xC9vtsO45X/jyPUMjF/+N1aEtdVUVCQiIiIiMjYW3CCjspKVXJ+V85zka92xklGv3i3d4WQtK3OfgPqPErCfj+FYYgbGLT+GlW+00yR4RERERETGpNNfpRYWFiy4QZVCl5GvXEURfj15BwAwql29Z7bXpp4D1rwVhDE/H8U/Nx9g7M9HsfKNdrCVmxsuaCIiIiKiCtDpmq8n7du3j4kXGYw6+cotKD/5+t/JO8grLEYDZyu83MDxuW229rLH2rdehp2FOU4kZWLsz8eQ9ZDXKRIRERGRcek08hUREYE5c+bAysoKERERz9x30aJFBgmMTIP6mqzccka+BEHQFNoYHVRf52qbreraYe1bQXj956M4dSsTY34+itVvBMHOkiNgRERERGQcOiVfJ0+e1FQ4PHnyZLn7sQw96Utdar68aYenbmXiYnI2ZGZiDGnjqVfbLT3tsO6tlzH6pyM4czsLUzacxKo32r1wzEREREREFaFT8rVv374yfyd6UdbSZ498qUe9+vm5w96y7Aqbz9LcwxbrJryMAd8ewp+X03D6ViZae9lXOF4iIiIioorS+5ovoGQqWHp6umbtL6KKeta0w6x8JbafvgugZMphRTVzt8VAfw8AQPSf1yrcDhERERHRi9Ar+UpJScHYsWPh4OAAV1dXuLi4wMHBAW+88QZSU1MrK0aqxdTTDstKvraeuA1FkQpN3WzQpp79Cx3n7S6+AICY8ym4npb7Qm0REREREVWEzgsgZWdno0OHDsjNzUVYWBiaNm0KQRBw4cIFrF+/HocOHcKJEydgbW1dmfFSLVNeqXlBEDRre41+WfdCG+Vp7GqDkGYu2HPxHn48cB3zh/i9UHtERERERPrSOfn6+uuvIZFIcP78eTg7O2vd9+mnn6Jjx4745ptv8H//938GD5JqL02peUWx1vZjNzJw9V4uLKUSvPpoyuCLeruLL/ZcvIdtJ+5gas/GcLWVG6RdIiIiIiJd6DztcOfOnfi///u/UokXALi4uCAyMhLbt283aHBU+z2+5kt7HS51oY1X/D1gY6AFkgO9HdHW2wGFxSosP3TDIG0SEREREelK5+Tr8uXL6NChQ7n3d+jQAQkJCQYJikzH42mHj0e+7ucqsOtcMgBgVLuKF9ooy+SuJdd+rT2axIWXiYiIiKhK6Zx8ZWdnw97evtz77e3tkZ2dbYiYyIRoCm4UPL7ma8vx21AWC2hd1w6t6toZ9HjdmrigiasNchVFWHPkpkHbJiIiIiJ6Fp2TL0EQIBaXv7tIJIIgCAYJikyHep2vwmIVCotUUKmeKLTxAuXlyyMSifB21wYAgBWHb6BAWfycRxARERERGYbOBTcEQUDjxo3LrTrHxIsqwkom0fyepyjCubtZuHk/HzYyM/Rv7V4px+zv54GFf1zGncyH2HL8Nl5/2fBJHhERERHR03ROvlasWFGZcZCJMpOIITcXo0CpQq6iCGuPlIx6DW7jCUupzi9PvZhLxJgQ7IPPt1/AjweuY0RbL5hJKrTeOBERERGRznT+63bcuHGVGQeZMGuZGQqUhbienofYiyWLdY+qhCmHTxrW1gtfx11BUkY+dp1LwYDWhilnT0RERERUHn7dT0anrni4/NANFKsEtPV2QBM3m0o9pqXUDOM7+AAAlu6/xmmzRERERFTpmHyR0anX+vrzchoAYFRQvSo57tj29WEpleBCcjYOXkmvkmMSERERkeli8kVGpx75AgB7S3P0aVk5hTae5mAlxYi2JYne0v3XquSYRERERGS6mHyR0T2ZfL0WUBdyc8kz9jast4J9YCYWIf76fZy6lVllxyUiIiIi08Pki4zO6onka2S7qplyqOZhb4FX/D0BANEc/SIiIiKiSqR3Le/i4mKsXLkScXFxuHfvHlQqldb9e/fuNVhwZBqs5SUvw44N66CBs3WVH//tLg2w9cRt/HEhBdfScuFrhBiIiIiIqPbTO/l6//33sXLlSvTr1w8tW7Ysd9FlIl0NeskTF+5m4+PQpkY5fiNXG4Q0c8Wei6n48c/rWDDUzyhxEBEREVHtpnfytWHDBmzatAl9+/atjHjIBLX1dsT/3u1o1Bgmd/XFnoup2HbyNqb2bAw3O7lR4yEiIiKi2kfva76kUikaNmxYGbEQGU1AfQe083GEsljA8sM3jB0OEREREdVCeidfH3zwAb7++msuSku1zuQuvgCAtUduIitfaeRoiIiIiKi20Xva4aFDh7Bv3z7s2rULLVq0gLm5udb927ZtM1hwRFWpaxNnNHWzwaWUHKw5ehPvduMILxEREREZjt4jX/b29hg0aBC6dOkCJycn2NnZaf0Q1VQikQhvPxr9Wn7oBgqUxUaOiIiIiIhqE71HvlasWFEZcRBVC/393LFwdwJuP3iIzcdvY8zL9Y0dEhERERHVElxkmegJZhIxJgQ3AAAsO3Cd1zYSERERkcHoPfIFAFu2bMGmTZuQlJSEwsJCrftOnDhhkMCIjGVYoBe+jLmEpIx8nEjKREB9B2OHRERERES1gN4jX9988w3CwsLg6uqKkydPol27dqhTpw6uX7+OPn36VEaMRFXKQipBz+auAIAdZ+4aORoiIiIiqi30Tr6+//57/Pjjj/j2228hlUrx8ccfIzY2FlOmTEFWVlZlxEhU5Qa09gAA7DyTjGIVpx4SERER0YvTO/lKSkpChw4dAAAWFhbIyckBAIwZMwbr1683bHRERhLcyBm2cjPcy1Hg2I0MY4dDRERERLWA3smXm5sbMjJK/hitV68ejhw5AgC4ceMGixNQrSE1E6N3SzcAnHpIRERERIahd/LVvXt3/PbbbwCAsLAwTJ06FT179sTw4cMxaNAgvQNYsmQJvL29IZfLERQUhGPHjpW777JlyxAcHAwHBwc4ODggJCSk1P4ikajMn3//+9+afby9vUvdP3/+fL1jp9pNPfVw17kUKItVRo6GiIiIiGo6vasd/vjjj1CpSv4Qfffdd1GnTh389ddfGDhwICZNmqRXWxs3bkRERASio6MRFBSExYsXIzQ0FAkJCXBxcSm1//79+zFy5Eh06NABcrkcCxYsQK9evXD+/Hl4enoCAJKTk7Ues2vXLrz55psYMmSI1vbZs2djwoQJmts2NjZ6xU61X/sGdVDHSor7eYX469p9dGnsbOyQiIiIiKgG0zv5EovFEIsfD5iNGDECI0aMqNDBFy1ahAkTJiAsLAwAEB0djZ07d2L58uWYPn16qf3Xrl2rdfunn37C1q1bERcXh7FjxwIomRb5pF9//RXdunVDgwYNtLbb2NiU2pfoSWYSMfq0csOaI0nYcfouky8iIiIieiEVWufr4MGD+OGHH3Dt2jVs2bIFnp6eWL16NXx8fNCpUyed2igsLMTx48cRGRmp2SYWixESEoL4+Hid2sjPz4dSqYSjo2OZ96empmLnzp1YtWpVqfvmz5+POXPmoF69ehg1ahSmTp0KM7Pynw6FQgGFQqG5nZ2dDQBQKpVQKpU6xVtZ1Mc3dhy1UZ8WLlhzJAkx51Mws39TyMyMsy45+9g0sJ9rP/axaWA/137sY9OgTz/r+lrQO/naunUrxowZg9GjR+PkyZOahCQrKwtffPEFfv/9d53aSU9PR3FxMVxdXbW2u7q64tKlSzq1MW3aNHh4eCAkJKTM+1etWgUbGxsMHjxYa/uUKVPQpk0bODo64q+//kJkZCSSk5OxaNGico8VFRWFWbNmldq+e/duWFpa6hRvZYuNjTV2CLWOSgDszCXIKijC1xv+QEtH4xaVYR+bBvZz7cc+Ng3s59qPfWwadOnn/Px8ndrSO/maO3cuoqOjMXbsWGzYsEGzvWPHjpg7d66+zVXY/PnzsWHDBuzfvx9yubzMfZYvX47Ro0eXuj8iIkLzu5+fH6RSKSZNmoSoqCjIZLIy24qMjNR6XHZ2Nry8vNCrVy/Y2toa4IwqTqlUIjY2Fj179oS5ublRY6mNTosuYWV8ElJknvi4r59RYmAfmwb2c+3HPjYN7Ofaj31sGvTpZ/WsuOfRO/lKSEhA586dS223s7NDZmamzu04OTlBIpEgNTVVa3tqaupzr8VauHAh5s+fjz179sDPr+w/hg8ePIiEhARs3LjxubEEBQWhqKgIiYmJaNKkSZn7yGSyMhMzc3PzavOmq06x1CavvFQXK+OTEHcpDUWCGBZSidFiYR+bBvZz7cc+Ng3s59qPfWwadOlnXV8HFVrn6+rVq6W2Hzp0qFRRi2eRSqUICAhAXFycZptKpUJcXBzat29f7uO+/PJLzJkzBzExMQgMDCx3v59//hkBAQFo3br1c2M5deoUxGJxmRUWify97FHXwQL5hcXYl3DP2OEQERERUQ2ld/I1YcIEvP/++zh69ChEIhHu3r2LtWvX4sMPP8TkyZP1aisiIgLLli3DqlWrcPHiRUyePBl5eXma6odjx47VKsixYMECfPbZZ1i+fDm8vb2RkpKClJQU5ObmarWbnZ2NzZs346233ip1zPj4eCxevBinT5/G9evXsXbtWkydOhWvv/46HBwc9H06yASIRCL09ytZ82v7aS64TEREREQVo/e0w+nTp0OlUqFHjx7Iz89H586dIZPJ8OGHH+K9997Tq63hw4cjLS0NM2bMQEpKCvz9/RETE6MpwpGUlKRV1n7p0qUoLCzE0KFDtdqZOXMmPv/8c83tDRs2QBAEjBw5stQxZTIZNmzYgM8//xwKhQI+Pj6YOnWq1vVcRE/r7+eO6D+vYe+le8hVFMFaVqFCoURERERkwvT+C1IkEuGTTz7BRx99hKtXryI3NxfNmzeHtbV1hQIIDw9HeHh4mfft379f63ZiYqJObU6cOBETJ04s8742bdrgyJEj+oRIhBYetmjgZIXr6XnYcyEVr77kaeyQiIiIiKiGqfCiRVKpFM2bN0e7du0qnHgR1RQikQj9W3PqIRERERFVnM4jX2+88YZO+y1fvrzCwRBVZwP83PFN3BUcuJKGrHwl7CxZ3YiIiIiIdKdz8rVy5UrUr18fL730EgTBuAvNEhlDI1cbNHWzwaWUHPxxPgXD2noZO6RyCYKAq/dy4etsDbFYZOxwiIiIiAh6JF+TJ0/G+vXrcePGDYSFheH111+Ho6NjZcZGVO0MaO2BSykJ2H7mbrVOvr6KvYxv9l7FtN5NMbmrr7HDISIiIiLocc3XkiVLkJycjI8//hjbt2+Hl5cXhg0bhj/++IMjYWQy+vu5AwD+unYf6bkKI0dTtlsZ+Yj+8zoAYMXhG1AWq4wcEREREREBehbckMlkGDlyJGJjY3HhwgW0aNEC77zzDry9vUuttUVUG9WvYwW/unYoVgnYdS7F2OGUaUHMJRQ+Srju5SgQeyHVyBEREREREfAC1Q7FYjFEIhEEQUBxcbEhYyKq1tSjXzuqYdXD4zcfYMeZZIhEQK/mJevlrTly08hRERERERGgZ/KlUCiwfv169OzZE40bN8bZs2fx3XffISkpieXmyWT08yspOX8sMQMpWQVGjuYxlUrAnB0XAADDA70wY0BziEQlUySvpXFkmoiIiMjYdE6+3nnnHbi7u2P+/Pno378/bt26hc2bN6Nv374Qiys8gEZU43jaWyCwvgMEAdh5NtnY4WhsP3MXp25lwlIqQUSvxqjrYInuTVwAAGuPJBk5OiIiIiLSudphdHQ06tWrhwYNGuDPP//En3/+WeZ+27ZtM1hwRNVVfz93/HPzAXacuYs3O/kYOxwUKIvxZUwCAOCdrr5wsZEDAF5/uT7iLt3DluO38FFoE1hIJcYMk4iIiMik6Zx8jR07FiIR1wsiAoC+fu6YveMCTiZl4lZGPrwcLY0az8+HbuBO5kN42MnxVnADzfbOjZ1R18ECtx88LCmPH1h9y+MTERER1XZ6LbJMRCVcbOR4uUEd/HXtPnaeTcbbXYy3llZajgLf77sKAPi4d1PIzR+PbknEIowKqocvYxKw9shNJl9ERERERsSLtYgqqP+jwhvbjVz1cFHsZeQVFqN1XTsMbO1R6v5hgV4wl4hw+nYWzt7OMkKERERERAQw+SKqsN4t3WAmFuH83WxcN1I1wUsp2dj4d0kxjU/7N4dYXHpqsJO1DH1alpTHZ9l5IiIiIuNh8kVUQY5WUnRs6AQA2HGm6qseCoKAeTsvQiUAfVu5oa23Y7n7vv5yfQDAr6fvIOuhsqpCJCIiIqInMPkiegEDWhtv6uH+y2k4eCUdUokY03o3fea+bb0d0NjVGgVKFbaduF1FERIRERHRk5h8Eb2AXi1cIZWIceVeLhJScqrsuMpiFebtvAgAGN/RG/XrWD1zf5FIpBn9Wns0CYIgVHqMRERERKSNyRfRC7CVm6NLE2cAVTv6teFYEq7ey4WjlRTvdmuo02MGveQJS6kEV+/l4sj1jEqOkIiIiIiexuSL6AWppx5uO3Ebey6kIk9RVKnHy3qoxFd7rgAApoY0gp2FuU6Ps5Gb4xV/TwDAmqMsvEFERERU1XRe54uIyhbSzAXWMjPczSrAW7/8A6lEjLY+DujS2BldGrugsau1QRco/37fVWTkFaKhizVGtqun12Nff7ke1h9Lwh/nUnAvpwAuNnKDxUVEREREz8aRL6IXZCk1w5q3gjDm5frwcrRAYbEKh6/exxe/X0Lo4gNoH7UX07acwe9nk1+40mBSRj5WHE4EAHzStxnMJPq9hVt42OGlevYoUgnY9PetF4qFiIiIiPTDkS8iA/D3soe/lz0EQUDi/XzsT7iHPy+nIf7afaRkF2DjP7ew8Z9bkIhFeMnLHl0aOyO4sTOau9tCaqZ7ArVw9xUUFqsQ3MgJXR9da6av14Pq42RSJtYfu4XJXRtCUsbaYERERERkeEy+iAxIJBLBx8kKPk4+COvogwJlMY7dyMD+hDT8efkerqXl4Z+bD/DPzQf4T+xlSCViNPew1SRvrb3s4V3HssxpitezgV3nUyEWAZ/0a1bhqYz9/NwxZ+cF3Ml8iH2X7iGkuavebVy4m43/++9ZdG/qgik9GlUoDiIiIiJTw+SLqBLJzSXo3NgZnRs7A2iOWxn5OHAlDfsT0nDsRgayHipx6lYmTt3K1DzGzsIcfnXt8NKjZKy1lz1szEX4300JAGB4Wy80dbN9oZheC6iLZQdvYM3Rm3onX3supGLKhpPILyzGheRshHX0ho1ct6IfRERERKaMyRdRFfJytMTooPoYHVQfgiDg5v18nL5dknydvpWJc3ezkfVQiYNX0nHwSrrmcc7WUqTlimAllWBqz8YvHMeooPpYdvAG/rychlsZ+fBytHzuYwRBwM+HbmDe7xehXiassEiF2AupGNym7gvHRERERFTbMfkiMhKRSARvJyt4O1lpSsAXFqmQkJKDU7dLkrHTtzJxNS0XabmFAIBJnX0MUqHQx8kKwY2ccPBKOtYeTcL0Pk2fub+yWIUZv57H+mNJAICR7erB0cocS/Zdw44zyUy+iIiIiHTA5IuoGpGaidGqrh1a1bXDmJfrAwByCpQ4dTMDcYePYlKwj8GONTqoPg5eScemf25has9GkJlJytwvK1+Jd9Ydx+Gr9yESlVRZfLOTD66l5WLJvms4cDkNmfmFsLeUGiw2IiIiotqIpeaJqjkbuTlebuCIl+oIEBuwMmFIMxe42cqRkVeImHMpZe5z834eBi89jMNX78NSKsGyMYF4K7gBRCIRGrrYoJm7LYpUQrmPJyIiIqLHmHwRmSgziRgj2nkBANYcuVnq/mM3MvDqksO4lpYHdzs5trzdoVRxjgGt3QEA28/crfyAiYiIiGo4Jl9EJmxE23qQiEX4O/EBLqVka7ZvPX4bo386ggf5SvjVtcOv73ZEc4/SFRb7t/IAAMRfu4+0HEWVxU1ERERUEzH5IjJhbnZy9GxWMpq17mgSVCoB//7jEj7YfBrKYgF9W7lh48T2cLEtu8hHvTqWaO1lD5UA7DqXXJWhExEREdU4TL6ITNzrjwp7bDtxB++sPYEl+64BAN7t5ovvRraBhbTsQhxqA/weTT08bbiph4IgYOrGUxj2QzwKlMUGa5eIiIjImJh8EZm4Dr514ONkhVxFEWLOp8BcIsJ/XmuNj0Kb6lTgo9+j5OvvxAdIznpokJiOXM/Af0/ewbEbGfjjPIt5EBERUe3A5IvIxInFIs3ol4OlOda+9TKGBOi+bpe7nQXaeTsCAHaeMczUwx8PXNP8vvXEHYO0SURERGRsXOeLiDCufX3YWZijvW8deNpb6P34Aa3dcSwxA9tP38VbwQ1eKJaElBzsS0iDSAQIAnDoShpSswvgWs51Z0REREQ1BUe+iAhmEjGGBtStUOIFAH1auUMsAk7fzkLS/fwXiuXHA9dL2mzphsD6DlAJwK+nOPpFRERENR+TLyJ6YU7WMnTwdQLwYmt+pWQV4LfTJYnWxM6+GNymZPrj1uN3IAjCiwdKREREZERMvojIIDQLLr9A1cMVh29AWSygnY8j/L3s0a+VO6RmYiSk5uBCcvbzGyAiIiKqxph8EZFBhLZwg7lEhEspObh6L0fvx2cXKLH2aBIA4O0uJdeN2Vmaa9Yh28bCG0RERFTDMfkiIoOwt5QiuJEzAGD7af2rHq4/moRcRREauVija2MXzfbBbTwBlFz3VVSsMkywREREREbA5IuIDEYz9fDMXb2u0SosUmH54RsAgAmdG2itL9a5sTPqWEmRnluIg1fSDRswERERURVi8kVEBhPSzBUyMzGup+XpdY3Wr6fuIDVbAVdbGV7x99C6z1wixsBH27aeuG3QeImIiIiqEpMvIjIYG7k5ujctmTK4Q8cFlwVBwLKDJeXlwzr6QGYmKbXPkEdVD3dfSEXWQ6WBoiUiIiKqWkZPvpYsWQJvb2/I5XIEBQXh2LFj5e67bNkyBAcHw8HBAQ4ODggJCSm1//jx4yESibR+evfurbVPRkYGRo8eDVtbW9jb2+PNN99Ebm5upZwfkanp71cySrX9tG5TD/cnpOFyai6sZWYYFVSvzH1aeNiisas1CotU2HVW/+vJiIiIiKoDoyZfGzduREREBGbOnIkTJ06gdevWCA0Nxb1798rcf//+/Rg5ciT27duH+Ph4eHl5oVevXrhzR7sKWu/evZGcnKz5Wb9+vdb9o0ePxvnz5xEbG4sdO3bgwIEDmDhxYqWdJ5Ep6d7UBZZSCW4/eIhTtzKfu3/0n9cAAKOC6sFWbl7mPiKRSLPmF6seEhERUU1lZsyDL1q0CBMmTEBYWBgAIDo6Gjt37sTy5csxffr0UvuvXbtW6/ZPP/2ErVu3Ii4uDmPHjtVsl8lkcHNzK/OYFy9eRExMDP7++28EBgYCAL799lv07dsXCxcuhIeHR5mPUygUUCgUmtvZ2SXXsyiVSiiVxp0GpT6+seOgylOT+thMBPRo6oztZ1Lw68nbaOluXe6+Z25n4eiNDJiJRXi9Xd1nnl+/li5YEHMJxxIzcC01C/UcLSsjfKOqSf1MFcM+Ng3s59qPfWwa9OlnXV8LRku+CgsLcfz4cURGRmq2icVihISEID4+Xqc28vPzoVQq4ejoqLV9//79cHFxgYODA7p37465c+eiTp06AID4+HjY29trEi8ACAkJgVgsxtGjRzFo0KAyjxUVFYVZs2aV2r57925YWlaPPwJjY2ONHQJVsprSx64KEQAJ/vvPTbQWruOJ4oVaVlwWAxDjpTrFOHl4L04+p93GtmIkZImxcPOf6O2lezXFmqam9DNVHPvYNLCfaz/2sWnQpZ/z8/N1astoyVd6ejqKi4vh6uqqtd3V1RWXLl3SqY1p06bBw8MDISEhmm29e/fG4MGD4ePjg2vXruH//u//0KdPH8THx0MikSAlJQUuLi5a7ZiZmcHR0REpKSnlHisyMhIRERGa29nZ2Zppj7a2tjrFW1mUSiViY2PRs2dPmJuXPW2Laraa1sc9ilTYuGA/sgqK4NLiZbTzdiy1z82MfJw5cggAMHNYRzRxs3luu0qPu/hw6zmcz7fG1306QSQqJ6uroWpaP5P+2Memgf1c+7GPTYM+/ayeFfc8Rp12+CLmz5+PDRs2YP/+/ZDL5ZrtI0aM0PzeqlUr+Pn5wdfXF/v370ePHj0qfDyZTAaZTFZqu7m5ebV501WnWKhy1JQ+NjcHerdww+bjt7Hr/D10bORaap9V8begEoCuTZzR0qt0claWvq09MWP7RSRlPMTZ5FwE1NftcTVNTelnqjj2sWlgP9d+7GPToEs/6/o6MFrBDScnJ0gkEqSmpmptT01NLfd6LbWFCxdi/vz52L17N/z8/J65b4MGDeDk5ISrV68CANzc3EoV9CgqKkJGRsZzj0tEuhvQuuT6yV1nU1BUrNK6736uApuP3wIATOzcQOc2LaVm6NOyZCHnrSy8QURERDWM0ZIvqVSKgIAAxMXFabapVCrExcWhffv25T7uyy+/xJw5cxATE6N13VZ5bt++jfv378PdveQPtvbt2yMzMxPHjx/X7LN3716oVCoEBQW9wBkR0ZM6+NaBo5UU9/MKEX/9vtZ9v8TfRIFShVaedmjfoI5e7Q5u4wkA2HH6LgqUxQaLl4iIiKiyGbXUfEREBJYtW4ZVq1bh4sWLmDx5MvLy8jTVD8eOHatVkGPBggX47LPPsHz5cnh7eyMlJQUpKSmaNbpyc3Px0Ucf4ciRI0hMTERcXBxeeeUVNGzYEKGhoQCAZs2aoXfv3pgwYQKOHTuGw4cPIzw8HCNGjCi30iER6c9MIkafliWjydtP39Vsf1hYjF/iEwEAk7o00Pu6rZcb1IG7nRzZBUXYe6nsZSkqgyAIuJdTUGXHIyIiotrHqMnX8OHDsXDhQsyYMQP+/v44deoUYmJiNEU4kpKSkJz8eEHVpUuXorCwEEOHDoW7u7vmZ+HChQAAiUSCM2fOYODAgWjcuDHefPNNBAQE4ODBg1rXa61duxZNmzZFjx490LdvX3Tq1Ak//vhj1Z48kQlQTz2MOZeCwqKSqYdbjt/Cg3wlvBwt0LuF/lN9JWIRXn2pZPRr24nbhgv2GTLzCzHhl+NoNy8O38RdqZJjEhERUe1j9IIb4eHhCA8PL/O+/fv3a91OTEx8ZlsWFhb4448/nntMR0dHrFu3TtcQiaiC2no7wsVGhns5Chy8koauTVyw7OANAMBbnRrATFKx738Gv+SJpfuvYX9CGtJzFXCyLl0Mx1D+SczAlPUncTerZNTru31XMeglT3jVwnXGiIiIqHIZdeSLiGo3iViEfn4l11tuP30XMedSkJSRDwdLc7wWWLfC7TZytYFfXTsUqQStKY2GpFIJWLLvKob/eAR3swrg42SF1nXtUFikwsLdCZVyTCIiIqrdmHwRUaVSTz2MvZCK7/eXVB0d094bltIXG3gfrJl6aPiqh2k5CoxbcQz//iMBxSoBr/p7YPt7nTBvUCuIRMCvp+7i1K1Mgx+XiIiIajcmX0RUqV7ysoenvQXyCotx/m42ZGZijGtf/4XbHdDaA2ZiEc7eycLl1BwDRFri0JV09Pn6IA5eSYfcXIwvh/rhq+H+sJaZoaWnHQa/VDJi98XOixAEwWDHJSIiotqPyRcRVSqRSIT+rd01t4cG1EUdA1yjVcdahq5NXAAYZvSrqFiFhX8kYMzyo0jPVaCJqw22h3fCsEAvrYqMH4Y2htxcjGOJGfjjfOozWiQiIiLSxuSLiCrdAL+SqYciETAhWPdFlZ9nyKM1v/538g6KVRUfhUrOeoiRy47gu31XIQjAyHZe+N+7HdHI1abUvu52FppzmL/roqaKIxEREdHzMPkiokrX0tMOXwxqha9HvARvJyuDtdu9mQts5WZIyS5A/LX7z39AGeIupqLP1wfxd+IDWMvM8M3IlxA12A8WUkm5j5nUxRdO1jIk3s/H2qM3Kxo+ERERmRgmX0RUJUYF1cPA1oZdyFxmJtEU9NB3za+HhcWYu+MC3lz1DzLzlWjlaYcd73XSKUZrmRkiejYGAHwddwVZ+Ur9gyciIiKTw+SLiGq0wW1KCmDsOpeCPEVRufsJgoALd7Pxw5/XMPqnI2g9azd+OlSy5lhYR29smdxer1G5YYF10djVGpn5Six5VMWRiIiI6FmMvsgyEdGLaFPPHt51LJF4Px8x51IwJODx+mFpOQocupqGg5fTceBKOtJzFVqPretggRn9m6NXCze9j2smESOybzOErfgbKw8nYszL9bnwMhERET0Tky8iqtFEIhEGt6mLRbGXsfn4LbjZyXHgSknCdSE5W2tfC3MJ2vvWQedGTghu7IwGTlZalQz11bWxM4IbOeHglXTMj7mEJaPavOjpEBERUS3G5IuIarxBL3liUexlHLmegSPXj2rd19LTFsGNnNG5kTPa1LeHzKz8Qhr6EolEiOzTDIeuHsTOM8l4o+MDBNR3MFj7REREVLsw+SKiGs/L0RIhzVyw5+I9uNjISpKtxk7o1NDJIGuKPUtzD1u8FlAXm/65jXk7L2Dr5A4vNJpGREREtReTLyKqFb4b1QZpOQrUdbCo8uTng15NsP10Mk4kZWLXuRT0beX+/AcRERGRyWG1QyKqFeTmEng5Whpl1MnVVo6JndULL1+Coqi4ymMgIiKi6o/JFxGRAUzs3ADONjIkZeRjdTwXXiYiIqLSmHwRERmAlcwMH/YqWXj5271XkZlfaOSIiIiIqLph8kVEZCBDA7zQ1M0GWQ+V+CaOCy8TERGRNiZfREQGIhGL8H99mwEAVh9JRGJ6npEjIiIiouqEyRcRkQF1buyMLo2doSwWsCDmkrHDISIiomqEyRcRkYH9X99mEIuAXedS8E9ihrHDISIiomqCyRcRkYE1cbPB8LZeAIAZv56Hslhl5IiIiIioOmDyRURUCSJ6NoG9pTkuJGdj6f5rxg6HiIiIqgEmX0RElcDZRoZZA1sAAL7dewUXk7ONHBEREREZG5MvIqJKMrC1B3o1d4WyWMCHm09z+iEREZGJY/JFRFRJRCIR5g5qCTsLc5y/m41oTj8kIiIyaUy+iIgqkYuNXDP98Ju9V3AphdMPiYiITBWTLyKiSvaKvwdCmhl/+qFKJaCIUx+JiIiMxszYARAR1XYikQhfDGqJvxMzcO5ONn48cB3vdmtYpTGk5yrwxsq/cTE5G83cbdG6rj38vezhX88ePnWsIBaLqjQeIiIiU8Tki4ioCrjYyvH5wOaYuvE0Fu+5jJBmrmjiZlMlx76b+RCv/3wU19PyAABnbmfhzO0srD5yEwBgKzdDa6+SZKx13ZKEzMlaViWxERERmRImX0REVeRVf0/sPJOMPRfv4aMtp7FtcgeYSSp39ndieh5G/3QUdzIfwsNOjsUjXkJqdgFO38rEqVuZOHsnC9kFRTh4JR0Hr6RrHlfXwQKtvewR3NAJrwV6QcKRMSIiohfG5IuIqIqIRCLMG9QKx278iTO3s/Djwet4p2vlTT+8lJKNMT8fQ1qOAj5OVljzVhA87S0AAANaewAAlMUqJKTk4NSjZOz0rUxcTcvF7QcPcfvBQ+w8k4wb9/MQ2adZpcVJRERkKph8ERFVIVdbOWYOaIEPNp/G4tgr6NnMFY1cDT/98NStTIxbfgxZD5Vo6maD1W8Gwdmm9FRCc4kYLT3t0NLTDq+/XB8AkF2gxLnbWTh4NR1L91/DD39eh39de/Rp5W7wOImIiEwJqx0SEVWxwW080b2pCwqLVfhw82mDVyCMv3Yfo5cdQdZDJV6qZ4+NE9uXmXiVx1Zujg4NnTCtd1NM7NwAAPDh5tO4ei/HoHESERGZGiZfRERVrKT6YSvYyM1w+nYWlh28YbC24y6mYtyKY8grLEbHhnWw5s0g2FmaV7i9j0Ob4OUGjsgrLMak1ceRqygyWKxERESmhskXEZERuNmVTD8EgK9iL+NK6ouPKv12+i4mrT6OwiIVQpq54udxbWEle7HZ5WYSMb4b1QZutnJcS8vDR5tPQxCEF46ViIjIFDH5IiIykiFtPNGtiXPJ9MMtZ15o+uH6Y0l4f8NJFKkEvOrvgaWvt4HcXGKQOJ2sZfj+9TYwl4iw61wKfjxw3SDtEhERmRomX0RERiISiRA12K9k+uGtTKyIv1mhdpYduI7IbWchCMDooHpYNMwf5gYuYd+mnoNmpG5BzCX8dTX9OY8gIiKipzH5IiIyIjc7OT7r3xwAsDjuGm7lAvmFRVCpnj+1TxAELNqdgHm/XwQATOrSAHNfbQlxJa3JNTqoHoa0qQuVAISvP4m7mQ8r5ThENd3p21nIKjR2FERUHbHUPBGRkb0WUBc7zyTjz8tpWHjWDAvP7gUAyM3FsDCXlPxIH/2YS2AhNYOFuRj5hcWahZE/Cm2Cd7tV3pphgHqdspa4lJKN83ezMXntCWya9DJkZoaZ3khUGxy4nIaxy49BJpHA1jcFr7bxMnZIRFSNcOSLiMjIRCIR5g9phXqOFlrbC5QqPMhX4m5WAa6l5eHcnWz8nfgABy6n4Y/zqZrEa/YrLSo98VKTm0sQ/XoA7CzMcfpWJmZtv1AlxyWqKX46VFK9VFEswr82ncEn/z2LAmWxkaMiouqCI19ERNWAu50F4qYGY8fO39G9Zy8oBTEeFhajQFmMh8pi5BeW/FtQ+Pj3h4XF8K9nj7bejlUaq5ejJb4e4Y+wlX9j3dEk+HvZY1ggv90nunovFwcup0EkAjq6qHAoVYy1R5NwMikTS0a3gY+TlbFDJCIjY/JFRFSNiEWApdQM5uYVX5urKnRt4oKpIY2xKPYyPv3fOTRzs0WrunbGDovIqH6JTwQA9GjijAEOyXgjNBAfbj2HC8nZGPDtIUQNboUBrT2MGyQRGRWnHRIRUYWEd2uIkGYuKCxS4e01x/EgjxUGyHRlFyix5fhtAMDY9vUAAMGNnPD7lGC083ZErqII760/iU//x2mIRKbM6MnXkiVL4O3tDblcjqCgIBw7dqzcfZctW4bg4GA4ODjAwcEBISEhWvsrlUpMmzYNrVq1gpWVFTw8PDB27FjcvXtXqx1vb2+IRCKtn/nz51faORIR1UZisQj/GeYP7zqWuJP5EFM2nESxDlUaiWqjTX/fQn5hMRq7WuNln8dTgd3s5Fg3IQjvdvMFAKw5koTB3/+FxPQ8Y4VKREZk1ORr48aNiIiIwMyZM3HixAm0bt0aoaGhuHfvXpn779+/HyNHjsS+ffsQHx8PLy8v9OrVC3fu3AEA5Ofn48SJE/jss89w4sQJbNu2DQkJCRg4cGCptmbPno3k5GTNz3vvvVep50pEVBvZWZgjekwALMwlOHglHV/FXjZ2SERVrlgl4JdH6/SN7+ADkUh7uQcziRgfhTbFyrC2cLSS4kJyNvp/ewg7ztwtqzkiqsWMes3XokWLMGHCBISFhQEAoqOjsXPnTixfvhzTp08vtf/atWu1bv/000/YunUr4uLiMHbsWNjZ2SE2NlZrn++++w7t2rVDUlIS6tWrp9luY2MDNzc3nWNVKBRQKBSa29nZ2QBKRtuUSqXO7VQG9fGNHQdVHvaxaaip/exbxwLzXm2OiM1n8d2+q9h9PgUNXazg62wFX2dr+DpbwaeOJWTmLElfU/uYni3u0j0kZeTDzsIM/Vo6l9vPHRs44Nd3XsbUTWfwz81MhK87ifir6Yjs3ZjvjxqG72XToE8/6/paEAmCYJQ5IoWFhbC0tMSWLVvw6quvaraPGzcOmZmZ+PXXX5/bRk5ODlxcXLB582b079+/zH327NmDXr16ITMzE7a2tgBKph0WFBRAqVSiXr16GDVqFKZOnQozs/Jz0c8//xyzZs0qtX3dunWwtLR8bqxERLXd9pti7Llb9oQKEQTUkQNuFgJcLQBXC0Hzu5yln6iGW3JBjMtZYnT3UOGV+qrn7l8sALtuiRF7p+T9UtdKwMB6KliaCTAXA+ZiQCoBpI9+r6R104nIgPLz8zFq1ChkZWVpco6yGO2/vPT0dBQXF8PV1VVru6urKy5duqRTG9OmTYOHhwdCQkLKvL+goADTpk3DyJEjtZ6EKVOmoE2bNnB0dMRff/2FyMhIJCcnY9GiReUeKzIyEhEREZrb2dnZmmmPz3qCq4JSqURsbCx69uxZ7SukUcWwj01DTe/nvgDuZD7ElXu5uHovD9fS8nAtLRfX0vKQXVCE9AIgvUCEcw+0H+dsLUX9OpbwrmMF7zqWj363RH1HS1hIa9doQE3vYyrtyr1cXI7/C2IRMGNkF3jaW+jUzwMAHLiSjg+3nMXtPCW+v1j+a91cIoKFuQRycwnk5mLIzSSQSx/9ay6G7NG/cnMJ5GZiyB79KzeXQPZofyuZBA6WUtSxksLRyhyOVlKYS4x+6X+Nxfey8QmCgBvp+XCwMoeDpbRSjqFPP6tnxT1Pjf2+cf78+diwYQP2798PuVxe6n6lUolhw4ZBEAQsXbpU674nkyg/Pz9IpVJMmjQJUVFRkMlkZR5PJpOVeZ+5uXm1edNVp1iocrCPTUNN7mdvZ3N4O9uiZ4vH2wRBQFqOAlfv5eJqWm7Jv/dyceVeLtJyFEjLLURabiH+uZlZqj03Wzl8nKzg7WQFHydL+DhZo1NDpxqflNXkPiZta4+VVDjs1dwN3s7aX8Y+r597NHfH7+/bY9ZvF5CQmqNZ1+9hYTEURY9H0JTFApTFRcguKDJo7LZyMzhZy+BoJUUdaykcrWSo8+j3eo6W6NrEBRIOuz0T38tVp0BZjNO3MnE86QFO3HyA4zcf4EG+ElGDW2Fku3rPb+AF6NLPur4OjJZ8OTk5QSKRIDU1VWt7amrqc6/FWrhwIebPn489e/bAz8+v1P3qxOvmzZvYu3fvc0emgoKCUFRUhMTERDRp0kT/kyEionKJRCK42MrhYitHh4ZOWvdlPVQiMT0PiffzcCM9D4npebhxPx+J6XnIeqhESnYBUrILEH/9vuYx/Vq5Y8noNlV9GkSlZOUrse1ESdGv8R29K9SGu50FoscElNquUglQFKkeJ2TKkkXXC5TFeFhYsr2gqBgFSpVme8lPWfepkKv4//buPC6qev0D+GeG2dgHUDZZzQXR2ESI1DYx67ZoaWnZ1fKm15JfmfdWVtclWzTvvd2yTCsztSzLvJp6cyEUTUOUxRXEDQSBYYdhnRlmzu8PcJLUVIQ5zPB5v17zmplzzsx5hocZ5uF7zvM1oLJeb76YBEDb1FLQnbtK58XhfXvgoycioe6kUQWiP1KibUJ6a5GVdr4KJwpr0Py7jrpKmRSVVjbNiWjFl0KhwODBg5GUlGQ+58tkMiEpKQkJCQlXfdzixYvxzjvvYMeOHYiOjr5s/cXC6/Tp09i9ezc8PDyuGcvhw4chlUrh6enZ7tdDREQ3ztVejnB/NcL91Zetq6rXI7eipSDLK69HtqYWiVkl2HemHIIgXNZRjsjSvk8rQKPBiBBvZ8Re0l6+I0ilEtgr7GCvsINbhz5zS3fGmkYDKut1KK9rKcYq6nSoqNejok6Pinoddp8swy+nyzF66X589udo9Pd27uAoiNrKLa/HvtNlSGstuC5UNV62jaezEtFBbogKcEN0kDtCfVygkFnX4bOiHnY4a9YsTJ48GdHR0YiJicEHH3yA+vp6c/fDSZMmoVevXli4cCEA4L333sPcuXPxzTffICgoCBqNBgDg5OQEJycnGAwGjBs3DhkZGdi6dSuMRqN5G3d3dygUCqSkpCA1NRV33303nJ2dkZKSgpdeeglPPfUU3Nw6+uONiIjay81RATdHBaICWj6bDUYTBs3bgZpGA3LL69G7p5PIEVJ3ZjQJWJ2SBwB4ZmiQVf0zwE4qgbujAu6OCvS5yv+ds4q0mPZVGs5XNOCRT/bj/cfDcd8gH8sGSjbNZBJwtLAGO09osDOrBGdK69qsl0qAEG8XDA50Mxdcfm72VvVeuxJRi6/x48ejrKwMc+fOhUajQUREBLZv325uwpGfnw+p9LdqdtmyZdDr9Rg3blyb55k3bx7mz5+PwsJCbN68GQAQERHRZpvdu3fjrrvuglKpxLp16zB//nzodDoEBwfjpZdeanMeGBERdT1yOynC/FxxKK8KmfnVLL5IVEnZJbhQ1Qi1gxyjI3qJHU6HC/V1weaEYUj4JgO/nq3A9K8z8H/39MFL8f0g5Xlg1E76ZhNSzlVg5wkNfs4uQYn2t2mcZFIJYnu7IybIA4MD3RDu7wpnle2dTyd6w42EhISrHmaYnJzc5n5eXt4fPldQUBCu1Tk/KioKBw4cuJEQiYioi4gMcGspvgqqMHawn9jhUDe26tc8AMATMQFQ2egcXe6OCqyZEoOF207ii325+GjXGWQVafGfCRFwscEvxdQ5tE0GJOeUYecJDfbklKFW91vjGCelDHf274l7Q71wV39PuNrb/u+V6MUXERHR9YpsPTcsM79a1Dioe8vR1OLXsxWwk0rw1G2BYofTqWR2Usx5MBQDfV0w+7/HkHSyFGNazwPr48nR5+7EYDShsl6PRv0lTWAuud2oN17SsdOERoMRWcVapJwth8H42+BIT2clRoZ64d5QL8Td4gGlzDb/eXE1LL6IiMhqRLae/3VSU4sGfTMcFPwzRpZ3cdRr1EAv9FLbixuMhTwa5Yc+nk7461fpOFdWjzFL9+OD8RGID/W69oPJqpVom7AmJQ9rU/NR3WBo13Pc0tMR9w70xshQL0T4qbv1oav8q0VERFbD21UFH1cVimuacOxCDWJ7X7ujLVFHqm7QY2Nmy9xeT98eLHI0lhXmp8bmhGGYsTYDB/Mq8eyaNMwa2Q8Jd/fp1l+mbdXxwhqs3JeLLUeLzCNXUgngoJBBJbeDvUIKe7mdeQJwe4Xdb/dbb3u5KHFPiBdHSS/B4ouIiKxKZIAaxcc0yCyoZvFFFvfdoQI0GUwI9XHBkKDu1yW5p7MSXz8bi7f/l4U1KefxfuIpnCiqwb8fj4CTkl8rrZ3JJGDXyVKs2HcOB85VmpfHBLljyrBgjAz14sTbN4nvEiIisiqR/m746ZgGmflVYodC3Uyz0YQ1KecBWF97+Y6kkEmxYPQgDPR1wZxNJ7DjRAnOLd2PlU8Pgb+7g9jhUTs06JuxIf0CVu7PQ27rpNt2UgkeuNUHfxkWfMW5GKl9WHwREZFViQxQAwAy8qs52TJZ1M/ZJSisboS7owIPhfuKHY7oxg8JQF8vZ0z/Kh2nS+vw/NoMbHjudqub9LY709Q0YXVKHr5JzUdNY8v5XM4qGZ6MDcDkuCD4dpNzGi2JxRcREVmVQb1cIZNKUFarQ1FNU7dpeEDi+3J/HgDgSRtuL3+jogLcsHHGUDyw5BccK6zBv3bm4PU/DRA7LLqGYxdq8MW+c9h6tBjNppbzuQI9HDBlaDDGDfaDIw8h7TT8yRIRkVVRye0Q6uuCoxdqkJlfxeKLLCKrSIvU3Mpu0V7+RvVS2+O9sWH461fp+GzvOQzr0wN39Ospdlj0O0aTgMQsDb7Yl4tDeb8dth0T7I6/DAtG/ACez2UJLL6IiMjqRPqrW4uvajwYxsO/qPOtbm0vf/8gb3i7qsQNpgsaNdAbE2MDsDY1H7O+P4LtM4ejh5NS7LC6BG2TAf9Nv4DDBdV4/u4+6OflbPH9f3+oAKt+zcOFqkYAgEwqwYNhPpgyLBhhfmqLxtPdsfgiIiKrExnghtUp59l0gyyisl6PTYcLAbQ02qArm/NgKA7lVeJUSR1eXn8EK58e0q3Pycwq0uLr1PPYlFmIBr0RAJCYVYIPJkRipAXmRztfUY8v9+dhfVoB6lv37+Ygx8TYQPw5LhBeLvwnghhYfBERkdW52HTjeJEWumYjlDKef0OdZ92hfOiaTbi1lyuiArpfe/nrpZLbYckTkXj44/3YnVOGL/fnYcqw7jUXmq7ZiO3HNfgq5TzSzv/2z6F+Xk5wVMqQmV+NaV+l4W8j+2HG3X06vDgVBAEHzlVi5f5c/JxdAqHldC709XTClGHBGBPRC/YKfl6KicUXERFZnQB3B7g7KlBZr0d2cS0i2AaZOkmz0YSvWtvLP317920vf71CvF3wjwcGYO6PJ7Bo20nE9nbHQF9XscPqdIXVjfgm9Ty+O1SA8jo9gJZD+0YN8sak2wIRE+yOZpOAt7a2zI/2r52nkK2pxT/HhcFBcfNfx5uNJvx4uAhf7MtFVrHWvPyu/j0xZWgwhvftwd/dLoLFFxERWR2JRIJIfzWSTpYiM7+KxRd1ijpdM97emoXimib0cFLgwXAfsUOyCn++LRB7T5Xj5+wSvPBtJrb837AOKTC6GpMA/HKmHN8eKkRSdglamwbCy0WJJ2MC8USMPzwvObRPbifBgtGDMMDHBXN/PI7/HS1Gblk9Pp8c3e7GQYIgYMcJDRbvyMG5spb5uVRyKcZG+eGZocHo4+l006+TOpbtvROIiKhbiAy4WHxV45mhYkdDtmb/mXK88sNRFFa3NCh4Mb4fD2+9ThKJBIvHheH+D/fibFk9FmzJwqKxYWKH1W61TQaUaJtQXNMETeulqLoBPx+zQ9mBDPN2t9/igUlxgRgxwAtyu6vPdfZETAD6eDph+lfpyCrW4uGP9mHZU4MRE+x+Q3EdzK3Ewm3ZyMyvBgC4Oyrw7PBgPBkTALWDol2vlTofiy8iIrJKka3n3mQWsOkGdZzaJgMWbjuJb1LzAQB+bvZYPDYMt/fpIXJk1sXdUYH/PB6BiV+kYt2hAtzRryf+dGvXHTk8U1qHlHMVKKlpKbJaiq1GlGh1qNM1X+VREjgpZRg32A9P3RaAPp7X38VwSJA7Nv/fMExbk4YTRVpMXHEAbz48CE/GBlzzsTmaWizefhJJJ0sBAPZyOzw7PBjT7ugNZ5X8umMgcbD4IiIiqxTm5wqJBCiobERZrQ49ndnWmm7OL6fLMHvDMfNo16S4QLx6XwgnnG2n2/v0wPQ7b8Gy5LOYveEowv3VXW5eviaDER8mncZne8/BePG4wStwVsng46qCt6s9vF2U8HRSoPrCafx9wj1QO7XvNfVS2+OH6bfj7z8cwf+OFuP1jceQXazF3IdCrzhyVlTdiP8knsKGjAswCYCdVIIJQ/zx4oi+bQ5vpK6NnyZERGSVnFVy9PN0Rk5JLQ4XVFukdTPZptomA979KRvfHiwAAPi722Px2HDE3eIhcmTWb9bIfvj1bAWOFFRj5rpMfDv1Nsj+4JA8S0o9V4HZ/z2G3PKWc6Vig93Rz8sZ3q4qeLuo4OOqglfr7d8X4AaDAT/9dOqmC3N7hR0+fiISoT4u+NfOHHx14DxOl9bik4mD4e7YcuhgTYMBnySfwZe/5kHfbALQMt/c30f1xy09eU6XtWHxRUREVisyQI2cklpk5lex+KJ22XOqDK9tOIqimiYALR0NXx7Vn6NdHURuJ8WSCRF4YMk+HMqrwse7z2BmfD9RY9I2GbDokkNLPZ2VeGvMIIwa6C1KPBKJBDPu7oP+Xs54cV0mDpyrxMMf78PHT0Yh9VwFlu4+A21Ty6GPMcHumH1/CKc8sGL8ZCEiIqsVGaDGukMF5hPOybo1G03Ye7oMZ0rr4KKSw9W+5eLSeq12kMNJKeuQltnaJgPe2ZqN79JaRrsC3B2weFwYbuvN0a6OFujhiLfGDMRL3x3BkqTTGNqnB4YE3VhziY6SmFWCOZuOQ6NtKbafiAnA7PtD4Gov/rlS8aFe2DhjKKauScP5igaMWbrfvK6/lzNm3x+Cu/r3ZMt4K8fii4iIrNbFphtHLlTDaBJgJ+WXEmuUVaTFhowL+PFwoXmOpKuxk0rgopK1FGYOipbiTCWDk1IGx4sXhR0clZcsa73fcrFDdrEWb2w8juJLRrteua+/TbZD7yoeifTDL6fK8d/MQsxcdxg/vTAcrg6WK3jK63SYv/kEth4tBgAEeThg4aNhXe7Q0n5ezvhxxlAkfJOJfWfK4euqwqx7++ORyF78fLMR/JQhIiKr1aenE5yVMtTqmnGqpBYDfFzEDomuU3mdDpsyC7EhoxDZl0wK6+GoQNwtHmjUG1HTaEB1owE1rRd9swlGk4CqBgOqGgxARcNNxRDk4YDF48JvuMU3tc+CMYOQnl+F8xUNeH3jMXz8ZGSnj+IIgoD/ZhTirf9lobrBADupBM8OD8ZL8f2gknfNqQPUDgqsnhKDoxeqMcDHpcvGSe3D4ouIiKyWVCpBuL8a+86UIzO/msVXF6drNmJXdil+SL+A5FNl5u5yCjspRgzwxNgoP9zZv+dV50hqMhhR3fBbMVbTaEB1gx7apmY06JpRp29Gva4ZDToj6nTNqNc3o15nRL2uZXm9vuW2VCrBU7GBeHlUf9gr+MXWUpyUMiyZEImxy37F/44Vo+xTHTycFHBWyeCskre5drnCMielDEqZ9LoLtoLKBryx6Tj2nioDAIT6uGDxuDAM6uXamS+zQ9hJJeaRfbItLL6IiMiqRQZcLL6qrmuOHLIsQRBw5EINNqRfwOYjRahpNJjXhfurMS6qFx4M84Wb47UnhVXJ7eDtagdv1/a31RYEwdymmywv3F+Nl0f1x8JtJ3Ewr/KGHy+RAA5yOzgoZXBQ2MFBcfHars19qUSCDRkX0KA3QiGTYmZ8X0wd3vsPJz8msgQWX0REZNUiA9QAgMyCalHjoMtlFWkx+79HcfRCjXmZl4sSj0T6YdzgXjc0KW1HkUgksGPdJaq/3nkLhgS7I6+8HnW6ZtQ2NUPbZEBtU3PrxfC762bzRMeCgJYRTL3xuvYVE+yORY/eit5syU5dBIsvIiKyahH+LYfmnCmtQ02joUt0Levu9M0mLN19Bkt3n0GzSYBKLsWogd4YG+WHoX16cNSJEBXgdkPt0o0mAY0GIxp0zWjQG1svV7rdct2oN2KAjwseDveFlL9v1IWw+CIiIqvm7qhAkIcD8ioacKSgGnf06yl2SN3a8cIa/H39EZzU1AIARg30wltjBsHTuf2HChLZSSVwau1gSWTN+BtMRERWLzLADXkVDcjMZ/ElFl2zER8lncGyPWdhNAlwd1TgzYcH4sEwH85LRETUisUXERFZvcgANTZmFiKzoErsULqlwwXVeOWHIzhVUgcAeCDMBwseHggPJ6XIkRERdS0svoiIyOpFtp73lZlfDUEQONJiIU0GI/7z8yl8vvccTALQw0mBt0YPwv23+ogdGhFRl8Tii4iIrF6IjzOUMilqGg3ILa9nZzMLSD9fhZd/OIJzZfUAgNERvpj/0MDrahlPRNRdsfgiIiKrJ7eTIszPFYfyqpCZX83iqxM16o34984cfLE/F4IA9HRW4t1HbsXIUC+xQyMi6vJYfBERkU2IDHBrKb4KqjB2sJ/Y4dgMXbMRJ4q0yMyvRkZ+FQ7mVqKsVgcAGBvlh7kPhsLVge39iYiuB4svIiKyCZH+agAt531R+wiCgKKaJmScbxlBzCyowolCLfRGU5vtvF1UWPjorbg7xFOkSImIrBOLLyIisgmRrRO2ntTUokHfDAcF/8Rdj6wiLX45XWYe2SptHdW6lIejApEBakQGuCEyQI2oADeo5HYiREtEZN34l4mIiGyCt6sKPq4qFNc04diFGsT29hA7pC5v18kSPLs6DSbht2UyqQShvi6I9G8ptqIC3ODvbs8OkkREHYDFFxER2YzIADWKj2mQWVDN4usadM1GvLklCyYBiAlyR3yoJyID3DDI1xX2Co5qERF1BhZfRERkMyL93fDTMQ0y89s32bIgCDAYBShk0g6OrOtZuS8P5ysa4OmsxMpnhsBJya8ERESdjZ+0RERkMyID1ACAjHZMtlyibcKUVYdwokgLJ6UMbo5yuDso4Oao+O3aUQE3h5brloscvdQOVjdSVKptwse7TgMAXr0vhIUXEZGF8NOWiIhsxqBerpBJJSir1aGopgm91PbX9biaRgMmrzyIk5paAECdrhl1umYUVDZe87Eejgp8/WwsBvi43FTslvTe9hzU642I8FfjkcheYodDRNRtsPgiIiKboZLbYYCPC44V1iAzv+q6iq8mgxFTV6fhpKYWPZ2VWDMlBiq5HSrr9aiq16OyofW69VLVcPHagFJtEyrq9fjrV+nYnDAUageFBV7lzcnMr8KGjAsAgHkPhUIqZSMNIiJLYfFFREQ2JTJA3Vp8VePBMN8/3LbZaELCN5k4mFcJZ6UMq5+JMY9gBfdwvOa+qhv0eOjjfcivbMAL6w7jy6eHwK4LFzMmk4A3t2QBaJkg+WJ7fiIisgzbP6OYiIi6lYvnfV2r6YYgCHh94zH8nF0ChUyKFZOjEep7Y4cOqh0U+PSpaKjkUuw9VYZ/78xpb9gWselwIQ4XVMNRYYdX7+svdjhERN2O6MXX0qVLERQUBJVKhdjYWBw8ePCq237++ecYPnw43Nzc4Obmhvj4+Mu2FwQBc+fOhY+PD+zt7REfH4/Tp0+32aayshITJ06Ei4sL1Go1/vKXv6Curq5TXh8REVlWpH/LaM7xIi10zcarbvfPHTn4Pu0CpBLgoyci292aPtTXBe+NDQMAfJJ8Fj8dK27X83S2Ol0zFm07CQBIuKcvPF1UIkdERNT9iFp8fffdd5g1axbmzZuHjIwMhIeHY9SoUSgtLb3i9snJyXjiiSewe/dupKSkwN/fH/feey8KCwvN2yxevBhLlizB8uXLkZqaCkdHR4waNQpNTU3mbSZOnIgTJ04gMTERW7duxd69ezFt2rROf71ERNT5Aj0c4OYgh77ZhOzi2itus3JfLj5JPgsAePeRWzFqoPdN7XN0RC9MHR4MAPj7+iM4VXLl/Yrpk91nUFqrQ6CHA6YMCxI7HCKibknU4uv999/H1KlT8cwzzyA0NBTLly+Hg4MDVq5cecXt165di+effx4REREICQnBihUrYDKZkJSUBKBl1OuDDz7AP/7xD4wePRphYWFYs2YNioqKsGnTJgBAdnY2tm/fjhUrViA2NhbDhg3DRx99hHXr1qGoqMhSL52IiDqJRCIxn8t0pUMPN2UWYsHWlvOeXh7VHxNiAjpkv6/eF4Lbb/FAg96IaWvSUNNo6JDn7QjnK+qx4pdcAMAbfxoApcy6WuMTEdkK0Rpu6PV6pKen47XXXjMvk0qliI+PR0pKynU9R0NDAwwGA9zd3QEAubm50Gg0iI+PN2/j6uqK2NhYpKSkYMKECUhJSYFarUZ0dLR5m/j4eEilUqSmpuKRRx654r50Oh10Op35vlarBQAYDAYYDOL+gb24f7HjoM7DHHcPzHPHCevlgl0nS5GeV4mnYvzMy/eeLsff1x8BAEy6LQBThwZ06M/7/cduxaPLDiCvogEvfpuBTydGtukmKFaO396aBb3RhKG3eOCuvu78HetkfC/bPua4e7iRPF/v74JoxVd5eTmMRiO8vLzaLPfy8sLJkyev6zleffVV+Pr6mostjUZjfo7fP+fFdRqNBp6enm3Wy2QyuLu7m7e5koULF+LNN9+8bPnOnTvh4OBwXfF2tsTERLFDoE7GHHcPzPPN01dLANgh5VQxfvqppa16Xi2wNMsOzSYJojxMiMQ5bNt2rsP3/WQA8OFxOySfKscLn+/An/xNl21jyRznVEuQmG0HKQTc4VSCbdu2WWzf3R3fy7aPOe4erifPDQ0N1/VcVttqftGiRVi3bh2Sk5OhUnX+ScOvvfYaZs2aZb6v1WrN55y5uIg7sabBYEBiYiJGjhwJuVwuaizUOZjj7oF57jjDmwxY9u5uVOgkiLljBGoamzF/xUHoTQYM6+OBTydGQiHrvCPvvfoV4eUNx7HjghRj7ohC/ICWf/pZOsfNRhM+WpoCoB5P3RaIKQ+EdPo+ie/l7oA57h5uJM8Xj4q7FtGKrx49esDOzg4lJSVtlpeUlMDb+49PfP7Xv/6FRYsW4eeff0ZYWJh5+cXHlZSUwMfHp81zRkREmLf5fUOP5uZmVFZW/uF+lUollErlZcvlcnmXedN1pVioczDH3QPzfPPc5XL09XTCqZI6/HyyHMuSz6KqwYBwfzU+/XM0HJWd++fvsSGBOFFch1W/5uHlDcexacZQ9PF0Mq+3VI7XHszFmbJ6uDnI8bd7Q/h7ZWF8L9s+5rh7uJ48X+/vgWgNNxQKBQYPHmxulgHA3DwjLi7uqo9bvHgx3nrrLWzfvr3NeVsAEBwcDG9v7zbPqdVqkZqaan7OuLg4VFdXIz093bzNrl27YDKZEBsb21Evj4iIRHax5fzczSdQVNOE3j0d8eXTQzq98LrojQcGICbYHXW6Zkz7Kg21TZY9N6SyXo/3E08BAP52b3+4OvALIhGR2ETtdjhr1ix8/vnnWL16NbKzs/Hcc8+hvr4ezzzzDABg0qRJbRpyvPfee5gzZw5WrlyJoKAgaDQaaDQa8xxdEokEM2fOxNtvv43Nmzfj2LFjmDRpEnx9fTFmzBgAwIABA3Dfffdh6tSpOHjwIPbv34+EhARMmDABvr6+Fv8ZEBFR57g42bIgAN4uKqyZEgN3R4XF9i+3k2Lpk1HwdlHhXFk9Zn1/BCaTYLH9/yfxFLRNzQjxdsYTHdTRkYiIbo6o53yNHz8eZWVlmDt3LjQaDSIiIrB9+3Zzw4z8/HxIpb/Vh8uWLYNer8e4cePaPM+8efMwf/58AMArr7yC+vp6TJs2DdXV1Rg2bBi2b9/e5rywtWvXIiEhASNGjIBUKsXYsWOxZMmSzn/BRERkMbf19oBUAjir5Fjzlxj4uVm+OVJPZyWW/3kwHl+egsSsEizbm4tgC+w3u1iLtannAQDzHhoIu0s6LhIRkXhEb7iRkJCAhISEK65LTk5ucz8vL++azyeRSLBgwQIsWLDgqtu4u7vjm2++uZEwiYjIygT1cMTG54eip7MSvmp70eKI8Ffj7TGD8MqGo/hw1xlM7S/Bnzpxf4IgYMGWLJgE4E+3eiPuFo9O3BsREd0I0YsvIiKizhLurxY7BADA40P8cbSwGl8fyMeqU1Ic/CwVagcFXO3lcLWXw0Ul/+22+VpmXuaokLWZL+yPbD+uQcq5CihlUrx2/4BOfmVERHQjWHwRERFZwNwHByJHU4tDeVU4XFBzQ4+VSgAnpQzOqpbizFklg4tKDheVrM19Z5UMH+8+AwD46x294e/eNeahJCKiFiy+iIiILEAhk2LN04PxyfrtCAkbjHq9gJpGA2oaDdA2Gcy3zcsam6FtNEBvNMEkANqmZmibmlFY3XjNffm4qjD9rlss8KqIiOhGsPgiIiKyEJmdFH1cgHtDva5rThhBENBkMKG2ydBafBlQ29RSlNU2Nbcub7tM12zC83fdAgcF/8QTEXU1/GQmIiLqoiQSCewVdrBX2MHTRexoiIjoZok6zxcREREREVF3weKLiIiIiIjIAlh8ERERERERWQCLLyIiIiIiIgtg8UVERERERGQBLL6IiIiIiIgsgMUXERERERGRBbD4IiIiIiIisgAWX0RERERERBbA4ouIiIiIiMgCWHwRERERERFZAIsvIiIiIiIiC2DxRUREREREZAEsvoiIiIiIiCyAxRcREREREZEFsPgiIiIiIiKyABZfREREREREFsDii4iIiIiIyAJkYgdgrQRBAABotVqRIwEMBgMaGhqg1Wohl8vFDoc6AXPcPTDPto857h6YZ9vHHHcPN5LnizXBxRrhalh8tVNtbS0AwN/fX+RIiIiIiIioK6itrYWrq+tV10uEa5VndEUmkwlFRUVwdnaGRCIRNRatVgt/f38UFBTAxcVF1FioczDH3QPzbPuY4+6BebZ9zHH3cCN5FgQBtbW18PX1hVR69TO7OPLVTlKpFH5+fmKH0YaLiws/AGwcc9w9MM+2jznuHphn28ccdw/Xm+c/GvG6iA03iIiIiIiILIDFFxERERERkQWw+LIBSqUS8+bNg1KpFDsU6iTMcffAPNs+5rh7YJ5tH3PcPXRGntlwg4iIiIiIyAI48kVERERERGQBLL6IiIiIiIgsgMUXERERERGRBbD4IiIiIiIisgAWX1Zu6dKlCAoKgkqlQmxsLA4ePCh2SHQT9u7di4ceegi+vr6QSCTYtGlTm/WCIGDu3Lnw8fGBvb094uPjcfr0aXGCpXZZuHAhhgwZAmdnZ3h6emLMmDHIyclps01TUxNmzJgBDw8PODk5YezYsSgpKREpYmqPZcuWISwszDwxZ1xcHLZt22ZezxzbnkWLFkEikWDmzJnmZcyz9Zs/fz4kEkmbS0hIiHk9c2wbCgsL8dRTT8HDwwP29va49dZbkZaWZl7fkd+/WHxZse+++w6zZs3CvHnzkJGRgfDwcIwaNQqlpaVih0btVF9fj/DwcCxduvSK6xcvXowlS5Zg+fLlSE1NhaOjI0aNGoWmpiYLR0rttWfPHsyYMQMHDhxAYmIiDAYD7r33XtTX15u3eemll7BlyxasX78ee/bsQVFRER599FERo6Yb5efnh0WLFiE9PR1paWm45557MHr0aJw4cQIAc2xrDh06hE8//RRhYWFtljPPtmHgwIEoLi42X/bt22dexxxbv6qqKgwdOhRyuRzbtm1DVlYW/v3vf8PNzc28TYd+/xLIasXExAgzZsww3zcajYKvr6+wcOFCEaOijgJA2Lhxo/m+yWQSvL29hX/+85/mZdXV1YJSqRS+/fZbESKkjlBaWioAEPbs2SMIQktO5XK5sH79evM22dnZAgAhJSVFrDCpA7i5uQkrVqxgjm1MbW2t0LdvXyExMVG48847hRdffFEQBL6XbcW8efOE8PDwK65jjm3Dq6++KgwbNuyq6zv6+xdHvqyUXq9Heno64uPjzcukUini4+ORkpIiYmTUWXJzc6HRaNrk3NXVFbGxscy5FaupqQEAuLu7AwDS09NhMBja5DkkJAQBAQHMs5UyGo1Yt24d6uvrERcXxxzbmBkzZuCBBx5ok0+A72Vbcvr0afj6+qJ3796YOHEi8vPzATDHtmLz5s2Ijo7GY489Bk9PT0RGRuLzzz83r+/o718svqxUeXk5jEYjvLy82iz38vKCRqMRKSrqTBfzypzbDpPJhJkzZ2Lo0KEYNGgQgJY8KxQKqNXqNtsyz9bn2LFjcHJyglKpxPTp07Fx40aEhoYyxzZk3bp1yMjIwMKFCy9bxzzbhtjYWKxatQrbt2/HsmXLkJubi+HDh6O2tpY5thHnzp3DsmXL0LdvX+zYsQPPPfccXnjhBaxevRpAx3//kt18yERE1B4zZszA8ePH25w/QLajf//+OHz4MGpqavDDDz9g8uTJ2LNnj9hhUQcpKCjAiy++iMTERKhUKrHDoU5y//33m2+HhYUhNjYWgYGB+P7772Fvby9iZNRRTCYToqOj8e677wIAIiMjcfz4cSxfvhyTJ0/u8P1x5MtK9ejRA3Z2dpd11CkpKYG3t7dIUVFnuphX5tw2JCQkYOvWrdi9ezf8/PzMy729vaHX61FdXd1me+bZ+igUCvTp0weDBw/GwoULER4ejg8//JA5thHp6ekoLS1FVFQUZDIZZDIZ9uzZgyVLlkAmk8HLy4t5tkFqtRr9+vXDmTNn+F62ET4+PggNDW2zbMCAAebDSzv6+xeLLyulUCgwePBgJCUlmZeZTCYkJSUhLi5OxMioswQHB8Pb27tNzrVaLVJTU5lzKyIIAhISErBx40bs2rULwcHBbdYPHjwYcrm8TZ5zcnKQn5/PPFs5k8kEnU7HHNuIESNG4NixYzh8+LD5Eh0djYkTJ5pvM8+2p66uDmfPnoWPjw/fyzZi6NChl035curUKQQGBgLohO9f7ekKQl3DunXrBKVSKaxatUrIysoSpk2bJqjVakGj0YgdGrVTbW2tkJmZKWRmZgoAhPfff1/IzMwUzp8/LwiCICxatEhQq9XCjz/+KBw9elQYPXq0EBwcLDQ2NoocOV2v5557TnB1dRWSk5OF4uJi86WhocG8zfTp04WAgABh165dQlpamhAXFyfExcWJGDXdqNmzZwt79uwRcnNzhaNHjwqzZ88WJBKJsHPnTkEQmGNbdWm3Q0Fgnm3B3/72NyE5OVnIzc0V9u/fL8THxws9evQQSktLBUFgjm3BwYMHBZlMJrzzzjvC6dOnhbVr1woODg7C119/bd6mI79/sfiych999JEQEBAgKBQKISYmRjhw4IDYIdFN2L17twDgssvkyZMFQWhpdzpnzhzBy8tLUCqVwogRI4ScnBxxg6YbcqX8AhC+/PJL8zaNjY3C888/L7i5uQkODg7CI488IhQXF4sXNN2wKVOmCIGBgYJCoRB69uwpjBgxwlx4CQJzbKt+X3wxz9Zv/Pjxgo+Pj6BQKIRevXoJ48ePF86cOWNezxzbhi1btgiDBg0SlEqlEBISInz22Wdt1nfk9y+JIAjCjY+XERERERER0Y3gOV9EREREREQWwOKLiIiIiIjIAlh8ERERERERWQCLLyIiIiIiIgtg8UVERERERGQBLL6IiIiIiIgsgMUXERERERGRBbD4IiIiIiIisgAWX0RERERERBbA4ouIiAhAWVkZnnvuOQQEBECpVMLb2xujRo3C/v37AQASiQSbNm0SN0giIrJqMrEDICIi6grGjh0LvV6P1atXo3fv3igpKUFSUhIqKirEDo2IiGyERBAEQewgiIiIxFRdXQ03NzckJyfjzjvvvGx9UFAQzp8/b74fGBiIvLw8AMCPP/6IN998E1lZWfD19cXkyZPxxhtvQCZr+f+mRCLBJ598gs2bNyM5ORk+Pj5YvHgxxo0bZ5HXRkREXQcPOyQiom7PyckJTk5O2LRpE3Q63WXrDx06BAD48ssvUVxcbL7/yy+/YNKkSXjxxReRlZWFTz/9FKtWrcI777zT5vFz5szB2LFjceTIEUycOBETJkxAdnZ2578wIiLqUjjyRUREBGDDhg2YOnUqGhsbERUVhTvvvBMTJkxAWFgYgJYRrI0bN2LMmDHmx8THx2PEiBF47bXXzMu+/vprvPLKKygqKjI/bvr06Vi2bJl5m9tuuw1RUVH45JNPLPPiiIioS+DIFxEREVrO+SoqKsLmzZtx3333ITk5GVFRUVi1atVVH3PkyBEsWLDAPHLm5OSEqVOnori4GA0NDebt4uLi2jwuLi6OI19ERN0QG24QERG1UqlUGDlyJEaOHIk5c+bg2Wefxbx58/D0009fcfu6ujq8+eabePTRR6/4XERERJfiyBcREdFVhIaGor6+HgAgl8thNBrbrI+KikJOTg769Olz2UUq/e1P7IEDB9o87sCBAxgwYEDnvwAiIupSOPJFRETdXkVFBR577DFMmTIFYWFhcHZ2RlpaGhYvXozRo0cDaOl4mJSUhKFDh0KpVMLNzQ1z587Fgw8+iICAAIwbNw5SqRRHjhzB8ePH8fbbb5uff/369YiOjsawYcOwdu1aHDx4EF988YVYL5eIiETChhtERNTt6XQ6zJ8/Hzt37sTZs2dhMBjg7++Pxx57DK+//jrs7e2xZcsWzJo1C3l5eejVq5e51fyOHTuwYMECZGZmQi6XIyQkBM8++yymTp0KoKXhxtKlS7Fp0ybs3bsXPj4+eO+99/D444+L+IqJiEgMLL6IiIg60ZW6JBIRUffEc76IiIiIiIgsgMUXERERERGRBbDhBhERUSfi0f1ERHQRR76IiIiIiIgsgMUXERERERGRBbD4IiIiIiIisgAWX0RERERERBbA4ouIiIiIiMgCWHwRERERERFZAIsvIiIiIiIiC2DxRUREREREZAH/D/rL8WpwCf0pAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def compute_table_difference(table1, table2):\n",
    "    difference = {}\n",
    "    for key, value in table1.items():\n",
    "        difference[key] = abs(value - table2[key])\n",
    "    return difference\n",
    "\n",
    "step_means = []\n",
    "for step_predictions in predictions:\n",
    "    step_differences = []\n",
    "    for agent_predictions, success_matrix_agent in zip(step_predictions.values(), success_matrix_normalized):\n",
    "        difference = compute_table_difference(agent_predictions, success_matrix_agent)\n",
    "        # Only calculate mean if there are values\n",
    "        if len(difference) > 0:\n",
    "            agent_mean = sum(difference.values()) / len(difference)\n",
    "            step_differences.append(agent_mean)\n",
    "    # Only calculate mean if there are values\n",
    "    if len(step_differences) > 0:\n",
    "        step_means.append(np.mean(step_differences))\n",
    "\n",
    "# Plot the results only if we have data\n",
    "if len(step_means) > 0:\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    plt.plot(step_means)\n",
    "    plt.xlabel('Step')\n",
    "    plt.ylabel('Mean Difference')\n",
    "    plt.title('Mean Difference Between Predicted and Actual Success Rates Over Time')\n",
    "    plt.grid(True)\n",
    "    plt.show()\n",
    "else:\n",
    "    print(\"No data available to plot\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Occupation Metrics (excluding noop actions):\n",
      "Mean occupation: 27.00%\n",
      "Standard deviation: 8.06%\n",
      "Min occupation: 16.67%\n",
      "Max occupation: 36.67%\n",
      "Occupation range: 20.00%\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1IAAAIjCAYAAAAJLyrXAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZENJREFUeJzt3Xt8zvX/x/HntYMdsA2zzTIsU8jxi4SchUIpfR3iy1Dq61QOFRWSU6kcckyJSCWlkwqFKClySoWkoa/MYm2zYcf37w+/Xblc29pnrtk1Hvfbbbdb1+fzuj7X6/rsvavr6fP5vD82Y4wRAAAAACDfPIq6AQAAAAAobghSAAAAAGARQQoAAAAALCJIAQAAAIBFBCkAAAAAsIggBQAAAAAWEaQAAAAAwCKCFAAAAABYRJACAAAAAIsIUgBwFThy5IhsNpuWLl1a1K2giCUnJyskJEQrVqwo6lbgIl9++aVsNpu+/PLLIu1j7dq1KlWqlP78888i7QNwFwQp4Boxf/582Ww2NW7cuKhbydH8+fMth4CUlBRNmjRJderUkb+/vwIDA9W8eXMtW7ZMxpjCabSIvfnmm5o1a1ZRt+EgOjpaNpvN/hMQEKC6devqxRdfVGpqalG3d9k+/fRTPf3000XdRr7Nnj1bpUuXVs+ePe3Lnn76adlsNoWGhurs2bNOz6lSpYo6d+58Jdu8qiQkJMjX11c2m0379+8v8HYK8jl4JXXs2FFRUVGaNm1aUbcCuAWCFHCNWLFihapUqaLt27fr119/Lep2nFj9AnHy5Ek1btxYTz/9tGrXrq1Zs2Zp0qRJ8vDwUL9+/dSrVy9lZmYWXsNFJLcgVblyZZ07d07/+c9/rnxTknx8fLR8+XItX75cU6dOVdmyZTV69Gj169evSPpxpU8//VQTJ04s6jbyJT09XbNnz9b9998vT09Pp/VxcXFasGBBEXR2dVu1apVsNpvCwsIu60hgbp+DLVq00Llz59SiRYvL6NI1HnzwQb388ss6c+ZMUbcCFDmCFHANiImJ0TfffKMZM2aofPnyV8UpP/369dP+/fv1/vvva8WKFRo0aJCGDx+uzZs3a/To0Vq5cqVeeOGFom7zirHZbPL19c3xy/OV4OXlpT59+qhPnz4aOnSoNmzYoIYNG2rlypX6448/LmvbWVlZOn/+vIs6vbqtWbNGf/75p7p3757j+nr16un555/XuXPnrnBnV7c33nhDd9xxh3r16qU333zT5dv38PCQr6+vPDyK/mtbt27dlJqaqlWrVhV1K0CRK/q/SACFbsWKFSpTpow6deqke++9N9cgdfr0af3nP/9RQECAgoKC1K9fP+3duzfHa28OHDige++9V2XLlpWvr68aNmyojz76yKFm6dKlstls2rp1q0aOHKny5curZMmSuvvuux3Osa9SpYp++uknbd682X56WKtWrXJ9P99++63WrVun6Oho3XnnnU7rp02bpmrVqum5555z+MKYlZWl2bNnq3bt2vL19VX58uXVsWNHff/99w7Pf+ONN3TzzTfL399fZcqUUYsWLbR+/Xr7epvNluOpXlWqVFF0dLTT+9+yZYsefPBBlStXTgEBAerbt6/++usvh+d++OGH6tSpk8LDw+Xj46OqVatq0qRJDkfVWrVqpU8++URHjx6176cqVapIyv0aqY0bN6p58+YqWbKkgoKCdNdddzmdepR92tevv/6q6OhoBQUFKTAwUP3798/xNLD88PDwsP8Ojxw5IklKTU3VhAkTFBUVJR8fH0VEROixxx5zOv3PZrNp6NChWrFihW666Sb5+Pho7dq1kqTjx49r4MCB9v0UGRmp//73v0pLS7M/PyEhQY888ogiIiLk4+OjqKgoPffcc8rKyrLXZO+vF154QYsWLVLVqlXl4+OjRo0aaceOHfa66OhozZs3z95X9k+2F154QU2bNlW5cuXk5+enBg0a6N1333XaH+fOndPw4cMVHBys0qVL684779Tx48dzHEvHjx/XgAEDFBoaKh8fH91000167bXX8rXfP/jgA1WpUkVVq1bNcf348eN18uTJfB2VSklJ0ahRo+z78cYbb9QLL7zgdNps9u/rgw8+UK1atew9Z//O/kl0dLRKlSql48ePq2vXripVqpTKly+v0aNHOx1Vzm9PGRkZmjRpkv33WqVKFT3xxBNOYy37lMb169erXr168vX1Vc2aNbV69ep89S5Jx44d01dffaWePXuqZ8+e9n+4ykleny15fQ7mdo3UqlWr1KBBA/n5+Sk4OFh9+vTR8ePHC7x/3377bTVo0EClS5dWQECAateurdmzZzvUhISEqE6dOvrwww/zvY+Aq5YBcNWrXr26GThwoDHGmC1bthhJZvv27Q41mZmZpkmTJsbT09MMHTrUzJ0719x2222mbt26RpJZsmSJvfbHH380gYGBpmbNmua5554zc+fONS1atDA2m82sXr3aXrdkyRIjydSvX9+0adPGzJkzx4waNcp4enqa7t272+vef/99U7FiRVO9enWzfPlys3z5crN+/fpc388TTzxhJJkvv/wy15oJEyYYSebzzz+3L4uOjjaSzO23325mzZplXnjhBXPXXXeZOXPm2GuefvppI8k0bdrUPP/882b27NnmvvvuM48//ri9RpKZMGGC02tWrlzZ9OvXz+n9165d2zRv3ty89NJLZsiQIcbDw8O0aNHCZGVl2Wu7du1qunfvbp5//nmzYMEC8+9//9tIMqNHj7bXrF+/3tSrV88EBwfb99P7779vjDEmJibG6ff0+eefGy8vL3PDDTeY6dOnm4kTJ5rg4GBTpkwZExMT47Sv6tevb+655x4zf/58c//99xtJ5rHHHst1H2fr16+fKVmypNPyu+++20gyBw4cMJmZmaZ9+/bG39/fPPLII+bll182Q4cONV5eXuauu+5yeJ4kU6NGDVO+fHkzceJEM2/ePLN7925z/PhxEx4ebt/GwoULzbhx40yNGjXMX3/9ZYwxJiUlxdSpU8eUK1fOPPHEE2bhwoWmb9++xmazmYcfftj+Gtn7q379+iYqKso899xzZvr06SY4ONhUrFjRpKWlGWOM+eabb8xtt91mJNn3+fLly+3bqVixohk8eLCZO3eumTFjhrn55puNJLNmzRqH99S9e3cjyfznP/8x8+bNM927d7f/bV08lmJjY03FihVNRESEeeaZZ8yCBQvMnXfeaSSZmTNn/uPvIioqytxzzz1Oy7N/x3/++adp06aNCQ0NNWfPnrWvr1y5sunUqZP9cVZWlmnTpo2x2Wzm/vvvN3PnzjVdunQxkswjjzzi9PuqW7euqVChgpk0aZKZNWuWuf76642/v785derUP/bcr18/4+vra2666SYzYMAAs2DBAtOtWzcjycyfP79APfXr189IMvfee6+ZN2+e6du3r5Fkunbt6lBXuXJlc8MNN5igoCAzZswYM2PGDFO7dm3j4eGR52fQxZ599llTqlQp+/6sWrWqGTx4sFPdP3225PU5uGnTJiPJbNq0yb697M+XRo0amZkzZ5oxY8YYPz8/U6VKFfvfg5X9u379eiPJtG3b1sybN8/MmzfPDB061Pz73/92ei/333+/CQ4Oztf+Aa5mBCngKvf99987BIqsrCxTsWJFhy+Vxhjz3nvvGUlm1qxZ9mWZmZmmTZs2Tl/Q27Zta2rXrm3Onz9vX5aVlWWaNm1qqlWrZl+W/T/6du3aOYSGESNGGE9PT5OQkGBfdtNNN5mWLVvm6z117drVSHL4snCp1atXG0nmpZdeMsYYs3HjRiPJDB8+3Kk2u7dDhw4ZDw8Pc/fdd5vMzMwca4yxHqQaNGhg/2JujDHTp083ksyHH35oX3bxl9psDz74oPH393fYz506dTKVK1d2qs0pSNWrV8+EhISY06dP25ft3bvXeHh4mL59+9qXZX/JHjBggMM27777blOuXDmn17pUdpD6888/zZ9//ml+/fVXM3XqVGOz2UydOnWMMcYsX77ceHh4mK+++srhuQsXLjSSzNatW+3LJBkPDw/z008/OdT27dvXeHh4mB07djj1kP37mTRpkilZsqT55ZdfHNaPGTPGeHp6mmPHjjnsr3Llypn4+Hh73YcffmgkmY8//ti+bMiQISa3f3e89PeWlpZmatWqZdq0aWNftnPnzhy/7GcH+4vH0sCBA02FChWcAkjPnj1NYGBgjuMkW3p6urHZbGbUqFFO6y4OUps3bzaSzIwZM+zrLw1SH3zwgZFkJk+e7LCde++919hsNvPrr7/al0kyJUqUcFi2d+9eI8nhHylykx16nnnmGYfl9evXNw0aNLDc0549e4wkc//99zvUjR492kgyGzdudHjfksx7771nX5aYmGgqVKhg6tev/4+9G2NM7dq1Te/eve2Pn3jiCRMcHGzS09Pty/L72ZLb5+ClQSotLc2EhISYWrVqmXPnztnr1qxZYySZ8ePH25fld/8+/PDDJiAgwGRkZPzje546daqRZE6ePPmPtcDVjFP7gKvcihUrFBoaqtatW0u6cBpOjx499Pbbbzuc1rF27Vp5e3vrgQcesC/z8PDQkCFDHLYXHx+vjRs3qnv37jpz5oxOnTqlU6dO6fTp0+rQoYMOHTrkdGrJoEGDHE6Hat68uTIzM3X06NECvafsi5xLly6da032uqSkJEnSe++9J5vNpgkTJjjVZvf2wQcfKCsrS+PHj3e6FuHi/q0aNGiQvL297Y//+9//ysvLS59++ql9mZ+fn/2/s/dr8+bNdfbsWR04cMDya544cUJ79uxRdHS0ypYta19ep04d3XbbbQ6vne2hhx5yeNy8eXOdPn3avg/zkpKSovLly6t8+fKKiorSE088oSZNmuj999+XdOEUpBo1aqh69er2MXPq1Cm1adNGkrRp0yaH7bVs2VI1a9a0P87KytIHH3ygLl26qGHDhk6vn/37WbVqlZo3b64yZco4vE67du2UmZmpLVu2ODyvR48eKlOmjMN7lqTffvvtH9+z5Ph7++uvv5SYmKjmzZtr165d9uXZp7gNHjzY4bnDhg1zeGyM0XvvvacuXbrIGOPQf4cOHZSYmOiw3UvFx8fLGOPwfnLSokULtW7dWtOnT8/1WqlPP/1Unp6eGj58uMPyUaNGyRijzz77zGF5u3btHE4nrFOnjgICAvK9H6Wcx9/Fz89vT9lje+TIkU51kvTJJ584LA8PD9fdd99tf5x9+u3u3bsVGxubZ88//PCD9u3bp169etmX9erVS6dOndK6devsy1z92fL9998rLi5OgwcPlq+vr315p06dVL16daf3KP3z/g0KClJKSoo+//zzf3z97DF26tQpy70DVxOvom4AQOHJzMzU22+/rdatWysmJsa+vHHjxnrxxRe1YcMGtW/fXpJ09OhRVahQQf7+/g7biIqKcnj866+/yhijcePGady4cTm+blxcnK677jr740qVKjmsz/6f8KXXCeVXdkg6c+aMgoKCcqy5NGwdPnxY4eHhDqHiUocPH5aHh4fDF3hXqFatmsPjUqVKqUKFCvZrhyTpp59+0lNPPaWNGzc6BZfExETLr5kdUm+88UandTVq1NC6deuUkpKikiVL2pfn9XsKCAjI8/V8fX318ccfS5L92qWKFSva1x86dEj79+9X+fLlc3x+XFycw+PIyEiHx3/++aeSkpJUq1atPPs4dOiQfvjhh3y/zuWOzTVr1mjy5Mnas2ePw/U3F385Pnr0qDw8PJze06V/W3/++acSEhK0aNEiLVq0KF/958TkY+r/p59+Wi1bttTChQs1YsQIp/VHjx5VeHi40z9W1KhRw77+YpfuR+nCvszej2lpaYqPj3dYX758efvkKNnXLOb2fCs9Ze/vS/dvWFiYgoKCnHqPiopyCjM33HCDpAvX0oWFhTm9t2xvvPGGSpYsqeuvv94+G6qvr6+qVKmiFStWqFOnTpJc/9mS19939erV9fXXXzssy8/+HTx4sN555x3dfvvtuu6669S+fXt1795dHTt2dHqN7DF2Of/ABFwNCFLAVWzjxo06ceKE3n77bb399ttO61esWGEPUvmVfcH+6NGj1aFDhxxrLv0Ck9tMcvn5wpeTGjVq6IMPPtAPP/yQ63TAP/zwgyS5PBTlpaDTrSckJKhly5YKCAjQM888o6pVq8rX11e7du3S448/7jBJQmG6nN+Tp6en2rVrl+v6rKws1a5dWzNmzMhxfUREhMPji4/0WJGVlaXbbrtNjz32WI7rs78gZ7uc9/zVV1/pzjvvVIsWLTR//nxVqFBB3t7eWrJkSYFmbsv+Pffp0yfXaePr1KmT6/PLli0rm82WrxDYokULtWrVStOnT3c6UlEQ/7Qfv/nmG/tR8WwxMTH2yVIKY7bJwv6Sb4zRW2+9pZSUlBw/Z+Li4pScnKxSpUoVah/5kZ/9GxISoj179mjdunX67LPP9Nlnn2nJkiXq27evXn/9dYfa7DEWHBxcKP0CxQVBCriKrVixQiEhIfZZxy62evVqvf/++1q4cKH8/PxUuXJlbdq0SWfPnnU4KnXpPaeuv/56SZK3t3eeX5ytsvKlp3Pnzpo2bZqWLVuWY5DKzMzUm2++qTJlyqhZs2aSpKpVq2rdunWKj4/P9ahU1apVlZWVpZ9//ln16tXL9fXLlCmjhIQEh2VpaWk6ceJEjvWHDh1y+BKZnJysEydO6I477pB0YUau06dPa/Xq1Q7v5+KjiNnyu58qV64sSTp48KDTugMHDig4ONjhaFRhq1q1qvbu3au2bdsW6Atu+fLlFRAQoB9//PEfXyc5OfmKjM333ntPvr6+WrdunXx8fOzLlyxZ4lBXuXJlZWVlKSYmxuHo5KV/W+XLl1fp0qWVmZlZoP69vLxUtWrVHMdNTp5++mm1atVKL7/8stO6ypUr64svvtCZM2ccjgBln2aaPb7yq27duk6njOV1pCcn+e0pe38fOnTIfrRKunDvuYSEBKfes4+yX/x7/uWXXyTJHvRysnnzZv3vf//TM8884/A60oWgMWjQIH3wwQfq06dPvj9bCvL3nX16bLaDBw9a/v1kK1GihLp06aIuXbooKytLgwcP1ssvv6xx48Y5/ANZTEyMgoODcz3yC1wruEYKuEqdO3dOq1evVufOnXXvvfc6/QwdOlRnzpyxT1neoUMHpaen65VXXrFvIysryymEhYSE2L985RQcLp7W3IqSJUs6hZPcNG3aVO3atdOSJUu0Zs0ap/VPPvmkfvnlFz322GP2IxvdunWTMSbHG6tm/6t5165d5eHhoWeeecbpKNDFRyiqVq3qdK3NokWLcj0itWjRIqWnp9sfL1iwQBkZGbr99tsl/f2vxRe/RlpamubPn++0rZIlS+brVL8KFSqoXr16ev311x32648//qj169fbQ9yV0r17dx0/ftxhfGU7d+6cUlJS8ny+h4eHunbtqo8//thpunrp733XvXt3bdu2zeH6lGwJCQnKyMiw3Ht24Lx0fHp6espmszn83o8cOaIPPvjAoS77yO2lv885c+Y4ba9bt2567733cgyM+fnbatKkSY77JyctW7ZUq1at9Nxzzzndp+uOO+5QZmam5s6d67B85syZstls9rGbX2XKlFG7du0cfi6+tic/8ttT9ti+9MbV2UdDs0+3y/bHH3/Yr+WTLlxXuWzZMtWrVy9fp/U9+uijTp+vDzzwgKpVq2a/1UR+P1vy+znYsGFDhYSEaOHChQ6nlH722Wfav3+/03vMj9OnTzs89vDwsB8BvXTa+J07d6pJkyaWXwO42nBECrhKffTRRzpz5kyO91mSpFtuucV+c94ePXqoa9euuvnmmzVq1Cj9+uuvql69uj766CP7dQ0X/0vpvHnzdOutt6p27dp64IEHdP311+vkyZPatm2b/ve//2nv3r2W+23QoIEWLFigyZMnKyoqSiEhIU7/0nqxZcuWqW3btrrrrrt03333qXnz5kpNTdXq1av15ZdfqkePHnr00Uft9a1bt9Z//vMfvfTSSzp06JA6duyorKwsffXVV2rdurWGDh2qqKgoPfnkk5o0aZKaN2+ue+65Rz4+PtqxY4fCw8M1bdo0SdL999+vhx56SN26ddNtt92mvXv3at26dbme5pKWlqa2bduqe/fuOnjwoObPn69bb73V/rtp2rSpypQpo379+mn48OGy2Wxavnx5jqeXNWjQQCtXrtTIkSPVqFEjlSpVSl26dMnxdZ9//nndfvvtatKkiQYOHKhz585pzpw5CgwMzPE+WIXpP//5j9555x099NBD2rRpk5o1a6bMzEwdOHBA77zzjtatW5fjJBIXmzp1qtavX6+WLVtq0KBBqlGjhk6cOKFVq1bp66+/VlBQkB599FF99NFH6ty5s6Kjo9WgQQOlpKRo3759evfdd3XkyBHLpyM1aNBAkjR8+HB16NBBnp6e6tmzpzp16qQZM2aoY8eOuu+++xQXF6d58+YpKirKfmpp9vO7deumWbNm6fTp07rlllu0efNm+1GPi/+2nn32WW3atEmNGzfWAw88oJo1ayo+Pl67du3SF1984XSd0aXuuusuLV++XL/88ovTaYw5mTBhgtMpd5LUpUsXtW7dWk8++aSOHDmiunXrav369frwww/1yCOP5HqfqsKU357q1q2rfv36adGiRfbTZrdv367XX39dXbt2dXq/N9xwgwYOHKgdO3YoNDRUr732mk6ePOl0ZPFiqampeu+993TbbbflGgjvvPNOzZ49W3Fxcfn+bMnv56C3t7eee+459e/fXy1btlSvXr108uRJzZ49W1WqVMnxurd/cv/99ys+Pl5t2rRRxYoVdfToUc2ZM0f16tVzOOIWFxenH374wWkiIuCadEXnCARwxXTp0sX4+vqalJSUXGuio6ONt7e3farlP//809x3332mdOnSJjAw0ERHR5utW7caSebtt992eO7hw4dN3759TVhYmPH29jbXXXed6dy5s3n33XftNdnTf186XXVO90SJjY01nTp1MqVLlzaS8jUV+pkzZ8zTTz9tbrrpJuPn52dKly5tmjVrZpYuXeowpXC2jIwM8/zzz5vq1aubEiVKmPLly5vbb7/d7Ny506HutddeM/Xr1zc+Pj6mTJkypmXLlg73o8rMzDSPP/64CQ4ONv7+/qZDhw7m119/zXX6882bN5tBgwaZMmXKmFKlSpnevXs7TElujDFbt241t9xyi/Hz8zPh4eHmscceM+vWrXPaT8nJyea+++4zQUFBRpJ9KvScpj83xpgvvvjCNGvWzPj5+ZmAgADTpUsX8/PPPzvUXDw19sWy+7/4nlM5ye0+UpdKS0szzz33nLnpppvs+7ZBgwZm4sSJJjEx0V4nyQwZMiTHbRw9etT07dvXlC9f3vj4+Jjrr7/eDBkyxKSmptprzpw5Y8aOHWuioqJMiRIlTHBwsGnatKl54YUX7NPQZ++v559/3uk1dMmU5BkZGWbYsGGmfPnyxmazOUyFvnjxYlOtWjXj4+NjqlevbpYsWWLfnxdLSUkxQ4YMMWXLljWlSpUyXbt2NQcPHjSSzLPPPutQe/LkSTNkyBATERFhvL29TVhYmGnb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Gm3ZskWDBg2yrx81apSuu+467dmzRxUqVNDo0aPt61auXCkPDw9169bNabv9+/fXggULlJGR4YpdkiuCFAAAAIq3lJTcf86fz3/tRSEnz9oC+Ne//qWIiAitXr3avmz16tWqVKmS6tev71CblZWladOmKTIyUn5+fqpbt67effdd+/rMzEwNHDjQvv7GG2/U7NmzHbYRHR2trl276oUXXlCFChVUrlw5DRkyROnp6bn2+Oeff2rjxo3q0qWLfVmtWrX03nvvqUuXLqpataratGmjKVOm6OOPP7YHFT8/P4WFhdl/PD09tXHjRoewdan9+/dr7dq1evXVV9W4cWPdeuutmjNnjt5++2398ccf9pp+/fqpWrVqio6O1v79+yVJCQkJeuqppzRv3rwct33bbbcpPj5emzdvzvX1XYEgBQAAgOKtVKncfy49YhESknvt7bc71lapknNdAQ0YMEBLliyxP37ttdfUv39/p7pp06Zp2bJlWrhwoX766SeNGDFCffr0sQeDrKwsVaxYUatWrdLPP/+s8ePH64knntA777zjsJ1Nmzbp8OHD2rRpk15//XUtXbpUS5cuzbW/r7/+Wv7+/qpRo0ae7yMxMVEBAQHy8sr5lrTLli2Tv7+/7r333ly3sW3bNgUFBalhw4b2Ze3atZOHh4e+++47SVLdunX1xRdfKCsrS+vXr1edOnUkSY8++qiGDBmiiIiIHLddokQJ1atXT1999VWe7+NyEaQAAACAK6BPnz76+uuvdfToUR09elRbt25Vnz59HGpSU1M1depUvfbaa+rQoYOuv/56RUdHq0+fPnr55ZclSd7e3po4caIaNmyoyMhI9e7dW/3793cKUmXKlNHcuXNVvXp1de7cWZ06ddKGDRty7e/o0aMKDQ3N8x5Lp06d0qRJkxxOwbvU4sWLdd9998nPzy/XmtjYWKfT/ry8vFS2bFnFxsZKkl544QUdOHBAVapU0aFDh/TCCy9oy5Yt2rNnj/r27avu3bvr+uuv10MPPaS0tDSHbYWHh+vo0aO5vr4r5BwjAQAAgOLiogkKnHh6Oj7OY/IDXRogLpnc4HKVL19enTp10tKlS2WMUadOnRQcHOxQ8+uvv+rs2bO67bbbHJanpaU5nAI4b948vfbaazp27JjOnTuntLQ01atXz+E5N910kzwvev8VKlTQvn37cu3v3Llz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sbRx40bTpEkTExgYaHx9fU21atXM448/zpffIlRcx9KlCFKXx2bM/58cCVymKVOmaOHChfr999+LuhUUc4wluApjCa7CWIKrMJauHlwjhQKbP3++GjVqpHLlymnr1q16/vnnNXTo0KJuC8UQYwmuwliCqzCW4CqMpasXQQoFdujQIU2ePFnx8fGqVKmSRo0apbFjxxZ1WyiGGEtwFcYSXIWxBFdhLF29OLUPAAAAACzihrwAAAAAYBFBCgAAAAAsIkgBAAAAgEUEKQAAAACwiCAFAAAAABYRpAAAAADAIoIUAKBY2rZtmzw9PdWpU6cief0jR47IZrNpz549RfL6AICiRZACABRLixcv1rBhw7Rlyxb98ccfRd0OAOAaQ5ACABQ7ycnJWrlypf773/+qU6dOWrp0qcP6jz76SNWqVZOvr69at26t119/XTabTQkJCfaar7/+Ws2bN5efn58iIiI0fPhwpaSk2NdXqVJFU6dO1YABA1S6dGlVqlRJixYtsq+PjIyUJNWvX182m02tWrWSJH355Ze6+eabVbJkSQUFBalZs2Y6evRooe0LAEDRIEgBAIqdd955R9WrV9eNN96oPn366LXXXpMxRpIUExOje++9V127dtXevXv14IMP6sknn3R4/uHDh9WxY0d169ZNP/zwg1auXKmvv/5aQ4cOdah78cUX1bBhQ+3evVuDBw/Wf//7Xx08eFCStH37dknSF198oRMnTmj16tXKyMhQ165d1bJlS/3www/atm2bBg0aJJvNdgX2CgDgSrKZ7P/zAABQTDRr1kzdu3fXww8/rIyMDFWoUEGrVq1Sq1atNGbMGH3yySfat2+fvf6pp57SlClT9NdffykoKEj333+/PD099fLLL9trvv76a7Vs2VIpKSny9fVVlSpV1Lx5cy1fvlySZIxRWFiYJk6cqIceekhHjhxRZGSkdu/erXr16kmS4uPjVa5cOX355Zdq2bLlFd0nAIAriyNSAIBi5eDBg9q+fbt69eolSfLy8lKPHj20ePFi+/pGjRo5POfmm292eLx3714tXbpUpUqVsv906NBBWVlZiomJsdfVqVPH/t82m01hYWGKi4vLtbeyZcsqOjpaHTp0UJcuXTR79mydOHHist8zAMD9EKQAAMXK4sWLlZGRofDwcHl5ecnLy0sLFizQe++9p8TExHxtIzk5WQ8++KD27Nlj/9m7d68OHTqkqlWr2uu8vb0dnmez2ZSVlZXntpcsWaJt27apadOmWrlypW644QZ9++231t8oAMCteRV1AwAA5FdGRoaWLVumF198Ue3bt3dY17VrV7311lu68cYb9emnnzqs27Fjh8Pjf/3rX/r5558VFRVV4F5KlCghScrMzHRaV79+fdWvX19jx45VkyZN9Oabb+qWW24p8GsBANwPQQoAUGysWbNGf/31lwYOHKjAwECHdd26ddPixYv1zjvvaMaMGXr88cc1cOBA7dmzxz6rX/akD48//rhuueUWDR06VPfff79Kliypn3/+WZ9//rnmzp2br15CQkLk5+entWvXqmLFivL19VV8fLwWLVqkO++8U+Hh4Tp48KAOHTqkvn37unQ/AACKHqf2AQCKjcWLF6tdu3ZOIUq6EKS+//57nTlzRu+++65Wr16tOnXqaMGCBfZZ+3x8fCRduPZp8+bN+uWXX9S8eXPVr19f48ePV3h4eL578fLy0ksvvaSXX35Z4eHhuuuuu+Tv768DBw6oW7duuuGGGzRo0CANGTJEDz74oGt2AADAbTBrHwDgqjdlyhQtXLhQv//+e1G3AgC4SnBqHwDgqjN//nw1atRI5cqV09atW/X888873SMKAIDLQZACAFx1Dh06pMmTJys+Pl6VKlXSqFGjNHbs2KJuCwBwFeHUPgAAAACwiMkmAAAAAMAighQAAAAAWESQAgAAAACLCFIAAAAAYBFBCgAAAAAsIkgBAAAAgEUEKQAAAACwiCAFAAAAABb9H6weBRP0t9wRAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Calculate occupation percentage and metrics for each agent\n",
    "action_history = data['action_history']\n",
    "\n",
    "# Count total actions and noop actions for each agent\n",
    "agent_stats = {}\n",
    "total_steps = 0\n",
    "\n",
    "for episode_actions in action_history:\n",
    "    total_steps += len(episode_actions)\n",
    "    for step_actions in episode_actions:\n",
    "        for action in step_actions:\n",
    "            # Extract agent number from action string\n",
    "            agent_num = int(action.split('agent')[1].split('_')[0])\n",
    "            \n",
    "            if agent_num not in agent_stats:\n",
    "                agent_stats[agent_num] = {'total': 0, 'noop': 0}\n",
    "            \n",
    "            agent_stats[agent_num]['total'] += 1\n",
    "            if action.startswith('noop'):\n",
    "                agent_stats[agent_num]['noop'] += 1\n",
    "\n",
    "# Calculate occupation percentage (non-noop actions)\n",
    "occupation_percentages = []\n",
    "agent_nums = []\n",
    "for agent_num in sorted(agent_stats.keys()):\n",
    "    total = agent_stats[agent_num]['total']\n",
    "    noop = agent_stats[agent_num]['noop']\n",
    "    occupation = ((total - noop) / total) * 100\n",
    "    occupation_percentages.append(occupation)\n",
    "    agent_nums.append(f'Agent {agent_num}')\n",
    "\n",
    "# Calculate metrics\n",
    "mean_occupation = np.mean(occupation_percentages)\n",
    "std_occupation = np.std(occupation_percentages)\n",
    "min_occupation = np.min(occupation_percentages)\n",
    "max_occupation = np.max(occupation_percentages)\n",
    "occupation_range = max_occupation - min_occupation\n",
    "\n",
    "print(f\"Occupation Metrics (excluding noop actions):\")\n",
    "print(f\"Mean occupation: {mean_occupation:.2f}%\")\n",
    "print(f\"Standard deviation: {std_occupation:.2f}%\")\n",
    "print(f\"Min occupation: {min_occupation:.2f}%\")\n",
    "print(f\"Max occupation: {max_occupation:.2f}%\")\n",
    "print(f\"Occupation range: {occupation_range:.2f}%\")\n",
    "\n",
    "# Plot results\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.bar(agent_nums, occupation_percentages)\n",
    "plt.axhline(y=mean_occupation, color='r', linestyle='--', label=f'Mean ({mean_occupation:.1f}%)')\n",
    "plt.xlabel('Agents')\n",
    "plt.ylabel('Occupation Percentage')\n",
    "plt.title('Agent Occupation Percentage (Non-noop Actions)')\n",
    "plt.ylim(0, 100)\n",
    "plt.grid(True, axis='y')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "goto_agent0_storage0\n",
      "goto_agent1_storage0\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "from mistralai import Mistral\n",
    "\n",
    "api_key = os.environ[\"MISTRAL_API_KEY\"]\n",
    "model = \"mistral-large-latest\"\n",
    "\n",
    "client = Mistral(api_key=api_key)\n",
    "\n",
    "chat_response = client.chat.complete(\n",
    "    model=model,\n",
    "    messages=messages\n",
    ")\n",
    "\n",
    "print(chat_response.choices[0].message.content)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'AWS_SECRET_ACCESS_KEY'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[3], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mos\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m \u001b[43mos\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43menviron\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mAWS_SECRET_ACCESS_KEY\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\n",
      "File \u001b[0;32m/data2/aamayuelasfernandez/miniconda3/envs/mindagent/lib/python3.10/os.py:680\u001b[0m, in \u001b[0;36m_Environ.__getitem__\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m    677\u001b[0m     value \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_data[\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mencodekey(key)]\n\u001b[1;32m    678\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m:\n\u001b[1;32m    679\u001b[0m     \u001b[38;5;66;03m# raise KeyError with the original key value\u001b[39;00m\n\u001b[0;32m--> 680\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m(key) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[1;32m    681\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdecodevalue(value)\n",
      "\u001b[0;31mKeyError\u001b[0m: 'AWS_SECRET_ACCESS_KEY'"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "os.environ[\"AWS_SECRET_ACCESS_KEY\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[TextBlock(citations=None, text=\"Hello! How can I assist you today? I'm ready to help with information, answer questions, or discuss topics you're interested in. What would you like to talk about?\", type='text')]\n"
     ]
    }
   ],
   "source": [
    "from anthropic import AnthropicBedrock\n",
    "import os\n",
    "\n",
    "client = AnthropicBedrock(\n",
    "    # Authenticate by either providing the keys below or use the default AWS credential providers, such as\n",
    "    # using ~/.aws/credentials or the \"AWS_SECRET_ACCESS_KEY\" and \"AWS_ACCESS_KEY_ID\" environment variables.\n",
    "    aws_access_key=os.environ[\"AWS_ACESS_KEY\"],\n",
    "    aws_secret_key=os.environ[\"AWS_SECRET_KEY\"],\n",
    "    # Temporary credentials can be used with aws_session_token.\n",
    "    # Read more at https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp.html.\n",
    "    # aws_session_token=\"<session_token>\",\n",
    "    # aws_region changes the aws region to which the request is made. By default, we read AWS_REGION,\n",
    "    # and if that's not present, we default to us-east-1. Note that we do not read ~/.aws/config for the region.\n",
    "    aws_region=\"us-east-2\",\n",
    ")\n",
    "\n",
    "response = client.messages.create(\n",
    "    model=\"arn:aws:bedrock:us-east-2:288380904485:inference-profile/us.anthropic.claude-3-7-sonnet-20250219-v1:0\",\n",
    "    max_tokens=256,\n",
    "    messages=[{\"role\": \"user\", \"content\": \"Hello, world\"}]\n",
    ")\n",
    "print(response.content)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"Hello! How can I assist you today? I'm ready to help with information, answer questions, or discuss topics you're interested in. What would you like to talk about?\""
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "response.content[0].text"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "39"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "response.usage.output_tokens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "from openai import OpenAI\n",
    "\n",
    "api_key = os.getenv(\"AVIOR_API_KEY\") # Not support yet\n",
    "api_base = \"http://avior.mlfoundry.com/live-inference/v1\"\n",
    "client_avior = OpenAI(\n",
    "    api_key=api_key,\n",
    "    base_url=api_base\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ChatCompletion(id='26fae7a3d019426b80d09e9ec0ff4dfc', choices=[Choice(finish_reason='stop', index=0, logprobs=None, message=ChatCompletionMessage(content=\"I'm an artificial intelligence designed to assist with providing information, answering questions, and engaging in conversation. How can I assist you today?\", refusal=None, role='assistant', audio=None, function_call=None, tool_calls=None), matched_stop=151645)], created=1742942250, model='Qwen/Qwen2.5-32B-Instruct', object='chat.completion', service_tier=None, system_fingerprint=None, usage=CompletionUsage(completion_tokens=28, prompt_tokens=23, total_tokens=51, completion_tokens_details=None, prompt_tokens_details=None))"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "messages = [\n",
    "    {\"role\": \"system\", \"content\": \"You are a helpful AI assistant\"},\n",
    "    {\"role\": \"user\", \"content\": \"Who are you?\"}\n",
    "]\n",
    "\n",
    "model = \"Qwen/Qwen2.5-32B-Instruct\"\n",
    "\n",
    "response = client_avior.chat.completions.create(\n",
    "                    model=model,\n",
    "                    messages=messages,\n",
    "                    temperature=0.7,\n",
    "                    max_tokens=100,\n",
    "                    stop=None\n",
    "                )\n",
    "\n",
    "response"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mindagent",
   "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
