{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/patrickknab/anaconda3/envs/XAI/lib/python3.11/site-packages/transformers/utils/generic.py:441: FutureWarning: `torch.utils._pytree._register_pytree_node` is deprecated. Please use `torch.utils._pytree.register_pytree_node` instead.\n",
      "  _torch_pytree._register_pytree_node(\n",
      "/Users/patrickknab/anaconda3/envs/XAI/lib/python3.11/site-packages/transformers/utils/generic.py:309: FutureWarning: `torch.utils._pytree._register_pytree_node` is deprecated. Please use `torch.utils._pytree.register_pytree_node` instead.\n",
      "  _torch_pytree._register_pytree_node(\n",
      "/Users/patrickknab/anaconda3/envs/XAI/lib/python3.11/site-packages/transformers/utils/generic.py:309: FutureWarning: `torch.utils._pytree._register_pytree_node` is deprecated. Please use `torch.utils._pytree.register_pytree_node` instead.\n",
      "  _torch_pytree._register_pytree_node(\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "\n",
    "path_to_add = os.path.abspath(os.path.join(os.getcwd(), '..'))\n",
    "if path_to_add not in sys.path:\n",
    "    sys.path.append(path_to_add)\n",
    "\n",
    "import time\n",
    "\n",
    "from efficientnet.tfkeras import EfficientNetB4\n",
    "from transformers import ViTImageProcessor, ViTForImageClassification, ViTFeatureExtractor, AutoImageProcessor, DetrForSegmentation, DetrFeatureExtractor\n",
    "import torch\n",
    "from segment_anything import SamAutomaticMaskGenerator, sam_model_registry\n",
    "\n",
    "from Utilities.utilities import *\n",
    "from Utilities.lime_segmentation import *\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "config = {\n",
    "    \n",
    "    \"XAI_algorithm\": {\n",
    "        \"DSEG\" : True,\n",
    "        \"LIME\" : True,\n",
    "        \"SLIME\" : True,\n",
    "        \"BayesLime\" : True,\n",
    "        \"GLIME\" : True,\n",
    "    },\n",
    "\n",
    "    'computation':{\n",
    "        'num_workers': 3,\n",
    "        'gpu_device': False,\n",
    "        'gpu_num': \"4\",\n",
    "    },\n",
    "    \n",
    "        \n",
    "    'model_to_explain':{\n",
    "        'EfficientNet' : True,\n",
    "        'ResNet': False,\n",
    "        'VisionTransformer': False,\n",
    "    },\n",
    "    \n",
    "    'lime_segmentation':{\n",
    "        #Lime Parameters\n",
    "        'num_samples': 256,\n",
    "        'num_features': 1000,\n",
    "        'min_weight': 0.01,\n",
    "        'top_labels': 2,\n",
    "        'hide_color': None,\n",
    "        'batch_size': 10,\n",
    "        'verbose': True,\n",
    "        \n",
    "        'slic': True,\n",
    "        'quickshift': False,\n",
    "        'felzenszwalb': False,\n",
    "        'watershed': False,\n",
    "        \n",
    "        'all_dseg': True,\n",
    "        'DETR' : False,\n",
    "        'SAM' : True,\n",
    "        'points_per_side' : 32,\n",
    "        'min_size': 512,\n",
    "        \n",
    "        'fit_segmentation' : True,        \n",
    "        'slic_compactness' : 16,\n",
    "        'num_segments': 20,\n",
    "        'markers' : 16,\n",
    "        'kernel_size' : 6,\n",
    "        'max_dist' : 32,\n",
    "        \n",
    "        #Lime Segmentation Parameters\n",
    "        'iterations': 1,\n",
    "        'shuffle': False,\n",
    "        'max_segments': 8,\n",
    "        'min_segments': 1,\n",
    "        'auto_segment': False, \n",
    "        \n",
    "        # LIME Explanation Parameters\n",
    "        \"num_features_explanation\": 2,\n",
    "        \"adaptive_num_features\": False,\n",
    "        \"adaptive_fraction\": True,\n",
    "        \n",
    "        'hide_rest': True,\n",
    "        'positive_only': True,\n",
    "        \n",
    "    },\n",
    "    \n",
    "    \"evaluation\": {\n",
    "        'noisy_background': True,\n",
    "        \n",
    "        #Correctness\n",
    "        \"model_randomization\" : False,\n",
    "        \"explanation_randomization\" : True,\n",
    "        \n",
    "        \"single_deletion\": False,\n",
    "        \"fraction\" : 0.1,\n",
    "        \"fraction_std\" : 0.05,\n",
    "        \n",
    "        \"incremental_deletion\": False,\n",
    "        \"incremental_deletion_fraction\": 0.15,\n",
    "        \n",
    "        \"stability\": False,\n",
    "        \"repetitions\": 8,\n",
    "        \n",
    "        #Output Completeness\n",
    "        \"preservation_check\": False,\n",
    "        \"deletion_check\": False,\n",
    "        \n",
    "        #Consistency\n",
    "        \"variation_stability\": False,\n",
    "        \n",
    "        #Contrastivity\n",
    "        \"target_discrimination\": False,\n",
    "        \"data_randomization\": False,\n",
    "        \n",
    "        #Covariate Complexity\n",
    "        \"covariate_homogeneity\": False,\n",
    "        \n",
    "        #Compactness\n",
    "        \"size\": False,\n",
    "        \n",
    "        #Confidence\n",
    "        \"confidence\": False,\n",
    "        \n",
    "        #Coherence\n",
    "        \"alignment\": False,\n",
    "    }\n",
    "}\n",
    "\n",
    "\n",
    "from Utilities.utilities import *\n",
    "from Utilities.lime_utilities import *\n",
    "from Utilities.lime_segmentation import *\n",
    "from Utilities.lime_base import *\n",
    "from Utilities.GLIME import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/patrickknab/anaconda3/envs/XAI/lib/python3.11/site-packages/segment_anything/build_sam.py:105: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  state_dict = torch.load(f)\n"
     ]
    }
   ],
   "source": [
    "os.environ['CUDA_VISIBLE_DEVICES'] = config['computation']['gpu_num'] if config['computation']['gpu_device'] else ''\n",
    "os.environ['TF_FORCE_GPU_ALLOW_GROWTH'] = 'true' if config['computation']['gpu_device'] else ''\n",
    "\n",
    "os.environ['XLA_FLAGS'] = '--xla_gpu_cuda_data_dir=/usr/local/cuda-11.4' if config['computation']['gpu_device'] else ''#-10.1' #--xla_gpu_cuda_data_dir=/usr/local/cuda, \n",
    "os.environ['TF_XLA_FLAGS'] = '--tf_xla_auto_jit=2 ,--tf_xla_enable_xla_devices' if config['computation']['gpu_device'] else ''#'--tf_xla_auto_jit=2' #, --tf_xla_enable_xla_devices\n",
    "os.environ['PYDEVD_DISABLE_FILE_VALIDATION'] = '1'\n",
    "\n",
    "image_path = \"./Dataset/COCO/val2017/\"\n",
    "annotation_path = \"./Dataset/COCO/stuff_val2017_pixelmaps/\"\n",
    "json_path = \"./Dataset/COCO/stuff_val2017.json\"\n",
    "\n",
    "\n",
    "if config['model_to_explain']['EfficientNet']: \n",
    "    model_explain = EfficientNetB4(weights='imagenet')\n",
    "    model_explain_processor = None \n",
    "elif config['model_to_explain']['ResNet']:\n",
    "    model_explain = torch.hub.load('pytorch/vision:v0.10.0', 'resnet101', pretrained=True)\n",
    "    model_explain.eval()\n",
    "    model_explain_processor = None\n",
    "elif config['model_to_explain']['VisionTransformer']:\n",
    "    model_explain_processor = ViTFeatureExtractor.from_pretrained('google/vit-base-patch32-384')\n",
    "    model_explain = ViTForImageClassification.from_pretrained('google/vit-base-patch32-384')\n",
    "\n",
    "if config['lime_segmentation']['DETR']:\n",
    "    feature_extractor = DetrFeatureExtractor.from_pretrained(\"facebook/detr-resnet-50-panoptic\")\n",
    "    model = DetrForSegmentation.from_pretrained(\"facebook/detr-resnet-50-panoptic\")\n",
    "\n",
    "else:\n",
    "    sam_checkpoint = \"../Models/pretrained/sam_vit_h_4b8939.pth\"\n",
    "    model_type = \"vit_h\"\n",
    "    model = sam_model_registry[model_type](checkpoint=sam_checkpoint)\n",
    "    DEVICE = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "    if config['computation'].get('gpu_device'):\n",
    "        model.to(device=\"cuda:0\")\n",
    "    else:\n",
    "        model.to(device=\"cpu\")\n",
    "\n",
    "    feature_extractor = SamAutomaticMaskGenerator(model,\n",
    "                                            min_mask_region_area=config['lime_segmentation']['min_size'],\n",
    "                                            points_per_side=config['lime_segmentation']['points_per_side'],\n",
    "                                            )\n",
    "   \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Dishwasher_woman.png', '000000289059.jpg', 'n04008634_projectile.JPEG', '000000547816.jpg', 'venice-8889871_1280.jpg', 'n04251144_snorkel.JPEG', 'n02981792_catamaran.JPEG', 'cake.jpg', 'n03028079_church.JPEG', 'elephant-5550233_1280.jpg', '000000424545.jpg', '.DS_Store', 'n01818515_macaw.JPEG', 'n03891251_park_bench.JPEG', 'n02802426_basketball.JPEG', 'n02093991_Irish_terrier.JPEG', '000000067213.jpg', 'n03887697_paper_towel.JPEG', 'n02134084_ice_bear.JPEG', '000000438269.jpg', 'bridge-8800485_1280.jpg', '000000463522.jpg', 'n02480855_gorilla.JPEG', '000000290619.jpg', '000000417465.jpg', 'n03384352_forklift.JPEG', '000000508602.jpg', 'shoes-8212405_1280.jpg', 'fridge.jpg', 'airplane.png', '000000552902.jpg', '000000528705.jpg', 'n02917067_bullet_train.JPEG', 'n02085620_Chihuahua.JPEG', 'n01983481_American_lobster.JPEG', '000000551439.jpg', 'n03792972_mountain_tent.JPEG', 'computer.jpg', 'n04458633_totem_pole.JPEG', 'Jogging.png', '000000000785.jpg', 'n04536866_violin.JPEG', '000000407960.jpg', 'n03933933_pier.JPEG', '000000523811.jpg', 'casio-8392121_1280.jpg', '000000521141.jpg', 'n02988304_CD_player.JPEG', 'n10565667_scuba_diver.JPEG', 'n03781244_monastery.JPEG', 'n02093859_Kerry_blue_terrier.JPEG']\n"
     ]
    }
   ],
   "source": [
    "image_paths = os.listdir(\"../Dataset/Evaluation/\")\n",
    "print(image_paths)\n",
    "path_image_id = \"../Dataset/Evaluation/\"+image_paths[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def segment_seed(image, \n",
    "                image_path, \n",
    "                config,\n",
    "                feature_extractor, \n",
    "                model, \n",
    "                settings,\n",
    "                dim):\n",
    "    \"\"\"\n",
    "    Segments the seed image using either the DETR or SAM method based on the configuration.\n",
    "\n",
    "    Args:\n",
    "        image (numpy.ndarray): The seed image to be segmented.\n",
    "        image_path (str): The path to the seed image.\n",
    "        config (dict): The configuration settings.\n",
    "        feature_extractor: The feature extractor used for segmentation.\n",
    "        model: The model used for segmentation.\n",
    "        dim (tuple): The dimensions to resize the segmented image to.\n",
    "\n",
    "    Returns:\n",
    "        numpy.ndarray: The segmented seed image.\n",
    "    \"\"\"\n",
    "    \n",
    "    if config['lime_segmentation']['DETR']:\n",
    "        image = load_img(image_path, target_size=dim)\n",
    "        inputs = feature_extractor(images=image, return_tensors=\"pt\")\n",
    "        outputs = model(**inputs)\n",
    "        result = feature_extractor.post_process_panoptic_segmentation(outputs, target_sizes=[dim])\n",
    "\n",
    "        # A tensor of shape (height, width) where each value denotes a segment id, filled with -1 if no segment is found\n",
    "        resized_panoptic_seg = result[0][\"segmentation\"]\n",
    "        resized_panoptic_seg_ = {}\n",
    "        hierarchical_dict = {}\n",
    "        link_ids = {}\n",
    "\n",
    "    elif config['lime_segmentation']['SAM']:\n",
    "        # SAM segmentation method\n",
    "        data_raw = cv2.imread(image_path)\n",
    "        data_raw = cv2.resize(data_raw, dim) \n",
    "        data_raw = cv2.cvtColor(data_raw, cv2.COLOR_BGR2RGB)\n",
    "        masks = feature_extractor.generate(data_raw)\n",
    "        result_dict = {}\n",
    "        for theta in settings:\n",
    "            small_mask, mask_sizes = remove_small_clusters(masks, theta, plot = False)\n",
    "            graph = draw_relation(mask_sizes)\n",
    "            roots = [node for node, in_degree in graph.in_degree() if in_degree == 0]\n",
    "            # Building the hierarchical dictionary\n",
    "            hierarchical_dict = {root: build_hierarchy(graph, root) for root in roots}\n",
    "\n",
    "            resized_panoptic_seg = {}\n",
    "            id_list = mask_sizes[1]\n",
    "\n",
    "            for num, mask in enumerate(small_mask):\n",
    "                int_array = np.zeros((mask['segmentation'].shape[0], mask['segmentation'].shape[1]))\n",
    "\n",
    "                for i in range(mask['segmentation'].shape[0]):\n",
    "                    for j in range(mask['segmentation'].shape[1]):\n",
    "                        if mask['segmentation'][i][j]:\n",
    "                            int_array[i][j] = 1\n",
    "\n",
    "                resized_mask = np.round(int_array)\n",
    "\n",
    "                resized_panoptic_seg[id_list[num]] = resized_mask\n",
    "            \n",
    "            before_hierachy = len(masks)\n",
    "            resized_panoptic_seg = create_mask_sam(resized_panoptic_seg, hierarchical_dict, iteration = 0, seeds = [7,8])\n",
    "            after_hierachy = len(np.unique(resized_panoptic_seg))\n",
    "            empty_space = np.count_nonzero(resized_panoptic_seg == 0)\n",
    "            #print(\"Empty Space: \", empty_space, \"Total Space: \", data_raw.shape[0]*data_raw.shape[1])\n",
    "            empty_space = empty_space/(data_raw.shape[0]*data_raw.shape[1])\n",
    "            resized_panoptic_seg = fill_with_nearest(resized_panoptic_seg)\n",
    "            resized_panoptic_seg_nums = np.unique(resized_panoptic_seg)\n",
    "\n",
    "            for old, new in zip(resized_panoptic_seg_nums, np.arange(len(resized_panoptic_seg_nums))):\n",
    "                resized_panoptic_seg[resized_panoptic_seg == old] = new\n",
    "            final_hierachy = len(np.unique(resized_panoptic_seg))\n",
    "            \n",
    "            local_result = {}\n",
    "            local_result['before_hierachy'] = before_hierachy\n",
    "            local_result['after_hierachy'] = after_hierachy\n",
    "            local_result['final_hierachy'] = final_hierachy\n",
    "            local_result['empty_space'] = empty_space\n",
    "            \n",
    "            result_dict[theta] = local_result\n",
    "    return resized_panoptic_seg, result_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "./Dataset/Evaluation_2/000000424545.jpg\n",
      "Empty Space:  11763 Total Space:  144400\n",
      "Empty Space:  12045 Total Space:  144400\n",
      "Empty Space:  12781 Total Space:  144400\n",
      "Empty Space:  13576 Total Space:  144400\n",
      "Empty Space:  18593 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03933933_pier.JPEG\n",
      "Empty Space:  77224 Total Space:  144400\n",
      "Empty Space:  78557 Total Space:  144400\n",
      "Empty Space:  80538 Total Space:  144400\n",
      "Empty Space:  86866 Total Space:  144400\n",
      "Empty Space:  93071 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03792972_mountain_tent.JPEG\n",
      "Empty Space:  99809 Total Space:  144400\n",
      "Empty Space:  104342 Total Space:  144400\n",
      "Empty Space:  105485 Total Space:  144400\n",
      "Empty Space:  108581 Total Space:  144400\n",
      "Empty Space:  113810 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000523811.jpg\n",
      "Empty Space:  18010 Total Space:  144400\n",
      "Empty Space:  18892 Total Space:  144400\n",
      "Empty Space:  18898 Total Space:  144400\n",
      "Empty Space:  18898 Total Space:  144400\n",
      "Empty Space:  22352 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000521141.jpg\n",
      "Empty Space:  12135 Total Space:  144400\n",
      "Empty Space:  14798 Total Space:  144400\n",
      "Empty Space:  16817 Total Space:  144400\n",
      "Empty Space:  18108 Total Space:  144400\n",
      "Empty Space:  21614 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n04458633_totem_pole.JPEG\n",
      "Empty Space:  82300 Total Space:  144400\n",
      "Empty Space:  87065 Total Space:  144400\n",
      "Empty Space:  88433 Total Space:  144400\n",
      "Empty Space:  93315 Total Space:  144400\n",
      "Empty Space:  106096 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000547816.jpg\n",
      "Empty Space:  27123 Total Space:  144400\n",
      "Empty Space:  27541 Total Space:  144400\n",
      "Empty Space:  30112 Total Space:  144400\n",
      "Empty Space:  47409 Total Space:  144400\n",
      "Empty Space:  40352 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02917067_bullet_train.JPEG\n",
      "Empty Space:  60816 Total Space:  144400\n",
      "Empty Space:  62997 Total Space:  144400\n",
      "Empty Space:  64819 Total Space:  144400\n",
      "Empty Space:  71368 Total Space:  144400\n",
      "Empty Space:  78121 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000000785.jpg\n",
      "Empty Space:  6895 Total Space:  144400\n",
      "Empty Space:  7234 Total Space:  144400\n",
      "Empty Space:  7957 Total Space:  144400\n",
      "Empty Space:  8696 Total Space:  144400\n",
      "Empty Space:  8696 Total Space:  144400\n",
      "./Dataset/Evaluation_2/bridge-8800485_1280.jpg\n",
      "Empty Space:  74729 Total Space:  144400\n",
      "Empty Space:  75697 Total Space:  144400\n",
      "Empty Space:  77128 Total Space:  144400\n",
      "Empty Space:  80299 Total Space:  144400\n",
      "Empty Space:  85116 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000289059.jpg\n",
      "Empty Space:  4652 Total Space:  144400\n",
      "Empty Space:  5100 Total Space:  144400\n",
      "Empty Space:  5425 Total Space:  144400\n",
      "Empty Space:  6906 Total Space:  144400\n",
      "Empty Space:  7059 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000508602.jpg\n",
      "Empty Space:  30293 Total Space:  144400\n",
      "Empty Space:  33137 Total Space:  144400\n",
      "Empty Space:  35437 Total Space:  144400\n",
      "Empty Space:  39054 Total Space:  144400\n",
      "Empty Space:  44422 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02134084_ice_bear.JPEG\n",
      "Empty Space:  51298 Total Space:  144400\n",
      "Empty Space:  51981 Total Space:  144400\n",
      "Empty Space:  53142 Total Space:  144400\n",
      "Empty Space:  54223 Total Space:  144400\n",
      "Empty Space:  59748 Total Space:  144400\n",
      "./Dataset/Evaluation_2/computer.jpg\n",
      "Empty Space:  22803 Total Space:  144400\n",
      "Empty Space:  23667 Total Space:  144400\n",
      "Empty Space:  26118 Total Space:  144400\n",
      "Empty Space:  35942 Total Space:  144400\n",
      "Empty Space:  46106 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000528705.jpg\n",
      "Empty Space:  31871 Total Space:  144400\n",
      "Empty Space:  32077 Total Space:  144400\n",
      "Empty Space:  32501 Total Space:  144400\n",
      "Empty Space:  34484 Total Space:  144400\n",
      "Empty Space:  37504 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03891251_park_bench.JPEG\n",
      "Empty Space:  49502 Total Space:  144400\n",
      "Empty Space:  50105 Total Space:  144400\n",
      "Empty Space:  52029 Total Space:  144400\n",
      "Empty Space:  55098 Total Space:  144400\n",
      "Empty Space:  58159 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02093991_Irish_terrier.JPEG\n",
      "Empty Space:  73832 Total Space:  144400\n",
      "Empty Space:  75522 Total Space:  144400\n",
      "Empty Space:  76207 Total Space:  144400\n",
      "Empty Space:  79922 Total Space:  144400\n",
      "Empty Space:  86194 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02480855_gorilla.JPEG\n",
      "Empty Space:  24171 Total Space:  144400\n",
      "Empty Space:  26695 Total Space:  144400\n",
      "Empty Space:  29014 Total Space:  144400\n",
      "Empty Space:  34642 Total Space:  144400\n",
      "Empty Space:  44149 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02988304_CD_player.JPEG\n",
      "Empty Space:  6176 Total Space:  144400\n",
      "Empty Space:  6340 Total Space:  144400\n",
      "Empty Space:  6766 Total Space:  144400\n",
      "Empty Space:  6766 Total Space:  144400\n",
      "Empty Space:  6766 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000290619.jpg\n",
      "Empty Space:  3337 Total Space:  144400\n",
      "Empty Space:  3337 Total Space:  144400\n",
      "Empty Space:  3337 Total Space:  144400\n",
      "Empty Space:  3869 Total Space:  144400\n",
      "Empty Space:  3869 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03781244_monastery.JPEG\n",
      "Empty Space:  28964 Total Space:  144400\n",
      "Empty Space:  29825 Total Space:  144400\n",
      "Empty Space:  31172 Total Space:  144400\n",
      "Empty Space:  36066 Total Space:  144400\n",
      "Empty Space:  37485 Total Space:  144400\n",
      "./Dataset/Evaluation_2/shoes-8212405_1280.jpg\n",
      "Empty Space:  15928 Total Space:  144400\n",
      "Empty Space:  15906 Total Space:  144400\n",
      "Empty Space:  15928 Total Space:  144400\n",
      "Empty Space:  15928 Total Space:  144400\n",
      "Empty Space:  20455 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n04008634_projectile.JPEG\n",
      "Empty Space:  49900 Total Space:  144400\n",
      "Empty Space:  55556 Total Space:  144400\n",
      "Empty Space:  63839 Total Space:  144400\n",
      "Empty Space:  72805 Total Space:  144400\n",
      "Empty Space:  88028 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n04251144_snorkel.JPEG\n",
      "Empty Space:  17353 Total Space:  144400\n",
      "Empty Space:  17951 Total Space:  144400\n",
      "Empty Space:  19091 Total Space:  144400\n",
      "Empty Space:  19637 Total Space:  144400\n",
      "Empty Space:  22107 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02981792_catamaran.JPEG\n",
      "Empty Space:  11055 Total Space:  144400\n",
      "Empty Space:  12754 Total Space:  144400\n",
      "Empty Space:  13065 Total Space:  144400\n",
      "Empty Space:  16135 Total Space:  144400\n",
      "Empty Space:  16135 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03887697_paper_towel.JPEG\n",
      "Empty Space:  5412 Total Space:  144400\n",
      "Empty Space:  5924 Total Space:  144400\n",
      "Empty Space:  7121 Total Space:  144400\n",
      "Empty Space:  7793 Total Space:  144400\n",
      "Empty Space:  9222 Total Space:  144400\n",
      "./Dataset/Evaluation_2/casio-8392121_1280.jpg\n",
      "Empty Space:  42467 Total Space:  144400\n",
      "Empty Space:  42467 Total Space:  144400\n",
      "Empty Space:  42855 Total Space:  144400\n",
      "Empty Space:  42855 Total Space:  144400\n",
      "Empty Space:  46122 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03028079_church.JPEG\n",
      "Empty Space:  54918 Total Space:  144400\n",
      "Empty Space:  56143 Total Space:  144400\n",
      "Empty Space:  57194 Total Space:  144400\n",
      "Empty Space:  57764 Total Space:  144400\n",
      "Empty Space:  57764 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n04536866_violin.JPEG\n",
      "Empty Space:  3979 Total Space:  144400\n",
      "Empty Space:  4444 Total Space:  144400\n",
      "Empty Space:  4444 Total Space:  144400\n",
      "Empty Space:  4444 Total Space:  144400\n",
      "Empty Space:  4444 Total Space:  144400\n",
      "./Dataset/Evaluation_2/fridge.jpg\n",
      "Empty Space:  38514 Total Space:  144400\n",
      "Empty Space:  41684 Total Space:  144400\n",
      "Empty Space:  44330 Total Space:  144400\n",
      "Empty Space:  59015 Total Space:  144400\n",
      "Empty Space:  93097 Total Space:  144400\n",
      "./Dataset/Evaluation_2/cake.jpg\n",
      "Empty Space:  30508 Total Space:  144400\n",
      "Empty Space:  30645 Total Space:  144400\n",
      "Empty Space:  31481 Total Space:  144400\n",
      "Empty Space:  33888 Total Space:  144400\n",
      "Empty Space:  36752 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n01818515_macaw.JPEG\n",
      "Empty Space:  5110 Total Space:  144400\n",
      "Empty Space:  5384 Total Space:  144400\n",
      "Empty Space:  5384 Total Space:  144400\n",
      "Empty Space:  5384 Total Space:  144400\n",
      "Empty Space:  5384 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000552902.jpg\n",
      "Empty Space:  4001 Total Space:  144400\n",
      "Empty Space:  4293 Total Space:  144400\n",
      "Empty Space:  5151 Total Space:  144400\n",
      "Empty Space:  5889 Total Space:  144400\n",
      "Empty Space:  7548 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000463522.jpg\n",
      "Empty Space:  50429 Total Space:  144400\n",
      "Empty Space:  52576 Total Space:  144400\n",
      "Empty Space:  55952 Total Space:  144400\n",
      "Empty Space:  58354 Total Space:  144400\n",
      "Empty Space:  61712 Total Space:  144400\n",
      "./Dataset/Evaluation_2/Jogging.png\n",
      "Empty Space:  50545 Total Space:  144400\n",
      "Empty Space:  51529 Total Space:  144400\n",
      "Empty Space:  53089 Total Space:  144400\n",
      "Empty Space:  57927 Total Space:  144400\n",
      "Empty Space:  62342 Total Space:  144400\n",
      "./Dataset/Evaluation_2/venice-8889871_1280.jpg\n",
      "Empty Space:  33979 Total Space:  144400\n",
      "Empty Space:  81761 Total Space:  144400\n",
      "Empty Space:  35283 Total Space:  144400\n",
      "Empty Space:  85129 Total Space:  144400\n",
      "Empty Space:  87979 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02802426_basketball.JPEG\n",
      "Empty Space:  8153 Total Space:  144400\n",
      "Empty Space:  10414 Total Space:  144400\n",
      "Empty Space:  12666 Total Space:  144400\n",
      "Empty Space:  17658 Total Space:  144400\n",
      "Empty Space:  23512 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000438269.jpg\n",
      "Empty Space:  33073 Total Space:  144400\n",
      "Empty Space:  34466 Total Space:  144400\n",
      "Empty Space:  35608 Total Space:  144400\n",
      "Empty Space:  37511 Total Space:  144400\n",
      "Empty Space:  38768 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n03384352_forklift.JPEG\n",
      "Empty Space:  11823 Total Space:  144400\n",
      "Empty Space:  13316 Total Space:  144400\n",
      "Empty Space:  14302 Total Space:  144400\n",
      "Empty Space:  15198 Total Space:  144400\n",
      "Empty Space:  16372 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000417465.jpg\n",
      "Empty Space:  2456 Total Space:  144400\n",
      "Empty Space:  2700 Total Space:  144400\n",
      "Empty Space:  2700 Total Space:  144400\n",
      "Empty Space:  2727 Total Space:  144400\n",
      "Empty Space:  2727 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000407960.jpg\n",
      "Empty Space:  23986 Total Space:  144400\n",
      "Empty Space:  24105 Total Space:  144400\n",
      "Empty Space:  24105 Total Space:  144400\n",
      "Empty Space:  24105 Total Space:  144400\n",
      "Empty Space:  24105 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000551439.jpg\n",
      "Empty Space:  15320 Total Space:  144400\n",
      "Empty Space:  15858 Total Space:  144400\n",
      "Empty Space:  15858 Total Space:  144400\n",
      "Empty Space:  16518 Total Space:  144400\n",
      "Empty Space:  16518 Total Space:  144400\n",
      "./Dataset/Evaluation_2/elephant-5550233_1280.jpg\n",
      "Empty Space:  54095 Total Space:  144400\n",
      "Empty Space:  54286 Total Space:  144400\n",
      "Empty Space:  55553 Total Space:  144400\n",
      "Empty Space:  58730 Total Space:  144400\n",
      "Empty Space:  62154 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02085620_Chihuahua.JPEG\n",
      "Empty Space:  7696 Total Space:  144400\n",
      "Empty Space:  7941 Total Space:  144400\n",
      "Empty Space:  28087 Total Space:  144400\n",
      "Empty Space:  30340 Total Space:  144400\n",
      "Empty Space:  35503 Total Space:  144400\n",
      "./Dataset/Evaluation_2/000000067213.jpg\n",
      "Empty Space:  7363 Total Space:  144400\n",
      "Empty Space:  8902 Total Space:  144400\n",
      "Empty Space:  10116 Total Space:  144400\n",
      "Empty Space:  12591 Total Space:  144400\n",
      "Empty Space:  16600 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n01983481_American_lobster.JPEG\n",
      "Empty Space:  9883 Total Space:  144400\n",
      "Empty Space:  10288 Total Space:  144400\n",
      "Empty Space:  12429 Total Space:  144400\n",
      "Empty Space:  14027 Total Space:  144400\n",
      "Empty Space:  16967 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n02093859_Kerry_blue_terrier.JPEG\n",
      "Empty Space:  8504 Total Space:  144400\n",
      "Empty Space:  10496 Total Space:  144400\n",
      "Empty Space:  11534 Total Space:  144400\n",
      "Empty Space:  13600 Total Space:  144400\n",
      "Empty Space:  18503 Total Space:  144400\n",
      "./Dataset/Evaluation_2/airplane.png\n",
      "Empty Space:  66390 Total Space:  144400\n",
      "Empty Space:  71001 Total Space:  144400\n",
      "Empty Space:  75591 Total Space:  144400\n",
      "Empty Space:  82591 Total Space:  144400\n",
      "Empty Space:  98468 Total Space:  144400\n",
      "./Dataset/Evaluation_2/Dishwasher_woman.png\n",
      "Empty Space:  20548 Total Space:  144400\n",
      "Empty Space:  22845 Total Space:  144400\n",
      "Empty Space:  26052 Total Space:  144400\n",
      "Empty Space:  31166 Total Space:  144400\n",
      "Empty Space:  41768 Total Space:  144400\n",
      "./Dataset/Evaluation_2/n10565667_scuba_diver.JPEG\n",
      "Empty Space:  70190 Total Space:  144400\n",
      "Empty Space:  70557 Total Space:  144400\n",
      "Empty Space:  71582 Total Space:  144400\n",
      "Empty Space:  72151 Total Space:  144400\n",
      "Empty Space:  76208 Total Space:  144400\n"
     ]
    }
   ],
   "source": [
    "complete_dict = {}\n",
    "for image in image_paths:\n",
    "    path_image_id = \"../Dataset/Evaluation/\"+image\n",
    "    print(path_image_id)\n",
    "    \n",
    "    data, data_raw = load_and_preprocess_image(path_image_id, config, plot = False, model = model_explain_processor)\n",
    "    if config[\"model_to_explain\"][\"EfficientNet\"]:\n",
    "        dim = (data.shape[0], data.shape[1])\n",
    "    elif config[\"model_to_explain\"][\"ResNet\"]:\n",
    "        dim = (data.shape[1], data.shape[2])\n",
    "    else:\n",
    "        dim = (data['pixel_values'][0].shape[1], data['pixel_values'][0].shape[2])\n",
    "\n",
    "    settings = [100, 300, 500, 1000, 2000]\n",
    "    resized_panoptic_seg, result_dict = segment_seed(data, path_image_id, config, feature_extractor, model, settings, dim)\n",
    "    complete_dict[image]= result_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print_dict = {}\n",
    "\n",
    "for key in complete_dict:\n",
    "    for theta in complete_dict[key]:\n",
    "        if theta not in print_dict:\n",
    "            #create array inside\n",
    "            print_dict[theta] = {}\n",
    "            print_dict[theta]['before_hierachy'] = []\n",
    "            print_dict[theta]['after_hierachy'] = []\n",
    "            print_dict[theta]['final_hierachy'] = []\n",
    "            print_dict[theta]['empty_space'] = []\n",
    "            \n",
    "            print_dict[theta]['before_hierachy'].append(complete_dict[key][theta]['before_hierachy'])\n",
    "            print_dict[theta]['after_hierachy'].append(complete_dict[key][theta]['after_hierachy'])\n",
    "            print_dict[theta]['final_hierachy'].append(complete_dict[key][theta]['final_hierachy'])\n",
    "            print_dict[theta]['empty_space'].append(complete_dict[key][theta]['empty_space'])\n",
    "        else:\n",
    "            #append results\n",
    "            print_dict[theta]['before_hierachy'].append(complete_dict[key][theta]['before_hierachy'])\n",
    "            print_dict[theta]['after_hierachy'].append(complete_dict[key][theta]['after_hierachy'])\n",
    "            print_dict[theta]['final_hierachy'].append(complete_dict[key][theta]['final_hierachy'])\n",
    "            print_dict[theta]['empty_space'].append(complete_dict[key][theta]['empty_space'])\n",
    "            \n",
    "data = print_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3132769/472674104.py:18: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  axs[i].boxplot(values, labels=thresholds)\n",
      "/tmp/ipykernel_3132769/472674104.py:18: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  axs[i].boxplot(values, labels=thresholds)\n",
      "/tmp/ipykernel_3132769/472674104.py:18: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  axs[i].boxplot(values, labels=thresholds)\n",
      "/tmp/ipykernel_3132769/472674104.py:18: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  axs[i].boxplot(values, labels=thresholds)\n"
     ]
    },
    {
     "data": {
      "image/png": "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nZOvr6/Gjh1blrcQAACUETkHOYfk/DnHli1blJ6erkGDBmnQoEHavHmzfvvtN/PxESNGqGvXrpKku+++WyaTSZGRkQoODtbPP/+sTZs2mV/v8jmalZWliRMnmt+HRo0a6aWXXlJ+fn6h9+HVV1/V3Llz1bBhQ7m7u+uXX365ZtwlVdyeGtfKnwquvbj8pyRz+lpj5Ofn64033lB4eLiqVaumOnXqqFevXtqxY0eh60hISFDz5s3Nec7q1avNxzZs2CCTyaQvv/yy0HlLly6VyWRSUlJSqd4/AKXDSg0ApdKgQQMlJSUpJSVFzZs3v2rfF154QdOmTdM999yjBx98UH/88Yfeeust3Xrrrfrxxx/NScr8+fM1fvx4RUREaNKkSUpPT1d0dLRq1qypG264odC4cXFx8vDw0FNPPaWDBw/qrbfeUtWqVeXi4qK///5bzz77rLZu3apFixYpJCRE06dPtzomSfr777/Vq1cvxcTE6J577tGKFSv05JNPKjw8XL1791ZYWJhmzZql6dOna8yYMYqIiJAkde7cWdKlX2afOXNGDz/8sGrVqqX//ve/euutt/Tbb79p+fLlkqSxY8fq6NGjWrNmjT755JNrvv8///yzIiIi5OPjoyeeeEJVq1bVu+++q8jISG3atEkdOnSw6D9hwgTVrFlTM2bMUHp6uubOnavx48frs88+K/Y1zpw5o3Xr1unWW2/VjTfeeM2YDMPQnXfeqQ0bNmjUqFFq1aqVvv32Wz3++OP6/fff9frrr19zjOLcc889CgkJUVxcnHbu3Kl//etfqlu3rl566SVJ0ieffKIHH3xQ//jHPzRmzBhJUsOGDa857pkzZ8z7TGRnZ2vVqlVavXq1YmNjLfp98sknGj58uHr27KmXXnpJZ86c0fz583XLLbfoxx9/VHBwsP75z3+qadOmeu+99zRr1iyFhISYY1i0aJFGjhyp9u3bKy4uTseOHdMbb7yhLVu2FJpvFy9eVM+ePXXLLbfo1Vdflaenp6RLc6RgnEcffVRpaWl6++239eOPP2rLli2qWrXqNa/3xIkTRbZfnvgU59ixY+rYsaN5I706depo1apVGjVqlLKzszVx4kSL/s8995zc3Nw0depU5ebmys3NTb/88osSEhJ09913KyQkRMeOHdO7776rrl276pdfflFQUNA1x1izZo369eunwMBA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ShqTNYr7IPrTTz/pwIED+uijj3T//feb29esWVPiMa5Up04deXp6av/+/YWO7du3Ty4uLoW+OVYanp6euu2227R+/XodOXLkmmM2aNBAa9euVU5OjsU3p/bt22c+Lv3vG09ZWVkW55flW1VSyd+/aym4ZcCpU6ck/W/zv7p16xb5baVrKbju/fv3F/q20v79+83Hr6Zhw4Zau3atunTpUqEJSYE6derI29tbeXl5pXoPCqxYsUJRUVH64IMPLNqzsrKKXEFypYK/i5SUlDLFcTk/Pz/17dtXS5Ys0dChQ7Vly5ZCGysCAADHQs5hiZzDMXOO+Ph4nTt3TvPnzy/0WXf//v165plntGXLFt1yyy1Wv17Dhg116tQpm30mtqWy5k+SdXP6anF8++23OnHiRIlWa5TEoEGDNHnyZH366ac6e/asqlatqnvvvdcmYwOwDntqACiVDRs2FPmNlW+++UbS/261ExMTI1dXV82cObNQf8Mw9Ndff0m6lJjUqlVL77//vvmXytKl5ZxXW65cGiWNyRrVq1eXVPhDc8E3Pi5/HcMw9MYbb5R4jCu5urqqR48e+uqrr5Senm5uP3bsmJYuXapbbrmlTLdkutyMGTNkGIbuu+8+8y/5L5ecnKyPPvpIktSnTx/l5eUV+qbK66+/LpPJpN69e0u6tNy4du3ahe7z+s4775Qp1urVq1/zvSuJf//735Kkli1bSpJ69uwpHx8fzZ49WxcuXCjU/48//rjqeO3atVPdunW1YMEC5ebmmttXrVqlvXv3qm/fvteM6Z577lFeXp6ee+65QscuXrxok+u+GldXVw0YMEBffPGFUlJSCh2/1ntw+ThX/swtX75cv//+e4nOb9OmjUJCQjR37txC11yWVTv33XeffvnlFz3++ONydXXVoEGDSj0WAACwHXIOS+QczpVzLF68WDfddJMeeughDRw40OIxdepUeXl5FbsS+1qvd8899ygpKUnffvttoWNZWVkW87uilTV/kqyb08UZMGCADMPQzJkzCx0rbe5Qu3Zt9e7dW4sXL9aSJUvUq1evEn05C4DtsVIDQKlMmDBBZ86c0V133aXQ0FCdP39eP/zwgz777DMFBwdr5MiRki59O+L5559XbGys0tPTFR0dLW9vb6WlpenLL7/UmDFjNHXqVLm5uenZZ5/VhAkTdNttt+mee+5Renq6Fi1apIYNG9p0w96SxmTtmDVq1NCCBQvk7e2t6tWrq0OHDgoNDVXDhg01depU/f777/Lx8dEXX3xRZNLUtm1bSdKjjz6qnj17XvWXq88//7zWrFmjW265RY888oiqVKmid999V7m5uXr55Zetf1OK0blzZ82bN0+PPPKIQkNDdd9996lx48bKycnRxo0b9fXXX+v555+XJN1xxx2KiorSP//5T6Wnp6tly5b67rvv9NVXX2nixIkWG689+OCDevHFF/Xggw+qXbt22rx5sw4cOFCmWNu2bau1a9fqtddeU1BQkEJCQtShQ4ernrNz504tXrxY0qX7+K5bt05ffPGFOnfurB49eki6lBDNnz9f9913n9q0aaNBgwapTp06Onz4sP7zn/+oS5cuV11yXLVqVb300ksaOXKkunbtqsGDB+vYsWN64403FBwcrEmTJl3z2rp27aqxY8cqLi5Ou3btUo8ePVS1alWlpqZq+fLleuONNzRw4EAr3i3rvfjii9qwYYM6dOig0aNH6+abb9aJEye0c+dOrV27VidOnLjmGP369dOsWbM0cuRIde7cWT/99JOWLFlisfnk1bi4uGj+/Pm644471KpVK40cOVKBgYHat2+ffv755yKTupLo27evatWqpeXLl6t3797F7l0CAAAqFjlH4THJOZwj5zh69Kg2bNhQaEPzAu7u7urZs6eWL1+uN99886qvN3/+fD3//PNq1KiR6tatq9tuu02PP/64vv76a/Xr108jRoxQ27Ztdfr0af30009asWKF0tPT7fbL9rLmT5KsmtPFiYqK0n333ac333xTqamp6tWrl/Lz85WYmKioqCiNHz++VNd3//33m3Ovor50BqCCGABQCqtWrTIeeOABIzQ01PDy8jLc3NyMRo0aGRMmTDCOHTtWqP8XX3xh3HLLLUb16tWN6tWrG6Ghoca4ceOM/fv3W/R78803jQYNGhju7u7GP/7xD2PLli1G27ZtjV69epn7bNiwwZBkLF++3OLchQsXGpKM7du3W7TPmDHDkGT88ccfVsfUtWtXo1mzZoWuZ/jw4UaDBg0s2r766ivj5ptvNqpUqWJIMhYuXGgYhmH88ssvRvfu3Q0vLy+jdu3axujRo43du3db9DEMw7h48aIxYcIEo06dOobJZDIu/ydakjFjxgyL19u5c6fRs2dPw8vLy/D09DSi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Guns2bNKT09XcHCwPDw87B2OpEurRoYNG+Ywq1kA2FZeXp6mTJmifv36KSEhQS4ul7aW7dixoxISEhQdHa2pU6eqf//+3IoKAJyI1UWNxx57TG+99ZbefPPN8ogHAAAAACSRe9hKWFiY2rRpY+8wJIkiFYAKlZiYqPT0dH366afmgkYBFxcXxcbGqnPnzkpMTFRkZKR9ggQAWM3qosZ///tfrV+/XitXrlSzZs0KbdYXHx9vs+AAAAAAVF7kHgCAssjIyJAkNW/evMjjBe0F/QAAzsHqokaNGjW41yAAAACAckfuAQAoi8DAQElSSkqKOnbsWOh4SkqKRT8AgHOwuqixcOHC8ogDAAAAACyQewAAJOnMmTPat2+f1edVr15dQUFBevLJJzVnzhzl5uaa9/Zxd3fXU089pXr16ql69erauXOn1eOHhobK09PT6vMAAGVjdVEDAAAAAAAAqCj79u1T27ZtS33+0aNH1b59+2KP/+Mf/yjVuMnJyQ6zZxEAVCZWFzVat24tk8lUqN1kMqlatWpq1KiRRowYoaioKJsECAAAAKByIvcAAEiXVkQkJyeX+vz169fr9ddf19GjR81t9erV08SJE3XbbbeVKS4AQMWzuqjRq1cvzZ8/X+Hh4eZK9vbt27Vnzx6NGDFCv/zyi7p37674+Hj179/f5gEDAAAAqBzIPQAAkuTp6VmmFRFt2rTRpEmT9MEHH2js2LF69913NWrUKLm6utowSgBARbG6qPHnn39qypQpmjZtmkX7888/r19//VXfffedZsyYoeeee47EAgAAAECpkXsAAGzF1dVV7dq1kyS1a9eOggYAODEXa0/4/PPPNXjw4ELtgwYN0ueffy5JGjx4sPbv31/26CQFBwfLZDIVeowbN06SFBkZWejYQw89ZJPXBgAAAGA/FZ17AAAAAHB8Vq/UqFatmn744Qc1atTIov2HH35QtWrVJEn5+fnmP5fV9u3blZeXZ36ekpKi22+/XXfffbe5bfTo0Zo1a5b5uaenp01eGwAAAID9VHTuAQAAAMDxWV3UmDBhgh566CElJyerffv2ki4VHv71r3/p6aefliR9++23atWqlU0CrFOnjsXzF198UQ0bNlTXrl3NbZ6engoICCjxmLm5ucrNzTU/z87OLnugAAAAAGyqonMPAAAAAI7P6qLGM888o5CQEL399tv6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8+fP2zhS+zpz5ow++OADjRo1yty2bds2vfbaa/rss8906623qm3btho9erS++eYbSVLz5s3VsGFDLV682F5hAwAAABWCvKJkyCsAwPYoagBAJRMQEGB++Pr6ymQyWbR5eXlJkvLz8/XEE0/Iz89PAQEBhb5pFRkZqfHjx2vixImqXbu2evbsqfz8fMXFxSkkJEQeHh5q2bKlVqxYYXHeihUrFB4eLg8PD9WqVUvdu3fX6dOnzcev9bq5ubl69NFHVbduXVWrVk233HKLtm/fXuz1nj59Wvfff7+8vLwUGBhY4mXc33zzjdzd3dWxY0dz26uvvqpu3bqpTZs25jZ/f3/9+eef5ud33HGHli1bVqLXAAAAAJwVeQV5BQDYC0UNAECRPvroI1WvXl3btm3Tyy+/rFmzZmnNmjWF+ri5uWnLli1asGCB4uLi9PHHH2vBggX6+eefNWnSJA0bNkybNm2SdOnbXIMHD9YDDzygvXv3auPGjYqJiZFhGCV+3f/H3p3HVVXt/x9/H5BRBkeElIScwHDEHDByCCWHlJAylTQz65aYifbtYjlVSoNj5lBeh0zNksjKSi3ToqLhYlokKJZkJaBmCE5gsH9/+OPcToCicjyAr+fjcR661157rc8+nGgvP2et9X//939666239Oqrr2rXrl1q3ry5wsPDdfz48TLv47HHHtOnn36qd955R9u2bdPOnTu1a9eui95/UlKSgoODzccFBQV6//33dccdd1jUO3v2rDw9Pc3HnTt31jfffKOCgoKL9gEAAADUdIwrGFcAQKUzAADXrFWrVhmenp6lynv06GHcfPPNFmU33XST8fjjj1vU6dChg/n47Nmzhqurq/Hll19aXDdmzBhj2LBhhmEYRkpKiiHJyMzMLDOei/V78uRJw8HBwVi3bp35fGFhoXHdddcZzz//vEU7EyZMMPLz8w1HR0fjzTffNJ/7448/DBcXF2PChAllxlBi8ODBxn333Wc+/vLLLw1JhrOzs1G7dm3zy9HR0QgPDzfX27NnzwXvEQAAAKhpGFeUj3EFAFS+WrZMqAAAqq62bdtaHPv4+OjIkSMWZX//xtGBAwd0+vRp9enTx6JOYWGhOnToIElq166dbr31VrVp00bh4eHq27evoqKiVLdu3Qr1+9NPP+ncuXPq3r27+byDg4M6d+6stLS0Uvfw008/qbCw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7u7uql27trp06VLmGqu33367evXqpSeeeEKZmZlq166dtm3bpnfeeUePPvqoxabgV8LBwUGJiYkKCwvTLbfcorvuukvdu3eXg4ODfvzxR61fv15169bVrFmz5ODgoOeee06jR49Wjx49NGzYMOXk5GjhwoXy8/PTxIkTze3ed999mjdvnsLDwzVmzBgdOXJEy5Yt04033qi8vLzLijU4OFjS+VkW4eHhF/xH7XXr1ql+/foKCQkp8/ygQYO0fPlyvf/++4qMjLxgf0888YTuvvtuOTg46Pbbb1ezZs30zDPPKC4uTpmZmYqIiJC7u7sOHjyot99+Ww888IAmT558WfdYGZ599lnt2LFDXbp00dixY9W6dWsdP35cu3bt0scff6zjx49ftI2KfqbLY2dnp6VLl+r2229X+/btNXr0aPn4+Cg9PV0//vijtm7deln3NmDAANWvX18bN25Uv3795OXldVntAACAa8eHH35onu38dyEhIRV+tqmIli1basyYMfr222/VqFEjrVy5Ujk5ORYz59u3by97e3s999xzOnHihJycnNS7d2/zM03Dhg112223aePGjapTp06F/rH69OnTCgkJUdeuXXXbbbfJ19dXubm52rRpk5KSkhQREaEOHTpYXFOvXj3dfPPNGj16tHJycrRgwQI1b95cY8eOlXR+idpmzZpp8uTJ+v333+Xh4aG33nqrzP3uXnzxRd18883q2LGjHnjgAfn7+yszM1Pvv/+++ctslfF8eiVeeOEF9evXT926ddOYMWN05swZLVq0SJ6enhbj2hIHDx7UoEGDdNtttyk5OVlr167V8OHD1a5dO0lSu3btNGrUKL3yyivKzc1Vjx499M033+jVV19VREREhZe4DQ4O1scff6x58+bpuuuuk7+/v3mD+r9r2LCh4uLiNHPmTN12220aNGiQ9u3bpyVLluimm26qUPILAK6YAeCatWrVKkOS8e2335Z5/uDBg4YkY9WqVeayUaNGGbVr1y5Vd/r06cY/f6WsWLHCaNGiheHk5GQEBAQYq1atKrNe06ZNjVGjRl0w1p9//tmYNm2a0bVrV8PLy8uoVauW0bBhQ2PAgAHGJ598Uqr+Tz/9ZIwcOdLw9vY2HBwcjMaNGxsDBw40EhISLOp99913RmhoqOHk5GQ0adLEiI+PN1588UVDkpGdnW0R44ABA0r1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Vvv27bVlyxbz5uGHDh2SnZ2duf6ff/6psWPHKjs7W3Xr1lVwcLC+/PJLtW7d2la3AAAAAKAMlZrUyMnJkYODQ/md1aqlo0ePVmaXAAAAFoqKijRp0iQNHDhQmzZtMv+jZdeuXbVp0yZFRERo8uTJGjx4MEtRATVcTExMuctN7dy50+J4/vz5mj9//lWICgAAAMCVsLt4lYpr3LixUlNTyz3//fffy8fHpzK7BAAAsJCUlKTMzExNmTLF4lvYkmRnZ6e4uDgdPHhQSUlJNooQAAAAAABcrkpNavTv319Tp07V2bNnS507c+aMpk+froEDB1ZmlwAAABaysrIkSUFBQWWeLykvqQcAAAAAAKqPSl1+6sknn1RiYqJatmypmJgYtWrVSpKUnp6uxYsXq6ioSE888URldgkAAGChZFZoamqqunbtWup8yaxSZo8CAAAAAFD9VOpMjUaNGunLL79UUFCQ4uLidMcdd+iOO+7QlClTFBQUpM8//9y8Md/lePbZZ2UymfToo4+ay86ePatx48apfv36cnNz05AhQ5STk1MJdwMAAKqj0NBQ+fn5afbs2SouLrY4V1xcrPj4ePn7+ys0NNRGEQK4kKKiIq1YsULDhw9XWFiYevfubfECAAAAcG2r1JkaktS0aVN98MEH+vPPP3XgwAEZhqEWLVqobt26V9Tut99+q5dffllt27a1KJ84caLef/99bdy4UZ6enoqJiVFkZKS++OKLK+oPAABUT/b29po7d66ioqIUERGhuLg4BQUFKTU1VfHx8dq8ebMSEhLYJByooiZMmKDVq1drwIABCgoKkslksnVIAAAAAKqQSk9qlKhbt65uuummSmnr5MmTGjFihJYvX65nnnnGXH7ixAmtWLFC69evN39ra9WqVQoMDNRXX31V5pITklRQUKCCggLzcV5eXqXECQAAqobIyEglJCRo0qRJCgkJMZf7+/srISFBkZGRNowOwIVs2LBBb775pvr372/rUAAAAABUQZW6/JS1jBs3TgMGDFBYWJhFeUpKis6dO2dRHhAQoOuvv17JycnlthcfHy9PT0/zy9fX12qxAwAA24iMjNSBAwe0Y8cOrV+/Xjt27FBGRgYJDaCKc3R0VPPmzW0dBgAAAIAqymozNSrLhg0btGvXLn377belzmVnZ8vR0VF16tSxKG/UqJGys7PLbTMuLk6xsbHm47y8PBIbAADUQPb29urZs6etwwBwCSZNmqSFCxfqpZdeYukpAAAAAKVU6aTGr7/+qgkTJuijjz6Ss7NzpbXr5OQkJyenSmsPAAAAQOX4/PPPtWPHDn344Ye68cYb5eDgYHE+MTHRRpEBAAAAqAqqdFIjJSVFR44cUceOHc1lRUVF+uyzz/TSSy9p69atKiwsVG5ursVsjZycHHl7e9sgYgAAAABXok6dOrrjjjtsHQYAAACAKspqSY2MjAzt2LFDR44cUXFxscW5adOmVaiNW2+9VT/88INF2ejRoxUQEKDHH39cvr6+cnBw0Pbt2zVkyBBJ0r59+3To0CF169atcm4EAAAAwFWzatUqW4cAAAAAoAqzSlJj+fLleuihh9SgQQN5e3tbrIVrMpkqnNRwd3dXUFCQRVnt2rVVv359c/mYMWMUGxurevXqycPDQ+PHj1e3bt3UtWvXyrshAAAAAFfV0aNHtW/fPklSq1at1LBhQxtHBAAAAKAqsEpS45lnntGsWbP0+OOPW6N5C/Pnz5ednZ2GDBmigoIChYeHa8mSJVbvFwAAAEDlO3XqlMaPH681a9aYZ3zb29tr5MiRWrRokVxdXW0cIQAAAABbsrNGo3/++afuvPNOazStnTt3asGCBeZjZ2dnLV68WMePH9epU6eUmJjIfhoAAABANRUbG6tPP/1U7733nnJzc5Wbm6t33nlHn376qSZNmmTr8AAAAADYmFWSGnfeeae2bdtmjaYBAAAA1GBvvfWWVqxYoX79+snDw0MeHh7q37+/li9froSEBFuHBwAAAMDGrLL8VPPmzTV16lR99dVXatOmjRwcHCzOP/LII9boFgAAAEA1d/r0aTVq1KhUuZeXl06fPm2DiAAAAABUJVZJarzyyityc3PTp59+qk8//dTinMlkIqkBAAAAoEzdunXT9OnTtWbNGjk7O0uSzpw5o5kzZ6pbt242jg4AAACArVklqXHw4EFrNAsAAACghlu4cKHCw8PVpEkTtWvXTpK0Z88eOTs7a+vWrTaODgAAAICtWSWp8XeGYUg6P0MDAAAAAC4kKChIGRkZWrdundLT0yVJw4YN04gRI+Ti4mLj6AAAAADYmtWSGmvWrNELL7ygjIwMSVLLli312GOP6Z577rFWlwAAAABqAFdXV40dO9bWYQAAAACogqyS1Jg3b56mTp2qmJgYde/eXZL0+eef61//+peOHTumiRMnWqNbAAAAANXQu+++q379+snBwUHvvvvuBesOGjToKkUFAAAAoCqySlJj0aJFWrp0qUaOHGkuGzRokG688UbNmDGDpAYAoMKKioqUlJSkrKws+fj4KDQ0VPb29rYOCwBQiSIiIpSdnS0vLy9FRESUW89kMqmoqOjqBQYAAIBqLSMjQ/n5+bYOwywtLc3iz6rA3d1dLVq0sHUYl8QqSY2srCyFhISUKg8JCVFWVpY1ugQA1ECJiYmaNGmSMjMzzWV+fn6aO3euIiMjbRcYAKBSFRcXl/l3AAAA4HJlZGSoZcuWtg6jTNHR0bYOwcL+/furVWLDKkmN5s2b680339SUKVMsyt94441q9eYAAGwnMTFRUVFRGjhwoF5//XUFBQUpNTVVs2fPVlRUlBISEkhsAEANtGbNGg0dOlROTk4W5YWFhdqwYYPFbHAAAACgPCUzNNauXavAwEAbR3PemTNnlJmZKT8/P7m4uNg6HKWlpSk6OrpKzWapCKskNWbOnKmhQ4fqs88+M++p8cUXX2j79u168803rdElAKAGKSoq0qRJkzRw4EBt2rRJdnZ2kqSuXbtq06ZNioiI0OTJkzV48GCWogKAGmb06NG67bbb5OXlZVGen5+v0aNHk9QAAADAJQkMDFTHjh1tHYZZyb+X4/JZJakxZMgQff3115o/f742bdok6fyH55tvvlGHDh2s0SUAKzh9+rTS09OvuJ3KzkIHBATI1dX1ittB1ZWUlKTMzEy9/vrr5oRGCTs7O8XFxSkkJERJSUnq2bOnbYIEAFiFYRgymUylyn/77Td5enraICIAAAAAVYlVkhqSFBwcrLVr11qreQBXQXp6uoKDg20dRikpKSlVKsOOyley/1JQUFCZ50vK2acJAGqODh06yGQyyWQy6dZbb1WtWv8bqhQVFengwYO67bbbbBghAAAAgKqg0pIaeXl58vDwMP/9QkrqAajaAgIClJKScsXtlKzPV1lrGAYEBFxxG6jafHx8JEmpqanq2rVrqfOpqakW9QAA1V9ERIQkaffu3QoPD5ebm5v5nKOjo/z8/DRkyBAbRQcAAACgqqi0pEbdunWVlZUlLy8v1alTp8wp4yVTyYuKiiqrWwBW5OrqWqkzIqraGoaoukJDQ+Xn56fZs2db7KkhScXFxYqPj5e/v79CQ0NtGCUAoDJNnz5dRUVF8vPzU9++fUlcAwAAAChTpSU1PvnkE9WrV0+StGPHjspqFgBwDbK3t9fcuXMVFRWliIgIxcXFKSgoSKmpqYqPj9fmzZuVkJDAJuEAUMPY29vrwQcfVFpamq1DAQAAAFBFVVpSo0ePHua/+/v7y9fXt9RsDcMw9Ouvv1ZWlwCAGiwyMlIJCQmaNGmSQkJCzOX+/v5KSEhQZGSkDaMDAFhLUFCQfv75Z/n7+9s6FAAAAABVkN3Fq1w6f39/HT16tFT58ePHGZwAACosMjJSBw4c0I4dO7R+/Xrt2LFDGRkZJDQAoAZ75plnNHnyZG3evFlZWVnKy8uzeF2KxYsXy8/PT87OzurSpYu++eabCl23YcMGmUwm8z4fAAAAAKqOSpup8Xcle2f808mTJ+Xs7GyNLgEANZS9vb169uxp6zAAAFdJ//79JUmDBg2yGFNc6v58b7zxhmJjY7Vs2TJ16dJFCxYsUHh4uPbt2ycvL69yr8vMzNTkyZPZtwkAgCoiIyND+fn5tg5DksxLZFalpTLd3d3VokULW4cBXFWVmtSIjY2VJJlMJk2dOlWurq7mc0VFRfr666/Vvn37yuwSAAAAQA1SWfvzzZs3T2PHjtXo0aMlScuWLdP777+vlStX6t///neZ1xQVFWnEiBGaOXOmkpKSlJubWymxAACAy5ORkaGWLVvaOoxSoqOjbR2Chf3795PYwDWlUpMa3333naTz36L64Ycf5OjoaD7n6Oiodu3aafLkyZXZJQAAAIAa5O979V2uwsJCpaSkKC4uzlxmZ2ensLAwJScnl3vdU089JS8vL40ZM0ZJSUkX7aegoEAFBQXm40tdHgsAAFxYyQyNtWvXKjAw0MbRSGfOnFFmZqb8/Pzk4uJi63CUlpam6OjoKjOTBbhaKjWpUfKtqtGjR2vhwoXy8PCozOYBANXM6dOnlZ6efsXtVPaDY0BAgMVsQgBA1ZKbm6sVK1aYl3a48cYbdd9998nT07NC1x87dkxFRUVq1KiRRXmjRo3K/f/S559/rhUrVmj37t0VjjM+Pl4zZ86scH0AAHB5AgMD1bFjR1uHIUnq3r27rUMArnlW2VNj1apV1mgWAFDNpKenKzg42NZhlJKSklJlHogBAJb++9//Kjw8XC4uLurcubOk80tJzZo1S9u2bbPK7+/8/Hzdc889Wr58uRo0aFDh6+Li4sxL8ErnZ2r4+vpWenwAAAAA/scqSQ3p/GDkzTff1KFDh1RYWGhxLjEx0VrdAgCqkICAAKWkpFxxOyVTaitrynFAQMAVtwEAsI6JEydq0KBBWr58uWrVOj9c+euvv3T//ffr0Ucf1WeffXbRNho0aCB7e3vl5ORYlOfk5Mjb27tU/Z9++kmZmZm6/fbbzWXFxcWSpFq1amnfvn1q1qxZqeucnJzk5OR0SfcHAAAA4MpYJamxYcMGjRw5UuHh4dq2bZv69u2r/fv3KycnR3fccYc1ugQAVEGurq6V+o3aqjTlGABgHf/9738tEhrS+cTC//3f/6lTp04VasPR0VHBwcHavn27IiIiJJ1PUmzfvl0xMTGl6gcEBOiHH36wKHvyySeVn5+vhQsXMvsCAAAAqEKsktSYPXu25s+fr3Hjxsnd3V0LFy6Uv7+/HnzwQfn4+FijSwAAAAA1gIeHhw4dOlRqVt2vv/4qd3f3CrcTGxurUaNGqVOnTurcubMWLFigU6dOafTo0ZKkkSNHqnHjxoqPj5ezs7OCgoIsrq9Tp44klSoHAAAAYFtWSWr89NNPGjBggKTz35I6deqUTCaTJk6cqN69e7OZHgAAAIAyDR06VGPGjNGcOXMUEhIiSfriiy/02GOPadiwYZfUztGjRzVt2jRlZ2erffv22rJli3nz8EOHDsnOzs4q9wAAAADAeqyS1Khbt67y8/MlSY0bN1ZqaqratGmj3NxcnT592hpdAgAAAKgB5syZI5PJpJEjR+qvv/6SJDk4OOihhx7Ss88+e0ltxcTElLnclCTt3LnzgteuXr36kvoCAAAAcHVYJalxyy236KOPPlKbNm105513asKECfrkk0/00Ucf6dZbb7VGlwAAAABqAEdHRy1cuFDx8fH66aefJEnNmjWTq6urjSMDAAAAUBVYJanx0ksv6ezZs5KkJ554Qg4ODvryyy81ZMgQPfnkk9boEgAAAEAN4urqat7XgoQGAAAAgBJWSWrUq1fP/Hc7Ozv9+9//tkY3AAAAAGqYv/76SzNnztSLL76okydPSpLc3Nw0fvx4TZ8+XQ4ODjaOEAAAAIAtWSWpYW9vr6ysLHl5eVmU//HHH/Ly8lJRUZE1ugUAAABQzY0fP16JiYl6/vnn1a1bN0lScnKyZsyYoT/++ENLly61cYQAAAAAbMkqSQ3DMMosLygokKOjozW6BAAAAFADrF+/Xhs2bFC/fv3MZW3btpWvr6+GDRtGUgMAAAC4xlVqUuPFF1+UJJlMJv3nP/+Rm5ub+VxRUZE+++wzBQQEVGaXAAAAAGoQJycn+fn5lSr39/fnC1IAUA1lZGQoPz/f1mFIktLS0iz+rArc3d3VokULW4cBANVKpSY15s+fL+n8TI1ly5bJ3t7efM7R0VF+fn5atmxZZXYJAAAAoAaJiYnR008/rVWrVsnJyUnS+Rnfs2bNUkxMjI2jAwBcioyMDLVs2dLWYZQSHR1t6xAs7N+/n8QGAFyCSk1qHDx4UJLUq1cvJSYmqm7dupXZPAAAAIAa7rvvvtP27dvVpEkTtWvXTpK0Z88eFRYW6tZbb1VkZKS5bmJioq3CBABUQMkMjbVr1yowMNDG0UhnzpxRZmam/Pz85OLiYutwlJaWpujo6CozkwUAqgur7KmxY8cOazQLAAAAoIarU6eOhgwZYlHm6+tro2gAsHTQhbF0UMUEBgaqY8eOtg5DktS9e3dbhwAAuEJWSWoUFRVp9erV2r59u44cOaLi4mKL85988ok1ugUAAABQza1atcrWIQD4/1g6qGJYOggAgKvLKkmNCRMmaPXq1RowYICCgoJkMpms0Q0AAACAGuro0aPat2+fJKlVq1Zq2LChjSMCrj0sHXRhLB0EAIBtWCWpsWHDBr355pvq37//FbWzdOlSLV26VJmZmZKkG2+8UdOmTVO/fv0kSWfPntWkSZO0YcMGFRQUKDw8XEuWLFGjRo2u9BYAAAAA2MCpU6c0fvx4rVmzxjzj297eXiNHjtSiRYvk6upq4wiBaw9LBwEAgKrEzhqNOjo6qnnz5lfcTpMmTfTss88qJSVF//3vf9W7d28NHjxYP/74oyRp4sSJeu+997Rx40Z9+umnOnz4sMXGgQAAAACql9jYWH366ad67733lJubq9zcXL3zzjv69NNPNWnSJFuHBwAAAMDGrDJTY9KkSVq4cKFeeumlK1p66vbbb7c4njVrlpYuXaqvvvpKTZo00YoVK7R+/Xr17t1b0vn1dwMDA/XVV1+pa9eu5bZbUFCggoIC83FeXt5lxwgAAACg8rz11ltKSEhQz549zWX9+/eXi4uL7rrrLi1dutR2wQEAAACwOaskNT7//HPt2LFDH374oW688UY5ODhYnE9MTLzkNouKirRx40adOnVK3bp1U0pKis6dO6ewsDBznYCAAF1//fVKTk6+YFIjPj5eM2fOvOQYAAAAAFjX6dOny1xO1svLS6dPn7ZBRNVbRkZGlVnvPy0tzeLPqsLd3Z1NngEAAKoRqyQ16tSpozvuuKNS2vrhhx/UrVs3nT17Vm5ubnr77bfVunVr7d69W46OjqpTp45F/UaNGik7O/uCbcbFxSk2NtZ8nJeXJ19f30qJFwAAAMDl69atm6ZPn641a9bI2dlZ0vnNgWfOnKlu3brZOLrqJSMjQy1btrR1GKVER0fbOoRS9u/fT2IDAACgmrBKUmPVqlWV1larVq20e/dunThxQgkJCRo1apQ+/fTTK2rTyclJTk5OlRQhAAAAgMqyYMEC3XbbbWrSpInatWsnSdqzZ4+cnZ21detWG0dXvZTM0Fi7dq0CAwNtHM355FRmZqb8/Pzk4uJi63AknZ81Eh0dXWVmswAAAODirJLUkKS//vpLO3fu1E8//aThw4fL3d1dhw8floeHh9zc3Crczt83HQ8ODta3336rhQsXaujQoSosLFRubq7FbI2cnBx5e3tX9u0AAAAAuAratGmjjIwMrVu3Tunp6ZKkYcOGacSIEVXmH8Krm8DAQHXs2NHWYUiSunfvbusQAAAAUM1ZJanxyy+/6LbbbtOhQ4dUUFCgPn36yN3dXc8995wKCgq0bNmyy267uLhYBQUFCg4OloODg7Zv364hQ4ZIkvbt26dDhw4xLR0AAACohs6dO6eAgABt3rxZY8eOtXU4AAAAAKogqyQ1JkyYoE6dOmnPnj2qX7++ufyOO+64pMFJXFyc+vXrp+uvv175+flav369du7cqa1bt8rT01NjxoxRbGys6tWrJw8PD40fP17dunW74CbhAAAAAKomBwcHnT171tZhAAAAAKjCrJLUSEpK0pdffilHR0eLcj8/P/3+++8VbufIkSMaOXKksrKy5OnpqbZt22rr1q3q06ePJGn+/Pmys7PTkCFDVFBQoPDwcC1ZsqRS7wUAAADA1TNu3Dg999xz+s9//qNatay2Wi4AAACAasoqo4Ti4mIVFRWVKv/tt9/k7u5e4XZWrFhxwfPOzs5avHixFi9efMkxVnUZGRlVZrO6tLQ0iz+rAnd3d7Vo0cLWYQAAAKCSffvtt9q+fbu2bdumNm3aqHbt2hbnExMTbRQZAAAAgKrAKkmNvn37asGCBXrllVckSSaTSSdPntT06dPVv39/a3RZo2RkZKhly5a2DqOU6OhoW4dgYf/+/SQ2AAAAapg6deqY98wDAAAAgH+ySlJj7ty5Cg8PV+vWrXX27FkNHz5cGRkZatCggV5//XVrdFmjlMzQWLt2rQIDA20cjXTmzBllZmbKz89PLi4utg5HaWlpio6OrjIzWQAAAHDliouL9cILL2j//v0qLCxU7969NWPGjCrx/AkAAACg6rBKUqNJkybas2ePNmzYoO+//14nT57UmDFjNGLECAYllyAwMFAdO3a0dRiSpO7du9s6BAAAANRgs2bN0owZMxQWFiYXFxe9+OKLOnr0qFauXGnr0AAAAABUIVbbea9WrVpVbrkiAAAAAFXTmjVrtGTJEj344IOSpI8//lgDBgzQf/7zH9nZ2dk4OgAAAABVhdWSGocPH9bnn3+uI0eOqLi42OLcI488Yq1uAQAAAFRDhw4dsth/LywsTCaTSYcPH1aTJk1sGBkAAACAqsQqSY3Vq1frwQcflKOjo+rXry+TyWQ+ZzKZSGoAAAAAsPDXX3/J2dnZoszBwUHnzp2zUUQAAAAAqiKrJDWmTp2qadOmKS4ujqniAAAAAC7KMAzde++9cnJyMpedPXtW//rXv1S7dm1zWWJioi3CAwAAAFBFWCWpcfr0ad19990kNAAAAABUyKhRo0qVsUcfAAAAgH+ySlJjzJgx2rhxo/79739bo3kAAAAANcyqVatsHQIAAACAasAqSY34+HgNHDhQW7ZsUZs2beTg4GBxft68edboFgAAAAAAAAAA1GBWWR8qPj5eW7duVU5Ojn744Qd999135tfu3but0SUAAAAAWFi8eLH8/Pzk7OysLl266Jtvvim3bmJiojp16qQ6deqodu3aat++vV577bWrGC0AAACAirDKTI25c+dq5cqVuvfee63RPAAAAABc0BtvvKHY2FgtW7ZMXbp00YIFCxQeHq59+/bJy8urVP169erpiSeeUEBAgBwdHbV582aNHj1aXl5eCg8Pt8EdAAAAACiLVWZqODk5qXv37tZoGgAAAAAuat68eRo7dqxGjx6t1q1ba9myZXJ1ddXKlSvLrN+zZ0/dcccdCgwMVLNmzTRhwgS1bdtWn3/+ebl9FBQUKC8vz+IFAAAAwLqsktSYMGGCFi1aZI2mAQAAKqyoqEg7d+7U66+/rp07d6qoqMjWIQG4CgoLC5WSkqKwsDBzmZ2dncLCwpScnHzR6w3D0Pbt27Vv3z7dcsst5daLj4+Xp6en+eXr61sp8QMAAAAon1WWn/rmm2/0ySefaPPmzbrxxhtLbRSemJhojW4BAADMEhMTNWnSJGVmZprL/Pz8NHfuXEVGRtouMABWd+zYMRUVFalRo0YW5Y0aNVJ6enq51504cUKNGzdWQUGB7O3ttWTJEvXp06fc+nFxcYqNjTUf5+XlkdgAAAAArMwqSY06derwjwUAAMBmEhMTFRUVpYEDB+r1119XUFCQUlNTNXv2bEVFRSkhIYFnFQCluLu7a/fu3Tp58qS2b9+u2NhY3XDDDerZs2eZ9Z2cnOTk5HR1gwQAAACucVZJaqxatcoazQIAAFxUUVGRJk2apIEDB2rTpk2yszu/2mbXrl21adMmRUREaPLkyRo8eLDs7e1tHC0Aa2jQoIHs7e2Vk5NjUZ6TkyNvb+9yr7Ozs1Pz5s0lSe3bt1daWpri4+PLTWoAAAAAuPqssqcGAACArSQlJSkzM1NTpkwxJzRK2NnZKS4uTgcPHlRSUpKNIgRgbY6OjgoODtb27dvNZcXFxdq+fbu6detW4XaKi4tVUFBgjRABAAAAXCarzNTo0KGDTCZTqXKTySRnZ2c1b95c9957r3r16mWN7gEAwDUsKytLkhQUFFTm+ZLyknoAaqbY2FiNGjVKnTp1UufOnbVgwQKdOnVKo0ePliSNHDlSjRs3Vnx8vKTzm3536tRJzZo1U0FBgT744AO99tprWrp0qS1vAwAAAMA/WGWmxm233aaff/5ZtWvXVq9evdSrVy+5ubnpp59+0k033aSsrCyFhYXpnXfesUb3AADgGubj4yNJSk1NLfN8SXlJPQA109ChQzVnzhxNmzZN7du31+7du7Vlyxbz5uGHDh2ySG6eOnVKDz/8sG688UZ1795db731ltauXav777/fVrcAAAAAoAxWmalx7NgxTZo0SVOnTrUof+aZZ/TLL79o27Ztmj59up5++mkNHjzYGiEAAIBrVGhoqPz8/DR79myLPTWk80vJxMfHy9/fX6GhoTaMEsDVEBMTo5iYmDLP7dy50+L4mWee0TPPPHMVogIAAABwJawyU+PNN9/UsGHDSpXffffdevPNNyVJw4YN0759+6zRPQAAuIbZ29tr7ty52rx5syIiIpScnKz8/HwlJycrIiJCmzdv1pw5c9gkHAAAAACAasgqSQ1nZ2d9+eWXpcq//PJLOTs7Szr/TcmSvwMAAFSmyMhIJSQk6IcfflBISIg8PDwUEhKi1NRUJSQkKDIy0tYhAgAAAACAy2CV5afGjx+vf/3rX0pJSdFNN90kSfr222/1n//8R1OmTJEkbd26Ve3bt7dG9wAAAIqMjNTgwYOVlJSkrKws+fj4KDQ0lBkaAAAAAABUY1ZJajz55JPy9/fXSy+9pNdee02S1KpVKy1fvlzDhw+XJP3rX//SQw89ZI3uAQAAJJ1fiqpnz562DgMAAAAAAFQSqyQ1JGnEiBEaMWJEueddXFys1TUAAAAAAAAAAKiBrLKnhiTl5uaal5s6fvy4JGnXrl36/fffrdUlAAAAAAAAAACowawyU+P7779XWFiYPD09lZmZqfvvv1/16tVTYmKiDh06pDVr1lijWwAAAAAAAAAAUINZJakRGxure++9V88//7zc3d3N5f379zfvqQHAujIyMpSfn2/rMCRJaWlpFn9WBe7u7mrRooWtwwAAAAAAAABwCayS1Pj222/18ssvlypv3LixsrOzrdElgL/JyMhQy5YtbR1GKdHR0bYOwcL+/ftJbAAAAAAAANRQ3m4mueTulw5bbReGas0ld7+83Uy2DuOSWSWp4eTkpLy8vFLl+/fvV8OGDa3RJYC/KZmhsXbtWgUGBto4GunMmTPKzMyUn5+fXFxcbB2O0tLSFB0dXWVmsgAAAAAAAKDyPRjsqMDPHpQ+s3UkVVOgzr9H1Y1VkhqDBg3SU089pTfffFOSZDKZdOjQIT3++OMaMmSINboEUIbAwEB17NjR1mFIkrp3727rEAAAAAAAAHANeTmlUEOnrVZgQICtQ6mS0tLT9fLc4Rpk60AukVWSGnPnzlVUVJS8vLx05swZ9ejRQ9nZ2erWrZtmzZpljS4BAEANc/r0aaWnp19xO9aYLRYQECBXV9dKaQsAAAAAYB3ZJw2dqdNSuq69rUOpks5kFyv7pGHrMC6ZVZIanp6e+uijj/TFF19oz549OnnypDp27KiwsDBrdAcAAGqg9PR0BQcH2zqMMqWkpFSZmXAAAAAAAFxLrJLUKNG9e3eWnAEAAJclICBAKSkpV9xOyT46lbnPUABTlwEAAAAAsIlKTWokJyfrjz/+0MCBA81la9as0fTp03Xq1ClFRERo0aJFcnJyqsxuAQBADeTq6lqpsyGq0j5DAAAAAADg8thVZmNPPfWUfvzxR/PxDz/8oDFjxigsLEz//ve/9d577yk+Pr4yuwQAAAAAAAAAANeISk1q7N69W7feeqv5eMOGDerSpYuWL1+u2NhYvfjii3rzzTcrs0sAAAAAAAAAAHCNqNSkxp9//qlGjRqZjz/99FP169fPfHzTTTfp119/rcwuAQAAAAAAAADANaJS99Ro1KiRDh48KF9fXxUWFmrXrl2aOXOm+Xx+fr4cHBwq3F58fLwSExOVnp4uFxcXhYSE6LnnnlOrVq3Mdc6ePatJkyZpw4YNKigoUHh4uJYsWWKRXAEAAAAAAABQ/Xi7meSSu186XKnfza4RXHL3y9vNZOswgKuuUpMa/fv317///W8999xz2rRpk1xdXRUaGmo+//3336tZs2YVbu/TTz/VuHHjdNNNN+mvv/7SlClT1LdvX+3du1e1a9eWJE2cOFHvv/++Nm7cKE9PT8XExCgyMlJffPFFZd4aAAAAAAAAgKvswWBHBX72oPSZrSOpegJ1/v0BrjWVmtR4+umnFRkZqR49esjNzU2vvvqqHB3/9x/WypUr1bdv3wq3t2XLFovj1atXy8vLSykpKbrlllt04sQJrVixQuvXr1fv3r0lSatWrVJgYKC++uorde3atXJuDAAAAAAAAMBV93JKoYZOW63AgABbh1LlpKWn6+W5wzXI1oEAV1mlJjUaNGigzz77TCdOnJCbm5vs7e0tzm/cuFFubm6X3f6JEyckSfXq1ZMkpaSk6Ny5cwoLCzPXCQgI0PXXX6/k5ORykxoFBQUqKCgwH+fl5V12TAAAAAAAAACsI/ukoTN1WkrXtbd1KFXOmexiZZ80bB0GcNVZZTE6T0/PUgkN6Xwy4u8zNy5FcXGxHn30UXXv3l1BQUGSpOzsbDk6OqpOnToWdRs1aqTs7Oxy24qPj5enp6f55evre1kxAQAAAAAAAACAq6fa7LAzbtw4paamasOGDVfcVlxcnE6cOGF+/frrr5UQIQAAAAAAAAAAsKZKXX7KWmJiYrR582Z99tlnatKkibnc29tbhYWFys3NtZitkZOTI29v73Lbc3JykpOTkzVDBgAAAAAAAAAAlaxKz9QwDEMxMTF6++239cknn8jf39/ifHBwsBwcHLR9+3Zz2b59+3To0CF169btaocLAAAAAAAAAACsqErP1Bg3bpzWr1+vd955R+7u7uZ9Mjw9PeXi4iJPT0+NGTNGsbGxqlevnjw8PDR+/Hh169at3E3CAQAAAAAAAABA9VSlkxpLly6VJPXs2dOifNWqVbr33nslSfPnz5ednZ2GDBmigoIChYeHa8mSJVc5UgCoWTIyMpSfn2/rMMzS0tIs/qwK3N3d1aJFC1uHAQAAAAAAcE2p0kkNwzAuWsfZ2VmLFy/W4sWLr0JEAFDzZWRkqGXLlrYOo0zR0dG2DsHC/v37SWwAAAAAAABcRVU6qQEAuPpKZmisXbtWgYGBNo7mvDNnzigzM1N+fn5ycXGxdThKS0tTdHR0lZrNAgAAAAAAcC0gqQEAKFNgYKA6duxo6zDMunfvbusQAAAAAAAAYGN2tg4AAAAAAKxh8eLF8vPzk7Ozs7p06aJvvvmm3LrLly9XaGio6tatq7p16yosLOyC9QEAAADYBkkNAAAAADXOG2+8odjYWE2fPl27du1Su3btFB4eriNHjpRZf+fOnRo2bJh27Nih5ORk+fr6qm/fvvr999+vcuQAAAAALoSkBgAAAIAaZ968eRo7dqxGjx6t1q1ba9myZXJ1ddXKlSvLrL9u3To9/PDDat++vQICAvSf//xHxcXF2r59+1WOHAAAAMCFkNQAAAAAUKMUFhYqJSVFYWFh5jI7OzuFhYUpOTm5Qm2cPn1a586dU7169cqtU1BQoLy8PIsXAAAAAOtio3AAAAAANcqxY8dUVFSkRo0aWZQ3atRI6enpFWrj8ccf13XXXWeRGPmn+Ph4zZw584piBYCaztvNJJfc/dJhvlf7Ty65++XtZrJ1GABQ7ZDUAAAAAIC/efbZZ7Vhwwbt3LlTzs7O5daLi4tTbGys+TgvL0++vr5XI0QAqDYeDHZU4GcPSp/ZOpKqJ1Dn3x8AwKUhqQEAAACgRmnQoIHs7e2Vk5NjUZ6TkyNvb+8LXjtnzhw9++yz+vjjj9W2bdsL1nVycpKTk9MVxwsANdnLKYUaOm21AgMCbB1KlZOWnq6X5w7XIFsHAgDVDEmNKorpmeVjembF8BkqH58hAABqNkdHRwUHB2v79u2KiIiQJPOm3zExMeVe9/zzz2vWrFnaunWrOnXqdJWiBYCaLfukoTN1WkrXtbd1KFXOmexiZZ80bB0GAFQ7JDWqKKZnlo/pmRXDZ6h8fIYAAKj5YmNjNWrUKHXq1EmdO3fWggULdOrUKY0ePVqSNHLkSDVu3Fjx8fGSpOeee07Tpk3T+vXr5efnp+zsbEmSm5ub3NzcbHYfAAAAACyR1KiimJ5ZPqZnVgyfofLxGQIAoOYbOnSojh49qmnTpik7O1vt27fXli1bzJuHHzp0SHZ2/5vRunTpUhUWFioqKsqinenTp2vGjBlXM3QAAAAAF0BSo4piemb5mJ5ZMXyGysdnCACuDadPn1Z6evoVt3PmzBllZmbKz89PLi4uV9xeQECAXF1dr7gdXFxMTEy5y03t3LnT4jgzM9P6AQEAAAC4YiQ1AAAAUCOlp6crODjY1mGUkpKSoo4dO9o6DAAAAAColkhqAAAAoEYKCAhQSkrKFbeTlpam6OhorV27VoGBgZUSFwAAAADg8pDUAAAAQI3k6upaqTMiAgMDmWEB4Jrj7WaSS+5+6bDdxStfY1xy98vbzWTrMAAAuOaQ1AAAAAAAAGV6MNhRgZ89KH1m60iqnkCdf38AAMDVRVIDAAAAAACU6eWUQg2dtlqBLJ1XSlp6ul6eO1yDbB0IAADXGJIaAAAAAACgTNknDZ2p01K6rr2tQ6lyzmQXK/ukYeswAAC45pDUAAAAAIAaiv0QLow9EQAAAKofkhoAAAAAUEOxH8KFsScCAABA9UNSAwAAAABqKPZDuDD2RAAAAKh+SGoAAEphqYoLY6mKi8vIyFB+fr6tw5AkpaWlWfxZVbi7u6tFixa2DgNADcd+CBfGnggAAADVD0kNAEApLFVxYSxVcWEZGRlq2bKlrcMoJTo62tYhlLJ//34SGwAAAAAAXAKSGgCAUliq4sJYquLCSmZorF27VoGBgTaORjpz5owyMzPl5+cnFxcXW4cj6fyskejo6CozmwUAAAAAgOqCpAYAoBSWqrgwlqqomMDAQHXs2NHWYUiSunfvbusQAAAAAABAJWCxdAAAAAAAAAAAUC2Q1AAAAAAAAAAAANUCSQ0AAAAAAAAAAFAtkNQAAAAAAAAAAADVAkkNAAAAAAAAAABQLZDUAAAAAAAAAAAA1QJJDQAAAAAAAAAAUC2Q1AAAAAAAAAAAANUCSQ0AAAAAAAAAAFAtkNQAAAAAAAAAAADVAkkNAAAAAAAAAABQLdSydQAAAADAP2VkZCg/P9/WYUiS0tLSLP6sCtzd3dWiRQtbhwEAAAAAVx1JDQAAAFQpGRkZatmypa3DKCU6OtrWIVjYv38/iQ0AAAAA1xySGgAAAKhSSmZorF27VoGBgTaORjpz5owyMzPl5+cnFxcXW4ejtLQ0RUdHV5mZLAAAAABwNVX5pMZnn32mF154QSkpKcrKytLbb7+tiIgI83nDMDR9+nQtX75cubm56t69u5YuXcq31gAAsCFvN5NccvdLh9m+qywuufvl7WaydRhVXmBgoDp27GjrMCRJ3bt3t3UIAAAAAABVg6TGqVOn1K5dO913332KjIwsdf7555/Xiy++qFdffVX+/v6aOnWqwsPDtXfvXjk7O9sgYgAA8GCwowI/e1D6zNaRVE2BOv8eAf+vvXsPjqo+/zj+STDZJIQkYEjCJUAUJCAYIEBMwSspKWX8gdoZ4OeFQcRLpRXRIHgBL3XCgFBaSkGnVXC0xUsHHBUjmShBJY2SgAoCggaxygYvkCUXEmS/vz/4cepKIBt2s2d3837N7Mie891znpN59vL4nO85AAAAANpGfX29JKmystLmSP4rGGeBh6Kgb2qMGzdO48aNa3adMUbLli3TQw89pAkTJkiSnnvuOaWmpmr9+vWaPHlys69rbGxUY2Oj9dzlcvk/cB8E2xuON1voIYfOjhwC2t5TFU2aNH+1BmRm2h1KUNq1e7eeWvK/+h+7AwEAAACAMLV7925J0owZM2yOJPh16tTJ7hBaJeibGmdTVVUlp9OpvLw8a1liYqJycnJUVlZ2xqZGYWGhHn300UCF2Wq84bwTam+2QCKHvEMOAW3HWWvUkHSR1H2I3aEEpQanW85aY3cYAAAAABC2Tt3CIDMzU3FxcfYG8/9O3R8vWO4fKJ38/2OhdiuHkG5qOJ1OSVJqaqrH8tTUVGtdc+bNm6fZs2dbz10ul9LT09smyHMQbG843myhhxxqGTkEAAAAAAAQvpKTk3XrrbfaHUazgun+gaEopJsa58rhcMjhcNgdxhkF6xuON1voIIcAAACkFStWaPHixXI6ncrKytLy5cs1cuTIZsfu3LlT8+fPV0VFhb788kv98Y9/1KxZswIbMAAAAIAWRdodgC/S0tIkSdXV1R7Lq6urrXUAAAAA2p8XX3xRs2fP1oIFC1RZWamsrCzl5+fr0KFDzY6vr6/XBRdcoIULF1JLAAAAAEEspJsaGRkZSktLU0lJibXM5XKpvLxcubm5NkYGAAAAwE5Lly7VjBkzNG3aNA0cOFCrVq1SXFycnnnmmWbHjxgxQosXL9bkyZO9ntXd2Ngol8vl8QAAAADQtoL+8lO1tbXat2+f9byqqkrbt29Xly5d1KtXL82aNUt/+MMf1K9fP2VkZOjhhx9W9+7drXsKAAAAAGhfmpqaVFFRoXnz5lnLIiMjlZeXp7KyMr/tp7CwUI8++qjftgcAADzV19dLkiorK22O5KSGhgbt379fffr0UWxsrN3haNeuXXaHANgi6JsaW7du1VVXXWU9P3WD76lTp2r16tWaM2eO6urqdNttt+nIkSMaPXq0ioqKFBMTY1fIAAAAAGz03Xff6cSJE0pNTfVYnpqaqt27d/ttP/PmzbPqE+nkrPH09HS/bR8AgPbu1Pf2jBkzbI4kuHXq1MnuEICACvqmxpVXXiljzBnXR0RE6LHHHtNjjz0WwKgAAAAAtHcOh8PrS1UBAIDWO3UllszMTMXFxdkbjE7OjLjxxhv1/PPPa8CAAXaHI+lkQ6Nfv352hwEEVNA3NQAAgRVs03slpvgCAFonOTlZHTp0UHV1tcfy6upqbgIOAEAISU5O1q233mp3GKcZMGCAhg0bZncYQLtFUwMA4IHpvd5jii/QdtLiIxR75DPpm0i7Qwk6sUc+U1p8hN1hBLXo6GhlZ2erpKTEOsPT7XarpKREM2fOtDc4AGhHgu2EKU6WAoDwQFMDAOAh2Kb3SkzxBdqj27OjNWDz7dJmuyMJPgN08u+Ds5s9e7amTp2q4cOHa+TIkVq2bJnq6uo0bdo0SdLNN9+sHj16qLCwUNLJm4t/+umn1r+//vprbd++XfHx8erbt69txwEAoYwTprzDyVIA0Do0NQAAHoJ1eq/EFF+gPXmqokmT5q/WgMxMu0MJOrt279ZTS/5X/2N3IEFu0qRJ+vbbbzV//nw5nU4NGTJERUVF1s3DDxw4oMjI/84E+uabbzR06FDr+ZNPPqknn3xSV1xxhTZt2hTo8AEgLATbCVOcLAUA4YGmBgAAAIKOs9aoIekiqfsQu0MJOg1Ot5y1xu4wQsLMmTPPeLmpnzcq+vTpI2P4uwKAPwXrCVOcLAUAoY2mBgAA8Cuundwyrp8MAAAAAMC5oakBAAD8imsne4/rJwMAAAAA0Do0NQAAgF9x7WTvcP1kAAAAAABaj6YGAADwK66dDABAeOCSkmfH5SQBALAHTQ0AAAAAAHAaLinpHS4nCQBAYNHUAAAAAAAAp+GSki3jcpIAAAQeTQ0AAAAEFS53cnZc7gRAoHBJSQAAEIxoagAAACCocLkT73C5EwAAAADtEU0NAAAABBUud9IyLncCbzDrqWXMfAIAAAg9NDUAAAAQVLjcCeAfzHryHjOfAAAAQgdNDQAAAAAIQ8x68g4znwAAAEILTQ0AAAAACEPMegIAAEA4irQ7AAAAAAAAAAAAAG/Q1AAAAAAAAAAAACGBpgYAAAAAAAAAAAgJNDUAAAAAAAAAAEBIoKkBAAAAAAAAAABCAk0NAAAAAAAAAAAQEmhqAAAAAAAAAACAkEBTAwAAAAAAAAAAhASaGgAAAAAAAAAAICScZ3cAaDv19fXavXu3z9vZtWuXx399lZmZqbi4OL9sC22LHIKvyCH4IljzRyKHAAAAAACwC02NMLZ7925lZ2f7bXs33nijX7ZTUVGhYcOG+WVbaFvkEHxFDsEXwZo/EjkEAAAAAIBdaGqEsczMTFVUVPi8nYaGBu3fv199+vRRbGysX+JCaCCH4CtyCL4I1vyRyCEAAAAAAOxCUyOMxcXF+e0s0lGjRvllOwgt5BB8RQ7BF+QPAAAAAAD4OW4UDgAAAAAAAAAAQgIzNQAAABCWgvVm89xoHqGG9xJ8RQ7BV+QQfEUOwRf+yh+JHPKXCGOMsTsIu7lcLiUmJqqmpkYJCQl2hwMAAAA/qKys9OvN5v0lHG80z+/pk8L178B7Cb4ih+Arcgi+Iofgi2DNHyn8csjb39PM1AAAAEBYCtabzXOjeYQa3kvwFTkEX5FD8BU5BF/4K38kcshfmKmh8D2jCgAAAAgEfk+fxN8BAAAAOHfe/p7mRuEAAAAAAAAAACAk0NQAAAAAEJZWrFihPn36KCYmRjk5Ofrggw/OOv7ll19WZmamYmJiNHjwYG3YsCFAkQIAAADwFk0NAAAAAGHnxRdf1OzZs7VgwQJVVlYqKytL+fn5OnToULPjt2zZoilTpmj69Onatm2bJk6cqIkTJ2rHjh0BjhwAAADA2XBPDXHtWwAAAMAXwfh7OicnRyNGjNBf/vIXSZLb7VZ6erp+97vfae7cuaeNnzRpkurq6vT6669byy699FINGTJEq1at8mqfwfh3AAAAAEJFu7unRmunlgMAAAAIT01NTaqoqFBeXp61LDIyUnl5eSorK2v2NWVlZR7jJSk/P/+M4yWpsbFRLpfL4wEAAACgbYVFU6O1U8sBAAAAhK/vvvtOJ06cUGpqqsfy1NRUOZ3OZl/jdDpbNV6SCgsLlZiYaD3S09N9Dx4AAADAWYVFU2Pp0qWaMWOGpk2bpoEDB2rVqlWKi4vTM8880+x4zqgCAAAA4Kt58+appqbGenz11Vd2hwQAAACEvZBvapzL1HLOqAIAAADCV3Jysjp06KDq6mqP5dXV1UpLS2v2NWlpaa0aL0kOh0MJCQkeDwAAAABtK+SbGucytZwzqgAAAIDwFR0drezsbJWUlFjL3G63SkpKlJub2+xrcnNzPcZLUnFx8RnHAwAAALDHeXYHYAeHwyGHw2F3GAAAAADayOzZszV16lQNHz5cI0eO1LJly1RXV6dp06ZJkm6++Wb16NFDhYWFkqS7775bV1xxhZYsWaLx48dr7dq12rp1q55++mk7DwMAAADAz4R8U+NcppYDAAAACG+TJk3St99+q/nz58vpdGrIkCEqKiqyZngfOHBAkZH/nbj+i1/8Qv/4xz/00EMP6YEHHlC/fv20fv16DRo0yK5DAAAAANCMCGOMsTsIX+Xk5GjkyJFavny5pJNTy3v16qWZM2dq7ty5Lb7e5XIpMTFRNTU1XAcXAAAAaCV+T5/E3wEAAAA4d97+ng75mRpSy1PLAQAAAAAAAABA6AuLpkZLU8tbcmqyisvlasswAQAAgLB06nd0GEwC9wl1BQAAAHDuvK0rwuLyU776z3/+o/T0dLvDAAAAAELaV199pZ49e9odhm2oKwAAAADftVRX0NTQyXtwfPPNN+rUqZMiIiLsDifouFwupaen66uvvuLawDgn5BB8RQ7BF+QPfEUOtcwYo6NHj6p79+4eN99ub6grzo73EnxFDsFX5BB8RQ7BV+TQ2XlbV4TF5ad8FRkZ2a7PKPNWQkICbzb4hByCr8gh+IL8ga/IobNLTEy0OwTbUVd4h/cSfEUOwVfkEHxFDsFX5NCZeVNXtN/TqAAAAAAAAAAAQEihqQEAAAAAAAAAAEICTQ20yOFwaMGCBXI4HHaHghBFDsFX5BB8m1gFAAAAEMdJREFUQf7AV+QQ4B+8l+Arcgi+IofgK3IIviKH/IMbhQMAAAAAAAAAgJDATA0AAAAAAAAAABASaGoAAAAAAAAAAICQQFMDAAAAAAAAAACEBJoaAAAAAAAAAAAgJNDUaKc2b96sa665Rt27d1dERITWr1/vsd4Yo/nz56tbt26KjY1VXl6e9u7d6zHmhx9+0A033KCEhAQlJSVp+vTpqq2tDeBRwE4rV67UJZdcooSEBCUkJCg3N1dvvvmmtf7YsWO66667dP755ys+Pl7XX3+9qqurPbZx4MABjR8/XnFxcUpJSVFBQYF+/PHHQB8KbPLII48oIiLC45GZmWmtJ4fwU4H63vr444912WWXKSYmRunp6Vq0aFFbHxoCpLCwUCNGjFCnTp2UkpKiiRMnas+ePR5j/PW5s2nTJg0bNkwOh0N9+/bV6tWr2/rwAFtRW8AX1BXwFXUFWovaAr6grggONDXaqbq6OmVlZWnFihXNrl+0aJH+/Oc/a9WqVSovL1fHjh2Vn5+vY8eOWWNuuOEG7dy5U8XFxXr99de1efNm3XbbbYE6BNisZ8+eWrhwoSoqKrR161ZdffXVmjBhgnbu3ClJuueee/Taa6/p5ZdfVmlpqb755htdd9111utPnDih8ePHq6mpSVu2bNGaNWu0evVqzZ8/365Dgg0uvvhiHTx40Hq899571jpyCD8ViO8tl8ulsWPHqnfv3qqoqNDixYv1yCOP6Omnn27z40PbKy0t1V133aV///vfKi4u1vHjxzV27FjV1dVZY/zxuVNVVaXx48frqquu0vbt2zVr1izdeuuteuuttwJ6vEAgUVvAF9QV8AfqCrQGtQV8QV0RJAzaPUlm3bp11nO3223S0tLM4sWLrWVHjhwxDofD/POf/zTGGPPpp58aSebDDz+0xrz55psmIiLCfP311wGLHcGlc+fO5m9/+5s5cuSIiYqKMi+//LK1bteuXUaSKSsrM8YYs2HDBhMZGWmcTqc1ZuXKlSYhIcE0NjYGPHYE3oIFC0xWVlaz68ghnE1bfW/99a9/NZ07d/bIn/vvv9/079+/jY8Idjh06JCRZEpLS40x/vvcmTNnjrn44os99jVp0iSTn5/f1ocEBAVqC/gDdQVag7oCvqC2gK+oK+zBTA2cpqqqSk6nU3l5edayxMRE5eTkqKysTJJUVlampKQkDR8+3BqTl5enyMhIlZeXBzxm2OvEiRNau3at6urqlJubq4qKCh0/ftwjhzIzM9WrVy+PHBo8eLBSU1OtMfn5+XK5XNZZWQh/e/fuVffu3XXBBRfohhtu0IEDBySJHEKr+Ot7q6ysTJdffrmio6OtMfn5+dqzZ48OHz4coKNBoNTU1EiSunTpIsl/nztlZWUe2zg15tQ2gPaG2gKtQV2Bc0VdAX+htkBrUVfYg6YGTuN0OiXJ44116vmpdU6nUykpKR7rzzvvPHXp0sUag/D3ySefKD4+Xg6HQ3fccYfWrVungQMHyul0Kjo6WklJSR7jf55DzeXYqXUIfzk5OVq9erWKioq0cuVKVVVV6bLLLtPRo0fJIbSKv763yKn2w+12a9asWRo1apQGDRokSX773DnTGJfLpYaGhrY4HCCoUVvAG9QV8AV1BfyJ2gKtQV1hn/PsDgBA6Orfv7+2b9+umpoavfLKK5o6dapKS0vtDgshYty4cda/L7nkEuXk5Kh379566aWXFBsba2NkAMLdXXfdpR07dnhcbxsAYB/qCviCugKAXagr7MNMDZwmLS1NklRdXe2xvLq62lqXlpamQ4cOeaz/8ccf9cMPP1hjEP6io6PVt29fZWdnq7CwUFlZWfrTn/6ktLQ0NTU16ciRIx7jf55DzeXYqXVof5KSknTRRRdp37595BBaxV/fW+RU+zBz5ky9/vrreuedd9SzZ09rub8+d840JiEhgf+xgnaJ2gLeoK6AP1FXwBfUFvAWdYW9aGrgNBkZGUpLS1NJSYm1zOVyqby8XLm5uZKk3NxcHTlyRBUVFdaYt99+W263Wzk5OQGPGcHB7XarsbFR2dnZioqK8sihPXv26MCBAx459Mknn3j8ECguLlZCQoIGDhwY8Nhhv9raWn3++efq1q0bOYRW8df3Vm5urjZv3qzjx49bY4qLi9W/f3917tw5QEeDtmKM0cyZM7Vu3Tq9/fbbysjI8Fjvr8+d3Nxcj22cGnNqG0B7Q22Bc0FdAV9QV8AX1BZoCXVFkLD7TuWwx9GjR822bdvMtm3bjCSzdOlSs23bNvPll18aY4xZuHChSUpKMq+++qr5+OOPzYQJE0xGRoZpaGiwtvGrX/3KDB061JSXl5v33nvP9OvXz0yZMsWuQ0KAzZ0715SWlpqqqirz8ccfm7lz55qIiAizceNGY4wxd9xxh+nVq5d5++23zdatW01ubq7Jzc21Xv/jjz+aQYMGmbFjx5rt27eboqIi07VrVzNv3jy7DgkBdu+995pNmzaZqqoq8/7775u8vDyTnJxsDh06ZIwhh+ApEN9bR44cMampqeamm24yO3bsMGvXrjVxcXHmqaeeCvjxwv/uvPNOk5iYaDZt2mQOHjxoPerr660x/vjc+eKLL0xcXJwpKCgwu3btMitWrDAdOnQwRUVFAT1eIJCoLeAL6gr4iroCrUVtAV9QVwQHmhrt1DvvvGMknfaYOnWqMcYYt9ttHn74YZOammocDocZM2aM2bNnj8c2vv/+ezNlyhQTHx9vEhISzLRp08zRo0dtOBrY4ZZbbjG9e/c20dHRpmvXrmbMmDFW4WGMMQ0NDea3v/2t6dy5s4mLizPXXnutOXjwoMc29u/fb8aNG2diY2NNcnKyuffee83x48cDfSiwyaRJk0y3bt1MdHS06dGjh5k0aZLZt2+ftZ4cwk8F6nvro48+MqNHjzYOh8P06NHDLFy4MFCHiDbWXP5IMs8++6w1xl+fO++8844ZMmSIiY6ONhdccIHHPoBwRG0BX1BXwFfUFWgtagv4groiOEQYY0zbzgUBAAAAAAAAAADwHffUAAAAAAAAAAAAIYGmBgAAAAAAAAAACAk0NQAAAAAAAAAAQEigqQEAAAAAAAAAAEICTQ0AAAAAAAAAABASaGoAAAAAAAAAAICQQFMDAAAAAAAAAACEBJoaAAAAAAAAAAAgJNDUAAAAAAAAAAAAIYGmBgAAAAAAAAAACAk0NQAAp7nyyis1a9askN1vS9vxdj/ff/+9UlJStH//fmuZMUZLly5VRkaG4uLiNHHiRNXU1EiSJk+erCVLlvgYPQAAABAeqCtOoq4AAP+iqQEA7UxERMRZH4888ojdIQaNJ554QhMmTFCfPn2sZQUFBVq5cqXWrFmjd999VxUVFdbf7KGHHtITTzxhFSMAAABAuKKu8B51BQD4F00NAGhnDh48aD2WLVumhIQEj2X33XffOW23qanJz5Haq76+Xn//+981ffp0a1l5ebmWLl2qF198UZdffrmys7M1Y8YMbdiwQZI0aNAgXXjhhXr++eftChsAAAAICOoK71BXAID/0dQAgHYmLS3NeiQmJioiIsJjWXx8vCTJ7XZrzpw56tKli9LS0k470+rKK6/UzJkzNWvWLCUnJys/P19ut1uFhYXKyMhQbGyssrKy9Morr3i87pVXXtHgwYMVGxur888/X3l5eaqrq7PWt7TfxsZG/f73v1dKSopiYmI0evRoffjhh2c83rq6Ot18882Kj49Xt27dvJ7GvWHDBjkcDl166aXWsieffFJjxozRsGHDrGWpqan67rvvrOfXXHON1q5d69U+AAAAgFBFXUFdAQB2oakBAGjWmjVr1LFjR5WXl2vRokV67LHHVFxcfNqY6Ohovf/++1q1apUKCwv13HPPadWqVdq5c6fuuece3XjjjSotLZV08myuKVOm6JZbbtGuXbu0adMmXXfddTLGeL3fOXPm6F//+pfWrFmjyspK9e3bV/n5+frhhx+aPY6CggKVlpbq1Vdf1caNG7Vp0yZVVla2ePzvvvuusrOzreeNjY164403dO2113qMO3bsmBITE63nI0eO1AcffKDGxsYW9wEAAACEO+oK6goA8DsDAGi3nn32WZOYmHja8iuuuMKMHj3aY9mIESPM/fff7zFm6NCh1vNjx46ZuLg4s2XLFo/XTZ8+3UyZMsUYY0xFRYWRZPbv399sPC3tt7a21kRFRZkXXnjBWt/U1GS6d+9uFi1a5LGdu+++2xw9etRER0ebl156yVr3/fffm9jYWHP33Xc3G8MpEyZMMLfccov1fMuWLUaSiYmJMR07drQe0dHRJj8/3xr30UcfnfUYAQAAgHBDXXFm1BUA4H/n2dlQAQAEr0suucTjebdu3XTo0CGPZT8942jfvn2qr6/XL3/5S48xTU1NGjp0qCQpKytLY8aM0eDBg5Wfn6+xY8fqN7/5jTp37uzVfj///HMdP35co0aNstZHRUVp5MiR2rVr12nH8Pnnn6upqUk5OTnWsi5duqh///4tHn9DQ4NiYmKs55999pk6duyo7du3e4wbP368RzyxsbGSTl47FwAAAGjvqCuoKwDA32hqAACaFRUV5fE8IiJCbrfbY1nHjh2tf9fW1kqS3njjDfXo0cNjnMPhkCR16NBBxcXF2rJlizZu3Kjly5frwQcfVHl5uTIyMrzebyAkJyfr8OHD1nOXy6Xk5GT17dvXWvbll19q7969uv76661lp6ard+3aNXDBAgAAAEGKuoK6AgD8jXtqAAD8YuDAgXI4HDpw4ID69u3r8UhPT7fGRUREaNSoUXr00Ue1bds2RUdHa926dV7t48ILL7SutXvK8ePH9eGHH2rgwIHNjo+KilJ5ebm17PDhw/rss89a3NfQoUP16aefWs+Tk5NVU1PjcZ3eJ554Qr/+9a899r1jxw717NlTycnJXh0TAAAAgP+irjiJugIAzoyZGgAAv+jUqZPuu+8+3XPPPXK73Ro9erRqamr0/vvvKyEhQVOnTlV5eblKSko0duxYpaSkqLy8XN9++60GDBjg1T46duyoO++8UwUFBerSpYt69eqlRYsWqb6+XtOnTz9tfHx8vKZPn66CggKdf/75SklJ0YMPPqjIyJZ7+vn5+Zo3b54OHz6szp076+qrr9axY8e0cOFCTZ48WS+88IJee+01ffDBBx6ve/fddzV27Fjv/mgAAAAAPFBXnERdAQBnRlMDAOA3jz/+uLp27arCwkJ98cUXSkpK0rBhw/TAAw9IkhISErR582YtW7ZMLpdLvXv31pIlSzRu3Div97Fw4UK53W7ddNNNOnr0qIYPH6633nrL4/q5P7V48WLV1tbqmmuuUadOnXTvvfeqpqamxf0MHjxYw4YN00svvaTbb79dqampWr16tQoKCvT444/r6quv1nvvvedxttixY8e0fv16FRUVeX08AAAAADxRV1BXAMDZRJifzncDAACWN954QwUFBdqxY4dXZ2GtXLlS69at08aNGwMQHQAAAIBQQF0BAP7FTA0AAM5g/Pjx2rt3r77++muPM6fOJCoqSsuXLw9AZAAAAABCBXUFAPgXMzUAAAAAAAAAAEBIaHnOGwAAAAAAAAAAQBCgqQEAAAAAAAAAAEICTQ0AAAAAAAAAABASaGoAAAAAAAAAAICQQFMDAAAAAAAAAACEBJoaAAAAAAAAAAAgJNDUAAAAAAAAAAAAIYGmBgAAAAAAAAAACAk0NQAAAAAAAAAAQEj4P1ttRdaIndHmAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1600x900 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Update the plot with improved titles and axis labels\n",
    "fig, axs = plt.subplots(2, 2, figsize=(16, 9))\n",
    "axs = axs.flatten()\n",
    "\n",
    "# Titles for the plots\n",
    "titles = [\n",
    "    'Segmentation Count Before Hierarchy',\n",
    "    'Segmentation Count After Hierarchy',\n",
    "    'Final Segmentation Count After Hierarchy',\n",
    "    'Empty Space Proportion'\n",
    "]\n",
    "metrics = ['before_hierachy', 'after_hierachy', 'final_hierachy', 'empty_space']\n",
    "thresholds = list(data.keys())\n",
    "\n",
    "# Plot IQR for each metric with improved titles and labels\n",
    "for i, metric in enumerate(metrics):\n",
    "    values = [data[th][metric] for th in thresholds]\n",
    "    axs[i].boxplot(values, labels=thresholds)\n",
    "    axs[i].set_title(titles[i])\n",
    "    axs[i].set_xlabel('Threshold ($\\\\theta$)')\n",
    "    axs[i].set_ylabel('Segmentation Count' if metric != 'empty_space' else 'Proportion')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
