{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import torch.multiprocessing as mp\n",
    "import torch.distributed as dist\n",
    "from torch.nn.parallel import DistributedDataParallel\n",
    "from torch.utils.tensorboard import SummaryWriter\n",
    "import pytorch_lightning as pl\n",
    "import random\n",
    "import dotenv\n",
    "import omegaconf\n",
    "import hydra\n",
    "import logging\n",
    "import wandb\n",
    "from datetime import date\n",
    "import dotenv\n",
    "import os\n",
    "import pathlib\n",
    "from typing import Dict, Any\n",
    "from copy import deepcopy\n",
    "\n",
    "from utils_eval import get_num_allzero_filters, get_num_allzero_fanout, get_num_allzero_kernels, get_num_kernels\n",
    "\n",
    "from rigl_torch.models import ModelFactory\n",
    "from rigl_torch.rigl_scheduler import RigLScheduler\n",
    "from rigl_torch.rigl_constant_fan import RigLConstFanScheduler\n",
    "from rigl_torch.datasets import get_dataloaders\n",
    "from rigl_torch.optim import (\n",
    "    get_optimizer,\n",
    "    get_lr_scheduler,\n",
    ")\n",
    "from rigl_torch.utils.checkpoint import Checkpoint\n",
    "from rigl_torch.utils.rigl_utils import get_T_end, get_fan_in_after_ablation, get_conv_idx_from_flat_idx\n",
    "from hydra import initialize, compose\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "resnet18\n"
     ]
    }
   ],
   "source": [
    "with initialize(\"../configs\", version_base=\"1.2.0\"):\n",
    "    cfg = compose(\n",
    "        \"config.yaml\",\n",
    "        overrides=[\n",
    "            \"dataset=cifar10\",\n",
    "            \"compute.distributed=False\",\n",
    "            \"model=resnet18\"\n",
    "            ])\n",
    "dotenv.load_dotenv(\"../.env\")\n",
    "os.environ[\"IMAGE_NET_PATH\"]\n",
    "print(cfg.model.name)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:rigl_torch.utils.checkpoint:Loading checkpoint from /Users/annago/Desktop/current_projects/work_w_UCalgary/checkpointsA/20221208_us1p7psr/checkpoint.pt.tar...\n",
      "Global seed set to 42\n",
      "INFO:/Users/annago/Desktop/current_projects/work_w_UCalgary/condensed-sparsity/src/rigl_torch/models/model_factory.py:Loading model resnet18/cifar10 using <function ResNet18 at 0x16c9feca0> with args: () and kwargs: {}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loading to device rank: 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:rigl_torch.utils.checkpoint:Loading checkpoint from /Users/annago/Desktop/current_projects/work_w_UCalgary/checkpointsA/20230111_ma4j6ft9/checkpoint.pt.tar...\n",
      "Global seed set to 6037\n",
      "INFO:/Users/annago/Desktop/current_projects/work_w_UCalgary/condensed-sparsity/src/rigl_torch/models/model_factory.py:Loading model resnet18/cifar10 using <function ResNet18 at 0x16c9feca0> with args: () and kwargs: {}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loading to device rank: 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:rigl_torch.utils.checkpoint:Loading checkpoint from /Users/annago/Desktop/current_projects/work_w_UCalgary/checkpointsA/20230112_f75f6a5m/checkpoint.pt.tar...\n",
      "Global seed set to 42\n",
      "INFO:/Users/annago/Desktop/current_projects/work_w_UCalgary/condensed-sparsity/src/rigl_torch/models/model_factory.py:Loading model resnet18/cifar10 using <function ResNet18 at 0x16c9feca0> with args: () and kwargs: {}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loading to device rank: 0\n"
     ]
    }
   ],
   "source": [
    "run_ids= [\"us1p7psr\", \"ma4j6ft9\", \"f75f6a5m\"]\n",
    "# ['20230112_8yltfx1b', '20230112_d17iii70']\n",
    "# [\"20230112_2jjmdzam\", \"20230112_37my33se\", \"20230112_4d3flaxi\", \"20230112_f75f6a5m\", \"20230112_tkcz3emd\"]\n",
    "#run_id = \"us1p7psr\" # us1p7psr (no dyn ablation), 8m2ytv3b (0.01), ek5wjcyn (0.1), ma4j6ft9 (0.3), f75f6a5m (0.5)\n",
    "\n",
    "rank=0\n",
    "ckpt_path=\"/Users/annago/Desktop/current_projects/work_w_UCalgary/checkpointsA\"\n",
    "NumZeroFilters={}\n",
    "NumZeroFanOut={}\n",
    "zkn={}\n",
    "zkf={}\n",
    "sparsity={}\n",
    "masks={}\n",
    "\n",
    "for run_id in run_ids:\n",
    "    checkpoint = Checkpoint.load_last_checkpoint(run_id=run_id, parent_dir = ckpt_path)\n",
    "    #checkpoint=None\n",
    "    if checkpoint is not None:\n",
    "        run_id = checkpoint.run_id\n",
    "        optimizer_state = checkpoint.optimizer\n",
    "        scheduler_state = checkpoint.scheduler\n",
    "        pruner_state = checkpoint.pruner\n",
    "        model_state = checkpoint.model\n",
    "        cfg = checkpoint.cfg\n",
    "    else:\n",
    "        run_id, optimizer_state, scheduler_state, pruner_state, model_state = (\n",
    "            None,\n",
    "            None,\n",
    "            None,\n",
    "            None,\n",
    "            None,\n",
    "        )\n",
    "\n",
    "\n",
    "        # cfg.compute.distributed=False\n",
    "        \n",
    "    pl.seed_everything(cfg.training.seed)\n",
    "    use_cuda = not cfg.compute.no_cuda and torch.cuda.is_available()\n",
    "    # if not use_cuda:\n",
    "    #     raise SystemError(\"GPU has stopped responding...waiting to die!\")\n",
    "    #     logger.warning(\n",
    "    #         \"Using CPU! Verify cfg.compute.no_cuda and \"\n",
    "    #         \"torch.cuda.is_available() are properly set if this is unexpected\"\n",
    "    #     )\n",
    "\n",
    "\n",
    "    if cfg.compute.distributed and use_cuda:\n",
    "        device = torch.device(f\"cuda:{rank}\")\n",
    "    else:\n",
    "        print(f\"loading to device rank: {rank}\")\n",
    "        device = torch.device(f\"cuda:{rank}\")\n",
    "    if not use_cuda:\n",
    "        device = torch.device(\"cuda\" if use_cuda else \"cpu\")\n",
    "    # train_loader, test_loader = get_dataloaders(cfg)\n",
    "\n",
    "    model = ModelFactory.load_model(\n",
    "        model=cfg.model.name, dataset=cfg.dataset.name\n",
    "    )\n",
    "    model.to(device)\n",
    "    if cfg.compute.distributed:\n",
    "        model = DistributedDataParallel(model, device_ids=[rank])\n",
    "    if model_state is not None:\n",
    "        try:\n",
    "            model.load_state_dict(model_state)\n",
    "        except RuntimeError:\n",
    "            model_state = checkpoint.get_single_process_model_state_from_distributed_state()\n",
    "            model.load_state_dict(model_state)\n",
    "            \n",
    "    optimizer = get_optimizer(cfg, model, state_dict=optimizer_state)\n",
    "    scheduler = get_lr_scheduler(cfg, optimizer, state_dict=scheduler_state)\n",
    "    pruner = None\n",
    "    if cfg.rigl.dense_allocation is not None:\n",
    "        T_end = get_T_end(cfg, [0 for _ in range(0,1251)])\n",
    "        if cfg.rigl.const_fan_in:\n",
    "            rigl_scheduler = RigLConstFanScheduler\n",
    "        else:\n",
    "            rigl_scheduler = RigLScheduler\n",
    "        pruner = rigl_scheduler(\n",
    "            model,\n",
    "            optimizer,\n",
    "            dense_allocation=cfg.rigl.dense_allocation,\n",
    "            alpha=cfg.rigl.alpha,\n",
    "            delta=cfg.rigl.delta,\n",
    "            static_topo=cfg.rigl.static_topo,\n",
    "            T_end=T_end,\n",
    "            ignore_linear_layers=cfg.rigl.ignore_linear_layers,\n",
    "            grad_accumulation_n=cfg.rigl.grad_accumulation_n,\n",
    "            sparsity_distribution=cfg.rigl.sparsity_distribution,\n",
    "            erk_power_scale=cfg.rigl.erk_power_scale,\n",
    "            state_dict=pruner_state,\n",
    "            filter_ablation_threshold=cfg.rigl.filter_ablation_threshold,\n",
    "            static_ablation=cfg.rigl.static_ablation,\n",
    "            dynamic_ablation=cfg.rigl.dynamic_ablation,\n",
    "            min_salient_weights_per_neuron=cfg.rigl.min_salient_weights_per_neuron,  # noqa\n",
    "            use_sparse_init=cfg.rigl.use_sparse_initialization,\n",
    "            init_method_str=cfg.rigl.init_method_str,\n",
    "            use_sparse_const_fan_in_for_ablation=cfg.rigl.use_sparse_const_fan_in_for_ablation,  # noqa\n",
    "        )\n",
    "        \n",
    "        step=0\n",
    "        \n",
    "        checkpoint = Checkpoint(\n",
    "                    run_id=run_id,\n",
    "                    cfg=cfg,\n",
    "                    model=model,\n",
    "                    optimizer=optimizer,\n",
    "                    scheduler=scheduler,\n",
    "                    pruner=pruner,\n",
    "                    epoch=0,\n",
    "                    step=step,\n",
    "                    parent_dir=ckpt_path,\n",
    "                )\n",
    "\n",
    "    NumZeroFilters[run_id]= []\n",
    "    NumZeroFanOut[run_id]= []\n",
    "\n",
    "    for i, w in enumerate(pruner.W):\n",
    "        if pruner.S[i]>0:\n",
    "            num_zero_filters= get_num_allzero_filters(w)\n",
    "            num_zero_fanout = get_num_allzero_fanout(w)\n",
    "        else:\n",
    "            num_zero_filters=0\n",
    "            num_zero_fanout=0\n",
    "        NumZeroFilters[run_id].append(num_zero_filters)\n",
    "        NumZeroFanOut[run_id].append(num_zero_fanout)\n",
    "\n",
    "    sparsity[run_id]=pruner.S\n",
    "\n",
    "    masks[run_id]= pruner.backward_masks\n",
    "\n",
    "    zkf[run_id]= []\n",
    "    zkn[run_id]= []\n",
    "\n",
    "    for i, w in enumerate(pruner.W):\n",
    "        if pruner.S[i]>0:\n",
    "            zero_kernel_fract= get_num_allzero_kernels(w)/get_num_kernels(w)\n",
    "            num_allzero_kernels= get_num_allzero_kernels(w)\n",
    "        else:\n",
    "            zero_kernel_fract=0\n",
    "            num_allzero_kernels=0\n",
    "        zkf[run_id].append(zero_kernel_fract)\n",
    "        zkn[run_id].append(num_allzero_kernels)\n",
    "\n",
    "\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_layers= len(pruner.W)\n",
    "layer_inds=[]\n",
    "\n",
    "for layer_idx in range(num_layers):\n",
    "    if pruner.W[layer_idx].shape[-1]==3:\n",
    "        layer_inds.append(layer_idx)\n",
    "        \n",
    "\n",
    "# check for zero fan-in and fan-out\n",
    "\n",
    "num_layers= len(pruner.W)\n",
    "num_disconnected_neurons={}\n",
    "\n",
    "for l in range(len(layer_inds)-1):\n",
    "    \n",
    "    w1= pruner.W[layer_inds[l]]\n",
    "    w2= pruner.W[layer_inds[l+1]]\n",
    "\n",
    "    num_neurons= w1.shape[0]\n",
    "    count=0\n",
    "    for neuron_idx in range(num_neurons):\n",
    "        if w2[:,neuron_idx,:,:].any()==False and w1[neuron_idx,:,:,:].any()==False:\n",
    "            count+=1\n",
    "    \n",
    "    num_disconnected_neurons[layer_inds[l]]=count\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_disconnected_neurons"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "run_id= \"f75f6a5m\"\n",
    "\n",
    "num_layers= len(masks[run_id])\n",
    "for layer_ind in range(num_layers):\n",
    "    if masks[run_id][layer_ind] is not None:\n",
    "        s= masks[run_id][layer_ind].shape\n",
    "    else:\n",
    "        s='None'\n",
    "    print(layer_ind, s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "MaskNumZeroFilters={}\n",
    "MaskNumZeroFanOut={}\n",
    "\n",
    "for run_id in run_ids:\n",
    "    MaskNumZeroFilters[run_id]= []\n",
    "    MaskNumZeroFanOut[run_id]= []\n",
    "    for i, w in enumerate(masks[run_id]):\n",
    "        if sparsity[run_id][i]>0:\n",
    "            num_zero_filters= get_num_allzero_filters(w)\n",
    "            num_zero_fanout = get_num_allzero_fanout(w)\n",
    "        else:\n",
    "            num_zero_filters=0\n",
    "            num_zero_fanout=0\n",
    "        MaskNumZeroFilters[run_id].append(num_zero_filters)\n",
    "        MaskNumZeroFanOut[run_id].append(num_zero_fanout)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# masks= checkpoint.pruner.backward_masks\n",
    "# num_layers= len(masks)\n",
    "# for layer_ind in range(num_layers):\n",
    "#     if masks[layer_ind] is not None:\n",
    "#         s= masks[layer_ind].shape\n",
    "#     else:\n",
    "#         s='None'\n",
    "#     print(layer_ind, s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_children(model: torch.nn.Module):\n",
    "    # get children form model!\n",
    "    children = list(model.children())\n",
    "    flatt_children = []\n",
    "    if children == []:\n",
    "        # if model has no children; model is last child! :O\n",
    "        return model\n",
    "    else:\n",
    "       # look for children from children... to the last child!\n",
    "       for child in children:\n",
    "            try:\n",
    "                flatt_children.extend(get_children(child))\n",
    "            except TypeError:\n",
    "                flatt_children.append(get_children(child))\n",
    "    return flatt_children"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "flatM= get_children(M)\n",
    "\n",
    "j=0\n",
    "for i, layer in enumerate(flatM):\n",
    "    if isinstance(layer, (torch.nn.Conv2d,torch.nn.AvgPool2d)):\n",
    "        print(j, layer, \"   \", masks[j].shape)\n",
    "        j+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%matplotlib inline\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "\n",
    "plot_savedir = '/Users/annago/Desktop/'\n",
    "cmap = matplotlib.cm.get_cmap('gnuplot2') # rainbow\n",
    "\n",
    "x=3.5\n",
    "title_font_size=6*x\n",
    "label_font_size=5.5*x\n",
    "tick_font_size=5*x\n",
    "legend_font_size=22*x/6\n",
    "legend_title_font_size=22*x/6\n",
    "\n",
    "# ==== plot styling\n",
    "plotparams = {'savefig.dpi': 300,\n",
    "              'text.usetex': True,\n",
    "              'font.family': 'serif',\n",
    "              'legend.fontsize': legend_font_size,\n",
    "              'legend.title_fontsize': legend_title_font_size,\n",
    "              'axes.labelsize': label_font_size,\n",
    "              'axes.titlesize': title_font_size,\n",
    "              'xtick.labelsize': tick_font_size,\n",
    "              'ytick.labelsize': tick_font_size,\n",
    "              'axes.grid': True,\n",
    "              'axes.grid.axis': 'both',\n",
    "              'axes.grid.which': 'both',\n",
    "              'grid.alpha': 0.5,\n",
    "              'grid.color': '#b0b0b0',\n",
    "              'grid.linestyle': '-',\n",
    "              'grid.linewidth': 0.8}\n",
    "plt.style.use(plotparams)\n",
    "import matplotlib as mpl\n",
    "mpl.rcParams.update(mpl.rcParamsDefault)\n",
    "\n",
    "\n",
    "def label_bars(ax, bars, text_format, **kwargs):\n",
    "    \"\"\"\n",
    "    Attaches a label on every bar of a regular or horizontal bar chart\n",
    "    \"\"\"\n",
    "    ys = [bar.get_y() for bar in bars]\n",
    "    y_is_constant = all(y == ys[0] for y in ys)  # -> regular bar chart, since all bars start on the same y level (0)\n",
    "\n",
    "    if y_is_constant:\n",
    "        _label_bar(ax, bars, text_format, **kwargs)\n",
    "    else:\n",
    "        _label_barh(ax, bars, text_format, **kwargs)\n",
    "\n",
    "\n",
    "def _label_bar(ax, bars, text_format, **kwargs):\n",
    "    \"\"\"\n",
    "    Attach a text label to each bar displaying its y value\n",
    "    \"\"\"\n",
    "    max_y_value = ax.get_ylim()[1]\n",
    "    inside_distance = max_y_value * 0.05\n",
    "    outside_distance = max_y_value * 0.01\n",
    "\n",
    "    for bar in bars:\n",
    "        text = text_format.format(bar.get_height())\n",
    "        text_x = bar.get_x() + bar.get_width() / 2\n",
    "\n",
    "        is_inside = bar.get_height() >= max_y_value * 0.15\n",
    "        if is_inside:\n",
    "            color = \"white\"\n",
    "            text_y = bar.get_height() - inside_distance\n",
    "        else:\n",
    "            color = \"black\"\n",
    "            text_y = bar.get_height() + outside_distance\n",
    "\n",
    "        ax.text(text_x, text_y, text, ha='center', va='bottom', color=color, **kwargs)\n",
    "\n",
    "\n",
    "def _label_barh(ax, bars, text_format, **kwargs):\n",
    "    \"\"\"\n",
    "    Attach a text label to each bar displaying its y value\n",
    "    Note: hacky ad-hoc solution to adjust text position inside/outside the bars.\n",
    "    \"\"\"\n",
    "    max_x_value = ax.get_xlim()[1]\n",
    "    distance = max_x_value * 0.15\n",
    "\n",
    "    for bar in bars:\n",
    "        text = text_format.format(bar.get_width())\n",
    "        \n",
    "        bwidth = bar.get_width()\n",
    "        if bwidth<distance: \n",
    "            text_x= bwidth + distance/4\n",
    "        else: \n",
    "            text_x= bwidth + distance/4\n",
    "            \n",
    "        text_y= bar.get_y() + bar.get_height() / 2\n",
    "\n",
    "        if bwidth>0: # do not print zero values\n",
    "            if bwidth==max_x_value:\n",
    "                ax.text(text_x-70, text_y, text, va='center', **kwargs)\n",
    "            else:\n",
    "                ax.text(text_x, text_y, text, va='center', **kwargs)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/n4/8l3wyv69321f4xp28b53dc240000gn/T/ipykernel_60284/136258565.py:1: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated since Python 3.3, and in 3.10 it will stop working\n",
      "  from collections import MutableMapping\n"
     ]
    }
   ],
   "source": [
    "from collections import MutableMapping\n",
    "def flatten(d, parent_key='', sep='_'):\n",
    "\titems = []\n",
    "\tfor k, v in d.items():\n",
    "\t\tnew_key = parent_key + sep + k if parent_key else k\n",
    "\t\tif isinstance(v, MutableMapping):\n",
    "\t\t\titems.extend(flatten(v, new_key, sep=sep).items())\n",
    "\t\telse:\n",
    "\t\t\titems.append((new_key, v))\n",
    "\treturn dict(items)\n",
    "\t\n",
    "def get_tensor_dims(model, ltypes):\n",
    "\t\"\"\" Makes dict tensor_dims containing the dimensions of each layer tensor. \"\"\"\n",
    "\ttensor_dims= {}\n",
    "\tfill_tensor_dims(model, ltypes, tensor_dims)\n",
    "\ttensor_dims= flatten(tensor_dims)\n",
    "\treturn tensor_dims\n",
    "\n",
    "\n",
    "def fill_tensor_dims(model, ltypes, tensor_dims):\n",
    "\t\"\"\" Fills the dict tensor_dims with the dims of each layer of type specified in ltypes \n",
    "\tin the given model. \"\"\"   \n",
    "\tfor lname, child in model.named_children():\n",
    "\t\tltype = child._get_name()\n",
    "\n",
    "\t\tif ltype in ltypes:\n",
    "\t\t\ttensor_dims[lname] = list(child.weight.shape)\n",
    "\t\telse:\n",
    "\t\t\ttensor_dims[lname] = {}\n",
    "\t\t\tfill_tensor_dims(child, ltypes, tensor_dims[lname])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "ltypes=['Linear', 'Conv2d']\n",
    "tdims= get_tensor_dims(model, ltypes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(\"orig.width - abl.neurons = remaining width\")\n",
    "for i in range(len(NumZeroFilters[run_id])-1):\n",
    "    num_out_dense= pruner.W[i].shape[0]\n",
    "    num_out_gone= NumZeroFilters[run_id][i]\n",
    "    num_out_left= pruner.W[i].shape[0]-NumZeroFilters[run_id][i]\n",
    "    print(f\"{num_out_dense} - {num_out_gone} = {num_out_left} ({100*num_out_left/num_out_dense:.1f} %)\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "run_ids"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "la= {'us1p7psr': 'no abl.', '8m2ytv3b': 'abl.t.=0.01', 'ek5wjcyn': 'abl.t.=0.1', 'ma4j6ft9': 'abl.t.=30%', 'f75f6a5m': 'abl.t.=50%'}\n",
    "ma= {'us1p7psr': 'x', \n",
    "'8m2ytv3b': 'o', \n",
    "'ek5wjcyn': 'o', \n",
    "'f75f6a5m': 'o'}\n",
    "ma_size=6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_fig= True\n",
    "fig_savename= 'combined'\n",
    "\n",
    "fig, axs = plt.subplots(1,4, figsize=(12,2.5))\n",
    "\n",
    "\n",
    "ax=axs[0]\n",
    "for run_id in run_ids:\n",
    "    v= sparsity[run_id]\n",
    "    ax.plot(v[:-1], label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.legend()\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('sparsity')\n",
    "ax.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "ax=axs[1]\n",
    "for run_id in run_ids:\n",
    "    v= zkf[run_id]\n",
    "    ax.plot(v[:-1], label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('fraction all-zero kernels')\n",
    "ax.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "\n",
    "ax=axs[2]\n",
    "for run_id in run_ids:\n",
    "    v= NumZeroFilters[run_id]\n",
    "    p= [v[i]/pruner.W[i].shape[0] for i in range(len(v))]\n",
    "    ax.plot(p[:-1], label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('fraction all-zero neurons')\n",
    "\n",
    "\n",
    "ax=axs[3]\n",
    "for run_id in run_ids:\n",
    "    v= NumZeroFanOut[run_id]\n",
    "    p= [v[i]/pruner.W[i].shape[1] for i in range(len(v))]\n",
    "    ax.plot(p[:-1], label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('fraction all-zero fan-out')\n",
    "\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "if save_fig:\n",
    "    fig.savefig(plot_savedir+fig_savename+'.png', format='png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_fig= True\n",
    "fig_savename= 'zero_kernel_fract'\n",
    "\n",
    "fig, ax = plt.subplots(1,1, figsize=(6,4))\n",
    "\n",
    "for run_id in run_ids:\n",
    "    v= zkf[run_id]\n",
    "    ax.plot(v, label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.legend()\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('fraction all-zero kernels')\n",
    "ax.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "plt.show()\n",
    "if save_fig:\n",
    "    fig.savefig(plot_savedir+fig_savename+'.png', format='png', bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_fig= True\n",
    "fig_savename= 'zero_neurons_fract'\n",
    "\n",
    "fig, ax = plt.subplots(1,1, figsize=(6,4))\n",
    "\n",
    "for run_id in run_ids:\n",
    "    v= NumZeroFilters[run_id]\n",
    "    p= [v[i]/pruner.W[i].shape[0] for i in range(len(v))]\n",
    "    ax.plot(p, label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.legend()\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('fraction all-zero neurons')\n",
    "\n",
    "plt.show()\n",
    "if save_fig:\n",
    "    fig.savefig(plot_savedir+fig_savename+'.png', format='png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_fig= True\n",
    "fig_savename= 'sparsity'\n",
    "\n",
    "fig, ax = plt.subplots(1,1, figsize=(6,4))\n",
    "\n",
    "for run_id in run_ids:\n",
    "    v= sparsity[run_id]\n",
    "    ax.plot(v, label=la[run_id], linestyle='', marker=ma[run_id], markersize=ma_size, markerfacecolor='none')\n",
    "\n",
    "ax.legend()\n",
    "ax.set_xlabel('layer index')\n",
    "ax.set_ylabel('sparsity')\n",
    "\n",
    "ax.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "plt.show()\n",
    "if save_fig:\n",
    "    fig.savefig(plot_savedir+fig_savename+'.png', format='png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Style sheet: \n",
    "style = \"\"\"\n",
    "# Figure properties\n",
    "figure.figsize: 10, 6 # figure size in inches\n",
    "\n",
    "# Font properties\n",
    "font.size: 16 # Size of the font\n",
    "font.family: sans-serif # Type of Font\n",
    "font.sans-serif : \"DejaVu Sans\"\n",
    "\n",
    "\n",
    "# Axes properties\n",
    "axes.linewidth: 2  # edge linewidth\n",
    "axes.labelpad: 8   # space between label and axis\n",
    "axes.prop_cycle: cycler(color=['00a5bb','f79141','499585', 'd81e52', '6cb2c5' , '6c77c5', 'c5ba6c', '56ce93', 'd88fBf', 'ffd505']) # color cycle for plot lines\n",
    "axes.titlepad: 20.0    # pad between axes and title in points\n",
    "axes.labelsize: 16     # Axes labels size\n",
    "axes.titlesize: 20     # Plot title size\n",
    "axes.labelweight: 500  # Axel Labels weight\n",
    "axes.titleweight: 500  # Axel Titleweight\n",
    "axes.edgecolor: 262626\n",
    "axes.labelcolor: 262626\n",
    "axes.titlecolor: 262626\n",
    "\n",
    "# Tick properties\n",
    "# x-axis\n",
    "xtick.direction: inout # direction: in, out, or inout\n",
    "xtick.major.size: 0 # major tick size in points\n",
    "xtick.major.width: 0 # major tick width in points\n",
    "xtick.minor.size: 0 # minor tick size in points\n",
    "xtick.minor.width: 0 # minor tick width in points\n",
    "xtick.major.pad : 10\n",
    "xtick.minor.pad: 10\n",
    "xtick.labelsize : 16\n",
    "\n",
    "# y-axis\n",
    "ytick.direction: inout # direction: in, out, or inout\n",
    "ytick.major.size: 0 # major tick size in points\n",
    "ytick.major.width: 0 # major tick width in points\n",
    "ytick.minor.size: 0 # minor tick size in points\n",
    "ytick.minor.width: 0 # minor tick width in points\n",
    "ytick.major.pad : 10\n",
    "ytick.minor.pad: 10\n",
    "ytick.labelsize : 16\n",
    "\n",
    "# Line properties\n",
    "lines.linewidth: 3.5\n",
    "\n",
    "# Legend properties\n",
    "legend.framealpha: 0.8  # opacity of legend frame\n",
    "legend.frameon: False   # whether or not to draw a frame around legend\n",
    "legend.fontsize: 14     # Font size of the legend\n",
    "legend.borderpad : 0\n",
    "#legend.borderaxespad: 1.5\n",
    "\n",
    "#Edge Color properties\n",
    "#patch.force_edgecolor: True #Edge color for the bars\n",
    "\"\"\"\n",
    "with open(\"plt_plot_style.mplstyle\", \"w\") as handle:\n",
    "  handle.write(style)\n",
    "\n",
    "plt.style.use(\"./plt_plot_style.mplstyle\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2kAAASUCAYAAAD9I0XvAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdeVxV1f7/8ddBZBBH1DTDORVvmqCgXEEFccihLMe0UlAr82tmX63QVCjzOtXvGw45peKQgBppiuWIOeKEYyaagLMkjuWAIPz+8HHO9XQOikpylPfz8eDxiLXXWvuzz1Xv/py112cbsrOzsxERERERERGbYJffAYiIiIiIiMh/KUkTERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIUrSREREREREbIiSNBERERERERtin98BiEju1KtXj1u3bmFnZ0fp0qXzOxwRERERseLChQtkZWXh4ODAvn37HmoOJWkiT4hbt26RlZVFVlYWqamp+R2OiIiIiNzDrVu3HnqskjSRJ4SdnR1ZWVnY2dlRtmzZ/A5HRERERKw4f/686Z7tYSlJE3lClC5dmtTUVMqWLcvGjRvzOxwRERERsaJp06akpqY+0vYUFQ4RERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERO6rSpUqVKlSJdf9IyIiMBgMRERE/GMxPa30MmsRERERsVmGhWvzO4QcZfdokd8hyFNKK2kiIiIiIiI2REmaiIiIiIiIDVGSJiIiIiKSTzZs2IDBYCAsLIxdu3bRsmVLihUrRokSJXjttddISUmxOm7Lli20a9cOV1dXnJyccHd3JzQ0lOvXr+f63Lt372bAgAHUqVOHEiVK4OzsTN26dRk7diwZGRk5jrt8+TLvvvsu5cuXx8nJCU9PTyIjIx/00uUelKSJiIiIiOSznTt30rRpUxwcHHj33Xfx8vJi6dKltGjRgps3b5r1Xbx4Mc2aNWPDhg28+uqrDBo0iCJFivD555/TvHlzi/45mTlzJj/88AN169bl3XffpU+fPmRnZzN06FBef/11q2Nu3bpFixYt+OWXX3jrrbfo3bs3J0+epEePHkyaNOmRPwe5Q4VDRERERETy2cqVK4mKiqJbt26mtp49ezJ//nyWLl1qSpquXr3K22+/jb29Pdu2bePFF18E4D//+Q89evQgOjqaCRMmMGLEiPuec9iwYUyZMoVChQqZ2rKzs+nbty+zZ89my5Yt+Pr6mo05e/YsNWrUYOvWrTg4OJjm8fT05KOPPqJjx44899xzj/x5FHRaSRMRERERyWdNmzY1S9AAevfuDdxZZTNatmwZV65coXfv3qYEDcDOzo7x48djb2+f65L3lSpVMkvQAAwGA//zP/8DwNq11itr/uc//zElaABubm588MEHpKenExUVlatzy70pSRMRERERyWcNGjSwaHNzcwPu7AEz2rNnDwD+/v4W/StVqkS1atVISkrizz//vO85b926xf/7f/+Phg0bUrx4cezs7DAYDKZYzpw5YzHG3t6ef//73xbtTZo0MYtPHo0edxQRERERyWfFixe3aLO3v3Orfvv2bVPb1atXAShXrpzVeZ599lmOHDnC1atXKVas2D3P2blzZ5YvX07NmjXp1q0bzzzzDIULF+by5cuEh4eTnp5uMaZMmTLY2Vmu8xjjuXLlyj3PKbmjJE1ERERE5AlhTOZSU1OtHj937pxZv5zs3LmT5cuX07p1a2JjY80ee4yPjyc8PNzquLS0NLKysiwSNWM8JUqUyN2FyD3pcUcRERERkSeEp6cncKd0/9+dPHmSY8eOUa1atfuuoh07dgyAdu3aWexL27RpU47jMjMz2bZtm0W7cYwxPnk0StJERERERJ4QHTp0oESJEsyZM4dff/3V1J6dnc0nn3xCZmYmQUFB952ncuXKAGzevNms/ddff2XMmDH3HDts2DBu3bpl+v3UqVOEh4fj6OiYY+n+u509e5bDhw/r0ch70OOOIiIiIiJPiOLFizNz5ky6d+9Oo0aN6NatG2XLlmXt2rXs3r2bhg0b8tFHH913noYNG9KwYUMWLVrE2bNn8fHx4cSJE/z444+0a9eOJUuWWB337LPPcu3aNV588UVefvllrl27xqJFi7hw4QITJ07MVfn9oUOHMnfuXObMmZOrhLIg0kqaiIiIiMgTpEuXLsTFxdG0aVNiYmL4v//7P/78809GjBjB+vXrcXJyuu8chQoVYsWKFfTu3Ztjx44xadIkDh06xJdffsn48eNzHOfg4MCaNWto1qwZ8+fPZ/bs2bi5ubFw4ULef//9vLzM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PFbLly9n165dPPvss3z//feULVvW7LiTkxNt27YF4MSJEyxevBiDwcCMGTMoXbq0qV/RokWZOXMmTk5ObN26la1bt1o936RJk6hZs6bp90KFCjF69GgAfvnlF7NVjW7dulGkSBHWrFnD6dOnzebJyMhgwYIFwJ3VOZG7FStWzPTf7777rsXxSpUqmVZf165dC8Do0aNJSEjgs88+o1atWo8nUBERkXvYsGEDBoOBsLCwx37usLAwDAZDjj85PTm1atUqmjVrRrFixShevDgBAQGsW7fOat8ff/wRDw8PihYtioeHBz/++KPVfr/++isODg4WW3AeJy0HyGP1888/A9CjRw+KFi16z74bN24kKyuL+vXr8+KLL1ocf+6552jdujXLli0jLi6Oxo0bmx23t7fnpZdeshhXvnx5SpUqxaVLl7hw4QLly5cH7txod+7cmXnz5jFv3jyGDh1qGhMbG8v58+dp2LAhL7zwwgNftzzdqlWrZvW/rfU5e/YsAD/88ANw54uLlStXmvU1/h9RbGws/v7+wJ3/4xQRKYjafvOf/A4hRyv7D7t/J3kgvXr1srryV7JkSYu2BQsW8NZbb1G2bFmCgoIAiI6OpmXLlixatIjOnTub+u7cuZNXX32VunXr0q9fP1atWsVrr73G9u3b8fLyMvXLysqib9++tGzZkh49euT15eWakjR5rI4fPw7c2QN2P8bVrKpVq+bYx1ho4e8rXwDPPvus2cuE71a8eHEuXbpkUSSkd+/ezJs3j4iICLMkzfioo1bRxJr69etjMBjIzs4mLS2NihUrWvRJS0sDsPhyYvPmzTnOe+7cOc6dO5e3wYqIiNiwoKAg0xeU93Lp0iXef/99ypQpQ0JCAm5ubgB88skneHp68t5779G6dWvT0y7ffvstJUuWZMuWLRQtWpSRI0dSuXJlvv32W7MkbfLkyRw8eJBff/31H7m+3NLjjvLUepg9Pk2bNqV69eocOXLE9AjlH3/8wcqVK3FycuL111/P6zDlKVC+fHn8/PyA/z7OeLeMjAx++eUXABo2bAjA3r17yc7OtvpjfBl2nz59TG0iIvJ0unXrFpMmTaJ169ZUrFgRR0dHnnnmGTp27MiePXtyHLds2TIaNmxIkSJFKFu2LL179yY1NfWh4wgLCyMgIACAzz77LFePGuanxYsXc/nyZd5//31TggZ3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a1fs7f+7vtS1a1dKlCjBpEmTTPUA4E5tgMmTJ1OmTBmr+8+Mdu7cycSJE5k8ebLZymPt2rXZtGkTf/75JwBbtmzh6tWr1K5dO8e5/glaSRMRERERySfvv/8+q1evxs/Pj65du+Lk5MSGDRs4ffo0/v7+pveB3a19+/a8/PLLdO7cmSpVqhAfH09cXBzVq1fn888/v+85T58+Te3atalcubLZFhB3d3cqVKhAVFQUjo6OuLm5YTAYeP/99ylRogQ7duwgICCAZs2aWY3rYV24cAF3d3e8vb2pXbs25cuXJzU1lbVr13Lq1Cnq1q3LhAkTzMaUKlWKyZMn89Zbb1G/fn26desGQHR0NBcuXCA6OppixYpZPV9mZiZ9+/alQ4cOFoncwIEDiYyMxM/Pj4CAAKKioihXrpxZzYTHQStpIiIiIiL5pH379ixZsoRq1aqxYMECFi5ciLu7Ozt27KBy5cpWx3Tq1InFixfz+++/8/XXX7N//36CgoLYvHnzIxVUK1SoEDExMfj4+BAZGcnIkSMZMWLEQ78gO7dcXV3p378/2dnZrFy5kq+++orvv/+eChUqMH78eLZv326x7wzgzTff5KeffsLd3Z05c+YQERHBv/71L1avXk2XLl1yPN/48eM5fvw4kydPtjjm4+PD3Llz+euvv5g6dSqVK1cmNjb2nu/2/ScYslXxQOSJ0LRpU1JTUylUtAhV+uT8D09++ank431/yIPI7tEiv0MQERGRAsJ4z1auXDk2btz4UHNoJU1ERERERMSGKEkTERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIXqZtcgTpoxLMVb2H5bfYYiIiIjIP0QraSIiIiIiIjZESZqIiIiIiIgNUZImIiIiIiJiQ5SkiYiIiIiI2BAlaSIiIiIiIjZESZqIiIiIiIgNUZImIiIiIiJiQ5SkiYiIiIiI2BAlaSIiIiIiIjbEPr8DEJEHk3btT9p+85/8DoOYzLWPNN65zLA8iuT+snu0eGznEhEREXlUWkkTERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIUrSRETy0K1bt5g4cSJ+fn64urri5OSEm5sb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GwwG5s2bR5s2bZgxYwa7d+/m2rVrlC9fnqCgIEJCQv6Rd0xVqFCB1q1bs3LlSuD+BUP27Nlj8c689PR0s/9NXnrppTyPU0RERESePobsJ2GDlA27fPkybm5u3Lx5k+TkZKult0XyQtOmTUlNTaVQ0SJU6dMlv8MhJtOyiuGDcC4zLI8iub/sHi0e27lERESkYDPes5UrV46NGzc+1BwFek9aXhgzZgzXrl2ja9euStBEREREROSRFfjHHR/G1q1bmT17NsnJyaxfv54iRYrwxRdf5HdYIiIiIiLyFFCS9hCOHDnCrFmzcHZ2xsfHh3HjxlGtWrX8DktERERERJ4CStIeQlBQkMqxi4iIiIjIP0J70kRERERERGyIkjQREREREREboiRNRERERETEhihJExERERERsSFK0kRERERERGyIkjQREREREREboiRNRERERETEhug9aSJPmDIuxVjZf1h+hwE8WgzZeRSFiIiIyNNGK2kiIiIiIiI2REmaiIiIiIiIDVGSJiIiIiIiYkOUpImIiIiIiNgQJWkiIiIiIiI2REmaiIiIiIiIDVGSJiIiIiIiYkOUpImIiIiIiNgQJWkiIiIiIiI2xD6/AxCRB5N27U/afvOf/A7jocRkrn2occ5lhj3SebN7tHik8SIiIiKPk1bSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIUrSREREREREbIiSNBERERERERuiJE1ERERERMSGKEkTERERERGxIUrSREREREREbIiSNBGRPHTr1i0mTpyIn58frq6uODk54ebmRps2bYiOjr7v+G+++QaDwYDBYKBv376PIWIRERGxNfb5HYCIyNPi1KlTtG7dmkOHDlGmTBl8fX1xcXHh5MmTbNy4ERcXF7p165bj+KSkJD7++GMMBgPZ2dmPMXIRERGxJQVqJa1KlSoYDAZSUlLyO5Q8l5CQwJdffkn37t2pWbMmdnZ2GAwGFixY8MhzL168GH9/f0qVKoWLiwv16tVj/PjxZGRk5EHkT77ExES+/vpr2rZty3PPPYeDgwPFixfH29ubMWPG8Ndff+V3iPIY3Lhxg5YtW3Lo0CHCwsI4c+YMy5cvJyoqii1btnD+/HmGDx+e4/isrCyCgoIwGAz07NnzMUYuIiIitkYraU+Jzz//nGXLluX5vIMGDSI8PBx7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bh21a9cmICCAYsWKsW3bNk6cOEHp0qVZvHgxDg4Ouf6sciM4OJjp06ebqnX26NHDrMz63xkfbYP/Fn7ZuXOnWfuIESN0k14AtGrVilatWj3SHGFhYYSFheVNQCIiIvLEKdBJGtx5/DA8PJx58+axefNmnJyc8PLyYuLEidSoUeO+SZqDgwP+/v5ER0fTt29fHB0dc+xboUIF4uPjiYiIIDo6mv3797Njxw5cXV2pUKEC/fr145VXXsHJyemBr+P8+fNs377dov3YsWOm5OpBXb161eqcp06d4tSpU6bf09PTcz1nqVKl+OWXX5g9ezYLFy5k7969bN26lWeeeQYPDw9effVVs/6Ojo78/PPPzJw5k3nz5rFp0ybS09OpWLEi77//Pp988kme7kczatSoES+88AK//vorcP9HHa19Tn///KytnoqIiIiI/J0hu6BukMojly9fxs3NjZs3b5KcnGy19LZIXmjatCmpqakUKlqEKn265Hc4uRaTaVnt8G7OZYb94zFk92jxj59DREREBP57z1auXDk2btz4UHMU6D1peWHMmDFcu3aNrl27KkETEREREZFHVuAfd3wYW7duZfbs2SQnJ7N+/XqKFCnCF198kd9hiYiIiIjIU0BJ2kM4cuQIs2bNwtnZGR8fH8aNG0e1atXyOywREREREXkKKEl7CEFBQQQFBeV3GCIiIiIi8hTSnjQREREREREboiRNRERERETEhihJExERERERsSFK0kRERERERGyIkjQREREREREboiRNRERERETEhihJExERERERsSF6T5rIE6aMSzFW9h+W32E8gHvHmv2YohARERF5UmglTURERERExIYoSRMREREREbEhStJERERERERsiJI0ERERERERG6IkTURERERExIYoSRMREREREbEhStJERERERERsiJI0ERERERERG6IkTURERERExIbY53cAIvJg0q79Sdtv/pPfYTySmMy1DzXOucywhxqX3aPFQ40TERERyQ9aSRMREREREbEhStJERERERERsiJI0ERERERERG6IkTURERERExIYoSRMREREREbEhStJERERERERsiJI0ERERERERG6IkTURERERExIYoSRMREREREbEhStJERPLQrVu3mDhxIn5+fri6uuLk5ISbmxtt2rQhOjr6vuO/+eYbDAYDBoOBvn37PoaIRURE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VhQ++OADLl++TK9evRSgiYiIiIjIXSvx0x3vREJCAvPnzyc1NZX4+HjKli2rdOsiIiIiIlIkFKTdgSNHjjBv3jycnJxo3rw5U6dOpU6dOsXdLREREREReQAoSLsDwcHB+WbwExERERERuRtakyYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkT7pIn8zbg7lyd28Jji7sYD7v4/39z7fkURERGxVRpJExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSFlirsDIlI4Zy9fpOPnk4u7GyVCdHZcsV7fyX1MsV07t2/bYru2iIhISaeRNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERIpNSkoKn332GcHBwTRq1IgyZcpgMBiYNGmS1fo5OTkkJCQwfvx4AgICcHNzw87ODnd3d5566im+/vprcnNz873e5cuX+eCDD/D19aVChQrY2dlRtWpVOnXqxKpVq+7VbYqIiBRKmeLugIiIlFyzZ89m+vTpBa5/9OhR/P39AXB1dcXX15dKlSpx9OhR4uLiiIuLY8mSJXzzzTfY29ubnXvu3DlatGjBwYMHKVeuHE888QQuLi78/PPPrFmzhjVr1jBs2LBC9UdEROReKPRIWq1atTAYDBw7duwedKf4XLlyhdWrVzNkyBAaN25M+fLlsbe3p3r16vTp04cdO3bcVfvLli2jVatWVKpUCWdnZxo3bsy0adPIysoqojuw7tixYxgMBmrVqnVPr1PSXbt2jalTp9K4cWOcnZ2pVKkSrVq1Yvny5cXdNRGb1rBhQ0aOHMnXX3/NoUOHeP75529Z32Aw0KZNG/73v/9x+vRp1q1bx5IlS9i1axebN2/G2dmZ1atXM2XKFItz33vvPQ4ePEjTpk1JS0tj3bp1REVFsWfPHtasWUOZMmWYMWMGiYmJ9+p2RURECkTTHf+/yMhInn32WWbNmsWFCxcIDAykc+fOODo6EhUVxZNP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FncV0vnz5/H09OTq1aukpqaaEoSIyP9p0aIF6enplC5XllovKvC7H6Kzi3e/LCf3McV27dy+bYvt2iIiIn9nxu9sVapUYevWrXfUxv3Ny56PDz74gMuXL9OrVy8FaCIiIiIiUqIVyXTHO5GQkMD8+fNJTU0lPj6esmXLMmnSpOLqjoiIiIiIiE0otiDtyJEjzJs3DycnJ5o3b87UqVOpU6dOcXVHRERERETEJhRbkJbfPjYiIiIiIiIlmU2sSRMREREREZE8CtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG1Js+6SJyJ1xdy5P7OAxxd2NEqJ4n3NusV5dREREiotG0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGxImeLugIgUztnLF+n4+eTi7sbfQnR2XHF3ASf3McXdhTuS27dtcXdBRESkxNJImoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIsUmJSWFzz77jODgYBo1akSZMmUwGAxMmjTJav2cnBwSEhIYP348AQEBuLm5YWdnh7u7O0899RRff/01ubm5+V7v8uXLfPDBB/j6+lKhQgXs7OyoWrUqnTp1YtWqVffqNkVERAqlTHF3QERESq7Zs2czffr0Atc/evQo/v7+ALi6uuLr60ulSpU4evQocXFxxMXFsWTJEr755hvs7e3Nzj137hwtWrTg4MGDlCtXjieeeAIXFxd+/vln1qxZw5o1axg2bFih+iMiInIvlKiRtFq1amEwGDh27Fhxd6VIXblyhdWrVzNkyBAaN25M+fLlsbe3p3r16vTp04cdO3bcUbuFfcNdUp07d44FCxYwdOhQnnjiCcqWLYvBYKBt27bF3TURm9ewYUNGjhzJ119/zaFDh3j++edvWd9gMNCmTRv+97//cfr0adatW8eSJUvYtWsXmzdvxtnZmdWrVzNlyhSLc9977z0OHjxI06ZNSUtLY926dURFRbFnzx7WrFlDmTJlmDFj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cpH1R+RBlpyczODBg03//uWXXwCYM2cOq1evNh1fsWIF1apVY+/evbz88svk5uZSp04dli9fnm/ioJvXls6fP5/WrVtz6NAhHnnkEZo3b467uzuHDh3ixx9/BKB///7069eviO9SRESkcEp04pBHHnkEgI0bN1psOj137lzTW9VbGT58OIApe5+1UTTIG0Hz8/Nj165dhISEWF139scffxAeHk52dnah7iMnJ4eQkBAiIyMLHaCNHj0ab29vRo8eXahr3srMmTPx9vZmwIABZsebNGlCly5d+Ouvv+jSpYvFOsDs7GxWrVpl+rejoyOvvvoqAG+88YZZJs2srCyGDx/O77//Tu3atU0L/ouCk5MTffr0IScnh6lTp7J27VrKli1L7969rdaPjY2lR48epk23FaCJFNyff/7Jd999Z/oxbvr+66+/mh3PzMwE8jaeN05BP3z4MAsXLsz352YNGzbkwIEDjBo1igYNGpCUlMTKlSs5ffo07dq1IyoqikWLFhX5SzQREZHCKtEjaT4+PnTp0oVvv/0WHx8fWrVqhaurK3v37iUlJYUxY8bw/vvv37KN3r178+abb5Kens5DDz2U7xf5UqVKsXLlSp555hkWLlzI8uXLady4MTVq1ODatWscPXqU/fv3c/36dYKDg61mgMzPzJkziYiIAPISaUycONFqPW9vb4u9wU6dOkVKSgqnTp2yqF/YN9xGZ8+eJSUlhapVq1q0+eWXX9KxY0cSExOpX78+TzzxBB4eHvz+++/s37+fM2fOmK0BfPfdd9m9ezcbN27kkUceoXXr1pQvX56dO3dy/Phx3NzcWLZsGfb29gV5VAUWEhLCnDlzTNk6+/bta7ZtgtHp06fp1q0b165dw9PTk4SEBKvZOQE++ugj3N3di7SfIn93rVq1srrut6jq36xKlSpMmTJF22KIiIhNK9FBGuRl4ps+fToRERFs374dR0dHfH19mTFjBvXr179tkGZvb0+rVq2Iiopi4MCBt9yw2MPDg8TERBYsWEBUVBQ//PADu3btwtXVFQ8PD0JDQ+ncuTOOjo6FuocbM5Ft3rw533otW7a0CNJuxfiG+2a//vorv/76q+nfxjfcBVGpUiW2bNnC/PnziYyMZO/evSQkJFC5cmWaNGlC165dzeo7ODiwdu1avvjiCyIiIti2bRuZmZlUr16doUOHMmrUqCJdj2bUrFkzHn30UdMUqPymOl65csV0/7/++mu+G2EDTJgwQUGaiIiIiNyWIfduXkkK58+fx9PTk6tXr5KammpKECJS1Fq0aEF6ejqly5Wl1otK638norOLb/8rJ/cxxXbtO5Hbt21xd0FERORvyfidrUqVKmzduvWO2ijRa9KKwgcffMDly5fp1auXAjQREREREblrJX66451ISEhg/vz5pKamEh8fT9myZZk0aVJxd0tERERERB4ACtLuwJEjR5g3bx5OTk40b96cqVOnUqdOneLuloiIiIiIPAAUpN2B4OBggoODi7sbIiIiIiLyANKaNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIdonTeRvxt25PLGDxxR3N/6miu+55RbblUVEROTvRiNpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEG1mLfI3c/byRTp+Prm4uyF/Q9HZccV6fSd3bcIulnL7ti3uLoiI2ByNpImIiIiIiNgQBWkiIiIiIiI2REGaiIiIiIiIDVGQJiIiIiIiYkMUpImIiIiIiNgQBWkiIiIiIiI2REGaiIiIiIiIDVGQJiIiIiIiYkMUpImIiIiIiNgQBWkiIiLyQMvKymLjxo28+eab+Pn54eLigp2dHVWrVqVz586sWbPG6nkTJkzAYDDc8ufw4cO3vPbWrVvp06cPnp6eODg44O7uTtOmTRkxYgRZWVn34nZF5AFQprg7ICIiInIvbdmyhaeeegqAqlWrEhAQgLOzMwcPHiQmJoaYmBgGDRpEeHg4BoPB4vzGjRvTpEkTq21XrFjR6vHc3FxGjBjB9OnTsbOzo1mzZrRo0YKzZ89y6NAhPv30UyZOnIidnV2R3aeIPDhKVJBWq1Yt0tLSSE1NpVatWsXdnSI1c+ZMtm3bxv79+zl9+jQXLlygfPnyNGzYkN69ezNo0KA7/iBYtmwZs2bNYt++fVy7do169erRr18/RowYoQ8X4PLly3z77bfs2bOHPXv2kJyczMWLF6lbty4///xzcXdPRKTEK1WqFN27d2f48OE8+eSTZmVRUVH069ePuXPn4u/vz4ABAyzO79q1KxMmTCjUNSdMmMD06dN54okniIyMpGbNmmblSUlJODo6FvpeRKRkKFFB2oNsypQppKen8+ijj9KsWTMqVKjAyZMn2blzJ9u2bWPRokXExcVRrly5QrX72muvMX36dMqUKUObNm0oV64c8fHxjBo1ipiYGNavX4+Tk9M9uqu/h59++ol+/foVdzdERCQfbdq0oU2bNlbLevfuzYYNG5g3bx4RERFWg7TCSklJYfLkyVSpUoU1a9bg4uJiUcfPz++uryMiDy4FaQ+IJUuW0KRJE4sg7Pjx4zz99NN89913vP/++3zwwQcFbnPlypVMnz6dcuXKsWXLFh577DEAzp49S5s2bdi+fTvjxo3jo48+KtJ7+bspX748ISEhPPbYY/j4+HD+/Hk6depU3N0SEZEC8vHxAeDEiRNF0t7s2bPJzs7mpZdeshqgiYjcjoK0B0RAQIDV4zVq1ODtt99mwIABrF+/vlBB2uTJkwEICwszBWgA7u7ufP755zz55JPMnDmTcePG5TsnvySoW7cu8+fPN/178+bNxdcZEREptJ9++gmAatWqWS1PTk4mLCyMjIwMKlasiI+PD88++yzly5e3Wn/dunUAtGjRgvPnzxMVFcUPP/xAqVKlaNiwId27d8fd3f3e3IyIPBBKfHbHtLQ0pk6dSps2bahRowYODg64uLgQEBDAnDlzyMnJMau/adMmDAYD3t7e5ObmWm3z6tWruLm5YTAYOHjwoFnZX3/9xccff0zz5s1xcXHB0dERLy8v3nrrLc6dO2fR1oIFCzAYDAQHB5ORkcFrr71G3bp1cXBwoFWrVgW6xzJl8mJxBweHAtUHOHnyJElJSQD07dvXojwgIIDq1auTmZlJbGxsgduFvMXU0dHRdOrUiapVq2Jvb29ayD116lT++usvi3OWLFlCYGAgrq6uODg4ULNmTV544QWOHDli9Rq1atXCYDBw7NgxNm3axNNPP02lSpVwcnLiscceIyIiwqz+9evX8fT0xGAwkJiYmG/fR44cicFgYMSIEYW6ZxERsU2///47CxYsAKB79+5W68TExDB16lS++OILPvroI/r160f16tUtPksArl27RkpKCgCpqal4eXkRGhrK559/zsyZMwkNDaV27dosWbLknt2TiPz9lfggbdGiRYSFhXHs2DEaNGhAt27daNKkCUlJSYSGhtKz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5/r16wQHB1vNAJmfn3/+mZCQEFxcXPDx8aFatWpcunSJ1NRU9u/fD+SN+ll723fq1ClSUlI4deqURVnXrl0ZNmwYM2bMoHnz5gQGBuLs7MzGjRs5f/48/v7+TJw40eK8CxcukJKSYnWvsWnTppGamsqqVato3LgxzZo1o3bt2pw9e5Yff/yRkydPkpqaagr8Xn75ZRISEli0aBG+vr60bNmSypUrk5ycTEpKCk5OTkRGRlpNcXw3BgwYwNixY02jqS1atKBevXr51v/3v/9teobGRDO//vorzZs3N9UZOHCgaXqMiIjcP8aRssJwc3MzvYC9U9WqVWPmzJn57qsqIpKfEh2kQd70w+nTpxMREcH27dtxdHTE19eXGTNmUL9+/dsGafb29rRq1YqoqCgGDhyIg4NDvnU9PDxITExkwYIFREVF8cMPP7Br1y5cXV3x8PAgNDSUzp07W8x9v51WrVoxbtw4tm/fzs8//8zOnTvJycmhcuXKPPvss/Tp04c+ffrc0VS96dOn4+/vz6xZs0hISCArK4u6desSFhbGiBEjCrX3GuQ9r5UrV7JkyRIWLFjAnj172L17N25ubtSvX5/XXnvNbG6/wWAgIiKCDh06MHfuXPbs2cPly5epWrUqwcHBhIWF4eXlVej7uh0PDw/atWtHbGwscPuEId9//73FnnmZmZlme+e0b9++yPspIiIiIg8eQ+79XiD1gDl//jyenp5cvXqV1NTUAiXlELkTLVq0ID09ndLlylLrxZ7F3R35G4rOjivW6zu5jynW64ttyu3btri7ICJSpIzf2apUqcLWrVvvqI0SvSatKHzwwQdcvnyZXr16KUATEREREZG7VuKnO96JhIQE5s+fT2pqKvHx8ZQtW5ZJkyYVd7dEREREROQBoCDtDhw5coR58+bh5ORE8+bNmTp1aoFT24uIiIiIiNyKgrQ7cCdZokRERERERApCa9JERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIZonzSRvxl35/LEDh5T3N2Qv6Xi/f9NbrFeXURE5O9DI2kiIiIiIiI2REGaiIiIiIiIDVGQJiIiIiIiYkMUpImIiIiIiNgQBWkiIiIiIiI2REGaiIiIiIiIDVGQJiIiIiIiYkMUpImIiIiIiNgQBWkiIiIiIiI2pExxd0BECufs5Yt0/HxycXdD5Lais+OKuwsWnNzHFHcX5Ca5fdsWdxdERGyORtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0EREReaBlZWWxceNG3nzzTfz8/HBxccHOzo6qVavSuXNn1qxZY/W8CRMmYDAYbvlz+PDhW15769at9OnTB09PTxwcHHB3d6dp06aMGDGCrKyse3G7IvIAKFPcHRARERG5l7Zs2cJTTz0FQNWqVQkICMDZ2ZmDBw8SExNDTEwMgwYNIjw8HIPBYHF+48aNadKkidW2K1asaPV4bm4uI0aMYPr06djZ2dGsWTNatGjB2bNnOXToEJ9++ikTJ07Ezs6uyO5TRB4cJSpIq1WrFmlpaaSmplKrVq3i7k6RmjlzJtu2bWP//v2cPn2aCxcuUL58eRo2bEjv3r0ZNGjQHX8QLFu2jFmzZrFv3z6uXbtGvXr16NevHyNGjNCHC5CSksL//vc/1q9fz759+zhz5gyOjo54eXnRrVs3hg4dSrly5Yq7myIiJVapUqXo3r07w4cP58knnzQri4qKol+/fsydOxd/f38GDBhgcX7Xrl2ZMGFCoa45YcIEpk+fzhNPPEFkZCQ1a9Y0K09KSsLR0bHQ9yIiJUOJCtIeZFOmTCE9PZ1HH32UZs2aUaFCBU6ePMnOnTvZtm0bixYtIi4urtDBwmuvvcb06dMpU6YMbdq0oVy5csTHxzNq1ChiYmJYv349Tk5O9+iu/h4CAwM5efIkjo6O+Pr60qJFC9LT09m5cye7d+9m3rx5xMfHU6NGjeLuqohIidSmTRvatGljtax3795s2LCBefPmERERYTVIK6yUlBQmT55MlSpVWLNmDS4uLhZ1/Pz87vo6IvLgUpD2gFiyZAlNmjSxCMKOHz/O008/zXfffcf777/PBx98UOA2V65cyfTp0ylXrhxbtmzhscceA+Ds2bO0adOG7du3M27cOD766KMivZe/Gy8vL9577z169epl9vyPHTtGp06d+PHHHwkODiY+Pr4YeykiIvnx8fEB4MSJE0XS3uzZs8nOzuall16yGqCJiNyOEoc8IAICAqyOktWoUYO3334bgPXr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rDDc3NxML2DvVLVq1Zg5c2a++6qKiOSnRAdpkDf9cPr06URERLB9+3YcHR3x9fVlxowZ1K9f/7ZBmr29Pa1atSIqKoqBAwfi4OCQb10PDw8SExNN+2f98MMP7Nq1C1dXVzw8PAgNDaVz584Wc99vp1WrVowbN47t27fz888/s3PnTnJycqhcuTLPPvssffr0oU+fPoVOogEwffp0/P39mTVrFgkJCWRlZVG3bl3CwsIYMWJEofZeg7zntXLlSpYsWcKCBQvYs2cPu3fvxs3Njfr16/Paa6+Zze03GAxERETQoUMH5s6dy549e7h8+TJVq1YlODiYsLAwvLy8Cn1ft+Ph4UG7du2IjY0Fbp0w5I8//gDg/PnzLFy4MN96xv3ZRERERERuxZB7vxdIPWDOnz+Pp6cnV69eJTU1tUBJOUTuRIsWLUhPT6d0ubLUerFncXdH5Lais+OKuwsWnNzHFHcX5Ca5fdsWdxdERIqU8TtblSpV2Lp16x21UaLXpBWFDz74gMuXL9OrVy8FaCIiIiIictdK/HTHO5GQkMD8+fNJTU0lPj6esmXLKt26iIiIiIgUCQVpd+DIkSPMmzcPJycnmjdvztSpUwuc2l5ERERERORWFKTdgTvJEiUiIiIiIlIQWpMmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZE+6SJ/M24O5cndvCY4u6GSAHY3v9Pc4u7AyIiIgWgkTQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREbUqa4OyAihXP28kU6fj65uLshJVh0dlxxd+GuObmPKe4uyP+X27dtcXdBRMTmaCRNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERkQdaVlYWGzdu5M0338TPzw8XFxfs7OyoWrUqnTt3Zs2aNVbPmzBhAgaD4ZY/hw8fvuW1t27dSp8+ffD09MTBwQF3d3eaNm3KiBEjyMrKuhe3KyIPgDLF3QERERGRe2nLli089dRTAFStWpWAgACcnZ05ePAgMTExxMTEMGjQIMLDwzEYDBbnN27cmCZNmlhtu2LFilaP5+bmMmLECKZPn46dnR3NmjWjRYsWnD17lkOHDvHpp58yceJE7Ozsiuw+ReTBUeggrVatWqSlpZGamkqtWrXuQZeKz8yZM9m2bRv79+/n9OnTXLhwgfLly9OwYUN69+7NoEGD7viP6bJly5g1axb79u3j2rVr1KtXj379+jFixIh7+gf62LFj1K5dm5o1a3Ls2LF7dp2S7tq1a/znP/8hMjKSn3/+GXt7exo3bsyQIUPo0aNHcXdPRKREK1WqFN27d2f48OE8+eSTZmVRUVH069ePuXPn4u/vz4ABAyzO79q1KxMmTCjUNSdMmMD06dN54okniIyMpGbNmmblSUlJODo6FvpeRKRk0HTHG0yZMoXo6Gjs7e1p1qwZPXr0oGHDhuzcuZMhQ4bw5JNPcunSpUK3+9prr9GrVy927NjB448/Tvv27Tl+/DijRo2iTZs2/PXXX/fgbmybcZqILahVqxYGg+GOg9grV67QunVrwsLCOH78OO3bt+fxxx9nx44d9OzZk5EjRxZth0VEpFDatGnD8uXLLQI0gN69exMcHAxAREREkVwvJSWFyZMnU6VKFdasWWMRoAH4+flRpowmNImIdfrrcIMlS5bQpEkTypUrZ3b8+PHjPP3003z33Xe8//77fPDBBwVuc+XKlUyfPp1y5cqxZcsWHnvsMQDOnj1LmzZt2L59O+PGjeOjjz4q0nuR+2fMmDEkJCTQqFEj4uPjcXd3B2DPnj20atWKjz/+mFatWtGpU6di7qmIiFjj4+MDwIkTJ4qkvdmzZ5Odnc1LL72Ei4tLkbQpIiWLRtJuEBAQYBGgAdSoUYO3334bgPXr1xeqzcmTJwMQFhZmCtAA3N3d+fzzz4G8aZYXLly4025LMfrjjz+YPXs2kPehbAzQAJo2bcqoUaMAeP/994ulfyIicns//fQTANWqVbNanpycTFhYGIMGDeLNN98kMjKSixcv5tveunXrAGjRogXnz59nzpw5vPrqqwwdOpQ5c+Zw9uzZor8JEXmgFEmQlpaWxtSpU2nTpg01atTAwcEBFxcXAgICmDNnDjk5OWb1N23ahMFgwNvbm9zcXKttXr16FTc3NwwGAwcPHjQr++uvv/j4449p3rw5Li4uODo64uXlxVtvvcW5c+cs2lqwYAEGg4Hg4GAyMjJ47bXXqFu3Lg4ODrRq1apA92ickuDg4FCg+gAnT54kKSkJgL59+1qUBwQEUL16dTIzM4mNjS1wuxcuXGDs2LE0atQIZ2dnHBwc8PDwwN/fn/Hjx+ebLSo3N5e5c+fStGlTnJ2dqVixIk8//TQ7d+7M91q//vorQ4cOpX79+jg6OlKxYkX8/f2ZM2cO169ft6h/u2dtzJRldHOWrJunHB45coTBgwfj5eVF2bJlqVChAv/4xz8YPHgwBw4cMNXbvHkzBoPhlr/Pm6dYGvualpYGQO3atc36snnz5nzbMoqNjeXatWvUqFEDf39/i3Lj7z0xMZHffvvttu2JiMj99fvvv7NgwQIAunfvbrVOTEwMU6dO5YsvvuCjjz6iX79+VK9e3er0yGvXrpGSkgJAamoqXl5ehIaG8vnnnzNz5kxCQ0OpXbs2S5YsuWf3JCJ/f0Uy3XHRokWMGzeO2rVr06BBA/z9/Tl16hQ7d+5kx44drF+/nuXLl5u+ILdu3ZpGjRqxf/9+4uLiTBmXbrR48WIyMjJo3bo1//jHP0zHf/vtN9q3b8/+/ftxdXXFz8+P8uXLk5yczIcffsiyZcvYvHmz1fnfZ8+exdfXl/Pnz/Pkk0/StGlT7O3tb3t/p0+fZurUqQB07ty5wM/l+++/B8DV1ZXatWtbrePr68uJEyf4/vvvee65527b5pUrVwgICODAgQM89NBDBAYG4uzszO+//87hw4dJSEjg9ddftzq9IiQkhMjISJ588kk6derE3r172bBhA1u3bmXLli00a9bMrH5SUhLt27cnIyODGjVq0LVrVy5cuMDmzZtJSEhgxYoVrFq1yuozzO9ZN2nShKCgIBYuXAhAUFCQ2Xk3jmRGRkbywgsvkJmZSY0aNejYsSM5OTkcPXqU8PBwKleuTMOGDW/7zPJTr149goKCWL58OZcvX6Z79+5m169atept2zD+jn19fa2W16lTB1dXVzIyMti7dy8eHh533F8RESla2dnZ9O/fnwsXLtCoUSNefvlls/K6desyefJkOnToYPpecfDgQaZMmcLq1asJCgqidOnS9OvXz3RORkaG6QX0kCFDeOSRR1i6dCmPPfYYv/32G1OmTGHBggX079+fhx9+2Oo6ORGRIgnS2rVrR9euXS2+MP/222907NiR6Oholi9fTs+ePU1lw4YN46WXXmLmzJlWg7RZs2YBeX/gjHJzc+nVqxf79+/nxRdf5D//+Q/ly5cH8v7QhoWF8fHHHxMSEkJ8fLxFm2vWrCEwMJDo6GgqVKiQ7/1ERkayfv16srOzOXXqFDt27CAzM5OgoCBef/31Aj+X1NRUIG+6ZH6qV69uVvd2li9fzoEDB+jQoQPffvutWWbInJwctm3bRtmyZS3OS0tLY/PmzRw4cIAGDRoAcP36dQYNGsT8+fMZP368aXoGQGZmJj179iQjI4PQ0FBmzJhhutbRo0cJDAxk3bp1vPvuu1an8t3qWXft2tUUpBnfXt5sz549BAcHk52dzYwZM3j11VcpVer/Bn7T0tLuerpIQEAAAQEBbN68mcuXL/PRRx8VOmNpQX7Hnp6eZGRkFPh3LCIi90doaCgbN27Ezc2N5cuXW7x0fP755y3O8ff3JyYmhmHDhvHZZ58xYsQIevbsaTr3xhlCTk5OxMXF8dBDDwHg5eXFl19+SXp6Ov/73/+YMGECGzduvId3KCJ/V0Uy3dHPz8/qiIaHhwfTpk0D8lLQ36hfv364ubmxevVq03Qzo8TERPbs2UP16tXp0qWL6fi6devYsWMHTZo0ITw83BSgQd50xGnTptGwYUM2bdpkNhXOyM7Ojrlz594yQAPYtWsXCxcu5OuvvyY+Pp5r166Z9jopyMibkXG+urOzc751jCM3f/75Z4HaTE9PB+Cpp56ySN1fqlQpWrZsmW8fP/vsM1OABlC6dGlTgLVlyxazaZLLli0jLS0NDw8PPv30U7Nr1alTx5To5LPPPuPq1asW1yros87PpEmTyMrKYsiQIQwdOtQsQAOoWbMmTZs2vaO2i9K9+B2LiMi9N3z4cObNm0elSpXYsGGD2edjQUyYMIHSpUtz5swZvvvuO9PxG7+bdOvWzRSg3Wjw4MEAbNu2jWvXrt3hHYjIg6zIEodkZmYSExPD+PHjCQ0NJSQkhODgYObMmQNgmp9t5OTkxKBBg8jJyTElXjAyjqKFhoZSunRp0/E1a9YAeXPGraWtLVWqFC1atAAgISHBotzHx4c6derc9l4+/fRTcnNzuXr1KocPH+btt98mPDycxo0bW6yPu9/8/PwAmDZtGhEREWRkZBTovDJlytC+fXuL41WrVqVSpUpkZmaareczrsfq06eP1XV43bp1o1KlSly8eJE9e/ZYlBf0WVtz/fp1NmzYAMCgQYPuqA0REZH8vPHGG8yYMQMXFxfWr19vyu5YGK6urlSuXBnIW79tVK5cOVNglt/noPF4VlaWkoiIiFVFEqQlJibSoEEDOnfuzMSJE5kzZw4LFixg4cKFREdHA9ZHEQYPHkyZMmWYN2+eaTTmzJkzLFu2DAcHB1566SWz+kePHgVg3LhxFgknjD/GjIlnzpyxuF5hp7I5ODjg5eXFxIkTWbhwIWlpaRZrqG7F+Dbt8uXL+dYx7rtW0BGnVq1aMWrUKE6fPk1QUBDu7u54eXnxwgsv8O2331okaTGqVq1avptmG69944jYyZMnAfJdS2cwGExlxro3upuNzs+dO2d6Zl5eXnfczv1wL37HIiJy77z11lt88sknVKxYkfXr1+e7pvh2rl+/bsrMfOPoGWCa6ZFfAHbjcWtZpUVE7npN2pUrV+jatSvp6emEhITwyiuvUK9ePSpUqEDp0qU5cuQIXl5eVrM4enp60q1bN5YuXUpUVBRBQUH897//JTMzk+eff95iioAxAAkICKBu3bq37Nejjz5qcczJyemO77N79+6UL1+e3bt3c+LECdNaslsxBiq32nfFWFaYoGbKlCmEhoYSExPD9u3b2bFjB19++SVffvklfn5+bNq0yWL63c3TBe+1u3nW90J+wevdMv7ejh8/nm8d4xvWuwlcRUTk7oWFhfHhhx9SsWJFNmzYYJqdcidWrVrFlStXMBgMFoFez549Wbt2LfHx8eTk5Fh8Bhtni3h5eekFnohYdddB2tatW0lPT+exxx5j/vz5FuXGvUfyM2zYMJYuXcqsWbPo378/4eHhgHnCECNjYNSlSxdGjhx5t10vlFKlSuHk5MTFixc5ffp0gYI04/SJc+fOkZqaanVUavfu3QBme6gVRK1atRg6dChDhw4F8jIx9u/fn6SkJKZNm8a7775bqPZu9vDDDwP/N3ppjTERhrFuUXFzc6Ns2bJcuXKFlJSUAmVwNK7Dy2/fmpvXPRYV4+/N+Hu82dGjR01TUu9kOo2IiBSNsWPHMnXqVNMUx9sFaMePH2fr1q306NEDR0dHs7KVK1cycOBAIG+N/c3ZgPv378/kyZM5cOAA48eP57333jMFaps2beKTTz4B8r4DiYhYc9fDK8YvoPllt/vqq69ueb6/vz9NmzYlKSmJsWPHcvz4cfz8/Hj88cct6nbo0AHIS2qR3/5q98qBAwc4ffo0pUuXLvBaK09PT9OHQGRkpEX59u3bOXHiBA4ODnTs2PGu+ufn52daiLx37967agsw7TcWFRVlNTHIihUr+OOPPyhfvvwdJfAwTr3Mzs62KCtdurQp4+cXX3xRoPZuDCqtLcI2rme0xhjgWevL7XTs2BF7e3uOHz/Ojh07LMqNv/fmzZsr/b6ISDFZtWqVKVFWvXr1mDVrFsHBwRY/N74AzsjIMM3qadGiBc899xxdu3alQYMG/Pvf/zZtE3TzunrI+1yJjo7G1dWV999/nwYNGtCjRw/+9a9/0bZtW65cuUJQUBCvvPLKfXsGIvL3ctdB2iOPPALAxo0bLZJqzJ07l6ioqNu2MXz4cCBvGh9YH0WDvBE0Pz8/du3aRUhIiNV1Z3/88Qfh4eGF/sK9fft2YmJirJ6XnJxs2sOsZ8+eVKpUyax89OjReHt7M3r0aItzx4wZY7q35ORk0/Fz586ZgqohQ4ZQsWJFs/NWrFiBt7c3gYGBFse3bt1qMX0vKyuLtWvXAljdI66wevbsSY0aNfjtt994/fXXzZ5Lamoqb7zxBgBDhw61eMNYEJ6engD8+OOPVsvffvttypQpw8yZM/n8888tgvK0tDSzhCU1a9akfv36nD9/3rSnndHmzZsZP378HfcFIDAwEG9vb1asWGF2vFKlSqYP2cGDB5slX0lOTjb15e233863bRERubduTLK1e/duFi5caPVn+fLlpnrVq1dn1KhRPP7446SlpRETE0NsbCyXLl2iU6dOREZGEhcXl++asn/+858cOHCAV199levXrxMTE8Phw4dp2bIlixcvZsGCBab9Y0VEbnbX0x19fHzo0qUL3377LT4+PrRq1QpXV1f27t1LSkoKY8aMsbqP1o169+7Nm2++SXp6Og899BC9e/e2Wq9UqVKsXLmSZ555xvTHtHHjxtSoUYNr165x9OhR9u/fz/Xr1wkODraaATI/P//8MyEhIbi4uODj40O1atW4dOkSqamp7N+/H8gb9bP2xuzUqVOkpKRw6tQpi7KuXbsybNgwZsyYQfPmzU2bT2/cuJHz58/j7+/PxIkTLc67cOECKSkpFqNYW7ZsYfr06bi7u+Pj40PlypW5ePEiiYmJnD59mocffpi33nqrwPedHwcHB5YvX0779u2ZPXs2sbGxNG/enIsXLxIfH8/Vq1dp164d77zzzh213717dz766CPatm1LmzZtTIuup06dipubG35+fsybN4+BAwfy6quvMm3aNPz8/EybWe/bt4/x48ebjeJNmTKFHj16MH78eKKjo6lfvz5Hjx4lOTmZcePG8d577+Xbl02bNtG/f3+efvppUxD+5ptvmhKX/PLLL6SlpZkWid9o8uTJ7Nq1i507d1K/fn3atGnD5cuX2bhxI1lZWbz++ut06tTpjp6TiIjcPeNIWWG4ubmZXh7fqWrVqjFz5kxmzpx5V+2ISMlTJNkkli1bxocffoiXlxfbt29n/fr11KhRg3Xr1pnmbN+Kvb29aXrdwIEDraZ8N/Lw8CAxMZHw8HAef/xxUlJSWL58Odu3bwfy0vavW7eu0KM7rVq1Yty4cfj4+PDzzz8THR3N2rVr+eOPP3j22Wf5+uuv2bp1Ky4uLoVqF2D69OlERUXxr3/9i4SEBGJjY/H09GTKlCnEx8cXKslGcHAwYWFheHt7c/DgQZYtW8bOnTupXr06kydPZt++faaRobvl5+fH3r17efXVVyldujQrVqxg27Zt+Pj4MHv2bFavXl2ofeNuNHHiRN566y1cXFxYuXIl8+bNY968eWZrygYMGMDevXt58cUXKVWqFDExMWzcuJFr167x6quv0qtXL7M2u3XrxurVq/H39+fIkSPExsZiZ2fHkiVLbrlG75VXXuGDDz6gZs2axMbGmvpiLei2pmzZsmzevJkPPviAhx9+mNjYWHbu3Mm//vUvli5dyscff3xHz0hERERESiZD7v1e3GXF+fPn8fT05OrVq6SmphYoKYdISdOiRQvS09MpXa4stV7sWdzdkRIsOjuuuLtw15zcxxR3F+T/y+3btri7ICJSpIzf2apUqcLWrVvvqI37m5c9Hx988AGXL1+mV69eCtBERERERKREu+s1aXcqISGB+fPnk5qaSnx8PGXLlmXSpEnF1R0RERERERGbUGxB2pEjR5g3bx5OTk40b96cqVOnFji1vYiIiIiIyIOq2IK0O8m0JCIiIiIi8qCziTVpIiIiIiIikkdBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiISFXXEQAAmVlJREFUiA1RkCYiIiIiImJDim2fNBG5M+7O5YkdPKa4uyEl2t///3+5xd0BERGRW9BImoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA0pU9wdEJHCOXv5Ih0/n1zc3RAbFp0dV6zXd3IfU6zXl7+X3L5ti7sLIiI2RyNpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiDzQsrKy2LhxI2+++SZ+fn64uLhgZ2dH1apV6dy5M2vWrLF63oQJEzAYDLf8OXz48C2vvXXrVvr06YOnpycODg64u7vTtGlTRowYQVZW1r24XRF5AJQp7g6IiIiI3EtbtmzhqaeeAqBq1aoEBATg7OzMwYMHiYmJISYmhkGDBhEeHo7BYLA4v3HjxjRp0sRq2xUrVrR6PDc3lxEjRjB9+nTs7Oxo1qwZLVq04OzZsxw6dIhPP/2UiRMnYmdnV2T3KSIPjhIVpNWqVYu0tDRSU1OpVatWcXenSM2cOZNt27axf/9+Tp8+zYULFyhfvjwNGzakd+/eDBo0qNAfBCkpKaxfv549e/awZ88eDh06xPXr15k4cSJjx469R3fy93Pu3DliYmJMz2nv3r389ddfBAYGEhcXV9zdExEp8UqVKkX37t0ZPnw4Tz75pFlZVFQU/fr1Y+7cufj7+zNgwACL87t27cqECRMKdc0JEyYwffp0nnjiCSIjI6lZs6ZZeVJSEo6OjoW+FxEpGUpUkPYgmzJlCunp6Tz66KM0a9aMChUqcPLkSXbu3Mm2bdtYtGgRcXFxlCtXrsBtzp49m+nTp9/DXj8Ytm3bRkhISHF3Q0RE8tGmTRvatGljtax3795s2LCBefPmERERYTVIK6yUlBQmT55MlSpVWLNmDS4uLhZ1/Pz87vo6IvLg0pq0B8SSJUv4448/2Lt3L2vWrGHx4sVs3bqVX375BS8vL7777jvef//9QrXZsGFDRo4cyddff82hQ4d4/vnn71Hv/96qVKnCyy+/zJw5c0hKSiL8/7F353FRV/sfx1/jBriiuBLuC5R4hYQ05Zpo97q0YO6ZC6h51UzraoWaS9ni0qZpgiYqlooYmqTXFTdUcqU0E00R10gkcQeR+f3Bj9FxBkVEGeX9fDzmwcz5nu/5nu9Mxnw453xOUFB+d0lERO6Bp6cnACdOnMiT9mbMmEF6ejqvv/661QBNRORuNJL2mPDx8bFaXq1aNUaNGkWvXr1Ys2YNn376aY7b7Nevn9nrQoUU01vz7LPP8uyzz5pe79+/Px97IyIi9+rw4cMAVKlSxerxPXv2EBgYSHJyMmXKlMHT05OXXnqJUqVKWa2/evVqAJo3b8758+cJCwvj119/pVChQri7u9OxY0fKly//YG5GRB4LBf5bd0JCAhMnTqRly5ZUq1YNOzs7HB0d8fHxITg4mIyMDLP6GzZswGAw4ObmhtFotNrmtWvXcHJywmAwcODAAbNjV69e5fPPP6dJkyY4Ojpib2+Pq6sr7777LufOnbNoa+7cuRgMBvz9/UlOTuatt96idu3a2NnZ0aJFixzdY5EimbG4nZ1djuo/aOnp6YSEhPD8889Tvnx57OzscHFx4fnnn+frr7+2Wj8oKIimTZtSpkwZ7O3tqVu3LkOGDOHUqVNWr5GVdQvghx9+wMfHh9KlS1OiRAmaNWvGypUrzeqfP38eBwcHChcunG2bAJ06dcJgMGgaqIjIY+LPP/9k7ty5AHTs2NFqncjISCZOnMisWbP47LPPeO2116hatSqhoaEWddPS0oiLiwMgPj4eV1dXBgwYwDfffMO0adMYMGAANWvWZNGiRQ/snkTk0Vfgg7T58+cTGBjIsWPHqFevHh06dMDDw4OdO3cyYMAAOnfubBaM+fr60qBBA+Li4rJNCrFw4UKSk5Px9fXlqaeeMpWfPn2axo0bM3z4cA4fPoy3tzft2rUjNTWVyZMn4+XlRUJCgtU2k5KS8PLyIjQ0FHd3d/z8/HBxcbnr/f31119MnDgRgJdffvle3poHIiUlBV9fX/r27cvmzZtNf1GsV68ev/76K0OGDDGrn5qaStu2bRk4cCB79+6lWbNmtG/fntTUVL7++ms8PDzYs2dPttcbO3YsnTt3BqBdu3bUrVuXbdu28eKLL7J06VJTPUdHR1555RUyMjKYP3++1bayEoQUK1aMHj165MG7ISIi+Sk9PZ0ePXqQkpJCgwYN+M9//mN2vHbt2nzyySfs3buX5ORkkpOTiY6O5sUXXyQlJYXevXvz/fffm52TnJxs+t4wePBgKleuzMaNG7lw4QIHDx7E39+fS5cu0aNHD7Zs2fLQ7lVEHi0Ffrpj69atad++Pe7u7mblp0+fpl27dkRERLBkyRLTF32AIUOG8PrrrzNt2jRTSt9bTZ8+Hcj8n3MWo9FIly5d2LdvH3379uXLL780TZNIT08nMDCQzz//nICAAKKioizaXLFiBa1atSIiIoLSpUtnez8LFixgzZo1pKenc+bMGbZu3Upqaiq9e/fmv//97729OQ9Anz59iI6OxtPTk4iICLMsm+np6RZ71YwdO5Z169ZRu3Zt1q1bZ6p//fp1Bg4cyOzZs+nUqRMHDx6kWLFiFtebOnUq27dvp3HjxqaycePG8cEHHxAYGMgrr7xi1reFCxcyb948AgMDLdr6/vvvSUtLo2PHjjg5Od3nOyEiIvltwIABrF+/HicnJ5YsWWLxe8TaWuxmzZoRGRnJkCFD+Prrr3n77bfp3Lmz6dxb/7Dr4ODAunXrqFChAgCurq7MmTOHxMRE/ve//zFu3DjWr1//AO9QRB5VBX4kzdvb2yJAA3B2dmbSpEkAhIeHmx177bXXcHJy4qeffrIY+YqJiWH37t1UrVoVPz8/U/nq1avZunUrHh4eBAUFmc1jL1KkCJMmTcLd3Z0NGzZYXdNUtGhRZs6ceccADWDHjh3MmzeP77//nqioKNLS0kz7tFgLYh6mX375hYiICOzt7YmMjLTYBqFIkSJm79m1a9dMAe+XX35pVr9o0aJMnTqVSpUqER8fz5IlS6xe88MPPzQL0ABGjBhBmTJlOHTokNki8VatWlG9enUOHjzI9u3bLdqaM2cOgDI5iog8BoYOHcrs2bMpW7Ysa9eupV69evd0/rhx4yhcuDBnz57l559/NpXf+vu9Q4cOpgDtVoMGDQIyswOnpaXl8g5E5HFW4IM0yJxSFxkZyZgxYxgwYAABAQH4+/sTHBwMYJpbnsXBwYH+/fuTkZHBjBkzzI5lBRUDBgygcOHCpvKsEaKOHTua1ojdqlChQjRv3hyAbdu2WRz39PSkVq1ad72Xr776CqPRyLVr1zh48CCjRo0iKCiIhg0bWqyPe9hWrVoFwAsvvMATTzxx1/q7du3i0qVLlCtXjpdeesniePHixenWrRuQuVbQGmvn2dnZmd7LW9efGQwGevfuDWBan5AlNjaW2NhYqlSpQps2be7adxERsV3Dhg1j6tSpODo6smbNGlN2x3tRrlw5KlasCMDJkydN5SVLljQFZtn93s4qv379OklJSfd8bRF5/BX4IC0mJoZ69erx8ssvM378eIKDg5k7dy7z5s0jIiICgAsXLlicN2jQIIoUKcLs2bO5du0aAGfPniU8PBw7Oztef/11s/pHjx4FYPTo0aakFrc/vvnmG1M7t7vXzbft7OxwdXVl/PjxzJs3j4SEBFMAkl+yRh3d3NxyVD8rgKpZs2a2dWrXrm1W93bVqlWzWp41Ipn12WUJCAjAYDAQFhbG1atXTeVZo2i9evUyC75FROTR8u677/LFF19QpkwZ1qxZg5eXV67auXHjBikpKQAWWR4bNWoEkG0Admv5vexfKiIFR4Fek3blyhXat29PYmIiAQEBDBw4kDp16lC6dGkKFy7MoUOHcHV1tZrF0cXFhQ4dOrB48WLCwsLo3bs33377LampqfTs2dNiekNWlkgfHx9TYJGd+vXrW5Q5ODjk+j47duxIqVKl2LVrFydOnKBq1aq5butRc6/bBtSoUQNfX1+ioqJYunQp3bt35/r16yxYsADQVEcRkUdZYGAgkydPpkyZMqxdu/a+NpRevnw5V65cwWAwWAR6nTt3ZtWqVURFRZGRkWHxu2jt2rVA5hq1uy1jEJGCqUAHaZs3byYxMZGnn36akJAQi+NZ+6ZkZ8iQISxevJjp06fTo0cP0ybGtyYMyZIVGPn5+TF8+PA86H3OFSpUCAcHBy5evMhff/2Vb0Fa1qjWwYMHc1Q/a0pkfHx8tnWyRihzMn0yp7KSt8yZM4fu3bsTGRlJUlISTZs2xdXVNc+uIyIiD8/777/PxIkTTVMc7xagHT9+nM2bN9OpUyfs7e3Nji1btsy0l+hrr71G5cqVzY736NGDTz75hP379zNmzBg+/PBDU6C2YcMGvvjiCwCLjMYiIlkKdJCWnJwMZD8l7rvvvrvj+c2aNaNRo0bs3LmT999/n+PHj+Pt7c0zzzxjUbdt27bMmjWL8PBwhg0bZtrD62HYv38/f/31F4ULF87RurYHpU2bNowYMYKVK1dy+vRpnJ2d71jfy8uLkiVLkpyczPLlyy22ELh69appnxlfX98862fHjh0ZPHgwUVFRnDhxQglDREQeccuXL+fjjz8GoE6dOqb147crX748n332GZD5HaFnz54MHDgQT09PnnjiCa5evcqBAwdMf8T19fW1WJsOUKxYMSIiIvD19eXjjz9m0aJFeHh4cOrUKXbs2EFGRga9e/dm4MCBD+iOReRRV6DXpD355JMArF+/3iKpxsyZMwkLC7trG0OHDgVgwoQJgPVRNMgcQfP29mbHjh0EBARYXXf2999/ExQURHp6+j3dR3R0NJGRkVbP27NnD6+++iqQOf2ibNmyZsdHjBiBm5sbI0aMuKdr3sm0adNwc3OjV69eZuUeHh74+flx9epV/Pz8OH78uNnx9PR0li9fbnptb2/PG2+8AWQu8r41k+b169cZOnQof/75JzVr1qRTp0551n8HBwe6detGRkYGEydOZNWqVRQvXpyuXbvm2TVEROThyfqjLGQmpZo3b57Vx62ZgqtWrcp7773HM888Q0JCApGRkaxcuZJLly7x4osvsmDBAtatW5ftmrJ//OMf7N+/nzfeeIMbN24QGRnJwYMHee6551i4cCFz5859qH+wFZFHS4EeSfP09MTPz48ff/wRT09PWrRoQbly5YiNjSUuLo6RI0ea/vKWna5du/LOO++QmJhIhQoVsv0iX6hQIZYtW8YLL7xg+kXQsGFDqlWrRlpaGkePHmXfvn3cuHEDf39/qxkgs/PHH38QEBCAo6Mjnp6eVKlShUuXLhEfH8++ffuAzFE/a3/tO3PmDHFxcZw5c8bi2J49e0xpggGOHDkCQHBwMD/99JOpfOnSpVSpUsX0Oikpibi4OIvpH5CZgKNdu3bExMRQt25dmjZtirOzM3/++Sf79u3j7NmzZmsAP/jgA3bt2sX69et58skn8fX1pVSpUmzfvp3jx4/j5OREeHh4nm8vEBAQQHBwsOmvrd27d7dYGH6rJk2amJ5nBeA7d+40Kx89ejQvvPBCnvZTRETuzt/fH39//3s6x8nJyfQH2NyqUqUK06ZNY9q0affVjogUPAU6SIPMPdCmTJlCaGgo0dHR2Nvb4+XlxdSpU6lbt+5dg7RixYrRokULwsLC6NevH3Z2dtnWdXZ2JiYmhrlz5xIWFsavv/7Kjh07KFeuHM7OzgwYMICXX37ZYu773bRo0YLRo0cTHR3NH3/8wfbt28nIyKBixYq89NJLdOvWjW7dut1zEo0LFy6Y7f2S5eTJk2bphlNTU3PcZtmyZdm0aRMhISEsWLCA2NhYtm3bRsWKFfHw8KB9+/Zm9e3s7Fi1ahWzZs0iNDSULVu2kJqaStWqVXnzzTd577338nQ9WpbGjRtTv359fvvtN+DuUx2tvU+3v3/WRk9FRERERG5nMFpLXSg5dv78eVxcXLh27Rrx8fEFKnOiPFzNmzcnMTGRwiWLU6Nv5/zujtiwiPR1+Xp9h/Ij8/X68mgxdn8+v7sgIpKnsr6zVapUic2bN+eqjQK9Ji0vfPrpp1y+fJkuXbooQBMRERERkftW4Kc75sa2bdsICQkhPj6eqKgoihcvzkcffZTf3RIRERERkceAgrRcOHToELNnz8bBwYEmTZowceLEfE1tLyIiIiIijw8FabmQmyxRIiIiIiIiOaE1aSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQ7RPmsgjpnyJUqwcNDK/uyE2LX//+zDm69VFREQefRpJExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSFF8rsDInJvki5fpN03n+R3N+QhiEhfl99dAMCh/Mj87oI8xozdn8/vLoiI2ByNpImIiIiIiNgQBWkiIiIiIiI2REGaiIiIiIiIDVGQJiIiIiIiYkMUpImIiIiIiNgQBWkiIiIiIiI2REGaiIiIiIiIDVGQJiIiIiIiYkMUpImIiIiIiNgQBWkiIiLyWLt+/Trr16/nnXfewdvbG0dHR4oWLUrlypV5+eWXWbFihdXzxo0bh8FguOPj4MGDd7z25s2b6datGy4uLtjZ2VG+fHkaNWrE22+/zfXr1x/E7YrIY6BIfndARERE5EHatGkT//rXvwCoXLkyPj4+lChRggMHDhAZGUlkZCT9+/cnKCgIg8FgcX7Dhg3x8PCw2naZMmWslhuNRt5++22mTJlC0aJFady4Mc2bNycpKYnff/+dr776ivHjx1O0aNE8u08ReXwUqCCtRo0aJCQkEB8fT40aNfK7O3lq2rRpbNmyhX379vHXX3+RkpJCqVKlcHd3p2vXrvTv3/+efxHExcWxZs0adu/eze7du/n999+5ceMG48eP5/33339Ad/Lo2bt3L6tWrWLdunXs37+f5ORkSpYsibu7O926dcvV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aNiwIdWqVSMtLY2jR4+yb98+bty4gb+/v9UMkNn5448/CAgIwNHREU9PT6pUqcKlS5eIj49n3759QOaon7W/9p05c4a4uDjOnDljcWzPnj2mNMEAR44cASA4OJiffvrJVL506VKqVKliep2UlERcXJzF9A/ITMDRrl07YmJiqFu3Lk2bNsXZ2Zk///yTffv2cfbsWbM1gB988AG7du1i/fr1PPnkk/j6+lKqVCm2b9/O8ePHcXJyIjw8PM+3FwgICCA4ONj019bu3btbLAyHzM3CO3ToQFpaGi4uLmzbts1qdk6Azz77jPLly+dpP0VE5O78/f3x9/e/p3OcnJzue/uUKlWqMG3aNKZNm3Zf7YhIwVOggzTIzMQ3ZcoUQkNDiY6Oxt7eHi8vL6ZOnUrdunXvGqQVK1aMFi1aEBYWRr9+/e64YbGzszMxMTHMnTuXsLAwfv31V3bs2EG5cuVwdnZmwIABvPzyyxZz3++mRYsWjB49mujoaP744w+2b99ORkYGFStW5KWXXqJbt25069btnpNoXLhwwWzvlywnT540Szecmpqa4zbLli3Lpk2bCAkJYcGCBcTGxrJt2zYqVqyIh4cH7du3N6tvZ2fHqlWrmDVrFqGhoWzZsoXU1FSqVq3Km2++yXvvvZen69GyNG7cmPr16/Pbb78B2U91vHLliun+T548ybx587Jtc9y4cQrSREREROSuDEZrqQslx86fP4+LiwvXrl0jPj6+QGVOlIerefPmJCYmUrhkcWr0VVr/giAifV1+dwEAh/Ij87sL8hgzdn8+v7sgIpKnsr6zVapUic2bN+eqjQK9Ji0vfPrpp1y+fJkuXbooQBMRERERkftW4Kc75sa2bdsICQkhPj6eqKgoihcvzkcffZTf3RIRERERkceAgrRcOHToELNnz8bBwYEmTZowceLEfE1tLyIiIiIijw8FabmQmyxRIiIiIiIiOaE1aSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQ7RPmsgjpnyJUqwcNDK/uyEPhW18zsb87oCIiEgBo5E0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG1IkvzsgIvcm6fJF2n3zSX53Q0SyEZG+Lr+7cE8cyo/M7y6IiDxWal5Jpeh9tqGRNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERtSJL87ICIiIiIiBUDQJNiy9s515qyAYsVuvr54AfZsh2OHIf4wJByBtFSo7wkjJ2XfzukT8MtO2LcLjh+FCylQtBg4u4CXD7RuD/YOeXJbD4KCNBEREREReXjq1YdKztaPFbptol/cPpj52b1f45N34e+kzMCsVj1wawAp5+HwATh6CDatgpGToXzFe2/7IShQQVqNGjVISEggPj6eGjVq5Hd3HrguXboQHh4OwPz58+nRo0eu2gkPD2f69On88ssvpKWlUadOHV577TXefvttihYtmpddfiRdvnyZH3/8kd27d7N792727NnDxYsXqV27Nn/88Ud+d09ERETEtrRoC8+1zlndMmWh5QtQsy7UqJM5mhYy5e7nObtAp97Q5DnzEbOzf8Jno+HkMQieDKMm5+oWHrQCFaQVJGFhYYSHh2MwGDAajblu56233mLKlCkUKVKEli1bUrJkSaKionjvvfeIjIxkzZo1ODjY7lDxw3D48GFee+21/O6GiIiIyOOn7lOZjywnjuXsvJHZBF8VKkOfofDh23AgFs6dBacK99vLPKcg7TGUmJjIG2+8gaenJ8WLF2fr1q25amfZsmVMmTKFkiVLsmnTJp5++mkAkpKSaNmyJdHR0YwePZrPPsvFEPRjpFSpUgQEBPD000/j6enJ+fPnefHFF/O7WyIiIiJiTfXaN58n22aQpuyOj6H+/ftz4cIF5syZQ5EiuY/DP/nkEwACAwNNARpA+fLl+eabbwCYNm0aKSkp99fhR1zt2rUJCQlh8ODBNGvWjBIlSuR3l0RERERs1++/wHdB8O2XsGg27IyG62kP7/p/nrr53LHcw7vuPSjwQVpCQgITJ06kZcuWVKtWDTs7OxwdHfHx8SE4OJiMjAyz+hs2bMBgMODm5pbtNMJr167h5OSEwWDgwIEDZseuXr3K559/TpMmTXB0dMTe3h5XV1feffddzp07Z9HW3LlzMRgM+Pv7k5yczFtvvUXt2rWxs7OjRYsW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OC8lJYW4uDire41NmjSJ+Ph4li9fTsOGDWncuDE1a9YkKSmJ3377jVOnThEfH28K/P7zn/+wbds25s+fj5eXF8899xwVK1Zkz549xMXF4eDgwIIFCyzWAN6vXr168f7775tGU5s3b06dOnWyrf/KK6+Y3sOsRDMnT56kSZMmpjr9+vWjX79+edpPERERkUdCxSrQc2Duzv1+7cM5x4YU6JE0yNwDbfLkybi6uhIdHc2aNWuoVq0aq1evztEX6mLFitGiRQsg80v4nbIrOjs7ExMTQ1BQEM888wxxcXEsWbKE6OhoIDNt/+rVq7G3t8+Te8sLU6ZMISwsjGeffZZt27axcuVKXFxcmDBhAlFRUdkmNMlOsWLFWLZsGQsWLOD555/n0KFDhIeH8+uvv1KrVi0mT55M5cqVTfUNBgOhoaEsWLAAHx8fdu/ezZIlS7hy5Qr+/v7s3buXtm3b5vVt4+zsTOvWrU2v75YwZO/evfz888/8/PPP/P7770Dm1g5ZZT///DMnT57M836KiIiIyOPHYLzTgia5q/Pnz+Pi4sK1a9eIj483JQgRyWvNmzcnMTGRwiWLU6Nv5/zujohkIyJ9XX534Z44lB+Z310QEXms1PxiFEUvnqdSpUps3rw5V20U+JG0+/Xpp59y+fJlunTpogBNRERERETuW4Fek5Zb27ZtIyQkhPj4eKKioihevDgfffRRfndLREREREQeAwrScuHQoUPMnj0bBwcHmjRpwsSJE6lVq1Z+d0tERERERB4DCtJywd/fX+nYRURERETkgdCaNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIdonTeQRU75EKVYOGpnf3RCRbD1a/z6N+d0BEZHHTPOgD0m8eH9taCRNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhhTJ7w6IyL1JunyRdt98kt/dEJF8EJG+Lr+7YDMcyo/M7y6IiFhV80oqRe+zDY2kiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiI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hReYN2+eKQV9tWrVSEtL4+jRo+zbt48bN27g7+9vNQPkg3DmzBni4uI4c+aMxbH27dszZMgQpk6dSpMmTWjVqhUlSpRg/fr1nD9/nmbNmjF+/HiL81JSUoiLi7O619ikSZOIj49n+fLlNGzYkMaNG1OzZk2SkpL47bffOHXqFPHx8abA7z//+Q/btm1j/vz5eHl58dxzz1GxYkX27NlDXFwcDg4OLFiwwGIN4P3q1asX77//vmk0tXnz5tSpU8dq3X//+9+kpKTg6OjIqVOnsg3mAgMDc5w0RUREROSxUrEK9ByYu3O/X/twzrEhBTpIg8w90KZMmUJoaCjR0dHY29vj5eXF1KlTqVu37l2DtGLFitGiRQvCwsLo16/fHbMrOjs7ExMTY9o/69dff2XHjh2UK1cOZ2dnBgwYwMsvv4y9vX1e32auTZkyhWbNmjF9+nS2bdvG9evXqV27NoGBgbz99tv3vGl2sWLFWLZsGYsWLWLu3Lns3r2bXbt24eTkRN26dXnrrbeoXLmyqb7BYCA0NJS2bdsyc+ZMdu/ezeXLl6lcuTL+/v4EBgbi6uqa17eNs7MzrVu3ZuXKlcCdE4b8/XfmX2DOnz/PvHnzsq2XtT+biIiIiMidGIx3WtAkd3X+/HlcXFy4du0a8fHxpgQhInmtefPmJCYmUrhkcWr07Zzf3RGRfBCRvi6/u2AzHMqPzO8uiIhYVfOLURS9eJ5KlSqxefPmXLVRoNek5YVPP/2Uy5cv06VLFwVoIiIiIiJy3wr8dMfc2LZtGyEhIcTHxxMVFUXx4sWVbl1ERERERPKEgrRcOHToELNnz8bBwYEmTZowceJEatWqld/dEhERERGRx4CCtFzw9/fPNoOfiIiIiIjI/dCaNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIdonTeQRU75EKVYOGpnf3RCRfKF/+1mM+d0BEZFsNA/6kMSL99eGRtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsSJH87oCI3Jukyxdp980n+d0NEXmIItLX5XcXbIpD+ZH53QURkWzVvJJK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qnzyySf88ssvppGh++Xt7U1sbCxvvPEGhQsXZunSpWzZsgVPT09mzJjBTz/9lOsNv8ePH8+7776Lo6Mjy5YtY/bs2cyePdtsTVmvXr2IjY2lb9++FCpUiMjISNavX09aWhpvvPEGXbp0MWuzQ4cO/PTTTzRr1oxDhw6xcuVKihYtyqJFi+64Rm/gwIF8+umnVK9enZUrV5r6Yi3otqZ48eJs3LiRTz/9lCeeeIKVK1eyfft2nn32WRYvXsznn3+eq/dIRERERAomgzEvF3fl0vnz53FxceHatWvEx8ebEoSIyE3NmzcnMTGRwiWLU6Nv5/zujog8RBHp6/K7CzbFofzI/O6CiEi2an4xiqIXz1OpUiU2b96cqzYebl72bHz66adcvnyZLl26KEATEREREZEC7eEs2rJi27ZthISEEB8fT1RUFMWLF+ejjz7Kr+6IiIiIiIjYhHwL0g4dOsTs2bNxcHCgSZMmTJw4kVq1auVXd0RERERERGxCvgVp/v7++Pv759flRUREREREbJJNrEkTERERERGRTArSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuSb/ukiUjulC9RipWDRuZ3N0TkodK/+VsZ87sDIiJ30DzoQxIv3l8bGkkTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIQrSREREREREbIiCNBERERERERuiIE1ERERERMSGKEgTERERERGxIUXyuwMicm+SLl+k3Tef5Hc3RB5ZEenr8rsLJg7lR+Z3F0REJI/VvJJK0ftsQyNpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEAVpIiIiIiIiNqRIfndAREREREQKgKBJsGXtnevMWQHFit18ffEC7NkOxw5D/GFIOAJpqVDfE0ZOyr6d0yfgl52wbxccPwoXUqBoMXB2AS8faN0e7B3y5LYeBAVpIiIiIiLy8NSrD5WcrR8rdNtEv7h9MPOze7/GJ+/C30mZgVmteuDWAFLOw+EDcPQQbFoFIydD+Yr33vZDUKCCtBo1apCQkEB8fDw1atTI7+48cF26dCE8PByA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iIjYEAVpIiIiIiIiNkRBmoiIiIiIiA1RkCYiIiIiImJDFKSJiIiIiIjYEO2TJvKIKV+iFCsHjczvbog8wmzn348xvzsgIiJ5rnnQhyRevL82NJImIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQ4rkdwdE5N4kXb5Iu28+ye9uiMgDEpG+Lr+78FhzKD8yv7sgIo+5mldSKXqfbWgkTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIYUye8OiIiIiIhIARA0CbasvXOdOSugWLGbry9egD3b4dhhiD8MCUcgLRXqe8LISdm3c/oE/LIT9u2C40fhQgoULQbOLuDlA63bg71DntzWg6AgTUREREREHp569aGSs/VjhW6b6Be3D2Z+du/X+ORd+DspMzCrVQ/cGkDKeTh8AI4egk2rYORkKF/x3tt+CApUkFajRg0SEhKIj4+nRo0a+d2dB65Lly6Eh4cDMH/+fHr06HFP58fFxbFmzRp2797N7t27+f3337lx4wbjx4/n/ffffxBdfiTt3buXVatWsW7dOvbv309ycjIlS5bE3d2dbt260b9/f4oWLZrf3RQRERGxDS3awnOtc1a3TFlo+QLUrAs16mSOpoVMuft5zi7QqTc0ec58xOzsn/DZaDh5DIInw6jJubqFB61ABWkFSVhYGOHh4RgMBoxGY67amDFjBlOm5OAfQQGWnp7O008/DUDJkiXx9vamUqVKnDx5ku3btxMdHU1oaCirV6/G0dExfzsrIiIi8qip+1TmI8uJYzk7b2Q2wVeFytBnKHz4NhyIhXNnwanC/fYyzylxyGMoMTGRN954A09PT5o2bZrrdtzd3Rk+fDjff/89v//+Oz179szDXj4+GjVqxOLFi0lKSiIqKoqFCxeyZcsW9u7dS5UqVdixYwf//e9/87ubIiIiIgJQvfbN58ln868fd6CRtMdQ//79uXDhAnPmzGHo0KG5bqdfv35mrwvdPkdYKFKkCLt27bJ6rEGDBkyaNImePXuyaNEigoODNe1RRERE5Pdf4EQ8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i4tj5MiRfPzxx3dso2vXrrzzzjskJiZSoUKFbL/IFypUiGXLlvHCCy8wb948lixZQsOGDalWrRppaWkcPXqUffv2cePGDfz9/a1mgHwQzpw5Q1xcHGfOnLE4tmfPHgYNurnJ35EjRwAIDg7mp59+MpUvXbqUKlWqmF4nJSURFxdH5cqWO7jPmTOHdu3aERMTQ926dWnatCnOzs78+eef7Nu3j7Nnz5qNDH7wwQfs2rWL9evX8+STT+Lr60upUqXYvn07x48fx8nJifDw8DzfFy4gIIDg4GBTts7u3bubbZuQ5a+//qJDhw6kpaXh4uLCtm3brGbnBPjss88oX758nvZTRERE5JFQsQr0HJi7c79f+3DOsSEFOkiDzEx8U6ZMITQ0lOjoaOzt7fHy8mLq1KnUrVv3rkFasWLFaNGiBWFhYfTr1++O2RWdnZ2JiYlh7ty5hIWF8euvv7Jjxw7KlSuHs7MzAwYM4OWXX8be3j6vbzNXLly4wM8//2xRfvLkSU6ePGl6nZqamuM2y5Yty6ZNmwgJCWHBggXExsaybds2KlasiIeHB+3btzerb2dnx6pVq5g1axahoaFs2bKF1NRUqlatyptvvsl7772Xp+vRsjRu3Jj69evz22+/AdlPdbxy5Yrp/k+ePJntRtgA48aNU5AmIiIiIndlMN5pQZPc1fnz53FxceHatWvEx8ebEoSI5LXmzZuTmJhI4ZLFqdFXaf1FHlcR6evyuwuPNYfyI/O7CyLymKv5xSiKXjxPpUqV2Lx5c67aKNBr0vLCp59+yuXLl+nSpYsCNBERERERuW8Ffrpjbmzbto2QkBDi4+OJioqiePHifPTRR/ndLREREREReQwoSMuFQ4cOMXv2bBwcHGjSpAkTJ06kVq1a+d0tERERERF5DChIywV/f3/8/f3zuxsiIiIiIvIY0po0ERERERERG6IgTURERERExIYoSBMREREREbEhCtJERERERERsiII0ERERERERG6IgTURERERExIYoSBMREREREbEh2idN5BFTvkQpVg4amd/dEJEHRv++HyRjfndARB57zYM+JPHi/bWhkTQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEK0kRERERERGyIgjQREREREREboiBNRERERETEhihIExERERERsSEGo9FozO9OiMjd1a9fn/T0dAoVKkSFChXyuzsiIiIiYsXZs2fJyMigSJEi/Pbbb7lqo0ge90lEHpCMjAzTz8TExHzujYiIiIjcSdZ3t9xQkCbyiChWrBhpaWkUKlQIJyen/O6OiIiIiFhx7tw5MjIyKFasWK7b0HRHERERERERG6LEISIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkiYiIiIiI2BAFaSIiIiIiIjZEQZqIiIiIiIgNUZAmIiIiIiJiQxSkidi48PBwWrRoQdmyZSlRogQNGzZk0qRJXL9+Pb+7Jv8vLi6Or7/+Gn9/fxo0aECRIkUwGAx89NFHdz133bp1tGvXjvLly+Pg4ICbmxujRo3i0qVLdzzvjz/+wN/fHxcXF+zs7HBxccHf35+jR4/m1W3JLa5fv8769et555138Pb2xtHRkaJFi1K5cmVefvllVqxYccfz9Tk/Gr7//nt69epFw4YNqVixIkWLFqVMmTI888wzfPrpp3f8vPQZP7reffddDAbDXf+/rc/40eHv72/6TLN7XLt2zeq5u3fvpnPnzlSqVAl7e3tq1qzJm2++yV9//XXHayYmJjJ48GBq1qyJnZ0dlSpVonPnzuzZsyd3N2EUEZs1dOhQI2AsUqSI8d///rex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",
      "text/plain": [
       "<Figure size 900x1200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# HORIZONTAL BAR PLOT\n",
    "save_fig= True\n",
    "fig_savename= \"resnet18_width\"\n",
    "fig, ax = plt.subplots(1,1,figsize=(9,12))\n",
    "#plt.suptitle(f'Per-layer sparsity distribution in {args.resnet_type} with base width {args.noc1_base}', fontsize=title_font_size)\n",
    "\n",
    "\n",
    "lnames= list(tdims.keys())\n",
    "lnames.remove('linear')\n",
    "y_pos = np.arange(len(lnames))\n",
    "\n",
    "x_val = [pruner.W[i].shape[0] for i in range(len(pruner.W)-1)]\n",
    "#x_val = np.zeros(len(pruner.S))\n",
    "error = None\n",
    "\n",
    "bars= ax.barh(y_pos, x_val, xerr=error, align='center', alpha=1, color='white')# , label='orig.width')\n",
    "ax.set_yticks(y_pos)\n",
    "ax.set_yticklabels([l.replace(\"_\",\".\") for l in lnames])\n",
    "ax.invert_yaxis()  # labels read top-to-bottom\n",
    "ax.set_xlabel('Layer Width') #Width Sparsity\n",
    "#ax.set_ylabel('Layer Index')\n",
    "ax.set_xlim([0,512]) \n",
    "value_format= \"{:.0f}\"\n",
    "label_bars(ax, bars, value_format)\n",
    "\n",
    "for run_id in run_ids:\n",
    "    x_val = [masks[run_id][i].shape[0]-MaskNumZeroFilters[run_id][i] for i in range(len(masks[run_id])-1)]\n",
    "    #x_val = [pruner.W[i].shape[0]-NumZeroFilters[run_id][i] for i in range(len(pruner.W))]\n",
    "    #x_val = 100*np.array(sparsity[run_id])\n",
    "    bars= ax.barh(y_pos, x_val, xerr=error, align='center', alpha=1, label=la[run_id])\n",
    "    \n",
    "    #label_bars(ax, bars, value_format)\n",
    "\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "#fig.subplots_adjust(wspace=0.25)\n",
    "plt.show()\n",
    "if save_fig:\n",
    "    fig.savefig(plot_savedir+fig_savename+'.svg', format='svg', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_val = [masks[run_id][i].shape[0]-MaskNumZeroFilters[run_id][i] for i in range(len(masks[run_id])-1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "lnames.remove('linear')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    w= pruner.W[i]\n",
    "    #r= 1-torch.count_nonzero(w)/w.numel()\n",
    "    r= 1-torch.count_nonzero(masks[i])/w.numel()\n",
    "    s= pruner.S[i]\n",
    "    print(f\"{r.item():.4}, {s:.4}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#NumZeroFilters={}\n",
    "NumZeroFilters[run_id]= []\n",
    "\n",
    "for i, w in enumerate(pruner.W):\n",
    "    if pruner.S[i]>0:\n",
    "        num_zero_filters= get_num_allzero_filters(w)\n",
    "    else:\n",
    "        num_zero_filters=0\n",
    "    NumZeroFilters[run_id].append(num_zero_filters)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for k, v in zkf.items():\n",
    "    print(k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.patches as mpatches\n",
    "\n",
    "cmap = mpl.cm.get_cmap('plasma') # rainbow\n",
    "\n",
    "x=2.6\n",
    "title_font_size=5.5*x\n",
    "label_font_size=5.5*x\n",
    "tick_font_size=5*x\n",
    "legend_font_size=23*x/6\n",
    "legend_title_font_size=22*x/6\n",
    "\n",
    "#==== plot styling\n",
    "plotparams = {\n",
    "              'legend.fontsize': legend_font_size,\n",
    "              'legend.title_fontsize': legend_title_font_size,\n",
    "              'axes.labelsize': label_font_size,\n",
    "              'axes.titlesize': title_font_size,\n",
    "              'xtick.labelsize': tick_font_size,\n",
    "              'ytick.labelsize': tick_font_size\n",
    "}\n",
    "plt.style.use(plotparams)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "    \n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "lrs=[]\n",
    "for _ in list(range(1,149)):\n",
    "    scheduler.step()\n",
    "    lrs.append(scheduler.get_last_lr())\n",
    "\n",
    "plt.plot(lrs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "scheduler_state_dict, optimizer_state_dict = checkpoint.get_state()[\"scheduler\"], checkpoint.get_state()[\"optimizer\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_optim = get_optimizer(cfg, model, optimizer_state_dict)\n",
    "ckp_scheduler= get_lr_scheduler(cfg, new_optim, state_dict=scheduler_state_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ckp_scheduler.state_dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "    \n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "lrs=[]\n",
    "for _ in list(range(149,501)):\n",
    "    ckp_scheduler.step()\n",
    "    lrs.append(ckp_scheduler.get_last_lr())\n",
    "\n",
    "plt.plot(lrs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ckp_scheduler.__dict__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "lrs = []\n",
    "for epoch in list(range(1,150)):\n",
    "    scheduler.step()\n",
    "    lrs.append(scheduler.get_last_lr())\n",
    "print(lrs)\n",
    "plt.plot(lrs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pruner.__str__()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# net = ModelFactory.load_model(\"wide_resnet22\", \"cifar10\")\n",
    "model = ModelFactory.load_model(\"resnet50\", \"imagenet\")\n",
    "device = torch.device(\"cuda:0\")\n",
    "train_loader, test_loader = get_dataloaders(cfg)\n",
    "# model = ModelFactory.load_model(\n",
    "#         model=cfg.model.name, dataset=cfg.dataset.name\n",
    "#     )\n",
    "model.to(device)\n",
    "optimizer = get_optimizer(cfg, model, state_dict=None)\n",
    "scheduler = get_lr_scheduler(cfg, optimizer, state_dict=None)\n",
    "T_end = get_T_end(cfg, train_loader)\n",
    "if cfg.rigl.const_fan_in:\n",
    "    rigl_scheduler = RigLConstFanScheduler\n",
    "else:\n",
    "    rigl_scheduler = RigLScheduler\n",
    "# pruner = rigl_scheduler(\n",
    "#     model,\n",
    "#     optimizer,\n",
    "#     dense_allocation=cfg.rigl.dense_allocation,\n",
    "#     alpha=cfg.rigl.alpha,\n",
    "#     delta=cfg.rigl.delta,\n",
    "#     static_topo=cfg.rigl.static_topo,\n",
    "#     T_end=T_end,\n",
    "#     ignore_linear_layers=False,\n",
    "#     grad_accumulation_n=cfg.rigl.grad_accumulation_n,\n",
    "#     sparsity_distribution=cfg.rigl.sparsity_distribution,\n",
    "#     erk_power_scale=cfg.rigl.erk_power_scale,\n",
    "#     state_dict=None,\n",
    "#     filter_ablation_threshold=cfg.rigl.filter_ablation_threshold,\n",
    "#     static_ablation=cfg.rigl.static_ablation,\n",
    "#     dynamic_ablation=cfg.rigl.dynamic_ablation,\n",
    "#     min_salient_weights_per_neuron=cfg.rigl.min_salient_weights_per_neuron,\n",
    "#     )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pruner(\n",
    "    \n",
    ")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.13 | packaged by conda-forge | (default, Mar 25 2022, 06:05:16) \n[Clang 12.0.1 ]"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "00f07e3d2e37fed0934a5fcb5990cf0253b1979f588b0b82b40c3b7117a4b479"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
