{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../')\n",
    "from quantization.posttraining.layer_scale_optimization import *\n",
    "from collections import namedtuple\n",
    "from tqdm import tqdm\n",
    "from mpl_toolkits import mplot3d\n",
    "%matplotlib inline\n",
    "import numpy as np\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import cm\n",
    "from quantization.methods.clipped_uniform import L2NormQuantization, L3NormQuantization, AciqLaplaceQuantization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Namespace(arch='resnet18', batch_size=64, bit_act=2, bit_weights=None, cal_batch_size=64, cal_set_size=64, custom_resnet=True, datapath=None, dataset='imagenet', gpu_ids=[0], pre_relu=False, pretrained=True, print_freq=10, qtype='max_static', shuffle=True, workers=25)"
      ]
     },
     "execution_count": 125,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "args_dict = {'arch': 'resnet18', 'custom_resnet': True, 'pretrained': True, 'dataset': 'imagenet', 'gpu_ids': [0], 'datapath': None,\n",
    "                     'batch_size': 64, 'shuffle': True, 'workers': 25, 'print_freq': 10,\n",
    "                     'cal_batch_size': 64, 'cal_set_size': 64}\n",
    "args_dict['bit_act'] = 2\n",
    "args_dict['bit_weights'] = None\n",
    "args_dict['pre_relu'] = False\n",
    "args_dict['qtype'] = 'max_static'\n",
    "args = argparse.Namespace()\n",
    "for k in args_dict:\n",
    "    setattr(args, k, args_dict[k])\n",
    "args"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {},
   "outputs": [],
   "source": [
    "if 'inf_model' in globals():\n",
    "    del inf_model\n",
    "\n",
    "# create model\n",
    "# Always enable shuffling to avoid issues where we get bad results due to weak statistics\n",
    "inf_model = CnnModel(args.arch, args.custom_resnet, args.pretrained, args.dataset, args.gpu_ids, args.datapath,\n",
    "                     batch_size=args.batch_size, shuffle=True, workers=args.workers, print_freq=args.print_freq,\n",
    "                     cal_batch_size=args.cal_batch_size, cal_set_size=args.cal_set_size)\n",
    "\n",
    "all_layers = []\n",
    "if args.bit_weights is not None:\n",
    "    all_layers += [n for n, m in inf_model.model.named_modules() if isinstance(m, nn.Conv2d)][1:-1]\n",
    "if args.bit_act is not None:\n",
    "    all_layers += [n for n, m in inf_model.model.named_modules() if isinstance(m, nn.ReLU)][1:-1]\n",
    "if args.bit_act is not None and 'mobilenet' in args.arch:\n",
    "    all_layers += [n for n, m in inf_model.model.named_modules() if isinstance(m, nn.ReLU6)][1:-1]\n",
    "    \n",
    "if 'mq' in globals():\n",
    "    del mq\n",
    "\n",
    "layers = all_layers # [all_layers[1], all_layers[2]]\n",
    "replacement_factory = {nn.ReLU: ActivationModuleWrapperPost,\n",
    "                       nn.ReLU6: ActivationModuleWrapperPost,\n",
    "                       nn.Conv2d: ParameterModuleWrapperPost}\n",
    "mq = ModelQuantizer(inf_model.model, args, layers, replacement_factory)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ActivationModuleWrapperPost - layer1.0.relu1 | MaxAbsStaticQuantization - [alpha: 3.8490, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer1.0.relu2 | MaxAbsStaticQuantization - [alpha: 6.5176, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer1.1.relu1 | MaxAbsStaticQuantization - [alpha: 3.9670, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer1.1.relu2 | MaxAbsStaticQuantization - [alpha: 13.9871, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer2.0.relu1 | MaxAbsStaticQuantization - [alpha: 5.5198, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer2.0.relu2 | MaxAbsStaticQuantization - [alpha: 11.6134, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer2.1.relu1 | MaxAbsStaticQuantization - [alpha: 5.9953, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer2.1.relu2 | MaxAbsStaticQuantization - [alpha: 11.2895, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer3.0.relu1 | MaxAbsStaticQuantization - [alpha: 7.0255, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer3.0.relu2 | MaxAbsStaticQuantization - [alpha: 9.8070, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer3.1.relu1 | MaxAbsStaticQuantization - [alpha: 6.7907, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer3.1.relu2 | MaxAbsStaticQuantization - [alpha: 11.2569, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer4.0.relu1 | MaxAbsStaticQuantization - [alpha: 6.1086, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer4.0.relu2 | MaxAbsStaticQuantization - [alpha: 15.1235, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "ActivationModuleWrapperPost - layer4.1.relu1 | MaxAbsStaticQuantization - [alpha: 5.4826, bits: 2, symmetric: False, tails: False, ] | cuda:0\n",
      "loss: 20.9363\n",
      "tensor([ 3.8490,  6.5176,  3.9670, 13.9871,  5.5198, 11.6134,  5.9953, 11.2895,\n",
      "         7.0255,  9.8070,  6.7907, 11.2569,  6.1086, 15.1235,  5.4826],\n",
      "       device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "loss = inf_model.evaluate_calibration()\n",
    "print(\"loss: {:.4f}\".format(loss.item()))\n",
    "\n",
    "# get clipping values\n",
    "init = get_clipping(mq)\n",
    "# print(init)\n",
    "\n",
    "init_ = init[0].new_empty(len(init))\n",
    "for i in range(len(init)):\n",
    "    init_[i] = init[i]\n",
    "    \n",
    "print(init_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "def separability_index(f, m, n, gpu=False, gamma_expecation=True):\n",
    "    x, z = torch.tensor(np.random.uniform(0, 1, size=(n, m))).float(), torch.tensor(np.random.uniform(0, 1, size=(n, m))).float()\n",
    "    if gpu:\n",
    "        x = x.cuda()\n",
    "        z = z.cuda()\n",
    "\n",
    "    print(\"Calaculate f(x)\")\n",
    "    t0 = f(x)\n",
    "    print(\"Calaculate f(z)\")\n",
    "    t1 = t0 + (m - 1)*f(z)\n",
    "\n",
    "    print(\"Calaculate f(xj,zj')\")\n",
    "    t2 = t1.new_zeros((n,))\n",
    "    for i in range(m):\n",
    "        y = z.clone()\n",
    "        y[:,i] = x[:,i]\n",
    "        t2 += f(y)\n",
    "\n",
    "    g = t0 * (t1 - t2)\n",
    "    gamma = g.mean()\n",
    "\n",
    "    s = (g - gamma).std()\n",
    "    T = np.sqrt(n) * gamma / max(s, 1e-8)\n",
    "\n",
    "    if gamma_expecation:\n",
    "        return gamma, T\n",
    "    else:\n",
    "        return g, T\n",
    "\n",
    "# assum x is matrix (n,m) in range [0,1]\n",
    "# n - number of sumples \n",
    "# m - number of variables\n",
    "def model_func(x, scales):\n",
    "    loss = x.new_empty(x.shape[0])\n",
    "    for i in tqdm(range(x.shape[0])):\n",
    "        # set clip value. rescale to [0.5,1] to avoid radical saturation\n",
    "        r = (x[i] + 1) / 2\n",
    "        set_clipping(mq, r*scales, inf_model.device)\n",
    "\n",
    "        # evaluate with clipping\n",
    "        loss[i] = inf_model.evaluate_calibration()\n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 2/50 [00:00<00:03, 13.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bits act: 8\n",
      "Calaculate f(x)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 16.91it/s]\n",
      "  4%|▍         | 2/50 [00:00<00:02, 17.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calaculate f(z)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.20it/s]\n",
      "  4%|▍         | 2/50 [00:00<00:02, 17.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calaculate f(xj,zj')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.21it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.19it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.14it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.98it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.05it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.10it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.11it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.08it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.07it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.07it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.05it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.03it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.02it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.00it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gamma^2: -0.00282\n",
      "T': -0.4046\n",
      "T norm: -0.05721836\n",
      "g: -0.1411\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f175023b550>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(\"bits act: \" + str(args_dict['bit_act']))\n",
    "n = 50\n",
    "gamma, T = separability_index(lambda x: model_func(x, init_), len(init_), n, gpu=True, gamma_expecation=False)\n",
    "g = gamma.cpu().numpy()\n",
    "g_cum = g.cumsum()\n",
    "plt.plot(g_cum);\n",
    "plt.axhline(g.mean())\n",
    "print(\"gamma^2: {:.5f}\".format(gamma.mean()))\n",
    "print(\"T': {:.4f}\".format(T))\n",
    "print(\"T norm: {:.8f}\".format(T / np.sqrt(n)))\n",
    "print(\"g: {:.4f}\".format(g.sum()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 2/50 [00:00<00:03, 14.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bits act: 4\n",
      "Calaculate f(x)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.00it/s]\n",
      "  4%|▍         | 2/50 [00:00<00:02, 17.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calaculate f(z)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.21it/s]\n",
      "  4%|▍         | 2/50 [00:00<00:02, 17.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calaculate f(xj,zj')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.21it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.20it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.15it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.15it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.15it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.13it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.12it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.09it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.10it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.08it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.07it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.96it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.91it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.88it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gamma^2: 0.03523\n",
      "T': 0.3287\n",
      "T norm: 0.04648666\n",
      "g: 1.7614\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f174d9d9438>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(\"bits act: \" + str(args_dict['bit_act']))\n",
    "n = 50\n",
    "gamma, T = separability_index(lambda x: model_func(x, init_), len(init_), n, gpu=True, gamma_expecation=False)\n",
    "g = gamma.cpu().numpy()\n",
    "g_cum = g.cumsum()\n",
    "plt.plot(g_cum);\n",
    "plt.axhline(g.mean())\n",
    "print(\"gamma^2: {:.5f}\".format(gamma.mean()))\n",
    "print(\"T': {:.4f}\".format(T))\n",
    "print(\"T norm: {:.8f}\".format(T / np.sqrt(n)))\n",
    "print(\"g: {:.4f}\".format(g.sum()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 2/50 [00:00<00:03, 13.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bits act: 2\n",
      "Calaculate f(x)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 16.98it/s]\n",
      "  4%|▍         | 2/50 [00:00<00:02, 17.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calaculate f(z)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.28it/s]\n",
      "  4%|▍         | 2/50 [00:00<00:02, 17.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calaculate f(xj,zj')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:02<00:00, 17.27it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.23it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.26it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.25it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.19it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.18it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.17it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.18it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.17it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.16it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.15it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.11it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 17.08it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.99it/s]\n",
      "100%|██████████| 50/50 [00:02<00:00, 16.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gamma^2: 20.44934\n",
      "T': 1.0199\n",
      "T norm: 0.14423628\n",
      "g: 1022.4673\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAD8CAYAAAB6paOMAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvNQv5yAAAIABJREFUeJzt3Xl4lOW5+PHvPZM9ZN83whYIAQFJRNwAAReslda6Htva1lbb2p72qG2xy/G05/Scahdbz6+1etS61Gpxp7ZqAVncAAMIsiYQyAYkgSxkTybz/P6YNzGQPTPJJDP357pyZeZ533nneXXIPc92P2KMQSmllP+yebsCSimlvEsDgVJK+TkNBEop5ec0ECillJ/TQKCUUn5OA4FSSvk5DQRKKeXnBh0IROQJEakUkT3dyn4pIgdEZLeIvCIi0d2O3Ssih0TkoIhc0a38SqvskIis8tytKKWUGo6htAieBK48q2wtMNsYMwcoAO4FEJEc4CZglvWaP4iIXUTswO+BFUAOcLN1rlJKKS8JGOyJxpjNIjLprLJ/dnu6BbjOerwSeN4Y0wocEZFDwALr2CFjTBGAiDxvnbuvv/eOj483kyZN6u8UpZRSZ9m+fftJY0zCQOcNOhAMwleAv1qP03AFhk5lVhlA6Vnl5/d2MRG5HbgdYOLEieTn53uwqkop5ftEpHgw53lksFhEfgQ4gGc9cT0AY8yjxpg8Y0xeQsKAAU0ppdQwud0iEJEvAVcDy8wnGezKgYxup6VbZfRTrpRSygvcahGIyJXA94FrjDFN3Q6tAW4SkWARmQxkAduAD4EsEZksIkG4BpTXuFMHpZRS7hl0i0BEngOWAPEiUgbch2uWUDCwVkQAthhjvm6M2Ssiq3ENAjuAO40xHdZ1vgW8BdiBJ4wxez14P0oppYZIxsN+BHl5eUYHi5VSamhEZLsxJm+g83RlsVJK+TkNBEop5ec0ECilVD+2F1ezq7TW29UYURoIlFKqH/e+/DH3vLDL29UYUZ5cWayUUj6lzeGkqKoRh9NQWt1ERmyYt6s0IrRFoJRSfTh6yhUEANbvr/BybUaOBgKllOpDQUU9AKGBdtYfqPRybUaOBgKllOpDQUUDNoEb8tLZWlRNQ6vD21UaERoIlFKqD4UV9WTGhXPVOSm0dTh5t7DK21UaERoIlFKqDwUV9WQlTiA3M4bIkADW7/fN7iENBEop1YtWRwdHTzUxPSmCALuNJTMS2XCwEqdz7KflGSoNBEop1YsjJxvpcBqykiYAsGxmIicb2thV5nuLyzQQKKVULwoqGgCYnhQBwOLpCdhtwts+OHtIA4FSSvWisKIem8CUhHAAosOCyM2MYZ0PjhNoIFBKqV4UVNQzKS6c4AB7V9my7ET2Hz/NsdpmL9bM8zQQKKVULworGrrGBzotm5kE4HPdQxoIlFLqLC3tHRw91dg1PtBpakI4mXFhPpduQgOBUkqdpaiqEaeBrLMCgYiwNDuR9w6foqnNd1YZayBQSqmzFFa6cgxNP6trCGD5zCTaHE7eP3RqtKs1YjQQKKXUWQoq6rHbhMnx4T2OnTcplgnBAaw/4DvdQ7ofgVJKnaWgooFJcWFnzBjqFBRgY9H0eNbvr8QYg4iMSB0qTrfw6OYiOpyG/7hm1oi8R6dBtwhE5AkRqRSRPd3KYkVkrYgUWr9jrHIRkYdE5JCI7BaR+d1ec6t1fqGI3OrZ21Fj2eoPS7l79S72Hz/t7aoo1a/CivoeA8XdLc1OorK+lb3HPP9ZLqtp4iev7uGSBzbw5PtHaWpzYMzIprUYSovgSeD/AU93K1sFrDfG/EJEVlnPfwCsALKsn/OBh4HzRSQWuA/IAwywXUTWGGNq3L0RNfY9/2EJO0pqeWlHGctnJvHtpdOYmxHt7WopdYaW9g6Kq5u4Zl5an+dcOiMBEVi3v4LZaVEeed8jJxt5eOMhXt5Rjghcl5vO1xdPJTOuZ/eUpw06EBhjNovIpLOKVwJLrMdPARtxBYKVwNPGFca2iEi0iKRY5641xlQDiMha4ErguWHfgRo3ymubuXJWMjNTInnivSOs/P17LJqewLeXTuO8SbHerp5SAByqbMCY3geKO8VNCObcjGjW76/ku8unu/2eP/3bXp56/yiBdhufX5jJ7YumkBod6vZ1B8vdweIkY8xx6/EJIMl6nAaUdjuvzCrrq7wHEbldRPJFJL+qyjdzgPuTNoeTyvpWslMi+M7yLN5btZRVK7LZd6yO6//4Abc/nT/izV+lBuOTGUN9dw0BXHVOCh+X17HbzSR0B0/U86f3jrJyXhrv/OBS/uOaWaMaBMCDs4asb/8e+5dsjHnUGJNnjMlLSEjw1GWVlxyva8YYSLM+4BOCA/j64qm88/2l3HpBJv/cV0FptW8t21fjU0FFAwE2YdIAXTI3npdBRHAAj2wqcuv9nv+whCC7jZ9cnUNiRIhb1xoudwNBhdXlg/W7c911OZDR7bx0q6yvcuXjymtcf+TTYs78phMaZOe6XNdHYs+xulGvl1JnK6yoZ3J8OEEB/f95jAgJ5JaFmbyx5zhHTzYO671a2jt4ZWc5l89KIjY8aFjX8AR3A8EaoHPmz63Aa93Kv2jNHloI1FldSG8Bl4tIjDXD6HKrTPm4MitJV3p0WI9j05MnEGATPi7XQKC8r6CiYcBuoU5fuWgSATYbj707vFbBW3tPUNvUzk3nTRzW6z1lKNNHnwM+AGaISJmI3Ab8ArhMRAqB5dZzgH8ARcAh4P+AbwJYg8T/CXxo/fysc+BY+baymmZsAslRPZu+wQF2pidFsEcDgfKy5rYOSmuaeiSb60tiZAjXzk/jhfwyTja0Dvn9nt9WSkZsKBdOjRvyaz1pKLOGbu7j0LJezjXAnX1c5wngicG+r/IN5TXNJEWG9NncPictirX7K0Z0gY5SAI4OJwH23j+Hn8wYGlyLAOBri6bw1/xSnnr/KHdfPmPQrzt6spEPik5xz+XTsdm8+5nXFBNqVJTXNnUNFPdmdlok1Y1tHKtrGcVaKX9xsqGVZz44yg2PfED2T97kzT0nej2vvxxDfZmaMIHLZibx9AfFNLYOPhHdX/NLsQlcn5cx8MkjTAOBGhXltc09Boq761yUo91DylNqm9p4flsJtzy2hQU/X8dPXttLdWMb6TGh/PjVPdQ2tfV4TUFFA4F2GfIirjsWT6WuuZ3nPywd+GSgvcPJC/llLM1OJCnSOzOFutNAoEZch9NwvLal3xbBzJRI7DbRQKA84p3CKs77+TpWvfwx5TXNfHPJNN787iWs/bdF/OGWXGqb2vjP1/f3eF1hRT1T4icQ2EfXUV9yM2NYMCmWx98por3DOeD5bx+o5GRDq9cHiTtpIFAjrrK+BYfT9NsiCAm0My1hggYC5RF/eu8oceHBvP7ti9lwzxLuuWIG2cmRiAg5qZF8ffFUXtpRxsaDZ+40VlBZP+iB4rPdsXgKx+paeH33sQHPfX5bCUmRwSyZMTbWSGkgUCOuzFpDkB7Tc+pod7PTotgzAkm8RkOH03D/mwd4fluJt6vi92oa29hcUMXKeanMTovqdfLBt5dNY2pCOD96ZQ8NVr9+U5uD0urmIQ0Ud3fpjESyEifwyKaiflfJH6ttZlNBFdfnZvQ5aD3axkYtlE/rWkw2wLL52WmRVNW3UnF6fA0YO52GH7y0m4c3HuY3aws0VYaXvbHnBA6n4Zp5qX2eExxg54Hr5nCsrpkH3jwAuGYMwdAGiruz2YQ7Fk/lwIl6Nhb0nRbnhfwynAZuGAODxJ00EKgRV1472EAw/gaMnU7Dj179mBe3l5GXGUNlfSt7ysdnq8ZXvPZROVMTwslJiez3vNzMWG69YBJPf1DMtiPVFFS4AsHZ21MOxTVzU0mODOGPGw/3+oWgw2lYnV/KxdPimRjXfwt5NGkgUCOurKaZuPAgQoN6bvLRXU5KJCKMmxXGxhjuW7OX57aV8q1Lp/HIF3IRwad2rhpvjtc1s+1oNdfMTRvUepTvXTGD9JhQVr20mz3ldQTZbWTGDv8PdFCAja9eMpmtR6q59Fcb+d/1hZTVNHUdf/fQScprm7nxvLHTGgDdoUyNgoGmjnYKDw5gSnz4uPhGbYzhZ6/v45ktxdyxaAp3Xz4dEeHcjGjePuCZ1MRq6F7fdRxj6LdbqLvw4AD+59pz+MLj2yiubiIrcYLb/fZfuWgyMWFBvLi9jF+vLeDXawu4cGocn5ufzht7jhMTFsjls5IGvtAo0haBGnHlNf0vJuvunLQo9o7x5HPGGH7xxgH+9N5RvnzRJFatyO769rlsZhK7y+qoHGfjHL5iza5jzEmP6nWv4b5ckpXA9bnpdDjNsAeKu7PZhM/lpvPc7Qt55/uX8m/Lp1NW08zdL+xi3f5Krp2f3usWmN6kgUCNKGOMq0UwyEAwOy2K43Utw8rbMloeXFfII5uL+PzCifz71TlndEEsm5kIuOaJq97VNLax6qXdHg+WRVUNfFxexzVzB9ca6O7Hn8phRlIEi6d7djpnRmwY31mexabvLWH1HRfwzSVTuWPxFI++hydoIFAj6lRjGy3tTtIH0TUEMCt1bA8YHznZyEPrC7l2fho/u2Z2j37oGUkRpEWHsl4DQZ9e332M5z8s5fsv7fboDKs1u44hAlfPGXogiAoL5K1/W8TnctM9Vp/uRIQFk2P5/pXZXttzoD8aCNSI+mQfgsENwM1Kc830GKuB4LltJQTYhFUrsntNFCYiLM1O5N3Ck7S0d3ihhmPfpoKTBNiEjQereHarZ9ZdGGNYs+sY50+O7TXDreqfBgI1ogY7dbRTZEggk+LCxuSAcUt7By/kl3L5rKR+v9UtnZlIc3sHW4pOjWLtxoc2h5P3D5/kxvMyuCQrnp//ff+wN3Xpbu+x0xRVNXLN3L43nFd900CgRlRfO5P1Z1Za1JjcreytvSeoaWrnXxZk9nveBVPiCA20s36/dg+dLb+4mqa2DpbMSOSX180l0C7ctfojHIPIz9OfNbuOEWgXVsxO9lBN/YsGAjWiymubiQgOICo0cNCvOSctirKaZmoae2aH9KZnt5QwKS5swE1EQgLtXJwVz9sHKnWV8Vk2F5wk0C5cMDWO5KgQ/vMzs9lRUssjm4e/76/TafjbrmMsykogxovbPY5nGgjUiCqraRpSawBgtjVgvHcM5R0qrKhn29Fqbl4wcVCbiCzLTqS8tpmDFfWjULvxY1NBFbmZMUwIdi1hWjkvjavnpPDg2oJhjwt9eLSa43Utg147oHrSQKBGVFlN86BnDHWabQ0Yj6UVxs9uLSHIbuO6Qc4qWZrtmkaq3UOfqDzdwv7jp1k8PfGM8v/6zGxiw4O4a/VHwxpgX7PrGKGBdpbPHFuLtMYTDQRqRA1lDUGn6LAg0mNCx8w4QXNbBy/vKOPK2cnETQge1GsSI0OYkx7F+v2abqLT5sKTACyaHn9GeXRYEA9cN4eCigZ+s7ZgSNds73Dyj4+PszwnifBgTZQwXPpfTo2Y0y3t1Lc4htw1BK7uob1jpEXw+u5jnG5xcMv5Q9tEZGl2Ir9bX8iphtZBBxBftqmgioSI4F6TwS2ZkcjnF07k/94poqaxjUnx4WTEhpERE8rE2DBiw4O61mw4nYbm9g6a2jp479BJaprah7WITH1CA4EaMZ+knx56Eq9z0qN4c+8JTre0Exky+IHmkfCXbSVMS5zAgsmxQ3rdsuwkfruukI0Hq0ZsodJ40eE0vFtYxdLspD6Twf3wqpmcqGvl7QOVnDprokB4kJ3gQDtNbQ5a2s+cYRQdFtijlaGGxiOBQET+DfgqYICPgS8DKcDzQBywHfiCMaZNRIKBp4Fc4BRwozHmqCfqocaW4Uwd7TQr1fWtcW/5aS4YYJaOO2qb2vjn3gpWnpvaa/6XfcdOs7OktkcqicGYlRpJYkQwbx+o9PtA8HF5HTVN7f3+wQ4LCuCxW/MAaGx1UFbTTEl1E6XVTZTWNNHe4SQsKIDQQDthQa6f0KAAclIix1zunvHG7UAgImnAvwI5xphmEVkN3ARcBTxojHleRP4I3AY8bP2uMcZME5GbgPuBG92thxp7OtPvDnWMAM7cm2AkA8ET7x3lofWF/On9ozx007weuej/sq2Y4AAbn5s/9D/kNpuwbGYif9t1nDaHk6AA/x2S23SwChFXgrfBCA8OYEZyBDOS3U8CpwbmqU9mABAqIgFAGHAcWAq8aB1/CviM9Xil9Rzr+DIZ6lctNS6U1zYTHGAjfsLQ53bHTwgmJSpkxAeMdxTXkBQZTMXpFq7+33d5Zktx19z/xlYHr+48xtVzUokKG1731NLsJBpaHXx4tNqT1R53NhdWMSc9mlid5z8muR0IjDHlwK+AElwBoA5XV1CtMcZhnVYGdK79TgNKrdc6rPNH7iuf8prOfQiGG+dnpUaNaM6hDqfho9Jals9M4s3vXsL5U+L4yat7+NrT26lubGPNrmM0tDr4lyEOEnd30bQ4ggJsfj2NtK6pnZ0lNSzO0n78scrtQCAiMbi+5U8GUoFw4EoPXPd2EckXkfyqqr73/1RjV3nN0KeOdndOWhRFJxu7Nhf3tMLKehpaHcyfGENiRAhPfuk8fnJ1DpsLqrjit5v546bDZCdHMH9i9LDfIywogAunxvHGnuPUNbV7sPbjx7uHTuI0sHiGZ1M8K8/xRNfQcuCIMabKGNMOvAxcBERbXUUA6UC59bgcyACwjkfhGjQ+gzHmUWNMnjEmLyFBP0DjUXnt0BeTdTcnIwpjRi63/47iWgDmZ8YArj792y6ezKt3XkR0aCDFp5q45fyJw27RdPrmkmmcbGjl9mfyaXX4X0bSzQVVRIYEMDd9+AFVjSxPBIISYKGIhFl9/cuAfcAG4DrrnFuB16zHa6znWMffNpqQxee0tHdwsqHNrRbBoqwEspMjuP+NAyOS0nlHSQ2x4UFMOmsT8ZzUSP727Yt5+Jb53LRg+N1CnRZMjuVX189l65Fq7nlhN06n/3zcjTFsKqji4qx4t7eAVCPHE2MEW3EN+u7ANXXUBjwK/AC4S0QO4RoDeNx6yeNAnFV+F7DK3TqosafMjamjnew24d8/nUN5bTOPvTP8pGR92VFSw7kZ0b1+4w8JtLPinBQCPfTHa+W8NFatyOZvu45x/5sHPHLN8aCwsoETp1s8vvOX8iyPrCMwxtwH3HdWcRGwoJdzW4DrPfG+auz6ZB+CoS8m6+7CqfFcMSuJ3284zHW5GR7bdKS2qY2iqsZhTQsdrjsWTeFYbTOPbC4iJSqEL100edTe21s2HXSN7y3SQDCmaVtNDUuro4PvvbCLwj6ya3YuJnNnjKDTj67KocNpeMCD36R3lrrGB851YyB4qESE+z49i8tykvjp6/t4c8+JUXtvb9lUUMX0pAmkRLn/OVAjRwOBGpYPj9TwwvYyfvb6vl6Pl9c2EWATkiLd/wY/MS6M2y6ZzMs7y9lRUuP29QB2FtdgE0Z9ANNuEx666VzmZUTzned3sr3Yd9cXNLU52HakWruFxgHNNaSGZZu1QOqdwpNsKTrFwilnLgUpr2kmOSoE+yBy9w/GnZdO48XtZfzsb/t4+RsXDmpPgP7sKKklOznSKxkrQ4PsPPbFPD738Pt85cl8fnX9XC7LGb8plP/9tT28kF9GbHgQMeGBxIQFERsehKPD0Nbh1G6hcUBbBGpYth05xYykCJIig/nVWwd77MQ1nPTT/ZkQHMD3r5jBR6W1vPpRea/n1DW184eNh3j/8Ml+r9W5kGx+pvemM8ZNCObpr5xPSlQIX3s6n7tX76KuefytMzh6spE/bylmbkYUC6fEkRgRQn2Lg49Ka9lcWEVGbCjnTRpasj41+rRFoIas1dHBzpJaPr8wk0nx4fzk1T1sLKji0hmfbDhSVtPs8RxBn5ufzjNbirn/zQNcMSu569t8fUs7T7x7lMfeLaK+xcGUhHDW37W4z/n/3ReSedPEuDDWfOtiHlpfyMObDvP+4ZPc/7k54+ob9B82HiLQbuOhm88lMcIzA/lq9GmLQA3Zx2V1tDqcLJgcy415GaTHhPLrf37SKmjvcFJxuoV0D7YIwLXg675P51BxupU/bjpMY6uD3284xCUPbODBdQVcMCWOby6ZSlFVI/nFfY8ldC0k83IgAAgKsHHPFTN4+RsXEh4cwBef2MYPX/l4xFZTe1JpdRMv7yjn5gUTNQiMcxoI1JBtPeIaHzhvUixBATa+u3w6e8pPd82COVHXgtNAeox7U0d7k5sZy8p5qTyyuYhFD2zgl28dZP7EGP72rYt59It53HnpNMKD7Pz1w9I+r9G5kCwzzvP1G665GdG8/u2LuX3RFJ7bVsKVv91MaXWTt6vVrz9uOoxNhDsWT/F2VZSbNBCoIdt2pJqsxAldmSQ/e24aUxPC+fXaAjqcxiOLyfqzakU2E4IDyEmN5OVvXsgTXzqPc9JdaavDgwP49NxU/r77OPUtvfe597eQzJtCAu388KqZrL7jAipPt/LEe0e8XaU+nahr4YX8Mq7LS9epoT5AA4Eakg6nYXtxzRm7ddltwl2XzeBQZQOvfVTebTHZyPyBSIkKZfuPl/PMbef32r1z43kZNLd38Pru4z2OdS4k68wvNBadNymWy3KSeHVnOW0O58Av8KCq+laue/h9XutjQL7THzcdpsMYvrF46ijVTI0kDQRqSPYfP01Dq6PHto0rZieTkxLJb9cVUnyqEYCU6JHrN+7v2/y8jGimJ03otXtoZ8noLyQbjuvy0qlpamf9/opRfd8H3jxAfnENd63exdp9vb93ZX0Lz20r4bPnppERO3a619TwaSBQQ9I5PnB2ILDZhHuumE5JdRNPf1BMYkSw17YPFBFuyMvgo9JaCs5a+byjxDsLyYZqUVYCyZEhvLC9bNTec2eJa5Hg5xdOZHZaFHf+ZUevU3Eff+cI7R1O7rx02qjVTY0sDQRqSLYdOcXE2LBe+4UvnZHI/InR1DW3j9j4wGBdOz+dQLv0aBXsKKnx2kKyobDbhGvnp7HxYCUVp1tG/P2cTsN/rNlLQkQwP7gymye/dB6T4sL42lP57LLScQBUN7bxzJZiPj03lcnx4SNeLzU6NBCoQTPGsO1IdY/WQCcR4Z4rZgAjNz4wWLHhQVyWk8QrO8u79gDocBo+KvHuQrKhuC43HaeBl3f031/vCS9sL2VXWR33rsgmIiSQmPAgnrntfGInBHHrn7Z1tayeePcIze0dfEtbAz5FA4EatEOVDdQ0tbOgn5WiF06N51+XZXFDXsYo1qx3N+RlUN3Yxrp9ro1tCirqaWzrGBPrBwZjSsIEzpsUwwvbS3us3PakuuZ2HnjzILmZMXz23LSu8qTIEP582/kE2m184fGt7Cmv46n3j7JidjJZSbqpvC/RQKAGra/xgbPdddn0MbE69pKsBFKjQvhrvqt7qDNh3XgJBADX52ZQVNXosWR7vfntugKqm9r46TWzegzCZ8aF8+fbzqel3cln//Ae9a0OHRvwQRoI1KB9eLSaxIjgMbUQqz92m3BdbjrvFFZRXtvMjuLaMbeQbCBXzUkhNNDOC/kjM2h88EQ9T39QzM0LXAPEvZmRHMGTXz6PQLuNy3OSmJXa+3lq/NJAoAbFGMPWItf4wFhbiNWf6/MyMAZezC9jZ0kN8yeOvYVk/ZkQHMCn5qTw+u7jNLX1nnbC6TT8zxv7+cUbB4bUhWSMa4B4QnAA37t8Rr/nnjsxhk3fu5SHbj53SPVX44MGAjUoZTXNnDjdwvkDdAuNNRmxYVw8LZ5ntxZTdLKRc8dRt1Cn63PTaWh18MbHPTeyMcZw35q9PLKpiD9uOsxT7x8d9HX/8fEJPig6xT2XTyfGWiXen4SIYEICvTMlWI0sDQRqUD4ZH/BsRtHRcMN5GVTWtwLja3yg04LJsWTGhfHC9jOnwhpj+O9/7OeZLcXcsWgKy2cm8V9/38+2IwNvdtPU5uDnf9/HzJRI/uX8zJGquhonNBCoQdl25BTRYYFkJU7wdlWG7PKcJKJCA7HbhLkZ469/W0S4PjedLUXVlJz6JBHdg+sK+b93jnDrBZmsWpHNb26cS0ZsGN98dgcn6vpee3CqoZVbHtvK8dMt/PSaWR7bPEiNXxoI1KBsO1JNXmas2zuDeUNIoJ1vLJnKynmphAWN7YVkfbl2fjoi8KLVKvjDxkM8tL6QG/MyuO/Trtk+kSGBPPKFXJraHHzj2e1d6ye6K6pq4LN/eJ99x07z8C3zB5wBpvyDRwKBiESLyIsickBE9ovIBSISKyJrRaTQ+h1jnSsi8pCIHBKR3SIy3xN1UCOn8nQLR081jbvxge6+vngqv7lhnrerMWyp0aFckpXASzvKeeydIh548yAr56Xy39eec0Zwnp4Uwa+un8vOklp+9rcz95PedqSaax9+n8ZWB8/dvpArZ6eM9m2oMcpTLYLfAW8aY7KBucB+YBWw3hiTBay3ngOsALKsn9uBhz1UBzVCOvcn1m+P3nV9bjrltc3819/3c+WsZH59/dxeu3WuOieFry+eyrNbS1htpdhYs+sYn39sK7FhQbz8zQvH5ViJGjlut5NFJApYBHwJwBjTBrSJyEpgiXXaU8BG4AfASuBp45rntsVqTaQYY3rmDFZjwrYj1YQF2ZmVGuntqvi1y3KSSI0KYWZKJA/dfC4B9r6/x33vihnsKa/jx6/u4ePyOp7ZUsyCSbE8+sVcosMGniGk/IsnWgSTgSrgTyKyU0QeE5FwIKnbH/cTQJL1OA3oPv2hzCpTY9S2I9XkZsb0+4dHjbyQQDtv37OEx27NIyig//8XdpvwvzefS0JEMM9sKWblvFSe+eoCDQKqV54YOQsA5gPfNsZsFZHf8Uk3EADGGCMiQ0qWIiK34+o6YuLEiR6ophqO2qY2Dpyo5+o52p88FgxlHn9MeBB//ur5bC+u4XPz08bVQjo1ujzxFa8MKDPGbLWev4grMFSISAqA9bvSOl4OdM9Ilm6VncEY86gxJs8Yk5eQ4P28Nf6qcyOXvH4Szamxa3J8ONflpmsQUP1yOxAYY04ApSLSuUZ9GbAPWAPcapXdCrxmPV4DfNGaPbQQqNPxgbGrMxe+7kSllO/y1KSJe88KAAAVb0lEQVTqbwPPikgQUAR8GVeQWS0itwHFwA3Wuf8ArgIOAU3WuWqMqmt2bQAfHRro5ZoopUaKRwKBMeYjIK+XQ8t6OdcAd3rifdXIq2tuJ8AmhAVpjhmlfJVOA1H9qm1uJyo0UPuYlfJhGghUv+qsQKCU8l0aCFS/Tje3E6mBQCmfpoFA9UtbBEr5Pg0Eql8aCJTyfRoIVL/qmtuJDtNAoJQv00Cg+uR0Gk5ri0Apn6eBQPWpoc2B06CBQCkfp4FA9amuybWqWGcNKeXbNBCoPnWml9AWgVK+TQOB6pMGAqX8gwYC1ScNBEr5Bw0Eqk9dmUd1+qhSPk0DgeqTtgiU8g8aCFSf6prbCbQLoUPYHlEpNf5oIFB9qtMU1Er5BQ0Eqk91TZp5VCl/oIFA9UkTzinlHzQQqD5pIFDKP2ggUH3SQKCUf9BAoPpU19xOtAYCpXyeBgLVK6fTcLpFWwRK+QOPBQIRsYvIThF53Xo+WUS2isghEfmriARZ5cHW80PW8UmeqoPynPpWB8Zo5lGl/IEnWwTfAfZ3e34/8KAxZhpQA9xmld8G1FjlD1rnqTGmMwW1tgiU8n0eCQQikg58CnjMei7AUuBF65SngM9Yj1daz7GOLxNdsTTmaHoJpfyHp1oEvwW+Dzit53FArTHGYT0vA9Ksx2lAKYB1vM46/wwicruI5ItIflVVlYeqqQZLA4FS/sPtQCAiVwOVxpjtHqhPF2PMo8aYPGNMXkJCgicvrQahKxBo5lGlfF6AB65xEXCNiFwFhACRwO+AaBEJsL71pwPl1vnlQAZQJiIBQBRwygP1UB7UlYI6NMjLNVFKjTS3WwTGmHuNMenGmEnATcDbxphbgA3AddZptwKvWY/XWM+xjr9tjDHu1kN5lnYNKeU/RnIdwQ+Au0TkEK4xgMet8seBOKv8LmDVCNZBDVNdcztBdhshgbrURClf54muoS7GmI3ARutxEbCgl3NagOs9+b7K8+qaXZlHdUKXUr5Pv+6pXtU1txEV6tHvCUqpMUoDgeqVJpxTyn9oIFC90kCglP/QQKB6VdfcTnSYTh1Vyh9oIFC9qmvSFoFS/kIDgerB6TTUtzo086hSfkIDgeqhvsWVglpbBEr5Bw0EqgddVayUf9FAoHqobW4DNBAo5S80EKgetEWglH/RQKB66Mo8qimolfILGghUD9oiUMq/aCBQPWggUMq/aCBQPdQ1txMUYCMk0O7tqiilRoEGAtXDac0zpJRf0UCgeqjV9BJK+RUNBOOY02l4aXsZLe0dHr2uZh5Vyr9oIBjH1u6v4O4XdvH33cc9et265naiNRAo5Tc0EIxjr+woB+DAidMeva62CJTyLxoIxqnapjbWH6gA4MCJeo9eu3O/YqWUf9BAME69vvs47R2GmSmRHPRgIOhwGupbHNoiUMqPuB0IRCRDRDaIyD4R2Ssi37HKY0VkrYgUWr9jrHIRkYdE5JCI7BaR+e7WYbwpr23mVEOrW9d4ZWc5WYkT+Oy5qVTWt1LT2OaRutW36GIypfyNJ1oEDuBuY0wOsBC4U0RygFXAemNMFrDeeg6wAsiyfm4HHvZAHcaNdfsqWPqrjdz9wq5hX6P4VCPbi2v47Pw0ZiRHAnCwwjOtAl1VrJT/cTsQGGOOG2N2WI/rgf1AGrASeMo67SngM9bjlcDTxmULEC0iKe7WYzxYnV/KHX/ejtMY3j98atjTPl/ZWY4IfGZeGtnJEQAe6x6qbdJAoJS/8egYgYhMAs4FtgJJxpjOeY0ngCTrcRpQ2u1lZVbZ2de6XUTyRSS/qqrKk9UcdcYYfr/hEN9/cTcXTo3jwRvn0eZwkn+0ZljXemVnOQsnx5EaHUpiRDBRoYEeGzDuahFo5lGl/IbHAoGITABeAr5rjDljPqMxxgBmKNczxjxqjMkzxuQlJCR4qpqjzuk0/PRv+/jlWwdZOS+Vx289j6XZiQTahXcODT3A7SippfhUE5+d74qdIsKM5AgOemgKaVcKam0RKOU3PBIIRCQQVxB41hjzslVc0dnlY/2utMrLgYxuL0+3ynxOq6OD7/z1I558/yhfuWgyD94wj6AAG2FBAcyfGMN7h04O+Zqv7CwjJNDGitnJXWXZyREUVDTgirfu0TECpfxPgLsXEBEBHgf2G2N+0+3QGuBW4BfW79e6lX9LRJ4HzgfqunUhjTutjg6eePcotc1ttLY7aXU4aXV00OZwUlTVyL7jp1m1Ips7Fk3B9Z/K5eJp8fxmXQHVjW3EhgcN6r3aHE5e332cy3OSiQj55A/1jOQIGlodlNc2kx4T5tb9dAYCXUeglP9wOxAAFwFfAD4WkY+ssh/iCgCrReQ2oBi4wTr2D+Aq4BDQBHzZA3Xwmjf3nOD+Nw8QFGAjOMBGcIDd9TvQRmignQdvnMtnz03v8bqLs+L59doC3jt0kk/PTR3Ue204WEltU3tXt1Cn7gPG7gaC083tBGsKaqX8ituBwBjzLiB9HF7Wy/kGuNPd9x0r1u+vJC48iG0/Wo7d1td/hp7mpEcTERIwpEDwyo5y4icEc8m0+DPKs5JcgeDAiXqWzUzq7aWDpukllPI/urLYDe0dTjYcrGRpduKQggCA3SZcODWOdwpPDqpvv66pnbcPVHLN3FQC7Gf+b4sMCSQtOtQjU0g1ECjlfzQQuOHDo9XUtziG/S384qwEymubKT7VNOC5r398jLYOJ9fO7zHTFsCaOeR+INC9CJTyPxoI3LB+fyVBdhuXZMUPfHIvLra6eN4ZxOyhV3a4UkrMSo3s9fiM5AgOVzXQ5nAOqy6d6prbidY1BEr5FQ0Ew2SMYd3+Ci6YGkd48PCGWibFhZEWHcq7hf2vJyg+1Ui+lVKi+8yj7rKTI3A4DUdONg6rLp0086hS/kcDwTAdrmqg+FQTy3OGPzgrIlySFc/7h0/R4ex7nOCxd45gtwmfmdd7txDA9K4BY/cWlul+xUr5Hw0Ew7Ruv2t93LLsRLeuc9G0eOpbHOwuq+31+OGqBv6yrYR/WTCR1OjQPq8zNWECATZxa5ygw2mob9UU1Er5Gw0Ew7R+fwU5KZH9/nEejIumxSMC7xb2Pk5w/xsHCA20853lWf1eJyjAxpSEcLcCwWldVayUX9JAMAzVjW1sL65xq1uoU2x4ELNSI3m3lwHjbUeq+ee+Cr6xZCrxE4IHvNaM5Ei3ks9pegml/JMGgmHYcKASp4HlM93rFup00bR4dpTU0Njq6CozxvDzf+wnOTKEr1w0eVDXyU6OoLy2uWtzmaGq1UCglF/SQDAM6w9UkBgRzOzUKI9c75JpCbR3GLYdqe4qe333cXaV1nL35dMJDRpcuofOAeOCioZh1aMr86hOH1XKr/h8IHj7QAWnh/kNuTetjg42F5xk2cwkbENcTdyXvEkxBAXYurqHWh0d3P/mAbKTI7h2fs88RX1xd5Ma7RpSyj95IuncmFVa3cRXnswn0C5cODWey2clcVlOEokRIX2+prHVQVCAjUB77zFya1E1Da0Oj3ULAYQE2lkwKbZrwPiZD4opq2nmmdsWDCl1RVp0KOFB9mHvTaCZR5XyTz4dCFKjQ3npGxfw1t4K3tp7gh+9socfv7qH+RNjuDwnieiwQEqqmyitbrZ+N3GqsY30mFD+8tWFTIzrmclz/f4KQgJtXDRteKuJ+3JxVjy/eOMAhRX1/O/bh1g0PYFLsoa2IY/NJkxPjhj2gLHOGlLKP/l0ILDbhNzMWHIzY7l3RTYFFQ28tfcEb+09wf+8caDrnLToUDJiQ7l8VhLJkaH86f0j3PToBzx3+0Iy48K7rudaTVzJxdPiPZ6muTPdxB3PbOd0Szv3rsge1nWykyN4Y88JjDF9rkLuS11zOyGBrlTaSin/4dOBoLvOLR1nJEfwr8uyOF7XjKPDkBIV0iOb52U5Sdzy2BZuenQLz3cLBgcr6imvbebbS6d5vH45KZHEhgdRdLKRG/LSmZnSe06hgUxPiuC5baVU1beSGNl3F1hv6jThnFJ+yecHi/uSEhVKRmxYjyAAkJMaybNfXUhLewc3PbqF4lOu/D3r9lUAsNTN1cS9sdnEamnYuOuyGcO+zozkT/YmGCpNQa2Uf/LbQDCQs4PB0ZONrNtfydz0qCF/0x6sf/90Dq/eeRHJUcO/fnayqyUxnJlDtc1tRIcObttMpZTv0EDQj5zUSP7ytYW0Opzc+OgH7CqrZbmbO4D1J35CcNcf8uGKDQ8iISJ4mC0Ch84YUsoPaSAYwMyUSJ796vm0dxiMwe2tIEdDdnIEByuGPoVUM48q5Z/8ZrDYHTNTIll9xwVsO1LNzJQIb1dnQNOTIvjzlmI6nGZI6xB0jEAp/6SBYJCmJU5gWuIEb1djUGYkR9DqcFJ8qpEpCYOrs6PDSYOmoFbKL3ktEIjIlcDvADvwmDHmF32dW1TVyI2PfDBqdRvvOpPX3fHMdmLDBzf467A2xnl5ZxnvHx5460yllO/wyhiBiNiB3wMrgBzgZhHJ8UZdfFFnkrqmto5Bv8bR4drrOMBD+ZOUUuOHt1oEC4BDxpgiABF5HlgJ7Ovt5CkJ4fz1jgtGsXrj35W/3UxCRDDP3Hb+oM7/qLSWz/z+PX78qRwuHYF1Ekqp0bf664M7z1uzhtKA0m7Py6wy5SG5mTF8VFLb717I3dU2tQGacE4pfzRmp4+KyO0iki8i+VVVVd6uzriTmxlDfauDgorBrSfQFNRK+S9vBYJyIKPb83SrrIsx5lFjTJ4xJi8hYWhZOBXkZcYCkF9cM6jzNfOoUv7LW4HgQyBLRCaLSBBwE7DGS3XxSRmxocRPCGbHIAOBtgiU8l9eGSw2xjhE5FvAW7imjz5hjNnrjbr4KhEhLzOG/OLqgU8Gjte1EBEcQFDAmO0tVEqNEK+tIzDG/AP4h7fe3x/kZsbw5t4TVJ5u6TdRnjGGdwpPcv6U2FGsnVJqrNCvfz4sd1IMANsH6B46XNVISXUTS2botFGl/JEGAh82KzWSoADbgIFg48FKAF0/oJSf0kDgw4ID7MxNjxpw5tCGg5XMSIogLTp0lGqmlBpLNBD4uPmZMew9VkdLe+/pJhpaHWw7Us2SbJ2iq5S/0kDg4/IyY2nvMOwuq+v1+LuFJ2nvMFyq4wNK+S0NBD4uN9M1YNzXNNKNByuJCAnoOk8p5X80EPi42PAgpsSH97qwzBjDhoOVLMpKINCuHwWl/JX+6/cDuZkxbC+uwZgzE9DtP15PxelWlszQ8QGl/JkGAj+QmxlDTVM7RScbzyjfYE0bXayBQCm/poHAD+R1Liw7emb30IYDlZyTFkViRN+rjpVSvk8DgR+YEj+BqNDAMxaW1Ta1saOkRheRKaU0EPgDm03IPSsB3ebCkzgNXKrdQkr5PQ0EfiI3M4bDVY3UNLp2IttwoJLY8CDmpEd7uWZKKW/TQOAnOtcJ7CipocNp2FRQxeLpCdh1s3ql/J7X0lCr0TU3PZoAm5BfXENseBDVjW06PqCUAjQQ+I3QIDuzUiPZXlxDoN2GTWBRVry3q6WUGgM0EPiR3MxYnt1azOnmduZPjCE6LMjbVVJKjQE6RuBHcjNjaHU4OXCiXruFlFJdNBD4kc6FZYBmG1VKddGuIT+SFBlCWnQoDqeTmSkR3q6OUmqM0EDgZ+69KhtBENFpo0opF7e6hkTklyJyQER2i8grIhLd7di9InJIRA6KyBXdyq+0yg6JyCp33l8N3dVzUvnUnBRvV0MpNYa4O0awFphtjJkDFAD3AohIDnATMAu4EviDiNhFxA78HlgB5AA3W+cqpZTyErcCgTHmn8YYh/V0C5BuPV4JPG+MaTXGHAEOAQusn0PGmCJjTBvwvHWuUkopL/HkrKGvAG9Yj9OA0m7HyqyyvsqVUkp5yYCDxSKyDkju5dCPjDGvWef8CHAAz3qqYiJyO3A7wMSJEz11WaWUUmcZMBAYY5b3d1xEvgRcDSwzn+yFWA5kdDst3Sqjn/Kz3/dR4FGAvLw809s5Siml3OfurKErge8D1xhjmrodWgPcJCLBIjIZyAK2AR8CWSIyWUSCcA0or3GnDkoppdzj7jqC/wcEA2uteelbjDFfN8bsFZHVwD5cXUZ3GmM6AETkW8BbgB14whiz1806KKWUcoN80pszduXl5Zn8/HxvV0MppcYVEdlujMkb8LzxEAhEpAooduMS8cBJD1VnPNH79i963/5lMPedaYwZcD/acREI3CUi+YOJir5G79u/6H37F0/et2YfVUopP6eBQCml/Jy/BIJHvV0BL9H79i963/7FY/ftF2MESiml+uYvLQKllFJ98OlA4E97H4jIEyJSKSJ7upXFishaESm0fsf0d43xRkQyRGSDiOwTkb0i8h2r3NfvO0REtonILuu+f2qVTxaRrdbn/a/W6n2fY6W03ykir1vP/eW+j4rIxyLykYjkW2Ue+az7bCDww70PnsS190N3q4D1xpgsYL313Jc4gLuNMTnAQuBO6/+xr993K7DUGDMXmAdcKSILgfuBB40x04Aa4DYv1nEkfQfY3+25v9w3wKXGmHndpo165LPus4EAP9v7wBizGag+q3gl8JT1+CngM6NaqRFmjDlujNlhPa7H9cchDd+/b2OMabCeBlo/BlgKvGiV+9x9A4hIOvAp4DHrueAH990Pj3zWfTkQ6N4HkGSMOW49PgEkebMyI0lEJgHnAlvxg/u2ukc+Aipx7RR4GKjttlGUr37ef4sr0aXTeh6Hf9w3uIL9P0Vku5WmHzz0WdfN6/2EMcaIiE9OERORCcBLwHeNMaetBIiA7963lcRxnrVP+CtAtperNOJE5Gqg0hizXUSWeLs+XnCxMaZcRBJxJfo80P2gO591X24R9Lcngr+oEJEUAOt3pZfr43EiEogrCDxrjHnZKvb5++5kjKkFNgAXANEi0vnlzhc/7xcB14jIUVxdvUuB3+H79w2AMabc+l2JK/gvwEOfdV8OBLr3get+b7Ue3wq85sW6eJzVP/w4sN8Y85tuh3z9vhOslgAiEgpchmt8ZANwnXWaz923MeZeY0y6MWYSrn/PbxtjbsHH7xtARMJFJKLzMXA5sAcPfdZ9ekGZiFyFq0+xc++Dn3u5SiNGRJ4DluDKSFgB3Ae8CqwGJuLK3nqDMebsAeVxS0QuBt4BPuaTPuMf4hon8OX7noNrYNCO68vcamPMz0RkCq5vyrHATuDzxphW79V05FhdQ/cYY672h/u27vEV62kA8BdjzM9FJA4PfNZ9OhAopZQamC93DSmllBoEDQRKKeXnNBAopZSf00CglFJ+TgOBUkr5OQ0ESinl5zQQKKWUn9NAoJRSfu7/A5vBrVP2+0smAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f174dbe2a58>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(\"bits act: \" + str(args_dict['bit_act']))\n",
    "n = 50\n",
    "gamma, T = separability_index(lambda x: model_func(x, init_), len(init_), n, gpu=True, gamma_expecation=False)\n",
    "g = gamma.cpu().numpy()\n",
    "g_cum = g.cumsum()\n",
    "plt.plot(g_cum);\n",
    "plt.axhline(g.mean())\n",
    "print(\"gamma^2: {:.5f}\".format(gamma.mean()))\n",
    "print(\"T': {:.4f}\".format(T))\n",
    "print(\"T norm: {:.8f}\".format(T / np.sqrt(n)))\n",
    "print(\"g: {:.4f}\".format(g.sum()))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv3",
   "language": "python",
   "name": "venv3"
  },
  "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.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
