{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "07351a36",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/projectnb/mcnet/gvfranco/.conda/envs/entity-tracking-env/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "/projectnb/mcnet/gvfranco/.conda/envs/entity-tracking-env/lib/python3.10/site-packages/transformers/utils/hub.py:105: FutureWarning: Using `TRANSFORMERS_CACHE` is deprecated and will be removed in v5 of Transformers. Use `HF_HOME` instead.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "os.environ['HF_HOME'] = \"\"\n",
    "os.environ['TRANSFORMERS_CACHE'] = \"\"\n",
    "import sys\n",
    "from nnsight import LanguageModel\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "sys.path.append(\"../nnsight_patching_experiment/\")\n",
    "\n",
    "from run_patching import get_model_and_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8933772b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import argparse\n",
    "\n",
    "args = argparse.Namespace(\n",
    "    model = \"codellama/CodeLlama-13b-hf\",\n",
    "    datafile = \"train-t5.jsonl\",\n",
    "    batch_size = 8,\n",
    "    num_samples = 16,\n",
    "    ops_order = \"remove\",\n",
    "    query_ops_order = \"remove\",\n",
    "    output_dir = \"results/\",\n",
    "    counterfactual = \"dcm_remove_second_oid_all\",\n",
    "    success_filter = True,\n",
    "    num_query_object = 1,\n",
    "    load_in_8bit = True,\n",
    "    debug = False,\n",
    "    filter_ctf_success = False,\n",
    "\n",
    "    # --- Add these missing arguments ---\n",
    "    seed=42,\n",
    "    load_in_4bit=False,  # 'action=\"store_true\"' defaults to False\n",
    "    load_graph=None,\n",
    "    operations_on_same_obj=None,\n",
    "    copy_filter=None,\n",
    "    max_initial_objects_per_box=None,\n",
    "    counterfactual_format='rand_obj_rand_query_id',\n",
    "    data_field='sentence',\n",
    "    token_step='pred',\n",
    "    sort_query_objects=False,  # 'action=\"store_true\"' defaults to False\n",
    "    overwrite_cache=False,  # 'action=\"store_true\"' defaults to False\n",
    "    n_groupA=7,\n",
    "    n_groupB=10,\n",
    "    n_groupC=6,\n",
    "    n_groupD=5,\n",
    "    score_source='prob',\n",
    "    use_object_index=None\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ec8ead5d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading checkpoint shards: 100%|██████████| 3/3 [00:10<00:00,  3.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MODEL LOADED\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing 69999/70000::   0%|          | 0/16 [00:17<?, ?it/s]"
     ]
    },
    {
     "ename": "Exception",
     "evalue": "Not enough samples (0/16) with operation sequence remove",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mException\u001B[0m                                 Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[3], line 1\u001B[0m\n\u001B[0;32m----> 1\u001B[0m dataloader, dataset, model \u001B[38;5;241m=\u001B[39m \u001B[43mget_model_and_dataset\u001B[49m\u001B[43m(\u001B[49m\u001B[43margs\u001B[49m\u001B[43m)\u001B[49m\n",
      "File \u001B[0;32m/projectnb/mcnet/gvfranco/entity-tracking-gemma/behavioral_experiments/../nnsight_patching_experiment/run_patching.py:121\u001B[0m, in \u001B[0;36mget_model_and_dataset\u001B[0;34m(args)\u001B[0m\n\u001B[1;32m    119\u001B[0m \u001B[38;5;28mprint\u001B[39m(\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mMODEL LOADED\u001B[39m\u001B[38;5;124m\"\u001B[39m)\n\u001B[1;32m    120\u001B[0m \u001B[38;5;66;03m# load dataset\u001B[39;00m\n\u001B[0;32m--> 121\u001B[0m dataloader, dataset \u001B[38;5;241m=\u001B[39m \u001B[43mload_dataloader\u001B[49m\u001B[43m(\u001B[49m\n\u001B[1;32m    122\u001B[0m \u001B[43m    \u001B[49m\u001B[43mmodel\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmodel\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    123\u001B[0m \u001B[43m    \u001B[49m\u001B[43mtokenizer\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmodel\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mtokenizer\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    124\u001B[0m \u001B[43m    \u001B[49m\u001B[43mdatafile\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mdatafile\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    125\u001B[0m \u001B[43m    \u001B[49m\u001B[43mnum_samples\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mnum_samples\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    126\u001B[0m \u001B[43m    \u001B[49m\u001B[43mnum_boxes\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;241;43m7\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m  \u001B[49m\u001B[38;5;66;43;03m# args.num_boxes,\u001B[39;49;00m\n\u001B[1;32m    127\u001B[0m \u001B[43m    \u001B[49m\u001B[43mops_order\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mops_order\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    128\u001B[0m \u001B[43m    \u001B[49m\u001B[43mquery_ops_order\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mquery_ops_order\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    129\u001B[0m \u001B[43m    \u001B[49m\u001B[43msuccess_filter\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43msuccess_filter\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    130\u001B[0m \u001B[43m    \u001B[49m\u001B[43moperations_on_same_obj\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moperations_on_same_obj\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    131\u001B[0m \u001B[43m    \u001B[49m\u001B[43mcopy_filter\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mcopy_filter\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    132\u001B[0m \u001B[43m    \u001B[49m\u001B[43mbatch_size\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mbatch_size\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    133\u001B[0m \u001B[43m    \u001B[49m\u001B[43mreturn_dataset\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43;01mTrue\u001B[39;49;00m\u001B[43m,\u001B[49m\n\u001B[1;32m    134\u001B[0m \u001B[43m    \u001B[49m\u001B[43mmax_initial_objects_per_box\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mmax_initial_objects_per_box\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    135\u001B[0m \u001B[43m    \u001B[49m\u001B[43mcounterfactual_format\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mcounterfactual_format\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    136\u001B[0m \u001B[43m    \u001B[49m\u001B[43mdata_field\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mdata_field\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    137\u001B[0m \u001B[43m    \u001B[49m\u001B[43mtoken_step\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mtoken_step\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    138\u001B[0m \u001B[43m    \u001B[49m\u001B[43mprepend_space_to_answer\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mprepend_space_to_answer\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    139\u001B[0m \u001B[43m    \u001B[49m\u001B[43mnum_query_object\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mnum_query_object\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    140\u001B[0m \u001B[43m    \u001B[49m\u001B[43msort_query_objects\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43msort_query_objects\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    141\u001B[0m \u001B[43m    \u001B[49m\u001B[43mseed\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43margs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mseed\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    142\u001B[0m \u001B[43m\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    143\u001B[0m \u001B[38;5;28mprint\u001B[39m(\u001B[38;5;124mf\u001B[39m\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mDATALOADER CREATED (\u001B[39m\u001B[38;5;132;01m{\u001B[39;00m\u001B[38;5;28mlen\u001B[39m(dataset)\u001B[38;5;132;01m=}\u001B[39;00m\u001B[38;5;124m)\u001B[39m\u001B[38;5;124m\"\u001B[39m)\n\u001B[1;32m    144\u001B[0m \u001B[38;5;28mprint\u001B[39m(\u001B[38;5;124mf\u001B[39m\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mmax data length: \u001B[39m\u001B[38;5;132;01m{\u001B[39;00m\u001B[38;5;28mlen\u001B[39m(dataset[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mbase_tokens\u001B[39m\u001B[38;5;124m'\u001B[39m][\u001B[38;5;241m0\u001B[39m])\u001B[38;5;132;01m}\u001B[39;00m\u001B[38;5;124m\"\u001B[39m)\n",
      "File \u001B[0;32m/projectnb/mcnet/gvfranco/entity-tracking-gemma/behavioral_experiments/../pp_experiment/utils.py:196\u001B[0m, in \u001B[0;36mload_dataloader\u001B[0;34m(tokenizer, datafile, num_samples, num_boxes, ops_order, query_ops_order, min_numops, min_query_numops, max_seq_len, batch_size, return_dataset, max_initial_objects_per_box, counterfactual_format, data_field, token_step, prepend_space_to_answer, model, success_filter, operations_on_same_obj, copy_filter, num_query_object, sort_query_objects, seed, object_data_file)\u001B[0m\n\u001B[1;32m    189\u001B[0m     raw_data \u001B[38;5;241m=\u001B[39m load_pp_data_nikhil(\n\u001B[1;32m    190\u001B[0m         tokenizer\u001B[38;5;241m=\u001B[39mtokenizer,\n\u001B[1;32m    191\u001B[0m         num_samples\u001B[38;5;241m=\u001B[39mnum_samples,\n\u001B[1;32m    192\u001B[0m         data_file\u001B[38;5;241m=\u001B[39mdatafile,\n\u001B[1;32m    193\u001B[0m         num_boxes\u001B[38;5;241m=\u001B[39mnum_boxes\n\u001B[1;32m    194\u001B[0m     )\n\u001B[1;32m    195\u001B[0m \u001B[38;5;28;01melse\u001B[39;00m:\n\u001B[0;32m--> 196\u001B[0m     raw_data \u001B[38;5;241m=\u001B[39m \u001B[43mload_pp_data\u001B[49m\u001B[43m(\u001B[49m\n\u001B[1;32m    197\u001B[0m \u001B[43m        \u001B[49m\u001B[43mtokenizer\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mtokenizer\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    198\u001B[0m \u001B[43m        \u001B[49m\u001B[43mnum_samples\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mnum_samples\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    199\u001B[0m \u001B[43m        \u001B[49m\u001B[43mnum_boxes\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mnum_boxes\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    200\u001B[0m \u001B[43m        \u001B[49m\u001B[43mdata_file\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mdatafile\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    201\u001B[0m \u001B[43m        \u001B[49m\u001B[43mobject_data_file\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mobject_data_file\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    202\u001B[0m \u001B[43m        \u001B[49m\u001B[43mops_order\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mops_order\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    203\u001B[0m \u001B[43m        \u001B[49m\u001B[43mquery_ops_order\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mquery_ops_order\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    204\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmin_numops\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmin_numops\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    205\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmin_query_numops\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmin_query_numops\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    206\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmax_initial_objects_per_box\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmax_initial_objects_per_box\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    207\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmax_seq_len\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmax_seq_len\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    208\u001B[0m \u001B[43m        \u001B[49m\u001B[43mcounterfactual_format\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mcounterfactual_format\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    209\u001B[0m \u001B[43m        \u001B[49m\u001B[43mdata_field\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mdata_field\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    210\u001B[0m \u001B[43m        \u001B[49m\u001B[43mtoken_step\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mtoken_step\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    211\u001B[0m \u001B[43m        \u001B[49m\u001B[43mprepend_space_to_answer\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mprepend_space_to_answer\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    212\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmodel\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmodel\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    213\u001B[0m \u001B[43m        \u001B[49m\u001B[43msuccess_filter\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43msuccess_filter\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    214\u001B[0m \u001B[43m        \u001B[49m\u001B[43moperations_on_same_obj\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43moperations_on_same_obj\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    215\u001B[0m \u001B[43m        \u001B[49m\u001B[43mcopy_filter\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mcopy_filter\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    216\u001B[0m \u001B[43m        \u001B[49m\u001B[43mnum_query_object\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mnum_query_object\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    217\u001B[0m \u001B[43m        \u001B[49m\u001B[43msort_query_objects\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43msort_query_objects\u001B[49m\n\u001B[1;32m    218\u001B[0m \u001B[43m    \u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    220\u001B[0m dataset \u001B[38;5;241m=\u001B[39m Dataset\u001B[38;5;241m.\u001B[39mfrom_dict(raw_data)\u001B[38;5;241m.\u001B[39mwith_format(\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mnumpy\u001B[39m\u001B[38;5;124m\"\u001B[39m)\n\u001B[1;32m    221\u001B[0m dataloader \u001B[38;5;241m=\u001B[39m DataLoader(dataset, batch_size\u001B[38;5;241m=\u001B[39mbatch_size, collate_fn\u001B[38;5;241m=\u001B[39mpartial(pad_batch_collate_fn, tokenizer\u001B[38;5;241m=\u001B[39mtokenizer))\n",
      "File \u001B[0;32m/projectnb/mcnet/gvfranco/entity-tracking-gemma/behavioral_experiments/../pp_experiment/utils.py:797\u001B[0m, in \u001B[0;36mload_pp_data\u001B[0;34m(tokenizer, num_samples, num_boxes, ops_order, query_ops_order, min_numops, min_query_numops, data_file, object_data_file, max_initial_objects_per_box, max_seq_len, counterfactual_format, data_field, token_step, prepend_space_to_answer, model, success_filter, operations_on_same_obj, copy_filter, num_query_object, sort_query_objects)\u001B[0m\n\u001B[1;32m    751\u001B[0m \u001B[38;5;28;01mdef\u001B[39;00m\u001B[38;5;250m \u001B[39m\u001B[38;5;21mload_pp_data\u001B[39m(\n\u001B[1;32m    752\u001B[0m     tokenizer:AutoTokenizer,\n\u001B[1;32m    753\u001B[0m     num_samples:\u001B[38;5;28mint\u001B[39m,\n\u001B[0;32m   (...)\u001B[0m\n\u001B[1;32m    772\u001B[0m     sort_query_objects: Optional[\u001B[38;5;28mbool\u001B[39m]\u001B[38;5;241m=\u001B[39m\u001B[38;5;28;01mFalse\u001B[39;00m,\n\u001B[1;32m    773\u001B[0m )  \u001B[38;5;241m-\u001B[39m\u001B[38;5;241m>\u001B[39m Dict[\u001B[38;5;28mstr\u001B[39m, torch\u001B[38;5;241m.\u001B[39mTensor]:\n\u001B[1;32m    774\u001B[0m \u001B[38;5;250m    \u001B[39m\u001B[38;5;124;03m\"\"\"\u001B[39;00m\n\u001B[1;32m    775\u001B[0m \u001B[38;5;124;03m    Load data for path patching task consisting of original and counterfactual\u001B[39;00m\n\u001B[1;32m    776\u001B[0m \u001B[38;5;124;03m    examples (random label and random object).\u001B[39;00m\n\u001B[0;32m   (...)\u001B[0m\n\u001B[1;32m    795\u001B[0m \u001B[38;5;124;03m        sort_query_objects (Optional[bool]): whether to sort query objects by appearance order.\u001B[39;00m\n\u001B[1;32m    796\u001B[0m \u001B[38;5;124;03m    \"\"\"\u001B[39;00m\n\u001B[0;32m--> 797\u001B[0m     input_ids,last_token_indices,output_ids,output_data \u001B[38;5;241m=\u001B[39m \u001B[43msample_box_data\u001B[49m\u001B[43m(\u001B[49m\n\u001B[1;32m    798\u001B[0m \u001B[43m        \u001B[49m\u001B[43mtokenizer\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mtokenizer\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    799\u001B[0m \u001B[43m        \u001B[49m\u001B[43mnum_samples\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mnum_samples\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    800\u001B[0m \u001B[43m        \u001B[49m\u001B[43mdata_file\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mdata_file\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    801\u001B[0m \u001B[43m        \u001B[49m\u001B[43mobject_data_file\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mobject_data_file\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    802\u001B[0m \u001B[43m        \u001B[49m\u001B[43mdesired_ops_order\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mops_order\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    803\u001B[0m \u001B[43m        \u001B[49m\u001B[43mdesired_query_ops_order\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mquery_ops_order\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    804\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmin_numops\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmin_numops\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    805\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmin_query_numops\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmin_query_numops\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    806\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmax_initial_objects_per_box\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmax_initial_objects_per_box\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    807\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmax_seq_len\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmax_seq_len\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    808\u001B[0m \u001B[43m        \u001B[49m\u001B[43mcounterfactual_format\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mcounterfactual_format\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    809\u001B[0m \u001B[43m        \u001B[49m\u001B[43mdata_field\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mdata_field\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    810\u001B[0m \u001B[43m        \u001B[49m\u001B[43mtoken_step\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mtoken_step\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    811\u001B[0m \u001B[43m        \u001B[49m\u001B[43mprepend_space_to_answer\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mprepend_space_to_answer\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    812\u001B[0m \u001B[43m        \u001B[49m\u001B[43mmodel\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mmodel\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    813\u001B[0m \u001B[43m        \u001B[49m\u001B[43msuccess_filter\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43msuccess_filter\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    814\u001B[0m \u001B[43m        \u001B[49m\u001B[43moperations_on_same_obj\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43moperations_on_same_obj\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    815\u001B[0m \u001B[43m        \u001B[49m\u001B[43mcopy_filter\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mcopy_filter\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    816\u001B[0m \u001B[43m        \u001B[49m\u001B[43mnum_query_object\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mnum_query_object\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    817\u001B[0m \u001B[43m        \u001B[49m\u001B[43msort_query_objects\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43msort_query_objects\u001B[49m\n\u001B[1;32m    818\u001B[0m \u001B[43m    \u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    820\u001B[0m     all_base_input_ids \u001B[38;5;241m=\u001B[39m []         \u001B[38;5;66;03m# Clean inputs\u001B[39;00m\n\u001B[1;32m    821\u001B[0m     all_base_input_last_pos \u001B[38;5;241m=\u001B[39m []    \u001B[38;5;66;03m# Clean last token indices\u001B[39;00m\n",
      "File \u001B[0;32m/projectnb/mcnet/gvfranco/entity-tracking-gemma/behavioral_experiments/../pp_experiment/utils.py:683\u001B[0m, in \u001B[0;36msample_box_data\u001B[0;34m(tokenizer, num_samples, data_file, object_data_file, desired_ops_order, desired_query_ops_order, min_numops, min_query_numops, max_initial_objects_per_box, max_seq_len, counterfactual_format, data_field, token_step, prepend_space_to_answer, model, success_filter, operations_on_same_obj, copy_filter, num_query_object, sort_query_objects)\u001B[0m\n\u001B[1;32m    680\u001B[0m         \u001B[38;5;28;01mbreak\u001B[39;00m\n\u001B[1;32m    682\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m \u001B[38;5;28mlen\u001B[39m(labels) \u001B[38;5;241m<\u001B[39m num_samples:\n\u001B[0;32m--> 683\u001B[0m     \u001B[38;5;28;01mraise\u001B[39;00m \u001B[38;5;167;01mException\u001B[39;00m(\u001B[38;5;124mf\u001B[39m\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mNot enough samples (\u001B[39m\u001B[38;5;132;01m{\u001B[39;00m\u001B[38;5;28mlen\u001B[39m(labels)\u001B[38;5;132;01m}\u001B[39;00m\u001B[38;5;124m/\u001B[39m\u001B[38;5;132;01m{\u001B[39;00mnum_samples\u001B[38;5;132;01m}\u001B[39;00m\u001B[38;5;124m) with operation sequence \u001B[39m\u001B[38;5;132;01m{\u001B[39;00mdesired_ops_order\u001B[38;5;132;01m}\u001B[39;00m\u001B[38;5;124m\"\u001B[39m)\n\u001B[1;32m    685\u001B[0m \u001B[38;5;66;03m# assert np.var([len(p.split()) for p in prompts]) == 0, \"number of white space tokens differ across prompts!\"\u001B[39;00m\n\u001B[1;32m    686\u001B[0m input_tokens \u001B[38;5;241m=\u001B[39m tokenizer(prompts, padding\u001B[38;5;241m=\u001B[39m\u001B[38;5;28;01mTrue\u001B[39;00m, return_tensors\u001B[38;5;241m=\u001B[39m\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mpt\u001B[39m\u001B[38;5;124m\"\u001B[39m)\n",
      "\u001B[0;31mException\u001B[0m: Not enough samples (0/16) with operation sequence remove"
     ]
    }
   ],
   "source": [
    "dataloader, dataset, model = get_model_and_dataset(args)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c1bd0ce7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# sentence = \"The pipe and the disk are in Box 0, the plant and the ball are in Box 1, the boot is in Box 2, the wire is in Box 3, the pin and the coin are in Box 4, the ticket is in Box 5, the guitar and the container are in Box 6. Remove the guitar from Box 6. Box 6 contains the\"\n",
    "# removed_obj = \"guitar\"\n",
    "# correct_obj = \"container\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ae840dd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "sentence = \"The pipe and the disk are in Box 0, the plant and the ball are in Box 1, the boot is in Box 2, the wire is in Box 3, the pin and the coin are in Box 4, the ticket is in Box 5, the guitar and the container are in Box 6. Remove the container from Box 6. Box 6 contains the\"\n",
    "removed_obj = \"container\"\n",
    "correct_obj = \"guitar\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "bb835dab",
   "metadata": {},
   "outputs": [],
   "source": [
    "llm = LanguageModel(\"codellama/CodeLlama-13b-hf\", device_map=\"mps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8dc52f24",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "LlamaForCausalLM(\n",
       "  (model): LlamaModel(\n",
       "    (embed_tokens): Embedding(32016, 5120)\n",
       "    (layers): ModuleList(\n",
       "      (0-39): 40 x LlamaDecoderLayer(\n",
       "        (self_attn): LlamaAttention(\n",
       "          (q_proj): Linear(in_features=5120, out_features=5120, bias=False)\n",
       "          (k_proj): Linear(in_features=5120, out_features=5120, bias=False)\n",
       "          (v_proj): Linear(in_features=5120, out_features=5120, bias=False)\n",
       "          (o_proj): Linear(in_features=5120, out_features=5120, bias=False)\n",
       "        )\n",
       "        (mlp): LlamaMLP(\n",
       "          (gate_proj): Linear(in_features=5120, out_features=13824, bias=False)\n",
       "          (up_proj): Linear(in_features=5120, out_features=13824, bias=False)\n",
       "          (down_proj): Linear(in_features=13824, out_features=5120, bias=False)\n",
       "          (act_fn): SiLU()\n",
       "        )\n",
       "        (input_layernorm): LlamaRMSNorm((5120,), eps=1e-05)\n",
       "        (post_attention_layernorm): LlamaRMSNorm((5120,), eps=1e-05)\n",
       "      )\n",
       "    )\n",
       "    (norm): LlamaRMSNorm((5120,), eps=1e-05)\n",
       "    (rotary_emb): LlamaRotaryEmbedding()\n",
       "  )\n",
       "  (lm_head): Linear(in_features=5120, out_features=32016, bias=False)\n",
       "  (generator): Generator(\n",
       "    (streamer): Streamer()\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "llm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "33764efa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "LlamaRMSNorm((5120,), eps=1e-05)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "llm.model.norm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "4f7b7079",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[5639]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "removed_obj_id = llm.tokenizer.encode(removed_obj, add_special_tokens=False)\n",
    "removed_obj_id"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e781b73b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[11210]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "correct_obj_id = llm.tokenizer.encode(correct_obj, add_special_tokens=False)\n",
    "correct_obj_id"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b2bad14b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bda3c403e0fc4825bfa1c7d794b32be3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/3 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "logit_lens_layers = []\n",
    "with llm.trace(sentence, remote=False):\n",
    "    for layer in range(len(llm.model.layers)):\n",
    "        layer_output = llm.lm_head(llm.model.norm(llm.model.layers[layer].output[0, -1])).save()\n",
    "        logit_lens_layers.append(layer_output)\n",
    "    output = llm.output.save()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b19a0664",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([40, 32016])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logit_lens_layers = torch.vstack(logit_lens_layers)\n",
    "logit_lens_layers.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "44423ae2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'guitar'"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "llm.tokenizer.decode(output[\"logits\"][0, -1, :].argmax())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "a30cf8cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(15.3195, device='mps:0', grad_fn=<MaxBackward1>),\n",
       " tensor(12.6021, device='mps:0', grad_fn=<SelectBackward0>))"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output[\"logits\"][0, -1, :].max(), output[\"logits\"][0, -1, removed_obj_id][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "8c78f6f8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHHCAYAAABTMjf2AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAm4dJREFUeJztnQd4E/Ufxt/u0kILhZa9R9l77yVDVJYgiAIyFAVRQRRcDPUPDhQUxQk4QFBAUFSUvfeeBcoqmxY66B75P9/fNSUtHUmbNuv9PM+1l0ty+V3uLvfedzrpdDodCCGEEEIcEGdLD4AQQgghxFJQCBFCCCHEYaEQIoQQQojDQiFECCGEEIeFQogQQgghDguFECGEEEIcFgohQgghhDgsFEKEEEIIcVgohAghhBDisFAI5TOVKlXC8OHD0x5v3rwZTk5O6r81M23aNDVOQrI7nvOKHGPjxo3L8XWLFi1Sr7148aLZPpvAZr93cx+H1kZ+XCfOnj2Lbt26wdfXV6171apVKCguXryoPlOOJ2uEQiiPPxCZTZMnT7b08AghDk5MTIy6obH2my5rw16/t2HDhuHYsWN4//338dNPP6Fp06YWHc/ff/+tvmdrwNXSA7B1ZsyYgcqVK6dbVrdu3Sxf3759e8TGxsLd3b0ARkeIffD0009j0KBB8PDwsPRQbOqCPn36dDXfsWNHu/reg4KC4OzsbLXfm7Uh15xdu3bhzTffNMoCa24qVqyoxuDm5pZOCH3xxRdWIYYohPJIz549TVLWcvJ6enrm65hI/pCUlISUlBSKWAvg4uKiJuIY33tO55q1CTNr5/bt2+p/0aJFLfL5Tk5OBXLdk2MmISHB5M+ia8wKfL9y1yFWpAMHDqB169YoVKiQsjJ99dVXmb532bJleOONN1CqVCl4e3vjscceQ0hIyAOftWfPHvTo0UP5hL28vNChQwfs2LHjgddt374dzZo1UwdP1apV8fXXX5u0TfI5Dz/8MIoVK6bGU79+fcydOzft+aNHjyp/fpUqVdRnyLhHjBiBsLCwdOuJiorCyy+/rPz/8kMXEBCAhx56CAcPHszVdpnDp/3xxx9jzpw56nuRMZ08eVI9f/r0aTz++OPw8/NT2yRi+I8//sjUfSrf7/jx4+Hv769+iJ577jl1soaHh2Po0KHqe5Pptddeg06nS7eO6OhoTJw4EeXLl1efHxgYqMZk+Do5djp16pTpj0LZsmXVOA2XyfbUqVNHjbtkyZJqPHfv3k33Xln/e++9h3LlyqnvWNZ/4sQJo78/Y8ZtyOLFi9VrZExNmjTB1q1bTY5Vke9fXiPHm54VK1aoZf369Uv32lq1auGJJ55Ie7xw4UJ07txZHXMy3tq1a2P+/PkPfMb+/fvRvXt3lChRIu08lWPZGP755x91rBYpUgQ+Pj7qnFuyZEm61/z2229q+2Xd8hlPPfUUrl69mu41ci4VLlxYLe/Tp4+al2Pr1VdfRXJysnqNfE+yTBDrht5tr7/7NvaczOx7l/PzkUceUcd18+bN1ftlPT/++OMD2yzHuJzT+uOgWrVq+OCDD9RxaOy5ZkyMkH6c8jswYcIEte3yW9S3b980EWDMPszpezP23L9z547aH/Xq1VP7R/a33DQfOXLkgW25cuWK2o8yXjn+XnnlFcTHx8NYDh06pNYtnyGf1aVLF+zevTvteRm7WGSESZMmqe2R7y87Ll26pK4rhmP6999/H7h2ZRWrJdc0Q2taxhgheY9YgwTDsBI9cizItbB48eJqH8k5sXz58ixjDOX3Q37T5LhZu3YtTIUWoTwSERGB0NDQdMvkBDMVuRCJmBg4cCAGDx6MX3/9Fc8//7y6I8r4Qys+XjkAXn/9ddy6dUv9eHTt2hWHDx9WB42wceNGdXLIATR16lRlidL/2G/btk39gAniM5YAOjn55YSROzF5vVwgjWHdunXqR7F06dJ46aWX1A/qqVOnsGbNGvVY/5rz58/jmWeeUc/LBfWbb75R/+WE1Z8AY8aMUQe7HNhyIZIfZfmxlfU1btzYpO0yF7LuuLg4PPvss+okkx8/GXebNm2UyJB4MPmxkP0lP2Zy4ZUfX0NefPFFtd3ywyrbK9sugmjnzp2oUKEC/ve//ykz8UcffaREjYgjQUSD/Bht2rQJI0eORMOGDdWPkfyYyUXw008/Va+TC7rsuxs3bqjP0SPf3bVr15RrQ4+IHvkxkn0h4uzChQuYN2+e+jGVi4jedP3OO+8oISTHpEwiRuU4EQGXE8aOW8+WLVuUuJfxyHf85ZdfKqG7d+/ebN3MGWnbtq06lkREiRgX5JiQY0S+Cz1yYZSLmaGLQESP/JDKuF1dXfHnn3/ihRdeUBfssWPHqtfIuaY/V2S/yz6UH/iVK1fmODb5zuU8ls+YMmWKeq985/Kj/eSTT6a9RvaLCKSZM2fi5s2b6oZC9ou81vBuXgSPXMxbtGihLhrr16/H7NmzlYiQ3w0Zo2yTzMvxqBeC+u/F2HMyK86dO6fEgOxfiT1ZsGCBurjJeSnbqHcxifCTfS7HnRzrcszL9l+/fl39buV0rpmKnGtyUyG/DbJv5DNkP8vxZcw+zOl7M/bcl+9WgpEHDBighJbsS7nBlO9DBF6ZMmXU68RdJMLl8uXL6viX5RK/I79zxiDjadeunRJBciMl5698jogQOa/k+JBtkO0UMSPXFjmfRTBldxPTuXNntY/0v+ki2OV8NhdyPMhvkxyHsr0ZkeNezsUhQ4ao35ylS5eq71KuK7169Ur3WvmuZB/IfpZrb04iL1N0JFcsXLhQbm0znQypWLGibtiwYWmPN23apF4j//V06NBBLZs9e3basvj4eF3Dhg11AQEBuoSEhHTvLVu2rC4yMjLttb/++qtaPnfuXPU4JSVFV716dV337t3VvJ6YmBhd5cqVdQ899FDasj59+ug8PT11ly5dSlt28uRJnYuLywPbkpGkpCS1PtnGu3fvpnsu4+dm5JdfflHr37p1a9oyX19f3dixY7P8PFO2K69cuHBBjc/Hx0d369atdM916dJFV69ePV1cXFy6sbVu3VqNL+MxknG8rVq10jk5OenGjBmT7rssV66cOhb0rFq1Sr3/vffeS/f5jz/+uHr/uXPn1OOgoCD1us8//zzd61544QVd4cKF077/bdu2qdctXrw43evWrl2bbrlsr7u7u65Xr17pxv3GG2+o1xkez5lh7LgF/Tmzf//+tGVyLMox2bdv3we+S9kv2VGnTh3dwIED0x43btxYN2DAAPXeU6dOqWUrV65Uj48cOZLtMSr7rUqVKmmPf//9d/W+ffv26UwhPDxcV6RIEV2LFi10sbGx6Z7Tf79yjsu5Xrdu3XSvWbNmjfrMd955J22ZfP+ybMaMGenW1ahRI12TJk3SHt++fVu9burUqQ+MydhzMrPvXc73jK+TY8bDw0M3ceLEtGXvvvuuztvbW3fmzJl0nzN58mT1+3L58uUcz7WsyPi7qh9n165d0x2zr7zyivos2QfG7sPsvjdjz315Pjk5Od17ZTvlOzLcb3PmzFGfJb/heqKjo3XVqlV74DqRGfL7LedqcHBw2rJr166p4619+/bpPlvW99FHH+lyYvbs2eq1ch7rkWOyZs2aD4wp437QI79jhr9l+s+X/aRHfuuzusZkPD7l/JBzo3PnzumWy/udnZ11J06c0OUFusbyiJj3RNUaTrlB7kJFJesRS5A8ljsYcZkZIhYDMa/rkTszsciIVUEQy5CkSsqdplhVxGIlkyh9ufuQO2a505W7SrlTl7sZuVszdBvI3WZOyF2qWBTE9J3R92x4R6m3UglyxydjadmypXps6PaSdYjbS+4UMsPY7TIn/fv3TzOV603ecgciljtx5enHIOOR70zGl9GVIXfNht+H3KXJOSzL9UgchpjY5U5Sj+xPWS53ioaIy0neL64WoUaNGsrqor/rFWTfinXt0UcfTfv+xe0i7kRxN+rHLZPcxcsdov6OT6wLchcmd9eG45b9bAzGjltPq1at1Bj0yLHYu3dvdWzqXT3GInfHYgUSZP+IK0IsDHKnqF8u/+VYM7Q2GR6jeiuv3L3L/pDHgv4Yl7vSxMREo8ckvwkyFrEgZIxd0H+/4q6Rc12sUIavkbvfmjVr4q+//npgvWJBzbjthsdPdhh7TmaFWGzl8/TIOSKuTcPPl+NNXiMWGsPjTazXsl8zuj8znmu5Qfa14TErny+fJa6evOxDU899sWjpg7nl8+U1co7Jd2T4/cq5Ir/dhu5rcUXLduSErPe///5Tv9/imtQj65PfSLGCRkZGwlTWrl2rLF5ikdEjx+To0aNRUBgen+ItkXNQ9mVmx6acp3I85gW6xvKIuGLMkYYoJlExsxoiFzhBTLf6HymhevXq6V4nJ7743vV+fDkhBTFZZ4UcWOKHFtNsxvUJcsLqhVVWBAcHq/85uS/kB0TcQmLelB/7jOPQ8+GHH6oxSzyBXBjFhCuiT3+SG7td8sObGeI6MkREgeEJlxkZMwLFJSAX87fffltNmSHbKD8kegxFpv5zBdnOjMsNY3Xkx1uOC0PRqxeq+uf1iHtM4sbkh1g+W/z4Mg7DOBj5/uT7EZ9/VuM2XG/G40IuUll9t4aYMu7MPkd/7ItrRdxYhu6+nJAfS4mtk/0kx6ecGyK09AJJfszlv7g3DLOOxP0k7hTJrJHPNUS+M9k38oMrF2s5lsW9J+4HuQjJRSe74F1jzhP9dyLnXUZECBm69vQXpoyiQfZNxlivvJ6TWZHxmM7s8+V4k1ikrMRNxs/NeK7lhozj0h+v+nHldh+aeu7LDZm4d8TNKzeLhoJe4l4M97v8dmd0RWZ2HGREzg05VjN7rZxrMgaJHdW7Ko3l0qVLysWacUwyzoJChKq45uXm1zBeKjOXrTmOGwohO0RvFZGYE7EUZIbcnZgSkJcX5A5KYgMkRkTGI58tY5Q4EEMLjrxOLli///67utOR8UtgpfjvJS7I2O3KCrlTyhiTkFNRtoxCST8GCYTMymqW8Qcjq6ybzJZnFUycEyJ4JPZC7sLFciM+c7l4y3dsOHYRQRJYmBl5vRu3BiROSBBrg1gnJLZMbjDkuPrss89w7949ZcmUODtDoSIWRREcn3zyiRKoYpGVGwG5WOr3ufwIi5VNYmgkhkgsVhL3I7E5siy7Y8/c5DWTy9hz0tTPNzx+ZT1ifZTYlczQ3+jpyemmxBhyGlde9qEp577E/YlYknW/++67Kt5JhLecm+a2WlsSpyxiyUT45fYYlRsVsUZJqRkRkvK7LbFP8nudMbnAXMcNhZCVIO4gcfEYWoXOnDmj/mcM/tJbRgxPcrlb0Qf0iZoXJIBOzNBZIRc+OYgyrk9fpyMn9J9z/PjxLD9H7sQ2bNig7sAkADerbdAjB724B2SSuyu5kMlFS4SQsduVFRndlqbeKQl665ScmLkZgylIpoe4qcQMb2hdkUBf/fOGd0VinRT3mAQNiniUO13Du1z5/mR9Yg3J7sdDv17ZR4Ymd7kDNcbiYMq49Z+TETn2xUVgqjgTi4BM8mMqQkjvvpEfVckmEqEoP9LyWI9cEOWmQDJ/DC0KWQWHinVWJjku5YdZAjrFsjJq1Kgcz5Os7qr134mcdxKoaogsy/id5eUiZeo5mVtku0V45vd5khuy24dZfW+mnPsitiTT8vvvv38gi84wmUb2qxwX8htu+LnG/P7KuSHnSGavlXNNhFdGq7MxVKxYUQV0ZxyTXGMyIhY32abMrEqGvx2ZkdX3LEHnYvEUkWr4+yVCKL9gjJCVINlahmnrEqMhj+VgN4yfECRNVS4yhiedRPiLWBDk9fIjJNkk8kOUEX06qSh2ubOR7AbJWtAjWVpyEOaEiBS5AEtmRsaTQX8Hpr8ryGjpyJgxIhenjCZ5sV6Ii0VvuTJ2u7JCfrwMp4wWImOQMYk5XfaNfOemjsEUxDUo34tkdRkiVgr5EdHvb0OrkNzVSgaPxC4YusX0VgBZn9yhZnb86fehfDfyY//555+n228Z95m5xi3uKEPfv5jzV69erbJ7cnNXKeJHYjkk60wvhMTqIaJs1qxZaem4ejI7RuVYzPjDKwIi43Gst0xmZ12V7ZDPlkwwiccxRL8+ca/LsSVuPcN1STyVnI8ZM2WMQS6SQsZz09hzMq/I8Sb7NrPfEhmTHHMFjTH7MKvvzZRzX77jjJ8jIjxj/KCcK3ITbJgaLu4uyeDLCfkMObbkXDEsbyAZaiLuxDoqN42m0r17dzVOw5IActx+++23D7xWfo/lN8cwm1TcWpmVc8mI/qY/s+NTficM3YmyffnZEoQWIStBLvjiBpIdLiZjubMX/6icEIbVOAUxs8pBLqmvctDLD5jcaeqD2eRO4LvvvlMXHLF6yOvEby0Ht9zlyskhd8GC3BVKcJxcMMQKIz9OcgGU9xnWY8kM+RxJNZWAXPkxkc8RcSF3I5LWKT+A8lly9y3xPxKcKOMQt5f4zQ0RYSc1ayRosEGDBspELVaFffv2KbO1qduV3wHy8v1LjRD5zuXOR/aD/OhLTZDMaoXkBvle5a5SqsHKcSHfi3x38sMnJna9pcHwwiNme5nkGMl41yrxERKALxdkObbkR1SOLbEEyI+0xDTI96+vSSOvk9II8mMt7iS5KBtTGsLUcUvsjPz4GqbPC/rqvqYix7K4/+THVO8qkx9XqUsix6RczAwL9cn3II9l3PL9iMiWH3258Ble8H744Qc1NkmRlm2QY1ZeJ8edfEdZIc+LCBRrg6TGSzyK3EnLcSIXPVmv7Ac5/+WYlv0kac769HmxCEvqs6mI4JMgUvktkd8UOSbku5bJmHMyr4jbTS6mcgzpU+vF6i0lO+TCL8dGbkqN5AVj9mF235ux575ss3QdkP0px51ssxyTGa0ksg65YZBYSEmKkd9PSSfXi7GckDgasXTLmOT3W5JuRKiJqJP9mxuee+45NSY5BiV9XsYkY9cH8RtacuSYln0pLlX5/RE3888///zAOZ4Z+psROe/l/JdzVEp9iOgXF7WsU84V8QzI9y7XuJyuSbkmTzlnDow+XTOnVFpj0+cl7VdSiCW1WlKH5X3z5s1Lty79eyXNdcqUKSrdtlChQirN2TD9Xc+hQ4d0/fr10xUvXlylbco6JbV4w4YN6V63ZcsWlXYraZiSLvzVV1+p1FFjD4/t27er1HVJ2ZR02fr166dL5b5y5YpKhS5atKhKkZd0ZknxNExRlXIBkyZN0jVo0CBtPTL/5Zdf5nq78kJO6aaSrjp06FBdqVKldG5ubqqkwSOPPKJbvnx5jseI/ruVNF1D5DiR7TYkKipKpQCXKVNGfY6k6MqYDFOEDWnTpo1a96hRo7Lctm+++Ubtbzl25LuWdODXXntN7RM9kvo7ffp0XenSpdXrOnbsqDt+/HiW6bIZMXbcMlZJo/3555/Va2R/Shp4xrRhY9PnBUmlldfWqlUr3XJJ55flb7/99gPv+eOPP9RxK+depUqVdB988IFuwYIF6T7z4MGDusGDB+sqVKigxinnn+xzw9T/7JDPkDRr+T4lVbx58+bqXDZk2bJlavtl/X5+frohQ4ao8yen40TI7JzduXNn2rlteL4Zc05mlz4vvzk5pUzrjwP5rZJ0cBlDiRIl1Hfw8ccfp5UFMSW1O6f0+YznWsbfW2P3YVbfm7HnvqTPSykB/fkj5+WuXbsy/Y7kt/uxxx7TeXl5qe/npZdeSitpkVP6vH6bpNSDlMqQdXTq1EmN3xBTv+Pz58+rfSxj9/f3V9uyYsUKtY7du3c/kG4v34F8n7Kd8l0akz4vJUNefPFFtX4pq2F47H7//fdpvweSti/vy+z41v9+5BWn1JURCyJ3qOLKEF9xdkgmkNxpy927YbolIfaOxFrI3aeY3MVySAgpWObMmaMsk2L5MsyKtQcYI0QIsXrERSUm+dxUGyaEmEZsbGy6xxIjJC43KXVhbyJIYIwQIcRqkfgLiUGQIGKpB2Rs7AQhJPf069dPZVBK7KckDkjcj8R+ZlV6w9ahECKEWC2SMSVBt1IaILOsFUKI+enevbtKTBHhI9lbEjwu5QUyZqLaC4wRIoQQQojDwhghQgghhDgsFEKEEEIIcVgYI5QD0hdGKn9KZdisSoITQgghxLqQyB8pmikFiw2bLGeEQigHRATlpl8LIYQQQixPTvXHKIRyQN80Ur7I3PRtIYQQQkjBExkZqQwZhs2fM4NCKAf07jARQRRChBBCiG2RU1gLg6UJIYQQ4rBQCBFCCCHEYaEQIoQQQojDwhghMyFlyBMTEy09DGJFuLm5wcXFxdLDIIQQkg0UQmaoU3Djxg2Eh4dbeijECilatChKlSrFGlSEEGKlUAjlEb0ICggIUJ2xecEjeoEcExODW7duqcelS5e29JAIIYRkAoVQHt1hehFUvHhxSw+HWBmFChVS/0UMyTFCNxkhhFgfDJbOA/qYILEEEZIZ+mOD8WOEEGKdUAiZAbrDSFbw2CCEEOuGQogQQgghDguFELFra8yqVaty/f7NmzerdWSXEWjMawghhFgvFEKE5IHWrVvj+vXr8PX1tfRQCCGE5AIKIYKEhARLD8FmcXd3Z50gQgjJLbdOA1E3YUkohByQjh07Yty4cXj55ZdRokQJdO/eXS0/fvw4evbsicKFC6NkyZJ4+umnERoamu59L774onpfsWLF1Gu+/fZbREdH45lnnkGRIkVQrVo1/PPPP+k+b8uWLWjevDk8PDxUPZ3JkycjKSlJPffNN9+gTJkySElJSfee3r17Y8SIEWmPV69ejcaNG8PT0xNVqlTB9OnT09YhnD17Fu3bt1fP165dG+vWrcvxe4iPj8f48eNVaru8r23btti3b98Dr9uxYwfq16+vXtOyZUv1Pemha4wQQvLA2teB2TWAI0thKSiEzF1ELyHJIpN8tin88MMPypohF/mvvvpKXcg7d+6MRo0aYf/+/Vi7di1u3ryJgQMHPvA+EU979+5Vouj555/HgAEDlIvo4MGD6NatmxJQUkxQuHr1Kh5++GE0a9YMR44cwfz58/H999/jvffeU8/Le8PCwrBp06a0z7hz5476/CFDhqjH27Ztw9ChQ/HSSy/h5MmT+Prrr7Fo0SK8//776nkRUf369VPbs2fPHrU9r7/+eo7fwWuvvYYVK1aobZKxi4gTUSifb8ikSZMwe/ZsJZL8/f3x6KOPMh2eEELySlwEcHG7Nl+2KSyFk87UK6iDERkZqeI/IiIi4OPjk+65uLg4XLhwAZUrV1bWAhEktd/51yLjPDmjO7zcjauPKZYd2S65+OsRYSKC499/74//ypUrKF++PIKCglCjRg31PikiKa8TZF6+GxEhP/74Y1qlbbH67Nq1S1lP3nzzTSU2Tp06leY++vLLL5VQke/U2dkZffr0UQUpRSDprURi8QkJCVHPd+3aFV26dMGUKVPSxvbzzz8rIXPt2jX8999/6NWrFy5duqSsS4IIKbFu/f7772r9GRErlli1RFA9+eSTapmIm0qVKimLl4gfsfZ06tQJS5cuxRNPPKFeIyKpXLly6n0iEvWvuXv3rmqnkZGMxwghhJBUjq8Elj8DFK8GvHgABXn9tkqL0NatW9WdtlzIMsv2GT58uFpuOPXo0SPH9X7xxRfq4iYXoRYtWihLBgGaNGmS7rFYa8QqI24x/VSzZk31XHBwcNrrxEWkRyoli4CpV69e2jJxlwn61hIigFq1apUuhqZNmza4d++eElqCWH5ELImrSli8eDEGDRqkRJB+bDNmzEg3ttGjR6sgZbE8yWeIYNOLIEE+Mztkm0T4yFgMm6SKC0/WZ4jhuvz8/BAYGPjAawghhJjImbXa/8CesCRW02JD7tAbNGig4kLEwpAZInwWLlyY9lhiTrJj2bJlmDBhgnKViAiaM2eOcn2IhUPiQsxNITcXZZmxBPLZpuDt7Z3usQgTEaIffPDBA6817JMlYsEQETiGy/SCJ2PMT3bI54ph8q+//lIuNLE4ffrpp+nGJhaizI4LWlkIIcQGSU4Czv6nzdegEFKIG0Om7BDhIxk6xvLJJ58oy4EE8goiiORiu2DBAhWwa25EBBjrnrI2JBBZrDJiPXN1Nd821KpVS61XhI5eJElckgRWi4tJL2ZE5Igl6Ny5c8riIuMxHJuIV4nhyeozxI0mFiK9aNu9e3e246patWpajFTFihXVMrEQSRyQuMYMkXVVqFBBzYsL7MyZM+ozCSGE5JIre4HYu4BnUaB8C1gSq3GNGYPEY4glRy6UEqQrQbbZpYQfOHBAxZfo0cebSPxKVoh7RvyKhpMjMHbsWBX/MnjwYCUGxHUk8UIiIiUWKLe88MILSqRIYPXp06dV9tfUqVOVpU7v+tK7x/QiVR8kreedd95RMUhiFTpx4oRyS0nczltvvaWel30qMUzDhg1TbjSxKElsUk4WMTmGJBZI4okkCFtEs7jaRo4cme614pbbsGGDyhYTF60Ei2cWd0QIIcRIglKzi6t3A1wsa0CwGSEkbjG5GMoFSdw3kpItFqSsLtKS9i3P6WNW9MhjCejNipkzZ6rgKv0ksSeOgMTXiHVEvjPJ/JK4H7GMSACwoWAxlbJly+Lvv/9WsVni+hwzZowSGnoRo0cy1iT+Riw/+uBlPeLOXLNmjQqKFteZBGGL60xvyZHxSVB0bGysivEZNWpUWkZZdsyaNQv9+/dXWW5idRJrlIg/CaLO+DrJWJO4Kjl2/vzzT2VNIoQQktf4oJxjfR0ya0xcKFll++g5f/68cm+sX79eZRRlRLKJ5CK8c+fOdMGukmkkIkrSrLOyCOmDdgWxCIkYMiZrjDgeIpxEkMuxkJk44jFCCCEZCAsGPm8MOLsCr50HPPOnMr/NZY2ZihTVExeF3MVnhjwnWU1SC8cQeZxdnJHEIckXZjgRkhlyLImrr3r16rQQEUKIqdagiq3zTQSZgs0KIUm9lhghw4wmQ+TCJK4McaXpkUwmeZxTajUhxiCFIsUiKSUaCCGEmBgfZOFsMT1Wk+IkKdKG1h1xJxw+fFjFjcgkgbISzyHWHAnkFReXvhKwHnGR9e3bV7WPECQgVwJomzZtqmJHJH1e3w6CkLwiwfiEEEJMQDLFLu20mvggqxJC0tZBKvTqEREjiJCRtgxHjx5VrRCkFYQE9kpA77vvvpuulpAIJMPeWFIN+Pbt2yrrSIJcGzZsqDKEMgZQE0IIIaQAOLcB0CUD/jUBvyqwBqxGCEn7huzitg1bP2TFxYsXH1gm1iG9hYgQQggh1uAW6wFrwWZjhAghhBBiQyQnAufWWUVbDUMohAghhBCS/1zerXWc9yoOlGsGa4FCiBBCCCEFlzYv1aSdTeuPmZ9QCBFCCCHEIeODBAoh4hBIIL1ULJeSDHl5DSGEWB0pKcCdC1pqurUSeha4Eww4uwFVO8OasJqsMUIyY9q0aVi1alWBiBNppSId7KUqOSGEWB2SWR1xBbh9Grh1EriV+v92EJAUCxQuCTy/C/AuDqu1BlVuB3haV8cGCiGSZxISEjJtMZGYmAg3NzfYCtKSJbv2K4QQUqCi59IO4Max+6JHBFB8ZNbvuXcTWP8O0NsKq90HWVc1aUPoGnNApNXIhx9+qCpzS0HKChUqpOvWfuzYMdUNvlChQihevDieffZZVflbz/Dhw1VDXHmPFLcMDAxMcystW7YMHTp0UA1GFy9erF7/3XffoVatWmpZzZo18eWXXz7QLmXw4MGqgri3t7eqBC5NcRctWqQqih85ckStWyZZltU2zZgxA+XKlVPbpC+emZHTp0+jdevWaix169ZVDXj10DVGCLEa1k4GFvXS/h/8EbiyVxNB0qjUvxZQpy/Q6U3giZ+BcQeAZ1KFxqGftewsayLmDhCy26qqSRtCi5C5FXxijGU+280LcHIy6qVTpkzBt99+i08//RRt27ZV7iARCIK0IJG2JdKPbd++fbh16xZGjRqlilIaihDp2SYNadetS60JkcrkyZMxe/ZsNGrUKE0MSWXvefPmqWWHDh3C6NGjleCRquEisEQ4lS1bFn/88YeyyBw8eFAJG6kMfvz4cSVopKeXIJ2EM2Pu3Lnqc7/++mv1OQsWLMBjjz2GEydOqKaoeiZNmqRardSuXRuffPIJHn30UdXORQQfIYRYBdePAnu+1uYDewElawMBtYCA2oBfVcA1kybPJaoBjZ4GDv0ErHkFeG4r4GIlFvmz6wBdChBQByhaAdYGhZA5ERH0vzKW+ew3rgHu3jm+LCoqSokGESYiRISqVasqQSQsWbIEcXFx+PHHH5VYEeS1Ihg++OCDtPYk8pxYevQuMX1V75dffhn9+vVL+7ypU6cqgaJfVrlyZZw8eVIJFvl8+TxpgyKiSyxCgliq9BQuXBiurq45uqw+/vhjvP766xg0aJB6LGPdtGmTEj2GTVFF0EnPOkFat4jI+v7771XvOkIIsYobarECQQfU7Q88vsD49z40Azj9l+ZK2/MV0PpFWAVn/rFaa5BA15iDcerUKcTHx6sGtVk936BBgzQRJLRp00ZZaIKCgtKW1atXL9O4IHFr6RHrkvR/GzlypBI0+um9995TywVxQ4kFRy+CckNkZCSuXbumxmmIPJbtMUQsXXpEYMl4M76GEEIsxsnVWmyQayGg63TT3uvlp4khYdNMLbDa0iQlaP3FrDQ+SKBFyNzuKbHMWOqzjUDifsyBoVDKark+rkjccC1atHggMNmc4yGEEJsnMQ5Y97Y232Y8ULS86etoOESLE5KYHLEsSQyRJbm8U4tt8vYHyjaBNUKLkDmRGB1xT1liMjI+SOJlRHxIjE9mSFCzBCeLNUfPjh074OzsrIKiTUHcaBJMff78eeXuMpzERSbUr19fWYXu3LmT6TrE6pScnJzt50isknyOjNMQeSyxQIbs3n0/iDApKQkHDhxQ20wIsSC7vgQ2vqf1onJkds0Dwi8DRcoAbV7K3TqcnYFHPgGcXIBTfwJn/oNFCUpNWqnRXRubFWKdoyL5hgQwSyyNxMRIHJC4qEQcSJyMMGTIEPUaid+RQGWJs3nxxRfx9NNPp8UHmYJkfc2cOROfffYZzpw5ozLSFi5cqAKVBckWk/gfyUIT4SKiacWKFdi1a5d6vlKlSiqYWcRSaGiocutlhgRBS1yQZK2JC0+CtuU9L72U/sdE4oV+//13FRw+duxY3L17FyNGjMjFN0kIMQvHVwD/TgG2fgSsel4rDuiIRF4Htmm/i3houlExn1lSsg7Q6gVt/u9XgYQYy8U7nbHetHk9FEIOyNtvv42JEyeqbC6xhkh2lmSHCV5eXvj333+VhaZZs2Z4/PHHVTyRBEznBsk4k6BqET8SVyQZYpJ9prcIicXnv//+Q0BAAB5++GH1mlmzZqW5ziSwuUePHujUqRP8/f3xyy+/ZPo548ePx4QJE9R2yTokCFqy0AwzxgRZt0wSB7V9+3b1GhZQJMRCRN0A/pp4//Gx37QLt1xAHY0NM4DEaK0Zab0BeV9fh8mAT1kg/BKwbTYswu0g4O5FwMUDqNoJ1oqTTueIR5xpgbiSsh0REaFcMIZIdpVYK+SiLlYUYtuIJUnqHJ09ezZd5lpe4DFCSBbIpeeXQVojzlL1gVZjgd/HaNlS7SYCXd6BVZIUD0RdByKuApHXALdCWu8slzyE3F49AHyb2nZi1EagnHGxNBGxidh74Q52Bodi38U7qB5QBJ8MbKDqoSlO/gH8+rTW1uL5nYB/DRQo2z4BNkwHqj0EPLXcqq7fhjBYmhBAWcCWL1+uThZptUEIyWckoFdEkIs70PdrrVaOlCCRGjhiwfD0zX2cTF6IDtUsGSJyIq9o/5XoSRU+0Zr1PB1S3LDft7mr26PS5ado8/UHZSuC7sUnKcGzKzhMTSeuRSDFwJRx/GokhrWuhIbli2oLaj2qdXo/+x/w1wRg2J9Gx5Oatdu8labN66EQIgRQKf4SOC21haQyNSEkH5GAYP3FX6ojiwgSmo4AYsM1K8K6dzQx1GR4wY3r9N/Ab8OB5MxjEdNw9QR8ymhBzSF7gBO/AylJQP8FmRc7zClGStYhmb9dp6Z7KjYhGQcu3cWu86HYGRyGo1cikGyofABUKeGNllWL4+zNKOy7eBdrjly7L4RE9PT8ELiwFbi4DTi2HKhvBrebsYIyZK9VdpvPCIUQIYAKoCaEFAASDL16LJAQBZRv8WDRv3YTgLgIYMcc4M+XAQ8foO79Iq35Ws15xShNBPmWB4pV0mJsRPD4yn+DSer16C0rZ/4Flj2lZWj9OhQY+APgauTNlAQxi+AT2k7QPiuVn3dfwow1J5GQlD54vLxfIbSqUhytq5ZAyyrFUcpXc7mvPX4D+y4ewF/HruONh2vB2Tl1fH6Vgfavall5/74BVH8IKJQqlPKTs5KtpgNK1QN8y8GaoRAihBBScOz7VrNQiAWkz3zAWUuMSEfXaZoYOrAQWPmsJoaqd83foO1fBmvBylU6AkOWG+/mkrTwwb8AS4doGVIiigb+BLgZERO48zPN5eZbAWg9Lm3xpqBbeGf1ceX2Ku3rqYRPq6raVK5Y5jXjOgb6o7CHK65HxOHA5btoVsmgSG3r8cCRZUDYWU0Q9foYjtxkNSPMGjMDjDcnWcFjgxADQs8B61LdP1IBuXjVzF8n1pZes4E6/YCURE1cXNJKapidxFhg6ZNaPFDx6sCAH0yP9anWFXhymVYNWiwhS0VUxWb/Hqn6vH3O/XR5CboGcO5WFMYvOaRE0BNNy2Pn5M745ImGGNC0fJYiSPB0c0G32lqJE3GPpUMsVPJ9Cvu+A64eRL4HlAdv1OYDKYTsGjc37WSJibFQjQZi9eiPDf2xQojDkpwErBoDJMVqVpemI7N/vViKJIhaMo7kPUue0NxX5kRuVFa9oGVtFSqmiZncuo1kmyQzys1bEwFLBgIJ9wvTPsD6adp2VWitBVtL6FRMAkb9sB9R8UloVqkY3u1T934GmBE80qC0+v/XsRsPxBKhSgeg3kDNXSUB6SnZF6rNExe3Awn3gMKlgNINYe3QNZYHpNZN0aJF09XgMeWgJfZtCRIRJMeGHCP6ukiE2CzizpI07Ir3+/WZhLiBruzT3Fy9vzCuyrAEHg/8Efi5v9aq4ae+wIh/tU7r5mDzLODESm27pBVFVhYqY6nUFnhqBbD4ce37WjxAE1ceRdK/ToKIpWYSnIAeM5UFLCk5BeOWHMLFsBiULVoI859qAndX02wVbav5w7eQG0LvxWPP+TC0rpahRlr397WYpuuHgf0LgOaj87a9OWWLWXE1aUMohPKIviu6XgwRYoiIIP0xQohNNwKVQGB9zIdcUE0RDTdPAJv+p833/MC04Fl3L+DJpcCiR4AbR4EfewMj1uauD5chkkG1ZZY2/8inmogxByIUn14F/NxPa54qIk5ijjx97geL//O6Nt9oCFBGs5i899cpbD8XCi93F3w7tClKFDY9e1WEU486pbBsfwj+PHr9QSFUOADo8rZWtFIKOEr/L4/CmktPMuEkrkn9T32sn0wRM2Jl07fVsAG3mMCCimYqyCT9sBITHbxPDkmHuMNoCSI2z63TwHddNFeHHrGgtHweaD/p/gU+u+7jUizw5jEgsBcwaHHuatncuw0s7AGEnQOKVwOG/wUUyeVNRsg+YFEvLUNMAom7vQuzI+42sWBJ0HfZppqlSNxuh3/RXITuRYAXDwBFSuKXvZcxZeUx9bavnmqCHnVzf/O07extPP39XhTzcsPeN7vCzSWDiBGXmOzPa4eMX6mLhxZnJO5K2fcSQ6Wfd3ZN/1ht+35NQL12QROyFoIFFQsYueDxokcIsSvkIr5siCaCKrcHenygdUc/t15zdR35BegyVet4npXVYOuHmggq5Ac8Oif3Bf0K+2uWlgWpYujzJpoYazXOtLgeqWEkwcwiggIf1jLU8gPptD70D+CnPpowkP/ifpPYIKH9RCWCxIX19qrjatHEh2rkSQQJkmFW3NsdYdEJ2HEuFB0DAzKPvfr3TSAuHEiK07req/+x9//rDGKI5LvKqbZSRsQtZkERZAq0CJlJURJCiF0hLhwRQUF/Az7lgOe2AN6prhbpaC6NUkWQCBIQKy6vCi3Tr+PKAeD7h7SLqmRj1emT93GFBWtFD8VNJnj4arWIWo55MBYnI/FRwPfdgVsngJL1NBebuIbykxvHNHdeTBjgXlgTlVKjaOxehEQmo/cXO3AnOgGP1C+Nzwc3Mkuc6VurjuHn3ZfxeJNy+HhAg9wHtyfFpookEUgJWtFIyeKT//J8Vo8l9kmEc0HUKzLD9ZtCKAcohAghDsmWj4BN72luEREMZRunf14ujHu/AbZ8AMRHasvqPq6lgksMkFgVvm4PhJ7Rmoj2/868Iu30Gi3u6PYpbZlYnNq+AjQblbklQlxCkiYvgbyFSwKjN+a50N+xKxGqgGHXWgFoUrFY1iLm5kngx8eA6Nva4yd+xr0qPfH4/J04fSMK9cr64tfnWqGQu3m8CrvPh2HQN7tRxNMV+9/qCg9Xx/RWRFIImQcKIUKIw3F2nZbxJKnWkuHV6KnsY3c2vgsc/FF7vQTetn1Za7EgxRMlhfqFXVo1ZnMj4ub4SmDzTOBOsLZMRI40bZXWHIYVnsUVtGueFrsy/G+jG5tmR+9523HkSoSaDyxZBENaVkCfRmXh45lJuYzbZ4CVo1SD2ZRHPsNziw9i3cmb8C/igT/GtUFpX62OkDmQ1PnWszbgZmQ8vhvaFF1T6ws5GpEUQuaBQogQ4lCI6+nbTlp8kPT+kowqY7h+BPhnspbmbohkTElbh/xE3DJHl2lZYBIDJIg7T1pLiIg7vAT4c7y2/PEFQN3+ef5IaYBaf9q/qvChp5sz4hK1VhiF3FzQu2EZDGlREfXK+Wb63o//DcK8TedUltfSZ1uicYViMDfT/zyBhTsuqrHMHdQIjkikkddv60/wJ4QQUjBIAcBlT2siqFwzLTjaWEo3AJ75G3h8odarSxCrTH6LIMHFVUtFH3cA6PWJ1gxVKkWveRn4vLHWeV3o+IZZRJBw8NJdJYLKFSuEPW90xbRHa6N6QGHEJiZj6b4QPDpvu7IY/bovBDEJSWnv++PINSWChFn96uWLCBIeqa/1LVt/8ibiEvOxeKIdwKwxQgixFyQwVzq2F61g+nvFOfDHi1ogsXeA1i/L1E7qEiMjDVKl27hYiMo3R4Ei4202Ustikz5l2z65byGS+KUOr5nto/ZdvKP+N6/kp4oYDm9TGcNaV1Id4BfvuYR/jt1QbrMjV47i3b9Oon/jcqr/16Tfjqj3Pde+Cvo1zr9mpI0rFFWFGa+Gx2LT6VvoWU+rOk0ehEKIEELsAWlrIEUHlRjpr3UzL1nb+Pfv/hI4vkKrCyPVnH3ycOGUYOXcVqA2B1IYUFLrGw8F9i8Eom8BHafkPnU/E/Ze0IRQs8r3Y58kWLp5ZT81vfNIPJYfuIIley/jUlgMFu28qCahc80AvNajJvITGYtkon299Tz+PHqNQigb6BojhBB7QNpFSLCyLkVr3zC/ldZR/cr+nN8r7SD+e1ub7z7TsiLGnLh7a13dpcFralNTcxCflIzDIeFqPl2XdwOKF/bAcx2qYtPEjvhxRHN0r1MSLs5OqFmqCOYOaqjm8xu9e2zj6VuIjr/vniPpoUWIEEJsncu7gYvbUntm/aQVOjz5h1YDSCap6SKZVJU7PGgVkS7ovz2j1fqpPyj/+k/ZEcevRiI+KQV+3u6o6u+d7WudnZ3Qvoa/miLjEuHh6lxg6ex1y/qgUnEv1b9s/amb6N2wbIF8rq1hNRahrVu34tFHH0WZMmWUSW/VqlVpz0nritdffx316tWDt7e3es3QoUNx7dq1bNc5bdo0tS7DqWbN/DVHEkJIgbP1I+1/w8FafydxbY3dm1rx2VWz+EhRP2mtcPovrQ6PIMXyJDg6JhQoVS9vlZ8dCH18UNPsagdlgqTVF2RNH809plmF1hy9DmskNiFZNam2JFYjhKKjo9GgQQN88cUXDzwnXbwPHjyIt99+W/1fuXIlgoKC8Nhjj+W43jp16uD69etp0/bt2/NpCwghxAJcPai1vHBy0eKC9PjXAPp8CYw/BDR/VqufI/2vpKjg/NbAkWXA3xOBaweBQsWAJxab1X1kz+xLjQ+SWCBr55EGWmzQlqDbiIi1vn6Yb68+jh5ztqkeaXB011jPnj3VlBlSB2DdunXpls2bNw/NmzfH5cuXUaFC1hkSrq6u7P5NCLFfts3W/kv1Zr/KDz4vGWQPf6Q1SN09H9j3nVaN+fdnteednLXaOsUqFuy4bZSUFB32X7qbbXyQNSGFHiWt/+yte6qAo7TdsBbuxSfhr6PXVckBqb8ER7cImYoUSBKzX9Gi2fcyOXv2rHKlValSBUOGDFHCKTvi4+NVESbDiRBCrJIbx7VWE9LbSWKAsqNwANB1KvDyMaDz24BXcW25NE2t2rlAhmsPnLkVpSwrXu4uqFPG+ovspnePZR9OUtD8dfSaEkFVSnirFiWWwiaFUFxcnIoZGjx4cLbVIlu0aIFFixZh7dq1mD9/Pi5cuIB27dohKioqy/fMnDlTWaD0U/nyqYXBCCHEWq1B0sxUXGHGII0wpeLyy8e1OCJph0FMdotJIURXF9u4hOrdY9vPhuJudAKshd/2X1H/BzQtb5Zms7nFNvaiARI4PXDgQBVcJeImO8TVNmDAANSvXx/du3fH33//jfDwcPz6669ZvmfKlCnK2qSfQkJC8mErCCEkj0jvqhO/a/PtXs1drR//QLMPy96Rgom24hbTU9W/MGqX9kFSig5rT9yANRB8+55yMUoZgf6NLZvN5myLIujSpUsqZsjU3l/iRqtRowbOndPKm2eGh4eHWq/hRAghVsf2T7S6QYG9gFJ1LT0ah0BuwPUZY80qWc6VkxerkLW4x35LtQZ1rOGPAB9Pi47F2dZEkMT8rF+/HsWLp/q3TeDevXsIDg5G6dKssEkIsWHuXACOplq2xc1FCoQrd2NxPSIOrs5OaJRPPcLyi0fqaXFCu4LDcDsq3qJjSUpOwYqD991ilsZqhJCIlMOHD6tJkHgemZfgZhFBjz/+OPbv34/FixcjOTkZN27cUFNCwn1/Z5cuXVQ2mZ5XX30VW7ZswcWLF7Fz50707dsXLi4uKraIEEJslu2fagUQq3UFyja29GgcBr01qG5ZXxRyt1yWU26oUNwLDcoXVY1i/zlu2ZpCW87cVmKsuLe7ajdiaaxGCInIadSokZqECRMmqPl33nkHV69exR9//IErV66gYcOGyqKjn0Tg6BFrT2hoaNpjeb2InsDAQGVNEivS7t274e/vb5FtJISQPCOVoA8v0eYlJZ4UGGmNVm2gflBmPFo/1T12xLJC6Nf9Wuxtn0Zl4e5qeRliNXWEOnbsmG11SWMqT4rlx5ClS5eaZWyEEGI17JgLpCQCldoBFVpaejQORVqjVRsKlDbk4Xql8d5fp7Dv0h1cj4hFad+CL6AZei8eG07dUvMDrcAtJlheihFCCDGOqJvAgR+0eVqDCpSwe/EIvh2d1lrDFilTtJAK8ha7ghQytASrDl1V2WsNyvkisFQRWAMUQoQQYivs+hxIjgfKNdcaqZICQ19NukbJwijm7Q5bxZK9x3Q6XZpbzBqCpPVQCBFCiC0QHQbsW6DNd3iNzVEtVEixqY26xfT0rFcKzk7A4ZBwhNyJKdDPPnolAmdu3oOHqzMebaAJMmuAQogQQmyB3V8CidFA6QZathixTKC0jQuhgCKeaFlFKz+z+vDVAv1svTWoZ91S8C3kBmuBQogQQqyd2HBg7zf3Y4NoDSpQouOTcPya1neymY1mjBnSv7HWePXbbRcQHlMwLTdiE5Lxx+FrVucWEyiECCHE2hERFB8JBNTWKkmTAuXQ5XAkp+hQtmghNdk6krYuXemleey8jVl3WjAn/564gaj4JPX9tUq1SFkLFEKEEGLNxEdpbjFBOsw782e7oNlro201skL6e73Rq5aa/2HXRVwK07Lh8pP7QdLl4CxBSlYEzyhCCLFm9n0PxN4FilcD6vS19Ggckv16IWQHbjE9HWr4o131EkhM1uGDtafz9bMkKHtncJjy6D7eRHPLWRMUQoQQYq0kxAC75hlYg2yrrYM9kJicolxj9hAonZE3e9VSGWR/H7uBA5c0sZcfLD+g9RVrU7UEyhXzgrVBIUQIIdbKwR+A6NtA0QpAvQGWHo1DcvxqBGITk1HUyw1V/QvDnqhZyieturNUnDamg4OppKTo0oSQuMWsEQohQgixVo78ov1v8zLgYj3pxo6YNt+0op/VxbaYgwkP1YCXu4uyev11zPxFFsUldjU8Fj6eruhepxSsEQohQgixRuTuPCxYm5e+YsQi7L2gVZRuXtk+AqUzEuDjiefaV1XzEisUn5ScL0HSjzUsA08363TtUggRQog1Ii6xhHsAnIBiFS09GodE3Dr7L9l2o1VjGN2+Mkr6eCDkTix+2Jm+eXleiIhJxNoTN6yqwapZhNDWrVuRlJT0wHJZJs8RQggxA3cuaP99ywGuHpYejUMSfPsewmMSUcjNBXXL+sJe8XJ3xcRugWr+843ncDfaPEUW/zhyFQlJKahZqgjqWfH3Z7IQ6tSpE+7ceTC6PCIiQj1HCCHEDNxNFULFKll6JHD0+kGNKhSFm4t9O1D6Ny6HWqV9EBWXhLkbzpplnb+lBUmXh5MVV0M3ec9KVHlmGxQWFgZvb29zjYsQQhybO+e1/36VLT0SOHqjVXt2ixkWWXwrtcjiz7sv4fxtccvmnlPXI1WTVTcXJ/RpaD0NVjPD1dgX9uvXT/0XETR8+HB4eNw31SYnJ+Po0aNo3bp1/oySEEIc1TXmV8XSI3FY9l286zBCSGhTrQQ6BfpjU9BtFTj99dNNkVt+269Zg7rWKonihT3sQwj5+vqmWYSKFCmCQoXu91txd3dHy5YtMXr06PwZJSGEOKpFqBgtQpZAUr5lEkuJuMYchTceroWtZ0Px74mb2HM+DC1y0RdM4oJ+P2TdtYNyJYQWLlyo/leqVAmTJk2Cl5f1VYckhBC7ixGia8yibrG6ZXzg7WH0pdLmqV6yCAY1K4/Fey7jf3+fwu8vtDG5ftKGUzdxNyYRAUU80L66P6wdk2OEhg4diqtXrz6w/OzZs7h40Xxpd4QQ4rDERQAxYdo8LUIWLaToKG4xQ17uWgPe7i44ciUCfx69htzWDurfpBxcbSDI3OQRSnzQzp07H1i+Z88e9RwhhBAzxQd5lQA8fSw9GscWQnbUaNVY/It44IVO1dT8h2uDEJdoXJHF6Pgk/HPsOracua0eD7DCBquZYbK979ChQ2jTps0DyyVGaNy4ceYaFyGEOC50i1kUqaNz5uY9h7UICSPbVlbZYxIntXDHRTzfUas+bYjEDJ8Pjcam07ewOeg29l64g4TkFPVc88p+qGIjvdlMFkKSNRYVFZVpHSHJHiOEEJJHmDFmUfZf0rLFqgUUhp+3OxwRTzcXTOoeiAm/HsGXm85hYNNyKvtLrEO7z4cp4bMp6BYuhcWke195v0LoHBiAcZ2rw1YwWQi1b98eM2fOxC+//AIXF61viAggWda2bdv8GCMhhDgWzBizKI4cH2RIn4ZllTXo2NUIvPLrEbg5O2FHcCjiEjWrjyB1glpULo6Ogf7oVDMAVUp4W3XxRLMIoQ8++ECJocDAQLRrpzUC3LZtGyIjI7Fx48b8GCMhhDgWd1MTT+gaswji4hGaVbLPRqvG4uzspNLpB3+7G1tT436E0r6e6BgYoGoOta5WAoVtPKvO5NHXrl1bFU+cN28ejhw5ouoJSSaZxAf5+Tm2eiaEELNA15jFiElIwvGrEWre0S1CQquqxTGuUzUcCrmbWnAxQPUOszWrT3bkSsaVKVMG//vf/8w/GkIIcXQS44DI1BIldI0VOIdDwpGUolNWj3LF7hcOdmRe7a41ZLVXcpXgL66wp556SrXU0NcU+umnn7B9+3Zzj48QQhyL8EuSjwO4Fwa8S1h6NA7Hvgv322rYk9WDmFEIrVixAt27d1cusYMHDyI+Pj4ta4xWIkIIMZdbrLKk6Vp6NA6HI9cPclRMFkLvvfcevvrqK3z77bdwc3NLWy61hUQYEUIIyQPMGLMYSckpOHhZswg1Z3yQw2CyEAoKClJZY5k1ZQ0PDzfXuAghxMGLKTJQuqA5ejUCMQnJ8C3khuoBtlEMkFhACJUqVQrnzp17YLnEB1WpwhOXEELM5hojBcqC7dp336GGv8mNRokDCaHRo0fjpZdeUr3FJJDs2rVrWLx4MV599VU8//zz+TNKQghxFOgaswhnbkbhr2PX1fwLnR5sJ0HsF5PT5ydPnoyUlBR06dIFMTExyk3m4eGhhNCLL76YP6MkhBBHICUZCL+szdM1VqB8tuEsdDrg4XqlULMUG906ErnqNfbmm29i0qRJykV27949VWSxcGH6UwkhJE9EXAFSEgEXd8CnjKVH45DWoPFdbKdHFrFgHSHB3d1dCaDmzZubRQRt3boVjz76qCrWKGJr1apVD3S5feedd1C6dGmVut+1a1ecPXs2x/V+8cUXqFSpEjw9PdGiRQvs3bs3z2MlhJB8dYsVrQg4a70cSf4zl9Ygh8Yoi1C/fv2waNEi+Pj4qPnsEFFUp04djBkzRmWSGUt0dDQaNGiAESNGZPoZH374IT777DP88MMPqFy5Mt5++21Vz+jkyZNK5GTGsmXLMGHCBJXuLyJozpw56j2S+RYQEGD02AghpEBgxliBE3QjCn/TGuTQGCWERNDoK2zmJG6kwKIIjx07duCPP/4weiA9e/ZUU2aINUhEzFtvvYXevXurZT/++CNKliypLEeDBg3K9H2ffPKJCu5+5pln1GMZ119//YUFCxaoWCdCCLEqmDFW4Hy2kdYgR8coIbRw4cJM57NCrDTNmjWDubhw4QJu3Lih3GF6RJCJlWfXrl2ZCqGEhAQcOHAAU6ZMSVvm7Oys1iHvyU7I6atlC5GRkWbbDkIIyRZmjBUotAaRPMUICSEhIWrKSGBgIHbu3Gm2b1hEkCAWIEPksf65jISGhiI5Odmk9wgzZ85UIks/lS9f3izbQAghOXL3ovafrrECgdYgkishlJSUpOJzRCRIELJMMi9uq8TERPUaFxcXFe9ji4gFSfqm6afMhB4hhJgduSLTNVZg0BpEcp0+L7WCVq5cqYKXW7VqpZaJq2natGkICwvD/PnzYW6kmrVw8+ZNlTWmRx43bNgw0/eUKFFCCTJ5jSHyWL++zJCaSDIRQkiBcu8WkBgtRUqAohUsPRq7h9YgkmuL0JIlS1QG2XPPPYf69eurSea///579Vx+IFliIl42bNiQLnZHqlvrxVhm6f1NmjRJ9x4pBCmPs3oPIYRYPGPMtzzgypux/ITWIJIni5BYS8QdlplYEfGRW6Qwo2EPMwmQPnz4MPz8/FChQgW8/PLLqvN99erV09LnpeZQnz590t4j1a779u2LcePGqceSOj9s2DA0bdpU1TuSzDNJ09dnkRFCiNUFSvs9+PtKzAutQSRPQkhExrvvvquyx/QuJMmyev/999MESG7Yv38/OnXqlPZYRIwgQkYsUK+99poSMc8++6zqct+2bVusXbs2XQ2h4OBgFSSt54knnsDt27dVIUYJkBY3mrwnYwA1IYRYHH18EDPG8hVag0hGnHRSpCcHMhY4XL9+vRJB+oDoI0eOqHR1schI/JA9IS44CQaXwGkpKEkIIfnCilHAsd+ArtOBti9bejR2y9jFB1U7DbEGfTmkiaWHQ6zg+m10QUVD+vfvn+4xU8wJIcRcrjFahPLTGsSeYiTPBRUJIYTkA3SNFUiHeaFXvdKMDSK5jxHSI7E30rNLX0DR398/t6sihBDHJjYciL2jzdMilC/QGkTMlj4vAcvSGFXq+bRv315Nkr01cuRIxMTEmLo6Qggh+tR5b3/Ao4ilR2P31qDAUvyOSR6EkGRzbdmyBX/++afK3pJp9erVatnEiRNNXR0hhJC0itJsrZEf0BpEzOoaW7FiBZYvX46OHTumLXv44YdRqFAhDBw4MF8qSxNCiENYhBgflC/QGkTMahES91dmdXgCAgLoGiOEkNzAjLF8g9YgYnYhJO0ppk6diri4uLRlsbGxmD59OltXEEJIbrjDrvP5xdwNZ9R/WoOI2Vxjc+fORffu3VGuXLl0BRWlwvO///5r6uoIIYTQNZYvHA4Jx9/HbsDJidYgYkYhVLduXZw9exaLFy/G6dOn1bLBgwdjyJAhKk6IEEKICSTGApFXtXm6xsyGNE2Y+fcpNd+3UVlag4h56wh5eXlh9OjRuXkrIYQQQ+5e0v57+ABexS09GrthU9At7LlwB+6uzpjYLdDSwyH2FCNECCEkP9xilaB8OCTPJKfoMOsfzWPxTOtKKFuU3gqSNRRChBBiSZgxZnZWHLiCMzfvwbeQG17oWM3SwyFWDoUQIYRYEhZTNCuxCcn4ZJ2WKTauUzX4erlZekjEyqEQIoQQa7AIMWPMLCzceQE3IuOUO+zpVhUtPRxiA1AIEUKINcQI0TWWZ+5EJ2D+pmA1P7FbDXi6uVh6SMRessaKFSsGJyOD+O7cSe2gTAghJHuSk4Dwy9o8XWN5Zt7Gc4iKT0Kt0j7o07CspYdD7EkIzZkzJ20+LCwM7733niqqqK8kvWvXLlVM8e23386/kRJCiL0REQKkJAEuHkCRMpYejU0TcicGP+3WKnRP6VkTzs7MwCNmFELDhg1Lm+/fvz9mzJiBcePGpS0bP3485s2bh/Xr1+OVV14x8qMJIcTBSUudrwg4M1IhL3z8XxASk3VoW60E2tfwt/RwiA1h8pknlp8ePXo8sFyWiRAihBBiJMwYMwvHrkRg9eFran5yz5qWHg6xdyFUvHhxrF69+oHlskyeI4QQYiTMGDNLK41Za7VWGn0alkHdsr6WHhKx9xYb0mV+1KhR2Lx5M1q0aKGW7dmzB2vXrsW3336bH2MkhBD75K6+6zyFUG7ZejYUO86Fwd2FrTRIAQmh4cOHo1atWvjss8+wcuVKtUweb9++PU0YEUIIMQK6xvLcSkPfWFVqBpX387L0kIijNF0VwSPd5wkhhOQSnc4gWJoWodyw6tBVnL4RhSKerqqKNCG5IVdpCsHBwXjrrbfw5JNP4tatW2rZP//8gxMnTuRqEIQQ4nDcuwkkxgBOzkDRCpYejc0Rl3i/lYb0Eyvm7W7pIRFHEUJbtmxBvXr1VFzQihUrcO/ePbX8yJEjmDp1an6MkRBC7Nct5lsOcOVF3FR+3HURV8NjUdrXE8+0qWTp4RBHEkKTJ09WBRXXrVsHd/f7J2/nzp2xe/duc4+PEELsE2aM5ZrwmARVRVp45SG20iAFLISOHTuGvn37PrA8ICAAoaGheRwOIYQ4Wo8xBkqbypebgxEZl4TAkkXQv3E5Sw+HOJoQKlq0KK5fv/7A8kOHDqFsWfZ2IYQQ0zLGaBEyBXGHLdp5Ma14ogtbaZCCFkKDBg3C66+/jhs3bqhGrCkpKdixYwdeffVVDB06NK/jIYQQx4CusVzx674QJCSloEVlP3QMZCsNYgEh9L///Q81a9ZE+fLlVaB07dq10b59e7Ru3VplkhFCCDECusZyxZYzt9X/fo3LqptxQgq8jpAESEsFaek0f/z4cSWGGjVqhOrVq+d5MIQQ4hDE3tUmoRgznozlbnQCjlwJV/MdagRYejjEUYWQVJBu27YtKlSooCZCCCG5jA/yDgA8Clt6NDbD1rO3VR3KmqWKoJSvp6WHQxzVNSZp8pUrV8Ybb7yBkydP5s+oCCHEnqFbLE9usQ6MDSKWFELXrl3DxIkTVWHFunXromHDhvjoo49w5coVc46LEELsP1CaGWNGk5Kiw1a9EKpBIUQsKIRKlCiBcePGqUwxabUxYMAA/PDDD6hUqZKyFuUXsn4JjMs4jR07NtPXL1q06IHXenrSlEoIsQLupHadZ8aY0Zy8HonQewnwdndB04p+lh4OcfSmq3rERSaVphs0aKCCp8VKlF/s27cPycnJaY8lUPuhhx5SQiwrfHx8EBQUlPaYGQaEEKuArrFcu8VaVysBd9dctckkxLxCSCxC0oF++fLliIuLQ+/evTFz5kzkF/7+6U2hs2bNQtWqVdGhQ4cs3yPCp1SpUvk2JkIIyRV0jZnM5iCtwTfdYsTcmCyrp0yZoixB4ga7fPky5s6dq4or/vTTT+jRowcKgoSEBPz8888YMWJEtlYeSe2vWLGiqnkkQu3EiRMFMj5CCMmSxFggKrU6P11jRhERm4iDl/Vp8xRCxMIWoa1bt2LSpEkYOHCgiheyBKtWrUJ4eDiGDx+e5WsCAwOxYMEC1K9fHxEREfj4449V0UcRQ+XKZd2bJj4+Xk16IiMjzT5+QogDczc1PsjDF/BirIsx7DgXiuQUHar6e6O8n5elh0McXQiJS8zSfP/99+jZsyfKlCmT5WtatWqlJj0igmrVqoWvv/4a7777bpbvE/fe9OnTzT5mQghJ7xarJP57S4/GJtgSpM8WYxFFYn5yFXEm2WIvvvgiunbtqqbx48erZQXBpUuXsH79eowaNcqk97m5uakK2OfOncvR9ScWJP0UEhKSxxETQkgmxRTpFjMKnU6XFijN3mLEKoTQv//+q/qL7d27V7mdZNqzZw/q1KmDdevWIb9ZuHAhAgIC0KtXL5PeJxlnx44dQ+nSpbN9nYeHh8o2M5wIIcRsMGPMJIJuRuFGZBw83ZzRvDJdicQKXGOSLv/KK6+orK2My6UrvaS05xfS6V6E0LBhw+Dqmn7o0vm+bNmyaZlrM2bMQMuWLVGtWjUVTyRFH8WaZKoliRBCzAozxnLlFmtVpTg83VwsPRxih5gshE6dOoVff/31geWSwTVnzhzkJ+ISk0w1+ayMyHJn5/sGrrt372L06NEqo61YsWJo0qQJdu7cqaxZhBBiMegaM4nNafFBdIsRKxFCUs/n8OHDD3Sbl2XisspPunXrpvzFmbF58+Z0jz/99FM1EUKI1ZCcCESkxh3SNZYj9+KTsP/SHTXfIZCB0sRKhJBYWZ599lmcP39eZWLpM8k++OADTJgwIT/GSAgh9oGIoJQkwMUDKJJ9vCIBdgWHITFZh4rFvVC5hLelh0PsFJOFkLTSKFKkCGbPnq0yrARJY582bZrKHiOEEJKDW0zigwxc+SRzWE2aWKUQkkrOEiwtU1RUlFomwogQQkgO3Dim/S9ezdIjsXqYNk9soukqBRAhhJjA5V3a/wr3i72SzAm+HY0rd2Ph7uKMllWKW3o4xI4xWQiFhYXhnXfewaZNm3Dr1i2V0m7InTtaYBshhBAD5LdSL4QqUgjlhN4aJLWDvNzzdM9OSLaYfHQ9/fTTqjrzyJEjUbJkyWybnhJCCEnl1kkgLgJw8wZKNbD0aKweusWI1Qqhbdu2Yfv27WjQgCcyIYQYzaWd2v8KLQAXWjiyIzYhGbvPh6l5BkqT/MbktIWaNWsiNjY2f0ZDCCH2yqXUhtUVtLIjJGt2XwhDQlIKyhYthGoBhS09HGLnmCyEvvzyS7z55pvYsmWLiheKjIxMNxFCCMmAFIJNiw+iEDK2rUb7Gv4MvyD5jsn22aJFiyrB07lz5wdSHeWAleamhBBCMvQXu3cTcHEHyjax9GhsJj6IbjFilUJoyJAhcHNzw5IlSxgsTQghprjFRAS5eVp6NFbNpbBoXAiNhquzE9pUY9o8sUIhdPz4cRw6dAiBgYH5MyJCCLE3LtEtZqo1qEnFYiji6Wbp4RAHwOQYoaZNmyIkJLVpICGEEIcIlBZLza3IuAKLD+rIJqvEWi1CL774Il566SVMmjQJ9erVU24yQ+rXr2/O8RFCiG0TcRUIvwQ4OQPlm8MWWbznEt5edRw+hdzw38vtEeCTP+69uMRk7Axm2jyxciH0xBNPqP8jRoxIWyZxQgyWJoSQTNBni5WqD3j6wJaQ3/W5G85izvqz6nF4TCLeWX0CXz2dPwHf+y/eRWxiMgKKeKBWabZwIlYqhC5cSO2eTAghxHi3mI3FByWn6PD26uNYsueyejyoWXksP3AFa0/cwD/HrqNnvdJm/8wtZ+53m2ciDrFaIVSxYsX8GQkhhNgjNhgoLS6ql5Yewr8nbkL0yIzedfF0y4ooUdgD8zadw9urT6BV1eIo6uVu1s/dnBof1IFtNYg1B0sLP/30E9q0aYMyZcrg0qVLatmcOXOwevVqc4+PEEJsl+gw4PYpm+o4HxGbiKHf71UiSDq/f/lkYyWChHGdq6GqvzdC78Xj/b9St8tMXA2Pxdlb9+DsBLSrRiFErFgIzZ8/HxMmTMDDDz+M8PDwtJggKbQoYogQQkiG+KASgYB3CVg7NyLiMPCrXdh78Q6KeLjix5HN07nAPN1c8EH/+spK9NuBK9h2VrPgmDNbrFGFYvD1Yto8sWIh9Pnnn+Pbb79VbTZcXFzSpdUfO3bM3OMjhBDbxYbaapy7dQ/95+9E0M0oFaz865hWaFnlwYKGTSv5YVirSmp+yspjiI5PMnt8ECFWLYQkWLpRo0YPLPfw8EB0dLS5xkUIIbaPjQRKH7x8F49/tVO5p6qU8MaK51ujVumsM9wmdQ9UDVGv3I3Fx/8F5fnzE5NTsOOcljbfkfFBxNqFUOXKlXH48OEHlq9duxa1atUy17gIIcS2iY8Crh+1eiG08fRNPPntbpUa36B8USx/vjXK+3ll+x5vD1f8r189Nb9o50UcuHQ3T2OQ99+LT0Jxb3fULeObp3URku9ZYxIfNHbsWMTFxakaE3v37sUvv/yCmTNn4rvvvjN5AIQQYpeE7AV0yUDRCoBvuXz/uKAbUfhu23klKIp6ucG3kDuKebllmNf+SwyOh6sLft0fotxbkiovlpgvhzSGl7txlwVxYfVvXA4rDl7B5BVHsWZ8W7XOvLTVkG7zzhItTYg1C6FRo0ahUKFCeOuttxATE4Mnn3xSZY/NnTsXgwYNyp9REkKIrXFpZ4G01bgeEYtP151RNX5SdMa/r5CbiypeKIigmdW/HtxcTHMSvP1ILRXbI9leX2wKxoSHapg6fETEJOLfEzfUPOODiNULoaSkJNV1vnv37qoLvQihe/fuISCAPWEIIXaCTgdEXgV8ykrZfLMGSofdi8d7f51CuWKFlPioVMI7T2nuX20JxoLtFxCflKKW9axbStX3ETeXmmITUudT/8dq8yKY9CJoTIeqeL1HYK4KGIqFafpjdTF2yUF8uemc+vzsYosMEY/Cn0evY8afJxB6LwFe7i5oV936M+uIgwshV1dXjBkzBqdOafUjvLy81EQIIXbD8RXAipFAh8lApym5W0diHHBlvzZfsU3a4o//O4PfD11V859vPIemFYuhf5Ny6FW/NHyM7LQen5SMn3ZdUoUNRdwIzSoVw+SetVTH9pxISdEhKj5JWWLcXJ1Q2rcQ8sLD9UqhW+2S+O/kTby+4ihWPt8arjlYlkLuxOCtVcfTXGJSm+jDx+ujeGGPPI2FkAJxjTVv3hyHDh1ihWlCiH1yfKX2f+fnQIvnAC8/09dx7SCQHA94+wPFq6pFl8Ni8Nv+EDXfvLIf9l+8g/2X7qpp2h8n0L1OKSWK2lYrAZdM4mREwPxx5JrK0pJsLaFaQGG83qMmutYKMNqiIzE4voUkbsg8tXrkc9/tUxe7zofh6JUILNxxEaPbV8n0tUnJKfh++wV8uv4M4hJTVMHGsZ2qYUzHKrmOLyKkwIXQCy+8gIkTJ+LKlSto0qQJvL3Tm3bZfZ4QYrOkJAOXtmvzidHAnq9zZxXSxweJWyxVoEjz0qQUnYqD+WFEc9yMjMOqQ1dVbI/E2IjIkamkjwf6NiqHx5uURbUArfHo9rOhmPnPKZy4Fqkey2te6VoDjzcpl6P1pSAo6eOJt3rVwusrjmH2uiB0q1MSFYunvzYcCQlXgdknr2vb0KKyn8o8q+pf2EKjJkTDSSeOWhNwdn7wpLPn7vORkZHw9fVFREQEfHxsq3M0IcRErh0Gvulw/7FnUeCVE4CHiRfrn/oBwRuAHh8ALceoYoXdPt2iYnNWj22j0tT1yG/nsasRShCJENK7uwR5XWEPl7QaO1LteUzHqhjRpjIKuVuXBUW2Y8h3e7AzOAytqhTHktEt1DVBstg+/jcIP+66qLZfLFFvPlwLA5qWY2NVYhXXb3afJ4QQPRdTrUFVuwB3LwJ3goEDi4DW44xfR3KSljpvECg9Z/0ZJQIeql0ynQgSRAzUL1dUTW/2qoWNp26plPRNQbeVFUVwc3HCUy0r4sXO1eHnbd5Gp+ZCtmNWv/roNmeLcpMt2xeiYn7eWX0c1yPi1Gv6NCyDtx6prZq3EmItsPs8IYToubhN+1+lI1CoKPDHi8CueUDz0YCrkRfvm8eAhCjAwxcoWQenrkdizdHr6qmc0sslTkZ6e8l0OypeWYgk02xQswqoUNz6E1NkjK92C1SZcRIMLa5AobxfIbzXpx7T44l9CCFCCLFLxJKjj+2p1BYoWRfYNBOIugYcWQo0GWZi/aAWgLOLqvEjSGaYsanlgn8RD4xsWxm2xjNtKqu0eLFmSdD36HZV8FKX6lbnyiNEj+Wj7AghxBq4cQSIj9QsOaUbAK7u911iO+ZogdQmBkofuxKh0solCeyVrtXhCIj4+eqpxhjXqRr+HNcWk3vWpAgiVg2FECGEGMYHSVyPc+qFu/EwoFAx4M554OSqnNchuSdphRTbqAwqoU/D+xlgjoDUJnq1eyBql2GCCbF+KIQIIUS4sO2+W0yPZIu1GKPNb/tUEzrZEXoGiAkDXAvhYGIFbA66rSwkLzmINYgQhxFC4eHhqsHqlClTcOfOHbXs4MGDuHpVq5hKCCE2RXLifUtO5Xbpn2v+LODmrQVBn1uf/Xou7dD+l2uKjzdcVLMDmpR7oKYOIcSGhdDRo0dRo0YNfPDBB/j444+VKBJWrlyphFF+MW3aNJWeaTjVrFkz2/f89ttv6jWenp6oV68e/v7773wbHyHEhrl+BEi4p9UNKlkv/XNSWbrpM9r8tk+Mig8K8Wmo6ulI5eQXu9AaRIhdCaEJEyZg+PDhOHv2rBIYeh5++GFs3boV+UmdOnVw/fr1tGn79lSffibs3LkTgwcPxsiRI1VLkD59+qjp+PHj+TpGQogNcmHrfbdYJkVj0Woc4OIOXN4JXN6d+TrEbZYqhBZcLq3+D2peHmWL5q2XFyHEyoTQvn378Nxzzz2wvGzZsrhx4wbyE2n6WqpUqbSpRImsOxXPnTsXPXr0wKRJk1CrVi28++67aNy4MebNm5evYySE2HD9IMP4IEN8SgMNBmdvFQq/rLrWpzi5YumNUvBw1fpoEULsTAh5eHiostUZOXPmDPz987dYllihypQpgypVqmDIkCG4fPlylq/dtWsXunbtmm5Z9+7d1fLsiI+PV9tnOBFC7D0+KNXKUylDfJAhbV4CnJyBs/8CN449+HyqNeisS1XEwhNPt6yoenARQuxMCD322GOYMWMGEhO1fjgSqyOC5PXXX0f//v2RX7Ro0QKLFi3C2rVrMX/+fNXqo127doiKisr09WKdKlmyZLpl8jgnq9XMmTNVbxL9VL58ebNuByHEyrh6EEiMAQr5AQG1s36ddJGv01eb3/7pg8+L2wzAprjq8HJ3UT3BCCF2KIRmz56Ne/fuISAgALGxsejQoQOqVauGIkWK4P3338+fUQLo2bMnBgwYoLrbi2VHAp8lUPvXX3816+dIwLc0aNNPISEhZl0/ISTvrD1+He0+3IgDl7Ss1TxxUR8f1Cbz+CBD2r6i/T/xOxAWnO4pXapFaF9KIJ5pU4n9tAix1xYbYiVZt26dClSWDDIRRRJ7k9ENld8ULVpUZa+dO3cu0+clhujmzZvplsljWZ6T608mQoj18s3W8wi5E4tP1p3B4lEtzVQ/qH3Ory1VD6jeDTj7H7DzM+DRudrye7fgFHYOKTonnHarg9ntquRtTIQQ6y+o2LZtW7zwwgt47bXXClwECSLAgoODUbq0lp2RkVatWmHDhg3plomAk+WEENslPCYBh1O7su84F4bzt+/lfmVJ8fc7xWesH5QVbSdo/w8vASK1ZqrJF7T6QUG68hjYrj6Kellnh3hCiJmarorAkOnWrVtISUlJ99yCBQuQH7z66qt49NFHUbFiRVy7dg1Tp06Fi4uLSpEXhg4dqjLXJMZHeOmll5TbTlx5vXr1wtKlS7F//3588803+TI+QkjBsO1sKFKbmiuW7LmMtx7JJrYnO64eAJJiAa8SgH/2dcnSqNgKqNBKK8C4+wug23u4cHAdJD/siHMtjGhbKXdjIYTYhkVo+vTp6NatmxJCoaGhuHv3bropv7hy5YoSPYGBgRg4cCCKFy+O3bt3p2WqScC21BbS07p1ayxZskQJnwYNGmD58uVYtWoV6tatm29jJITkP9K2QtB3cv/twBXEJRrZEDW7thpOTsa/r91E7f++BUi8F4aUi1p8kF/tTiji6Za7sRBCLIKTTpdT85z0iCvqww8/xNNPPw1HQNLnJS5KAqd9fNhAkBBLkpKiQ/P/bUDovXj8NLI5Jq84hqvhsZg9oAH6Nyln+goXPaLVEOo1G2g2yvj3yc/m1+1UGv2pSk8j8MLPcHbSIWb8CXj55WIchBCLXb9NtgglJCQoawshhBQ0J69HKhEk6enNK/vhyRYV1PKf91wyfWWJcffjg4wJlE5F7h2PXY3EGp9B6nGtiz8pERRRqDxFECE2iMlCaNSoUcrlRAghBc2WM5pbrHXVEvBwdcHApuXh5uKEQ5fDceJahGkru7IPSI4HCpcESmTfDyw+KRmbg27hzd+PodXMjXh03naMP1oRF1Lu1yrzrmG8mCKE2FiwtPQX0yPB0RJ3s379elXTx80tvT/8k09yaEpICCG5RMSI0CFQiw30L+KB7nVKYc3R61i85zL+1zdDw1Rj22pkEh90NzoBG0/fwvpTN7H1zG1EJ9yPQxKLVIcapXDH63lUPjpNLXOVOkSEEPsUQtK01JCGDRuq/2xgSggpKCJiE3HwspY237HG/XY+Q1pUVEJo1aGrmNKzpvHByhe3Z9pW43JYDCavPIrd58PSZaeV9PFA11ol0bV2SbSqUhyebi5AUl0gZBEQdROo0tEcm0kIsUYhtGnTpvwfCSE2HMC76vBVFPVyQ+ea6du6EPOx41woklN0qOrvjfJ+XmnLW1bxU8uCb0dj1eFrqsdXjiTGaq6xDEJI9uUrvx7GgUt30zLTHqoVoMRPvbK+qqVQOlw9gJHrgYQowLesuTaVEGLNMUIjRozItL9XdHS0eo4QR0ICd4cv2ocJvx7BiEX78em6MyqY1h6JikvEO6uPY93J9BXbC9ot1jEwIN1yESdiFRIW775k3PcfsgdITgCKlNZ6iKWy/OAVJYLE9bXulfb456V2mNAtEPXLFX1QBOkp7A/4sZI0IQ4jhH744QfVYywjsuzHH38017gIsXp2ngtFz7nbVPyIu4t2Ks3dcFaldCclpy80ag+8u+Ykftx1CS8vPYTbUfEF+tkibvSB0h0M3GJ6JHXe080Zp29EpVlzjHaLpQocqVg965/Tav7lrtVRvWQRs24DIcTGhZDk40suvvwgiUVIHusnKaQoTVClESsh9o6InNn/BWHI93uUIKhRsjDWjG+L9/vWhbMTsGx/CJ796QBiEpJgL2w6fQu/7r+i5iVo+NP1Zwr080Xg3IyMRyE3LW0+I76F3PBYgzJqXoKmjS6kaNBW48N/g3AnOkHtz2faVDbj6AkhdiGEpMmpn5+fMg9Ls9NixYqlTSVKlFBusbFjx+bvaAmxMNcjYvHkt3vw+cZzqqbe4OblsXpsW9QoWUS5Z756qgk8XJ1VttHgb3Yj7F7BWk7yg4iYRBU8LLStVkL9X7r3Ms7cfNBFnt/VpFtVTQ1SzgS9e+yvo9eVoMmShGittYY+Y0zahoWE45e9moB6t3dduKVa+Agh9o/RZ7sETEtbDbEISbuKjRs3pk3SiV5aXLz55pv5O1pCLMiGUzfx8Nxt2HvxDgp7uOKzwY0ws199FHK/f2HuVqcUloxuiWJebjhyJQL95+/EpbBo2DIz1pxU1pjKJbzx7dCm6F6npMqm+t/fpywQH/SgW0xPg/JFVUBzQnIKlh8IyXpll3cDKYmATzmgWGUVgP3WqmNK2PZrXBYtqhTPj00ghNh601VpYCpcuHABFSpUyDpwkBA7IyEpBR+sPY3vt19Qj+Vi+/ngRqhUwjvT1zepWAzLn2+NYQv24mJYDPp9uRMLhjdTF2pbFH8rDl5RYTQfPa6Jvsk9aymLl1hpJD6qfSYxO+YO0tbH/WQWH2TIkBYVMHnlMeUeG9W2CpzFV5lVfJC4xZycsGT3RRy/Gokinq6Y0rNWvmwDIcR6Mdn+K93fKYKIoyDWnMe/2pkmgka0qYzlz7fKUgTpqepfGCtfaI06ZXwQFp2AQd/sxqZUq4YtucSmrDym5ke1rYymlbTYHLEMPd1S67AuViGxqOQnO86FISlFpz63YvHsv/fHGpZRguZSWAy2nwvNsZCixHhJbJAwqXugKtBICHEs6AgnJAv+PHINvT7bjqNXIlSNoO+GNsU7j9ZWrR2MIaCIJ5Y91wrtqpdAbGIyRv2wH7/uz8ZlY2VM//MEbkXFo4q/NyZ2C0z33Pgu1VSAsgQx/5bP27TlTGo1aSMsT17urujfWOv3tTiz/mPxUcDVg9p8pXaY+c8pRMUloW5Zn7QYI0KIY0EhREgmrrC3Vx3Hi78cwr34JDSrVAx/j2+niuqZisQSfT+sGfo1KqssJ68tP4rPNpw1utaQvE6yz2RMBYnUClp56KrKgvt4QIMHApSLerljfBetP9fsdWfU95QfyPbrA6Wziw8yRN+Idf2pW7gREZf+yct7AF0yULQC9twtjJUHryq333t96sElMzcaIcTuMSpG6I8//kDPnj0f6CtGiL1xKzIOzy8+qGJS5AI5tmM1VVPGNQ9ZRO6uzpg9sAFK+Xriy83B+GTdGVwLj1WFAaV2zd2YRITHJiA8Wvsvj8UtdTcmAeGxiUoEyTqaVCiG1lWLo3W14qrAX35lNkmPrTd+11xio9tVQeMKxTJ9nVRw/mnXRRUH9fWW4AesRubg7K17uB4RpzLxWhoZxCwZfJJiv/fCHZUJ9spDNe4/eXGr+pdSsR3eXq21CBrcvAIa2mD8FiGkAIVQ3759cePGDfj7+8PFxQXXr19nzSBidxy4dAfP/3xQuYMkzuSzQY3QqaZ5jnOJq3utR00lhqb+cQJL94WoyVhEDO06H6am2esAb3etno50YZeU8tqlfTIPDM4F0/48oWJnpG1FOhGRARFnk3vWxJifD+LbbeeVJaa0byHkR7aYiKCs0uazCpoWIbR032W82LnafSGbWj9oa0Igzty8Bz9vd7zW3fwCjhBiZ0JIBNDu3bvx6KOPKlM1g6WJPSHH9M97LmPGnyeQmKxDYMki+PrpJjkGROeGoa0qoZSPJ+ZvCYacRcW83OHr5ab+Fy3khqLe2n/12MstdXLHzcg47AwOw67gUOwKDlNWo01Bt9UkyOtaVtasRWI1kmDt3Jyna4/fwOrD15RLbPbAhjmKD+n83rySnyop8NG/QfhkoNaQ2VyY6hbT06NuKRT3lu8tXrnI5DHiIoHrh9XzM05o1qXJPWqq75cQ4rgYJYTGjBmD3r17qx9WmUqVKpXla5OTk805PkLylbjEZNU/S181uVe90vjw8frw9jC6soTJSK0hmUyhsH9hJW7EHSWNQSVIeWdwqBJHe86HITwmEWtP3FCTIKn64ztXQ+eaAUYLIilCKPV0hOc6VDXKXSTrfrNXLfT+YoeKt3mmdWXUK+cLcxAdn4R9F+8YHShtiAS0D2xWHvM3B6ugaSWELu8CdCm47VYG56OKqTIHjzfRAqsJIY6LUb/206ZNw6BBg3Du3Dk89thjWLhwoao0TYgtI3E6z/98QBU+FAvI6z1q4tn2Vaze4ikusNplfNQ0ql0VJCan4NjVCGUpEnG07+JdHAkJx8gf9qv0fXENdatdKkfXmQjC0HtaiwmJizIWEV19GpZRnd/f++sklj7b0izfoYg8sdBV8PNSqfOm8mTzCvhqSzC2nQ3FxdBoVLqgxQdtiK2h9rdUkDaXO5EQYrsYfdtbs2ZNNU2dOhUDBgyAl5dX/o6MkHxERMO4JQdVjR9xK0mBxHbV87cwYH4hQdMS0CzT2E7VVHzPd9vP46ddl3DiWqSK4RF339jO1ZTFK7PsqL+PXceao9fVc5IlZmyJAD2TetTEP8dvYM+FOyrjzFSLV07VpHMjrMr7eSlLkrjXluy9jMmXt6k02V0ptTGsdSUlJAkhxOS0ExFCIoJu376tWmvIJPOE2Eo8kBRHfOr7PUoESZDxn+Pa2qwIygwpCigVkne83llZg4p4uCLoZhTG/3IID326BSsOXFGNY/VIPzQpFyA836GqykgzlbJFC2FUO61R6cx/Tuc53T83afOZoa8N9M++03C6ofVLO+vVCBOyCQInhDgWJguhmJgY1WC1TJkyaN++vZpkfuTIkeo5QqyV2IRkvLzsMN5dc1LV9OnbqCxWPN9aWQ7skWLe7iqlffvkznilaw1VAPH87WhM/O0IOs/eohqnimB5Z/UJJQrFavRil2q5/rznO1ZDicLuuBAanXkxQxMIvh2Nq+GxcHcxPm0+MyRGqoyvJwLjj8EJOgSnlMZzj7RBEU+WAiGE5FIIvfLKK9iyZYuqLRQeHq6m1atXq2UTJ040dXWEFJgIGvD1TpURJe6fqY/WxicDG6RrmGqviAB6qWt1bH+9k4qDkmyqy3diVE+u1rM24K9jmktMah2Z6hLLWDxSn24/d8NZVQspr26xFlX8VLXo3CLbJXWCWjmfVI8vFm6ExxqUyfX6CCH2h8lCaMWKFfj+++9VgUUfHx81Pfzww/j2229VV3pCrJH/Tt5QjTUlHmjxqBZ4pk1lqw+KNjdiBXm+Y1Vse70T3upVS7nQJDhaGNuxKuqWzXu21xNNy6N6QGGVxTZv09lcr2fLmdu5yhbLdEzNyqOVyyk1X6fNIw633wkh+eAaK1nywVYDUmCRrjFirejjTeSimBdXiz0gFhbJNtv2Wie816euipcZ19n4LLHskMKFkk4v/LDzkmpaayrSUmTPeS1tXqpv55WAW9tR2+mimi9Vv2ue10cIcXAh1KpVKxUwHRd3v4dPbGwspk+frp4jxNqQeCC9q6WTGS6s9oIUS3yqZUXVM0yqRJsLES/SaDYhOQUfrD1t8vt3nw9T75UAbKlunSfuXgJWjNLmm44AipjeL44QYt+Y7HyfO3cuunfvjnLlyqFBgwZq2ZEjR+Dp6Yl///03P8ZISJ44ciVcVWKWthlSRI/kP2IVenjuNvx97AZ+3HVRFYI01iVlmC2WJzdWYhzw69NA7F2gTGOgx6zcr4sQYreYfBtYt25dnD17FjNnzkTDhg3VNGvWLLWsTp06+TNKQvLA5tOaNah9df98a1RK0lOzlA+Gt9bS6SUrbfzSw0Z1qE+fNp9H693frwLXjwCF/ICBPwKuHnlbHyHELslVOobUERo9erT5R0NIPrBR7xYzUwNVYhxvP1ILZYp6YtY/p/HnkWs4cS0CXw5prERSVkgne8loc3NxUj3Tcs2BH4BDPwFOzsDjC4Ci5XO/LkKIXcPbY2LX3IqMU9li5spAIsYjbi0Jyl72XEuU9vVUNYz6fLEDv+0PyfI9+liuZpX8ct/v7epB4O9J2nznt4CqnXK3HkKIQ0AhROwavZulfjlflS5OCp4mFf3w1/h2aF/DH3GJKZi0/Cgm/XZE1XbKSJ6rSUeHAb8OBZLjgcBeQJtX8jp8QoidQyFE7JpNzBazCvy83bFoeDNMfEhrePrbgSvo++UOBN++l/aauMRklTGW6/iglGRg5SggIgTwqwL0nS8das25GYQQO4S/EsRuka7s0nlcYHyQ5ZFO7y92qY6fR7ZAicIeOH0jCo99vl3FDwkiguKTUlRLDCnKaDKbZwLBGwHXQsATPwOeeS8QSQixf0wWQlWqVEFYmHbXZoi02pDnCLEW9l28ozKVpKVEfTNUTSbmoXW1Evh7fFu0qOyH6IRkvPjLIdX09b+TN9XzHXKTNh+0Ftj6kTb/2GdASWawEkLySQhdvHgRyckP+vbj4+Nx9epVU1dHSL6hjzeRC6tYI4j1EODjqVqdjO1UVT3+afclLNlzWc13qGGi9S4sGFj5rDbf/Dmg/kCzj5cQYr8YnZYhTVb1SOFEX9/7d9gijDZs2IBKlSohv5C6RStXrsTp06dRqFAhtG7dGh988AECAwOzfM+iRYvwzDPPpFvm4eGRrio2sV82ptYPYnyQdSLtOCZ1r4mmlfzwyrLDqj+Zq7MT2lQzIW0+IUYLjo6PAMq3ALq9l59DJoQ4shDq06eP+i8m62HDhqV7zs3NTYmg2bNnI7+Q7vZjx45Fs2bNkJSUhDfeeAPdunXDyZMn4e2ddRl+aQobFBSU9pgNFx2DkDsxOHfrnuo+LoUUifUiQlWyyt5bcxL1yvmq5rBGodMBa14Bbh4HvAOAAT8Aru75PVxCiKMKoZSUFPW/cuXK2LdvH0qUKIGCZO3atQ9Ye6TR64EDB9C+ffss3yfCp1SpUgUwQmJN6OvRNKlQDL5eRl5YicWQvmLzn2pi2pv2fw8cXQo4uQADFgI+pfNreIQQO8bkGKELFy4UuAjKjIiICPXfz88v29fdu3cPFStWRPny5dG7d2+cOHEi29dLrFNkZGS6idiuW6xjTVqD7JKQfcA/k7X5h6YDldpaekSEEHu2CH322Wd49tlnVWNVmc+O8ePHI78R69TLL7+MNm3aqN5nWSHxQwsWLED9+vWVcPr4449VbJGIIWkam1Us0vTp0/Nx9CS/kXo0O4O1zMbOTJu3P6JDgd+GASmJQO3eQKtxlh4RIcSGcdJJl8McEHfY/v37Ubx4cTWf5cqcnHD+/HnkN88//zz++ecfbN++PUtBkxmJiYmoVasWBg8ejHfffTdLi5BMesQiJNYkEVISb0Rso4jiMwv3qbYOOyd3ZlyYPSFFExc/rtULKl4deHYT4FHE0qMihFghcv2WxK6crt+uxrrDMpu3BOPGjcOaNWuwdetWk0SQPqi7UaNGOHfuXJavkawymYjtsknvFgsMoAiyN7Z8qIkgNy/giZ8oggghjlNZWgxXIoJ+//13bNy4MVvLVFZImv+xY8dQujSDKu0VOU708UF0i9kZZ9cDWz7Q5h+dCwTUsvSICCF2gMntnSdMmJDpcrnzlhiiatWqqaDknIKYTUVS55csWYLVq1ejSJEiuHHjhlouZi+pKyQMHToUZcuWVXE+wowZM9CyZUs1Jql8/dFHH+HSpUsYNWqUWcdGrAfpXXXlbizcXZzRuqoJ9WiIdRMeovURgw5oOoJFEwkhlhNChw4dwsGDB5V1RV/M8MyZM3BxcUHNmjXx5ZdfYuLEiSp+p3bt2mYb6Pz589X/jh07plu+cOFCDB8+XM1fvnwZzgZNFu/evYvRo0cr0VSsWDE0adIEO3fuNOu4iHWx6bRWTbpFFT94e5h8eBNrJClBC46OvQuUaQT0mGXpERFC7AiTrxR6a48IEH3wkQQiiZWlbdu2Sng8+eSTeOWVV1QFanNhREw3Nm/enO7xp59+qibiOLDbvB3y35vA1QOAZ9HUoomM4SOEFHDWmCHielq3bt0DVhVJSZdKz9JvTCxGMh8aqnX+doSoc2J5ouIS0WjGOiSl6LDp1Y6oXCLriuPERji2HFgxUpt/8legRndLj4gQYmfXb5ODpWWFt25pd92G3L59O634YNGiRZGQkGDqqgnJEzvOhSoRJAKIIsgOuHUa+CO1Llm7VymCCCH5gnNuXGMjRoxQ2VtXrlxRk8yPHDkyrR/Z3r17UaNGjfwYLyE5xgd1DGQ1aZsn/p7WTDUxGqjcHuj0hqVHRAixU0yOEfr6669V/M+gQYNU81O1EldX1YhVH48jQdPfffed+UdLSBaIh5fxQXaCeOv/fAkIDQKKlAb6LwCcXSw9KkKInWKyECpcuDC+/fZbJXr0VaSrVKmilutp2LCheUdJSA6cuBaJW1HxKOTmojLGiA2z7zvg+HLA2RUYsAgoTAsfIST/yHV+sQgffa0gQxFEiCWrSbepVgIerrQe2CxX9gNrp2jzD80AKrS09IgIIXaOc24ankqhQonElq7uMklwtPTukucIsQRpbjF2m7ddYu4Av6Y2U631GNDyBUuPiBDiAJhsEXrzzTfx/fffY9asWar7uyDFE6dNm4a4uDi8//77+TFOQrLkTnQCDoWEq3nGB9koyUnAytFA5BXAryrQ+wspV2/pURFCHACThdAPP/ygAqEfe+yxtGX169dX9YVeeOEFCiFS4Gw9c1vF19YsVQRlimrtVogNkZyo1Qo6tx5wLaQ1U/VkzS5CiJUKoTt37qissIzIMnmOEEu5xaTbPLExkuKB354Bgv4CXNyBAQuBknUsPSpCiANhcoxQgwYNMG/evAeWyzJ5jpCCJDlFhy1ntPpB7DZvYyTGAcueThVBHsCgJUBgT0uPihDiYJhsEfrwww/Rq1cvrF+/Hq1atVLLdu3ahZCQEPz999/5MUZCsuRwyF2ExyTCx9MVjSsUtfRwiLEkxgJLhwDBGzR32OBfgKqdLD0qQogDYrJFqEOHDqrbfN++fREeHq6mfv36ISgoCO3atcufURKSQzXp9jX84epi8uFMLEFCNLBkoCaC3LyAIb9RBBFCbKuOUJkyZR4IipZWG88++yy++eYbc42NkBzZmFo/iNliNkJ8FLDkCeDSDsC9sCaCKra29KgIIQ6M2W6hw8LCVFo9IQXFjYg4nLweqbKsO7C/mPUTFwn83F8TQR4+wNO/UwQRQmy3sjQhlmbLGc0aVL9cUZQo7GHp4ZDsiA3XRNDV/YCnryaCyjax9KgIIYRCiNgu60/p3WK0Bll9xeif+gLXDwOFigFDVwOlmWFKCLEOGF1K8pXLYTE4dPmu2dd7MTQaG07dVPM96pYy+/qJmYgOA354TBNBXsWBYWsoggghtmkRksyw7JDsMUIMiYhJRN8vd+BOTAJWPN8ajSsUM9u6v9oSjBSdZg2qWYpViK2SiKvA4seBWycB7wBg2B9AQC1Lj4oQQnInhKTJak7PDx061NjVEQfgk3VBCItO0Ob/O4OfR7Uwy3qvhcdixcEran5sp2pmWScxY5HEoL+BI0u1lhm6ZKBIaWDYn0CJ6pYeHSGE5F4ILVy40NiXEoKT1yLx0+5Lat7F2Qnbz4Vi9/kwtKxSPM/r/nbbeSQm69Cish+aVvIzw2hJnpBGbyF7gCO/AMd/B+Ij7j9XvgXQZz5QvKolR0gIIVnCYGlidnQ6Hab9cUK5rh6uVwrFvT2UKBKr0LLnWsIpD13FQ+/F45e9l9U8rUEW5s4F4Ogyzfpz98L95b7lgfpPAA0G0QpECLF6KISI2fnjyDXsvXgHnm7OeLNXbbg4OWHZ/hC1bNvZUFUFOrcs2H4BcYkpqF/OF+2qlzDruIkRxEUAJ1Zp4ufyzvvLpThi7T6a+KnYBnBmHgYhxDagECJmJTo+Cf/7+5Saf6FjNZQtWkjNP9WiIhbsuIDZ684oAZMbq1BEbCJ+2nUpzRqUF8sSyQW3zwALugGx+ixAJ601RoPBQM1egLu3hQdICCGmQyFEzMq8TedwMzIe5f0K4dn2VdKWP9+xqnJpHQkJV20xutQqafK6f9p1EVHxSahRsjAeysX7SR7Z/D9NBBWrBDR5Bqg/EPApY+lREUJInqD9mpiNC6HR+G7beTX/dq/a8HRzSXvOv4gHhrWupOZn/3cGKRJAZAIxCUlYsONimqXJ2ZnWoALldpDmEhOeWAy0fZkiiBBiF1AIEbMx488TKptLYoAeqv2gxea59lVQ2MNV9Qf798QNk9b9y94Q3IlOQAU/LzxSv7QZR02MYttsCYMHAnsBpepaejSEEGI2KISIWZAqz5uCbsPNxQlTH62dafxOMW93jGhbWc1/su4Mko20CsUnJePbrZqlaUyHqnB14WFboIQFA8d+0+Y7TLL0aAghxKzwikLyTFxiMmasOanmR7SpjKr+hbN87ci2leHj6Yqzt+5hzdFrRq1/5cGruBEZh5I+HujfpKzZxk2MZPsngC4FqPYQUKaRpUdDCCFmhUKI5Jnvt1/ApbAYBBTxwItdsq8b41vIDc910IrrzVl/FknJKdm+Xp6fvzlYzY9uVwUervfjjkgBcPeSliovdHjN0qMhhBCzQyFE8tzuYt7Gc2p+ysM1VQxQTgxvXQl+3u4quHrloavZvvavY9dx+U4Minm54ckWFcw2bmIkO+YAKUlA5Q5A+eaWHg0hhJgdCiGSJ6RmUGxiMppWLIY+DY1zW3l7uOL5VKvQ3PVnkZCUuVVIMsu+2HQuzeXm5c5qDwVK5DXg0M/aPK1BhBA7hUKI5JpdwWFYc/Q6JC562mN1TCpw+FTLiiql/mp4LH7dH5Lpa9afuokzN++hiIcrhqam3pMCZMdcIDkBqNAaqNTW0qMhhJB8gUKI5AqJ3Zn+5wk1/2TzCqhb1tek9xdyd8HYjppVSFxrEnCdsV+Z3hr0dKuKKraIFCBRN4EDi7R5ZooRQuwYCiGSK37efQmnb0ShqJcbXu0WmKt1DG5RAWV8PVVG2JI9WiNVPTvOheHIlQjVr0yfck8KkF2fA0lxQNmmQJVOlh4NIYTkGzYnhL744gtUqlQJnp6eaNGiBfbu3Zvt63/77TfUrFlTvb5evXr4+++/C2ys9krYvXhVB0iY2C1Q1QfKDZIBNq6zlmX25eZgVT1az7xNZ9X/Qc0qoERhD7OMmxhJdBiwb8H92CD2dCOE2DE2JYSWLVuGCRMmYOrUqTh48CAaNGiA7t2749atW5m+fufOnRg8eDBGjhyJQ4cOoU+fPmo6fvx4gY/dnvjo3yBExiWhdmkf5RbLCwOallPVokPvxePH1IaqBy7dwe7zd1RxRsN+ZaSA2P0FkBgNlG4AVO9m6dEQQki+YlNC6JNPPsHo0aPxzDPPoHbt2vjqq6/g5eWFBQtS714zMHfuXPTo0QOTJk1CrVq18O6776Jx48aYN28e7JmtZ27j6e/34KN/T2PfxTs51uoxBlmHrGvWP6exLDW4eXrvOnDJY88vNxdnjE+tPfT1lmBExSXii01a3aB+jcqhTGr3elJASFPVPd9o8+0n0RpECLF7bCYfOSEhAQcOHMCUKVPSljk7O6Nr167YtWtXpu+R5WJBMkQsSKtWpTaPzIT4+Hg16YmMjIQtsSnoFp778QASklOw7WyoEhVSybldDX90CgxAhxr+KlvLGG5HxWPLmdtqndvO3FZWID39G5dDs0p+Zhlzn4Zl8OWmczgfGo3JK4+p7vSir8akBlOTAmTP10BCFBBQW+srRgghdo7NCKHQ0FAkJyejZMn0zTzl8enTpzN9z40bNzJ9vSzPipkzZ2L69OmwRUS0PPeTJoI6BvrDx9MNW8/eRnhMIv46el1NQr2yvur5joEBaFi+aJpVR3p/HbkSjs2nb6m+YceuRqRbvwRGt6/uj041/fFoffN1HpfeYS8/VAPjfzmUNsZe9cugcglvs30GMYK4SGD3l9p8+1flTsPSIyKEkHzHZoRQQSEWJ0MrkliEypcvD2tn29nbGP3jflWcsHudkpj3ZGPldhJxczgkHFuC7osb/fT5xnNp4kY8IOJSuxuTmG69WYkmc/NIvdL4YuM5BN2MUo9foDWo4Nn3LRAXARSvDtTuY+nREEJIgWAzQqhEiRJwcXHBzZs30y2Xx6VKlcr0PbLclNcLHh4earIldpwLxagfNBH0UO2S+HywJoIEES5NKhZT04RugbgVFYetZ0LT3F1iLfrjyP3mp0U8XZUwEvHTIdAfAUU8C2QbnJ2d8HrPQIz8YT961SuNWqV9CuRzSSoJ0cCuLwysQezpRghxDGxGCLm7u6NJkybYsGGDyvwSUlJS1ONx48Zl+p5WrVqp519++eW0ZevWrVPL7YWdwaEY+cM+xCeloGutAHzxZGO4u2bt0hBh83iTcmqSAOhDIeHKEqTTAe1r+KNxhaLKVWUJOtcsie2vd4Y/0+ULnv0LgJgwoFhloO7jlh4NIYQUGDYjhARxWQ0bNgxNmzZF8+bNMWfOHERHR6ssMmHo0KEoW7asivMRXnrpJXTo0AGzZ89Gr169sHTpUuzfvx/ffJOaFWPj7D4fhhGL9iEuMQWdawbgiyHZi6CMiOCRgGdzBT2bg7L5lSWWkgwc/AHwKgHU7EWLhyGJscCOz7T5dhMAF5v6WSCEkDxhU794TzzxBG7fvo133nlHBTw3bNgQa9euTQuIvnz5ssok09O6dWssWbIEb731Ft544w1Ur15dZYzVrVsXts7eC3fwzEJNBIkb68shjVWBQpIF694BdqWWTfCrArQeDzQYDLgVjOvPqjn4IxB9C/AtD9QfZOnREEJIgeKkk6ZOJEskWNrX1xcRERHw8bGOuBWp5zNswV7EJCQrd9Y3TzeBpxtFUJYc+AH4c7w27+ELxKdmwxUuCbR8Hmg6AvA0rVea3ZAUD8xtCERdA3rNBpqNsvSICCGkQK/fzI+1MaTq8vBUEdSuegmKoJy4sBX4KzULsOMUYMJJoPtMwKcscO8msH4a8GldYN1UICrrsgp2h9z/RF4Dts/RRFCR0kDDpyw9KkIIKXBoEbJWi1ByEnDzOBCyFwjZA1w7iNv+LdDpdF/ci09Cm2rF8d3QZqqLO8mC0HPAd12AuHCgbn+g//f3KyUnJQDHlwM75gK3U+tQubgDDZ/U3GbFq9qR4LmqbeOt09r/20HapLeMCT1madYxQghxsOs3hZC1CKHYcODKfiBktyZ8rhzQ+j1l4JH491CkcjMsGE4RlC0xd4DvugJ3grUO6sPXAG6ZBGKnpABn1gI75mjfu8IJqN0baPsyUKYRbC7w+dDPwLXD90WPVIrODCcXLV6qQgvg4dmMlyKE2BUUQtYuhO6cBy6nip7Le1KtEul3RYJrEVwsVBt7EquhfPRxdHQ5gm2endBkwnJ4udtUnHvBkpwI/NQXuLhNCwAetQEokr7CeKZc2gVs/xQ4++/9ZX2/BhrYSABxQgzwyxOaO9AQZ1fAryrgHwgE1NL++9cEilcDXFmqgBDi2NdvXk0txW/DgetH0i0KL1QeJ11qYlNMFWyJrYKzcWWhu6eFcdVxqq2EUNuEbXCKvQm4l7XQwK0c0fUSEyQiyL0wMHipcSJIqNhKm26eADbPAk79Afw1ESjfXLOcWDPx94BfBt3f7pYvACVra4JHRJCru6VHSAghVgmFkIW4ULgJXLxTsD+lBv6LrIj9ydURGnc/c8ndxRmNyvqgcQWtKnTjil2AFf/A6dJ2YO83wEO22Q8t35HqyJIOLu4tiQkqlYtSCSXrAAMWAT88ClzaAax8FnhmrfXW14mPAhYPBC7vBNyLAE+t0NxdhBBCcsRKf9ntn9ejBmJvWNe0xwFFPNBTBE8FET3FULesz4N1gVqNBUQIHVgItJ8EeBQu+IFbM0H/AP+9pc13fx8I7JH7dUnBxb5fAfPbAlf2AVs/AjpNgVU2Sl08QIst8/ABnv4dKNfU0qMihBCbgULIQjzaoDRql/FBowpFlcVHKio76TOasqJGD81FI/FFh5cALZ4tqOFaPzeOActHanFWTYZrrqG8UrSCVltn5Shg64dAtS6am8xakAapP/fXhJrUQRIRVLaJpUdFCCE2BesIWYinW1XCtMfqoHfDsihXzCtnESRI1Wz9BX7PfK1tBAGibgJLBmlZdpXbAw9/fD9NPq/UHwDUGwjoUoAVozQLjDUgWYY/9kkVQUWBoX9QBBFCSC6gELI1pM6NXPjEKiRp346OpIsvfRKIvKJlQQ38EXBxM+9n9PoY8K0AhF8C/nkdVlEa4MfeqrYUCvkBw/4EyjS09KgIIcQmoRCyNdy9gabP3A8MdvQMsVUvAFf3a+LwyV+BQsXM/znidur3NeDkDBxZApz4HZYVQY8B1w8DXsU1EVS6vuXGQwghNg5jhGyR5s8COz/XMpquHgTKNobdIKnrEVeBhHvaJGnhD8xHa5lSMWFa9W2pk/PEz/lbDbpia6DtK8C22cCfLwPlmgO+BVzCIDpUswTJNnv7a+4wSZEnhBCSayiEbBGfMlrLiKPLgN1fAv2/g11wag2wbIjp73vkU6ByO+Q70qsseCNw7RCwagzw9GotbqsguHdbswTdOqk1ixVLkBRGJIQQkidYWdoGu88rpIXCNx00a8hLRwveOpEf1aC/aKG1xJDMOGkCKoUBpUSAuAOlPo6aT33sUUSbl7gg/xoF27/s63ZAYgzw0LtAm9Su9vkdDC4iSKqPFy6ltQspUT3/P5cQQmwYVpa2dyQ4tlI7rZKwPRRYPPSTJoK8SgDPbdWEjjVSohrQYybw50vAhhlAlY75G6MTdUMr7Bh6BihSRhNB9tIQlhBCrAAGS9sy+lR6KbAo8TO2isT8SEsLocNr1iuC9DQeBgT2AlIStZR66fGVH0ReBxb10kSQTzngmb8oggghxMxQCNky+gKLUlhPCizaKrvnA/duAkUrAk1SM+KsGalR9NjnWqxOaBCw7h3zf0bkNU0EhZ3TGseKJcja+50RQogNQiFkyxgWWJSgaVsssCjp4DvmavOd37ad5qDexYE+87X5fd8CZ/4zswh6RHMVSv0iJYIqm2/9hBBC0qAQspcCi3cvaL22bA1JR4+PBErV0zLhbAlpudHieW1+9QtaZldekdIBYgkyFEHFKuV9vYQQQjKFQsguCiyOsM0Ci+GXtUBvoeu0gktFNycy7oDaQPRt4LdhQFhw7tcVcSVVBJ3X+pxJTFCxiuYcLSGEkAzY4JWHPEDz0Voa/eWdWoFFW2HT/4DkBK0/WNUusEncPLU6Tq6eWoHLL5oDf70K3Ltl2nrCQzQRJJY9iZUa/rcmhgghhOQrFEL2VGBRHytkKxWkjyy9b1UxV5NUS1CyDjB6I1DtISAlSYsZmtsQ2DRTq4BtjGVMiaCLmhvsGRFB5Qti5IQQ4vBQCNkL+qBp6YMlLhZrZ73UPdIBtfvYR9d0EUNPLU9tgNoYSIwGtszSBNGeb4CkhMzfd/eSJoKkoWuxysDwvwDfcgU9ekIIcVgohOytwKJYJPRxN9bKxR3A2X8BJxctU8yeEDefWIcG/AD4VQViQoF/JgFfNAOOLQdSUjKIoEc0i5CkxlMEEUJIgUMhZE+0Gqv937/IegssSkeX9VO1+SbDtErN9oa4+er0AcbuAXp9AngHaG6vFSOBbzsCwZu0x2IJihARVDVVBNl4mxRCCLFBKITsierdtYtqvBRYXAyr5PRfwJV9gJsX0OF12DUubkCzkcD4Q0Cnt7R+adePAD/1Ab5sBUSEaL3SRARJnBchhJACh0LI7gosPn+/WrO1FVhMTgI2TL8f01SkFBwCaRbbYRLw0mGt7pCzm9a0tXh1YNgawKe0pUdICCEOC7vP22r3+ez6dn1SG4gL1zKQpA2EV3HAyy/1v0wlDOZTl3v65n/m1sEfgT9eBAr5aaJAPtMREbeYVKKu2w/wLmHp0RBCiF3C7vOOXGCx1Thg03vaBVcmYyjfEnhqhWa9yA+kMamkkwvtX3VcESSIQG3xrKVHQQghhELIThGhIdaGqBtATFjWU3Tqf0n1DtkN/PcW8Oic/BnT3q+BqGtaA9GmI/PnMwghhBAToRCyR8TFVbyqNhnD+S3Aj48BBxYCNR8Bqnc1f2PV7Z9q853e1KoxE0IIIVYAg6UJUKUD0GKMNv/HOE24mBMRQXERWk+u+gPNu25CCCEkD1AIEY0uU7VU7qjrwN+TzLdeqXK952uDxqou5ls3IYQQkkcohIiGuxfQ92vAyRk4vlxr1ZFXJCFxw7tAcjxQoTVQvZs5RkoIIYSYDQohcp9yTYF2E7X5NROAqJt5E0Eb3wWOpjZWfWi6bTdWJYQQYpfYhBC6ePEiRo4cicqVK6NQoUKoWrUqpk6dioSELBpZptKxY0c4OTmlm8aMSY2FIZnT/jWgVH0g9g7w53hN0ORKBL0HbJutPe4xCyjf3OxDJYQQQhwia+z06dNISUnB119/jWrVquH48eMYPXo0oqOj8fHHH2f7XnndjBkz0h57eXkVwIhtGFd3zUX2TQfgzFrg0M9A46dzIYI+vi+C9NWuCSGEECvDJoRQjx491KSnSpUqCAoKwvz583MUQiJ8SpVykFYO5qJkbS3NXZqjrp2idVQvVtE4EbTp/fsiqPtMiiBCCCFWjU24xjJDSmb7+fnl+LrFixejRIkSqFu3LqZMmYKYmJgCGZ/N0/pFrdp0QhSw6gUgJcUIEfQ/YOtH2uPu/wNavVAgQyWEEELs2iKUkXPnzuHzzz/P0Rr05JNPomLFiihTpgyOHj2K119/XVmSVq5cmeV74uPj1WTYq8QhkTT3vvOB+W2BS9uBPV9lL2w2zwS2fqjNd3sfaDW2wIZKCCGE2GTT1cmTJ+ODDz7I9jWnTp1CzZo10x5fvXoVHTp0UIHQ3333nUmft3HjRnTp0kUJKQm4zoxp06Zh+vTUDukG2EzTVXOz73vgrwmAqyfw3DbAv8aDr5EeYltm3RdBrccV+DAJIYSQ3DRdtagQun37NsLCwrJ9jcQDubu7q/lr164pAdSyZUssWrQIzs6mefYkuLpw4cJYu3YtunfvbrRFqHz58o4rhOTw+Lk/ELwBKNMYGLkOcDEwJG6epVmDhG7vaS41QgghxMLYRPd5f39/NRmDWII6deqEJk2aYOHChSaLIOHw4cPqf+nSpbN8jYeHh5pIKlL7p/c84MuWwLWDwPZPgA6vPSiCHnqXIogQQojNYRPB0iKCxBJUoUIFFRcklqQbN26oyfA14kLbu3evehwcHIx3330XBw4cUHWI/vjjDwwdOhTt27dH/fr1Lbg1NohPGeDh1HisLR8A1w4Dmz8wEEEzgDbjLTpEQgghxG6DpdetW6fiemQqV65cuuf0nr3ExEQVCK3PChN32vr16zFnzhzlEhP3Vv/+/fHWW29ZZBtsnnoDgNNrgJOrgR97A3HhBiLoJUuPjhBCCMkVFo0Rsicfo0MQHaa5yKJvaY+7TgfavmzpURFCCCG5vn7bhGuMWAnexYF+3wDFq2sVoymCCCGE2Dg24RojVkTVTsCL+y09CkIIIcQs0CJECCGEEIeFQogQQgghDguFECGEEEIcFgohQgghhDgsFEKEEEIIcVgohAghhBDisFAIEUIIIcRhoRAihBBCiMNCIUQIIYQQh4VCiBBCCCEOC4UQIYQQQhwWCiFCCCGEOCwUQoQQQghxWCiECCGEEOKwuFp6ANaOTqdT/yMjIy09FEIIIYQYif66rb+OZwWFUA5ERUWp/+XLl7f0UAghhBCSi+u4r69vls876XKSSg5OSkoKrl27hiJFisDJycmsSlXEVUhICHx8fGCvcDvtC26n/eAI2yhwOx13O3U6nRJBZcqUgbNz1pFAtAjlgHx55cqVy7f1y46054NWD7fTvuB22g+OsI0Ct9Mxt9M3G0uQHgZLE0IIIcRhoRAihBBCiMNCIWQhPDw8MHXqVPXfnuF22hfcTvvBEbZR4HbaFx75sJ0MliaEEEKIw0KLECGEEEIcFgohQgghhDgsFEKEEEIIcVgohAghhBDisFAIWYgvvvgClSpVgqenJ1q0aIG9e/fCnpg2bZqqxG041axZE7bO1q1b8eijj6pKpbJNq1atSve85B688847KF26NAoVKoSuXbvi7NmzsKdtHD58+AP7tkePHrA1Zs6ciWbNmqmq8QEBAejTpw+CgoLSvSYuLg5jx45F8eLFUbhwYfTv3x83b96EvW1nx44dH9inY8aMga0wf/581K9fP63IXqtWrfDPP//Y1X40ZjttfT9mxaxZs9S2vPzyy/myTymELMCyZcswYcIElQJ48OBBNGjQAN27d8etW7dgT9SpUwfXr19Pm7Zv3w5bJzo6Wu0vEbKZ8eGHH+Kzzz7DV199hT179sDb21vtWzlp7WUbBRE+hvv2l19+ga2xZcsW9UO6e/durFu3DomJiejWrZvafj2vvPIK/vzzT/z222/q9dJup1+/frC37RRGjx6dbp/KsWwrSPV/uVgeOHAA+/fvR+fOndG7d2+cOHHCbvajMdtp6/sxM/bt24evv/5aCUBDzLpPJX2eFCzNmzfXjR07Nu1xcnKyrkyZMrqZM2fq7IWpU6fqGjRooLNn5PT5/fff0x6npKToSpUqpfvoo4/SloWHh+s8PDx0v/zyi84etlEYNmyYrnfv3jp749atW2p7t2zZkrbv3NzcdL/99lvaa06dOqVes2vXLp29bKfQoUMH3UsvvaSzJ4oVK6b77rvv7HY/ZtxOe9yPUVFRuurVq+vWrVuXbtvMvU9pESpgEhISlJoXl4lhPzN5vGvXLtgT4hIS90qVKlUwZMgQXL58GfbMhQsXcOPGjXT7VvrciOvT3vbt5s2blZslMDAQzz//PMLCwmDrREREqP9+fn7qv5ynYj0x3J/i3q1QoYJN78+M26ln8eLFKFGiBOrWrYspU6YgJiYGtkhycjKWLl2qLF7iOrLX/ZhxO+1tPwpiyezVq1e6fSeYe5+y6WoBExoaqg7gkiVLplsuj0+fPg17QS7+ixYtUhdKMc9Onz4d7dq1w/Hjx1Wsgj0iIkjIbN/qn7MHxC0mJujKlSsjODgYb7zxBnr27Kl+gFxcXGCLpKSkqPiDNm3aqAuIIPvM3d0dRYsWtZv9mdl2Ck8++SQqVqyoblyOHj2K119/XcURrVy5ErbCsWPHlCAQN7TEjPz++++oXbs2Dh8+bFf7MavttJf9qEdEnoSOiGssI+Y+NymESL4gF0Y94tsVYSQn6K+//oqRI0dadGwkbwwaNChtvl69emr/Vq1aVVmJunTpAlu98xSRbg9xbLnZzmeffTbdPpVgf9mXInRl39oCctMlokcsXsuXL8ewYcNU7Ii9kdV2ihiyh/0ohISE4KWXXlIxbZJQlN/QNVbAiMlS7pozRrfL41KlSsFeEeVeo0YNnDt3DvaKfv852r4V16cc17a6b8eNG4c1a9Zg06ZNKhhVj+wzcWWHh4fbxf7MajszQ25cBFvap2IhqFatGpo0aaIy5STgf+7cuXa3H7PaTnvZj3rXlyQPNW7cGK6urmoSsSeJKDIvlh9z7lMKIQscxHIAb9iwIZ25Wh4b+nntjXv37qm7ErlDsVfEVSQnoeG+jYyMVNlj9rxvr1y5omKEbG3fSiy4iANxLWzcuFHtP0PkPHVzc0u3P8XNILFutrQ/c9rOzBCLg2Br+9QQ+V2Nj4+3m/2Y03ba037s0qWLcgHK+PVT06ZNVaypft6s+9SsId7EKJYuXaoyiRYtWqQ7efKk7tlnn9UVLVpUd+PGDZ29MHHiRN3mzZt1Fy5c0O3YsUPXtWtXXYkSJVTGiq1nMRw6dEhNcvp88sknav7SpUvq+VmzZql9uXr1at3Ro0dVdlXlypV1sbGxOnvYRnnu1VdfVZkZsm/Xr1+va9y4scrsiIuL09kSzz//vM7X11cdp9evX0+bYmJi0l4zZswYXYUKFXQbN27U7d+/X9eqVSs12dN2njt3Tjdjxgy1fbJP5ditUqWKrn379jpbYfLkySoLTsYv5508dnJy0v333392sx9z2k572I/ZkTEjzpz7lELIQnz++edqJ7q7u6t0+t27d+vsiSeeeEJXunRptX1ly5ZVj+VEtXU2bdqkxEHGSVLK9Sn0b7/9tq5kyZJK7Hbp0kUXFBSks5dtlItnt27ddP7+/ip9tWLFirrRo0fbpIjPbBtlWrhwYdprRMC+8MILKkXZy8tL17dvXyUi7Gk7L1++rC6Wfn5+6pitVq2abtKkSbqIiAidrTBixAh1LMrvjRybct7pRZC97MecttMe9qMpQsic+9RJ/pjXqEUIIYQQYhswRogQQgghDguFECGEEEIcFgohQgghhDgsFEKEEEIIcVgohAghhBDisFAIEUIIIcRhoRAihBBCiMNCIUQIIYQQh4VCiBBikwwfPhx9+vSx9DAIITYOhRAhhJgB6YZNCLE9KIQIIXbHJ598gnr16sHb2xvly5fHCy+8gHv37qnnoqOj4ePjg+XLl6d7z6pVq9Tro6Ki1OOQkBAMHDgQRYsWhZ+fH3r37o2LFy8+YJF6//33UaZMGQQGBhbwVhJCzAGFECHE7nB2dsZnn32GEydO4IcffsDGjRvx2muvqedE7AwaNAgLFy5M9x55/Pjjj6NIkSJITExE9+7d1fy2bduwY8cOFC5cGD169Ehn+dmwYQOCgoKwbt06rFmzpsC3kxCSd9h0lRBik4hFJjw8XFlyckKsP2PGjEFoaKh6vHfvXrRu3VpZfUqXLo1bt26hbNmyWL9+PTp06ICff/4Z7733Hk6dOgUnJyf1HhFAYh2Sz+vWrZv6/LVr1+Ly5ctwd3fP9+0lhOQPtAgRQuwOETRdunRR4kasOk8//TTCwsIQExOjnm/evDnq1KmjrEWCCJ+KFSuiffv26vGRI0dw7tw59V6xBMkk7rG4uDgEBwenfY643yiCCLFtKIQIIXaFxPE88sgjqF+/PlasWIEDBw7giy++UM8ZurVGjRqFRYsWpbnFnnnmmTTrj8QTNWnSBIcPH043nTlzBk8++WTaOsTNRgixbVwtPQBCCDEnInxSUlIwe/ZsFSsk/Prrrw+87qmnnlJxQxJLdPLkSQwbNiztucaNG2PZsmUICAhQgdWEEPuFFiFCiM0SERHxgNWmRIkSKtj5888/x/nz5/HTTz/hq6++euC9xYoVQ79+/TBp0iQV81OuXLm054YMGaLWI5liEix94cIFbN68GePHj8eVK1cKeCsJIfkJhRAhxGYRcdKoUaN0kwgfSZ//4IMPULduXSxevBgzZ87M9P0jR45U7rIRI0akW+7l5YWtW7eiQoUKSizVqlVLvVZihGghIsS+YNYYIcRhEdH0yiuv4Nq1awx6JsRBYYwQIcThkOyx69evY9asWXjuuecogghxYOgaI4Q4HB9++CFq1qyJUqVKYcqUKZYeDiHEgtA1RgghhBCHhRYhQgghhDgsFEKEEEIIcVgohAghhBDisFAIEUIIIcRhoRAihBBCiMNCIUQIIYQQh4VCiBBCCCEOC4UQIYQQQhwWCiFCCCGEwFH5P+HH09EGKR9nAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(logit_lens_layers[:, removed_obj_id].detach().cpu(), label=\"removed obj\");\n",
    "plt.plot(logit_lens_layers[:, correct_obj_id].detach().cpu(), label=\"correct obj\");\n",
    "plt.ylabel(\"Logit of the removed object\");\n",
    "plt.xlabel(\"Layer\");\n",
    "#plt.axhline(y=14.9147, color=\"black\", ls=\"--\");\n",
    "plt.legend();\n",
    "plt.title(\"Flipped case - removed obj was container instead of guitar\");"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "entity-tracking-env",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
