{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib notebook\n",
    "from DataGenerator import * \n",
    "from network import LocalNet, LocalNetOutputMultiRuleModel\n",
    "from BrainNet import BrainNet\n",
    "from LocalNetBase import Options, UpdateScheme\n",
    "import matplotlib.pyplot as plt\n",
    "from train import train_local_rule, train_vanilla, train_given_rule\n",
    "import numpy as np\n",
    "from train import evaluate\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torchvision\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "np.set_printoptions(precision=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "transform = torchvision.transforms.Compose([torchvision.transforms.ToTensor(), \n",
    "                                            torchvision.transforms.Lambda(lambda x : x.flatten().double())])\n",
    "trainset = torchvision.datasets.MNIST(root='data', train=True, download=True, transform=transform)\n",
    "trainloader = torch.utils.data.DataLoader(trainset, batch_size=100, shuffle=True)\n",
    "\n",
    "testset = torchvision.datasets.MNIST(root='data', train=False, download=True, transform=transform)\n",
    "testloader = torch.utils.data.DataLoader(testset, batch_size=100, shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 0.7803,  0.9886, -0.6112,  1.7310, -0.7242,  0.7870,  0.4545,  0.4581,\n",
       "         -1.0893, -0.6807, -0.4602,  0.0526, -0.4796,  0.3159,  1.1265,  0.3986],\n",
       "        [-0.8096, -0.7319,  0.6772, -1.4320,  0.1725, -0.3537, -0.5178, -1.0124,\n",
       "          1.0002,  1.1567,  1.5561, -0.2078,  0.0146, -0.0695,  0.6294, -1.3165],\n",
       "        [-1.1028, -0.4310,  2.3873,  0.3228,  0.8246,  0.4661,  1.9818,  1.1587,\n",
       "         -0.3125, -1.3558, -0.2346, -1.0303, -0.9985, -0.5305,  0.7147, -0.1906],\n",
       "        [ 0.6772,  1.4189, -1.2097,  1.7252,  1.1301,  0.3751,  1.5695,  1.0631,\n",
       "          1.6430,  0.8621, -0.5989, -2.3664, -0.9359, -0.5777,  0.0496,  0.0417],\n",
       "        [-2.3534, -0.6881, -1.1857,  0.9374,  0.8594, -0.7962,  1.0144,  1.0012,\n",
       "         -0.9105, -0.6119,  0.7736,  1.0765, -0.3487, -0.2760,  0.2863,  0.4135],\n",
       "        [-0.2670,  0.8769, -0.5086,  0.0656, -0.3993,  1.2959, -1.1586, -2.1786,\n",
       "         -0.8233, -1.5003, -0.3633, -0.0106, -0.2217, -0.9604, -0.4083, -1.2216],\n",
       "        [-0.8203, -1.1708,  0.1268, -0.9371,  0.6325,  0.6635, -0.1394,  0.8061,\n",
       "          0.6391,  0.2807,  1.2454,  1.8433, -1.4823,  1.2458,  0.5616,  0.9019],\n",
       "        [-1.3602, -1.0266,  0.2597, -0.6436,  1.3926, -0.5802,  0.6602, -2.0025,\n",
       "          0.6206,  1.6285, -0.0663, -0.7518, -2.2166, -0.3938, -0.1989,  1.0570],\n",
       "        [-0.1736, -1.1085,  0.1297,  0.1375, -0.4493,  0.7962,  1.4761,  1.8185,\n",
       "         -0.2851, -2.2109, -0.8887,  1.3660,  1.0157,  0.1629,  0.5135,  1.7018],\n",
       "        [ 0.3418,  0.1125,  0.1368, -0.5463,  0.0349, -0.3341,  0.3583,  1.2748,\n",
       "         -1.0892,  1.0491, -0.2385,  0.3309, -0.0235,  0.4277, -0.8624, -1.6845],\n",
       "        [-0.4079, -0.1798, -0.8679,  0.4065,  0.0742,  0.1246,  0.3471,  1.0237,\n",
       "          0.4530,  0.0034, -0.2148, -1.1529,  0.2627,  1.7953, -0.7523,  0.4480],\n",
       "        [ 0.5348,  0.5277, -0.0591,  0.3136,  0.5772,  0.8547,  0.9455,  0.3408,\n",
       "         -0.2648, -0.2894,  1.1882,  0.3587, -0.4230, -0.3212, -1.5688,  0.1032],\n",
       "        [-0.9868, -0.5422,  0.3635,  0.0677, -1.0329,  0.7466, -0.4953,  0.8430,\n",
       "         -0.8285, -1.5383, -0.3269, -0.2665,  0.1627,  0.2809,  0.0121, -0.2713],\n",
       "        [-0.0322, -0.2972, -1.3736, -0.4829,  0.7301,  0.0982, -0.6915, -1.4398,\n",
       "         -1.9363,  0.6709,  0.6522, -0.2962,  1.7239,  0.3252, -2.4525,  0.1974],\n",
       "        [-1.0655, -0.8837, -0.8313, -0.1621,  0.1853, -0.2498, -0.0206,  0.2764,\n",
       "          2.1809, -1.1896,  1.2638,  0.7190, -0.9679, -1.2517, -0.5179,  0.6115],\n",
       "        [-0.4732, -0.0088,  1.7917,  0.1987, -1.0905, -2.0065,  0.4233, -1.3251,\n",
       "         -0.1952, -0.4130,  0.1910, -1.1940, -0.1694, -1.0334,  0.3267, -1.0445]])"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "options = Options(\n",
    "                 gd_output = False,\n",
    "                 gd_input = False,\n",
    "                 use_graph_rule = True, \n",
    "                 use_input_rule = False,\n",
    "                 use_output_rule = True,\n",
    "                 gd_output_rule = False,\n",
    "                 gd_graph_rule = True,\n",
    "                 additive_rule = True)\n",
    "\n",
    "scheme = UpdateScheme(\n",
    "            cross_entropy_loss = True, \n",
    "            mse_loss = False, \n",
    "            update_misclassified = True,\n",
    "            update_all_edges = False\n",
    "        )\n",
    "\n",
    "local_net = LocalNet(784, 10, num_v = 100, p = .5, cap = 50, rounds = 0, step_sz=1e-2, options = options, update_scheme = scheme)\n",
    "# local_net.input_weights = torch.ones_like(local_net.input_weights).double()\n",
    "# local_net.graph_weights = torch.ones_like(local_net.graph_weights).double()\n",
    "# local_net.set_output_rule(torch.tensor([[-1, 1], [1, -1]]))\n",
    "local_net.set_output_rule(torch.tensor([[-1, 1], [1, -1]]))\n",
    "# local_net.set_rnn_rule(torch.tensor([[0.15, -0.12, 0.20, -0.06],\n",
    "#                                      [0.44, 0.08, 0.47, -0.11],\n",
    "#                                      [0.26, 0.43, 1.41, -0.77],\n",
    "#                                      [0.19, -0.54, 0.16, -0.31]]))\n",
    "\n",
    "losses = []\n",
    "optimizer = torch.optim.Adam(local_net.parameters(), lr=1e-2, weight_decay = 0.01)\n",
    "local_net.rule.detach().reshape(16, 16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 Batch 0: 49985.061\n",
      "Epoch 0 Batch 100: 68.994\n",
      "Epoch 0 Batch 200: 31.037\n",
      "Epoch 0 Batch 300: 25.028\n",
      "Epoch 0 Batch 400: 27.324\n",
      "Epoch 0 Batch 500: 27.694\n",
      "Epoch 1 Batch 0: 23.196\n",
      "Epoch 1 Batch 100: 29.524\n",
      "Epoch 1 Batch 200: 17.459\n",
      "Epoch 1 Batch 300: 17.654\n",
      "Epoch 1 Batch 400: 13.506\n",
      "Epoch 1 Batch 500: 11.855\n",
      "Epoch 2 Batch 0: 10.643\n",
      "Epoch 2 Batch 100: 8.595\n",
      "Epoch 2 Batch 200: 7.757\n",
      "Epoch 2 Batch 300: 7.060\n",
      "Epoch 2 Batch 400: 5.326\n",
      "Epoch 2 Batch 500: 5.121\n",
      "Epoch 3 Batch 0: 5.191\n",
      "Epoch 3 Batch 100: 4.028\n",
      "Epoch 3 Batch 200: 4.190\n",
      "Epoch 3 Batch 300: 3.728\n",
      "Epoch 3 Batch 400: 3.735\n",
      "Epoch 3 Batch 500: 3.136\n",
      "Epoch 4 Batch 0: 2.894\n",
      "Epoch 4 Batch 100: 2.569\n",
      "Epoch 4 Batch 200: 2.413\n",
      "Epoch 4 Batch 300: 2.443\n",
      "Epoch 4 Batch 400: 1.987\n",
      "Epoch 4 Batch 500: 1.738\n",
      "Epoch 5 Batch 0: 1.570\n",
      "Epoch 5 Batch 100: 1.372\n",
      "Epoch 5 Batch 200: 1.438\n",
      "Epoch 5 Batch 300: 1.256\n",
      "Epoch 5 Batch 400: 1.108\n",
      "Epoch 5 Batch 500: 1.150\n",
      "Epoch 6 Batch 0: 1.174\n",
      "Epoch 6 Batch 100: 1.000\n",
      "Epoch 6 Batch 200: 1.075\n",
      "Epoch 6 Batch 300: 1.045\n",
      "Epoch 6 Batch 400: 1.012\n",
      "Epoch 6 Batch 500: 1.084\n",
      "Epoch 7 Batch 0: 1.104\n",
      "Epoch 7 Batch 100: 1.127\n",
      "Epoch 7 Batch 200: 1.125\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-94-59a2ab4f2094>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      3\u001b[0m         \u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m         \u001b[0moptimizer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mzero_grad\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 5\u001b[0;31m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlocal_net\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcontinue_\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      6\u001b[0m         \u001b[0mlosses\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mloss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      7\u001b[0m         \u001b[0mloss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbackward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    720\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    721\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 722\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    723\u001b[0m         for hook in itertools.chain(\n\u001b[1;32m    724\u001b[0m                 \u001b[0m_global_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/LocalNetBase.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, inputs, labels, epochs, batch, continue_)\u001b[0m\n\u001b[1;32m    151\u001b[0m             \u001b[0;32mfor\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mell\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabels\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    152\u001b[0m                 \u001b[0moutputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward_pass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munsqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 153\u001b[0;31m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate_weights\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mell\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    154\u001b[0m         \u001b[0moutputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward_pass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    155\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/LocalNetBase.py\u001b[0m in \u001b[0;36mupdate_weights\u001b[0;34m(self, probs, label)\u001b[0m\n\u001b[1;32m    109\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0muse_graph_rule\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    110\u001b[0m             \u001b[0ma1\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mactivated\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrepeat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_v\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_v\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 111\u001b[0;31m             \u001b[0ma2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mactivated\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrepeat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_v\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_v\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_v\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    112\u001b[0m             \u001b[0mact\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m**\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrounds\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0ma1\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0ma2\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    113\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for i in range(20):\n",
    "    for j, data in enumerate(trainloader):\n",
    "        inputs, labels = data\n",
    "        optimizer.zero_grad()\n",
    "        loss = local_net(inputs, labels, 10, 10, continue_=False)\n",
    "        losses += [loss.item()]\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        if j % 100 == 0:\n",
    "            print('Epoch {:d} Batch {:d}: {:.3f}'.format(i, j, np.median(losses[i*600 + j-100:i*600 + j+1])))\n",
    "            local_net.step_sz *= 0.96"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "rule_2 = np.array([[0.15, -0.12, 0.20, -0.06], \n",
    "                   [0.44, 0.08, 0.47, -0.11], \n",
    "                   [0.26, 0.43, 1.41, -0.77], \n",
    "                   [0.19, -0.54, 0.16, -0.31]])\n",
    "\n",
    "rule_4 = np.zeros((16, 16))\n",
    "for i in range(16):\n",
    "    for j in range(16):\n",
    "        rule_4[i, j] = rule_2[i // 4, j//4] + rule_2[i % 8 // 2, j % 8 // 2] + rule_2[i % 4, j % 4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "options = Options(\n",
    "                 gd_output = False,\n",
    "                 gd_input = False,\n",
    "                 use_graph_rule = False, \n",
    "                 use_input_rule = False,\n",
    "                 use_output_rule = True,\n",
    "                 gd_output_rule = False,\n",
    "                 gd_graph_rule = False,\n",
    "                 additive_rule = True)\n",
    "\n",
    "scheme = UpdateScheme(\n",
    "            cross_entropy_loss = True, \n",
    "            mse_loss = False, \n",
    "            update_misclassified = True,\n",
    "            update_all_edges = False\n",
    "        )\n",
    "\n",
    "local_net = LocalNet(784, 10, num_v = 1000, p = .5, cap = 500, rounds = 0, step_sz=1e-2, options = options, update_scheme = scheme)\n",
    "local_net.input_weights = torch.ones_like(local_net.input_weights).double()\n",
    "# local_net.graph_weights = torch.ones_like(local_net.graph_weights).double()\n",
    "local_net.set_output_rule(torch.tensor([[-1, 1], [1, -1]]))\n",
    "# local_net.set_output_rule(torch.tensor([[-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1]]))\n",
    "# local_net.set_rnn_rule(rule)\n",
    "\n",
    "losses = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Accuracy: 10.290%\n",
      "Epoch 0 Batch 0: 627.425\n",
      "Epoch 0 Batch 100: 72.829\n",
      "Epoch 0 Batch 200: 44.104\n",
      "Epoch 0 Batch 300: 36.976\n",
      "Epoch 0 Batch 400: 33.373\n",
      "Epoch 0 Batch 500: 25.547\n",
      "Test Accuracy: 89.390%\n",
      "Epoch 1 Batch 0: 26.183\n",
      "Epoch 1 Batch 100: 19.030\n",
      "Epoch 1 Batch 200: 18.784\n",
      "Epoch 1 Batch 300: 16.382\n",
      "Epoch 1 Batch 400: 15.772\n",
      "Epoch 1 Batch 500: 15.528\n",
      "Test Accuracy: 90.530%\n",
      "Epoch 2 Batch 0: 18.208\n",
      "Epoch 2 Batch 100: 10.953\n",
      "Epoch 2 Batch 200: 14.395\n",
      "Epoch 2 Batch 300: 10.119\n",
      "Epoch 2 Batch 400: 14.364\n",
      "Epoch 2 Batch 500: 13.556\n",
      "Test Accuracy: 90.440%\n",
      "Epoch 3 Batch 0: 12.999\n",
      "Epoch 3 Batch 100: 11.409\n",
      "Epoch 3 Batch 200: 9.025\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-4-af0157096b0d>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     13\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     14\u001b[0m             \u001b[0mcontinue_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 15\u001b[0;31m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlocal_net\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcontinue_\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     16\u001b[0m         \u001b[0mlosses\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mloss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     17\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mj\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;36m100\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    720\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    721\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 722\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    723\u001b[0m         for hook in itertools.chain(\n\u001b[1;32m    724\u001b[0m                 \u001b[0m_global_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/LocalNetBase.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, inputs, labels, epochs, batch, continue_)\u001b[0m\n\u001b[1;32m    150\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mepoch\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mepochs\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    151\u001b[0m             \u001b[0;32mfor\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mell\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabels\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 152\u001b[0;31m                 \u001b[0moutputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward_pass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munsqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    153\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate_weights\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mell\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    154\u001b[0m         \u001b[0moutputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward_pass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/BrainNet.py\u001b[0m in \u001b[0;36mforward_pass\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m     61\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     62\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclone\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 63\u001b[0;31m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfeed_input\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     64\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0m_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrounds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     65\u001b[0m             \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstep_once_graph\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/BrainNet.py\u001b[0m in \u001b[0;36mfeed_input\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m     93\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     94\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfeed_input\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 95\u001b[0;31m         \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minput_weights\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minput_layer\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     96\u001b[0m         \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mres\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgraph_bias\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     97\u001b[0m         \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mF\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrelu\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mres\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for i in range(20):\n",
    "    for j, data in enumerate(trainloader):\n",
    "        if j == 0:\n",
    "            local_correct = 0\n",
    "            with torch.no_grad():\n",
    "                for inputs, labels in testloader:\n",
    "                    outputs = local_net.forward_pass(inputs)\n",
    "                    local_correct += np.count_nonzero((outputs.argmax(axis=1) == labels).numpy())\n",
    "            print('Test Accuracy: {:.3f}%'.format(local_correct / len(testset) * 100))\n",
    "        inputs, labels = data\n",
    "        if i == 0 and j == 0:\n",
    "            continue_ = False\n",
    "        else:\n",
    "            continue_ = True\n",
    "        loss = local_net(inputs, labels, 1, 1, continue_=True)\n",
    "        losses += [loss.item()]\n",
    "        if j % 100 == 0:\n",
    "            print('Epoch {:d} Batch {:d}: {:.3f}'.format(i, j, np.median(losses[i*600 + j-100:i*600 + j+1])))\n",
    "            local_net.step_sz *= 0.95"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "options = Options(\n",
    "                 gd_output = False,\n",
    "                 gd_input = False,\n",
    "                 use_graph_rule = True, \n",
    "                 use_input_rule = False,\n",
    "                 use_output_rule = True,\n",
    "                 gd_output_rule = False,\n",
    "                 gd_graph_rule = False,\n",
    "                 additive_rule = True)\n",
    "\n",
    "scheme = UpdateScheme(\n",
    "            cross_entropy_loss = True, \n",
    "            mse_loss = False, \n",
    "            update_misclassified = True,\n",
    "            update_all_edges = False\n",
    "        )\n",
    "\n",
    "local_net = LocalNet(784, 10, num_v = 500, p = .5, cap = 250, rounds = 3, step_sz=1e-2, options = options, update_scheme = scheme)\n",
    "# local_net.input_weights = torch.ones_like(local_net.input_weights).double()\n",
    "# local_net.graph_weights = torch.ones_like(local_net.graph_weights).double()\n",
    "# local_net.set_output_rule(torch.tensor([[-1, 1], [1, -1]]))\n",
    "local_net.set_output_rule(torch.tensor([[-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1], [-1, 1], [1, -1]]))\n",
    "local_net.set_rnn_rule(torch.tensor(rule_4))\n",
    "# local_net.set_rnn_rule(rule)\n",
    "\n",
    "losses = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Accuracy: 8.310%\n",
      "Epoch 0 Batch 0: 8802957.343\n",
      "Epoch 0 Batch 100: 58512442082.454\n",
      "Epoch 0 Batch 200: 259296814388.058\n",
      "Epoch 0 Batch 300: 526543465096.718\n",
      "Epoch 0 Batch 400: 831656271437.358\n",
      "Epoch 0 Batch 500: 1294371080090.808\n",
      "Test Accuracy: 73.570%\n",
      "Epoch 1 Batch 0: 1681635541553.612\n",
      "Epoch 1 Batch 100: 1838175887172.150\n",
      "Epoch 1 Batch 200: 2392750582759.803\n",
      "Epoch 1 Batch 300: 2771604790436.031\n",
      "Epoch 1 Batch 400: 3424641413528.264\n",
      "Epoch 1 Batch 500: 3756564278121.226\n",
      "Test Accuracy: 74.260%\n",
      "Epoch 2 Batch 0: 4250039727615.484\n",
      "Epoch 2 Batch 100: 4158757218741.047\n",
      "Epoch 2 Batch 200: 5324563066044.432\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-11-f8e7490fdbd8>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     13\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     14\u001b[0m             \u001b[0mcontinue_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 15\u001b[0;31m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlocal_net\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcontinue_\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     16\u001b[0m         \u001b[0mlosses\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mloss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     17\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mj\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;36m100\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    720\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    721\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 722\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    723\u001b[0m         for hook in itertools.chain(\n\u001b[1;32m    724\u001b[0m                 \u001b[0m_global_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/LocalNetBase.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, inputs, labels, epochs, batch, continue_)\u001b[0m\n\u001b[1;32m    150\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mepoch\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mepochs\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    151\u001b[0m             \u001b[0;32mfor\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mell\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabels\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 152\u001b[0;31m                 \u001b[0moutputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward_pass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munsqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    153\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate_weights\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mell\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    154\u001b[0m         \u001b[0moutputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward_pass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/BrainNet.py\u001b[0m in \u001b[0;36mforward_pass\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m     63\u001b[0m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfeed_input\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     64\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0m_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrounds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 65\u001b[0;31m             \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstep_once_graph\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     66\u001b[0m         \u001b[0mout\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_output\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     67\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/BrainNet.py\u001b[0m in \u001b[0;36mstep_once_graph\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m    110\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    111\u001b[0m         \u001b[0mr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mF\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrelu\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mres\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 112\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_cap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    113\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    114\u001b[0m     \u001b[0;31m# only top nodes will fire.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Projects/Learning Plasticity Rules/BrainNet.py\u001b[0m in \u001b[0;36mget_cap\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m    122\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    123\u001b[0m                 \u001b[0mactivated\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mzeros_like\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mindices\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 124\u001b[0;31m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mactivated\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mactivated\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mactivated\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    125\u001b[0m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mactivated_rounds\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mactivated\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    126\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mException\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for i in range(20):\n",
    "    for j, data in enumerate(trainloader):\n",
    "        if j == 0:\n",
    "            local_correct = 0\n",
    "            with torch.no_grad():\n",
    "                for inputs, labels in testloader:\n",
    "                    outputs = local_net.forward_pass(inputs)\n",
    "                    local_correct += np.count_nonzero((outputs.argmax(axis=1) == labels).numpy())\n",
    "            print('Test Accuracy: {:.3f}%'.format(local_correct / len(testset) * 100))\n",
    "        inputs, labels = data\n",
    "        if i == 0 and j == 0:\n",
    "            continue_ = False\n",
    "        else:\n",
    "            continue_ = True\n",
    "        loss = local_net(inputs, labels, 1, 1, continue_=True)\n",
    "        losses += [loss.item()]\n",
    "        if j % 100 == 0:\n",
    "            print('Epoch {:d} Batch {:d}: {:.3f}'.format(i, j, np.median(losses[i*600 + j-100:i*600 + j+1])))\n",
    "            local_net.step_sz *= 0.96"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f6dd57394d0>]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot(losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Local Net Test Accuracy: 91.020%\n"
     ]
    }
   ],
   "source": [
    "local_correct = 0\n",
    "\n",
    "with torch.no_grad():\n",
    "    for inputs, labels in testloader:\n",
    "        outputs = local_net.forward_pass(inputs)\n",
    "        local_correct += np.count_nonzero((outputs.argmax(axis=1) == labels).numpy())\n",
    "print('Local Net Test Accuracy: {:.3f}%'.format(local_correct / len(testset) * 100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAgAElEQVR4nO3de3RU9b3+8S+BXAgmoVwkBGqCEi4aQ4mKtgopcu0hwmlXW+GA8lPLTSOIWLRajVQI2Fo8nlPFSpFVWwUrifVS1BOUYCXBUgMSG6mWSwgBSwUTUEm45Pn9kZWpmwyQsJN898x+v9Z6/nBmZ7IzfBafx5nMxggAAAC+YmyfAAAAANoWBRAAAMBnKIAAAAA+QwEEAADwGQogAACAz1AAAQAAfIYCCAAA4DMUQAAAAJ+hAAIAAPgMBRAAAMBnKIAAAAA+QwEEAADwGQogAACAz1AAAQAAfIYCCAAA4DMUQAAAAJ+hAAIAAPgMBRAAAMBnKIAAAAA+QwEEAADwGQogAACAz1AAAQAAfIYCCAAA4DMUQAAAAJ+hAAIAAPgMBRAAAMBnKIAAAAA+QwEEAADwGQogAACAz1AAAQAAfIYCCAAA4DMUQAAAAJ+hAAIAAPgMBRAAAMBnKIAAAAA+QwEEAADwGQogYNnKlStljNHmzZttn0ojU6dOVXJycpOOM8bo4osv1okTJxrdb4zRbbfddk7nsGjRIr344ovN+prq6motXrxYQ4YMUUJCgjp06KDzzz9fY8aM0bPPPquamppzOpeWkJOTI2OM/vWvfzX7a2+77TYZY7R//37H7QcPHlS7du3UoUMHHTlyxHFfRUWFjDGaO3dus79fr169dMsttzT76yTp6quv1qBBg856XEVFhXJycvT++++f0/cBcG4ogIBl4VQAjTH6zW9+0+h+NwWwU6dOmjp1apOP/+ijj3ThhRfqvPPO05133qmXXnpJb7/9tp5//nndfPPNio6O1k9/+tNzOpeW4KYArlmzRsYYrVq1ynF7fn6+IiMjFRkZqddee81x3zPPPCNjjF5++eVmf7+SkhLt2LGj2V8nNb0AFhcXyxij3/3ud+f0fQCcGwogYFm4FMBOnTpp6NCh6tWrl7788kvH/W1VAI8fP66LL75YnTt3VllZWdBjdu/efdZXFI8dO6bjx48391SbxE0B/PTTT9WuXTvNmDHDcfvs2bP1rW99S9/85jc1f/58x30333yzIiIiVFVV5eq8m4sCCHgbBRCwrKkFsLy8XJMnT1b37t0VFRWlAQMG6JFHHtHJkycdx9XU1GjBggUaMGCAoqOj1aVLF33729/Wxo0bA8f86le/0tChQ9W9e3fFxsYqLS1NDz/8sI4dO+Z4rOYWwKKiIhljtHjxYsf9wQpgdXW15s2bp5SUFEVGRiopKUlz5szR559/7vi6U5OZmXna8/jDH/4gY4x+8YtfnPWcG6xfv17GGD3zzDO68847lZSUpHbt2unDDz/UgQMHNGvWLA0cOFCdOnVS9+7dNXz4cL399tuOx9i1a5eMMXr44Ye1cOFCff3rX1d0dLQuu+wyrVu3znFsQwH84IMPNHHiRMXHx+v888/XTTfd1KSSlp6erv79+ze67d5779U999yjK664wnHfhRdeqMsvv9xxW1VVle68887Ac9+rVy/NnTtXX3zxheO4YG8Bb9u2TSNGjFDHjh3VrVs3ZWdn66WXXpIxRn/+858DxzUUwE2bNulb3/qWOnbsqAsvvFAPP/yw6urqJEkFBQVB/4wfeughSdLHH3+sH/zgB0pMTFRUVJR69OihESNGaNu2bWd9ngCcGQUQsKwpBfDAgQPq1auXunfvrieffFKvv/66srOzZYzRrFmzAscdP35cw4cPV4cOHXTXXXdp7dq1evnll3Xvvfc63jacO3euli1bptdff11vvfWWHn30UXXr1k033XST4/s2twBK0ne/+1117txZBw8eDNx/agH84osv9I1vfEPdunXT0qVLtW7dOj322GNKSEjQtddeGygIxcXF6tixo/7jP/5DxcXFKi4u1t/+9rfTnse0adNkjNHf//73s55zg4YC2KtXL33/+9/Xyy+/rFdffVUHDx7U9u3bNWvWLK1evVqFhYV69dVXdcsttygiIkLr168PPEZDAfz617+ua665Rnl5eXrhhRd0xRVXKDIyUkVFRYFjGwpg//799cADD6igoEBLly5VdHR0o+c/mDlz5sgYo3379kn696uCb7zxhl577TW1b99e1dXVkqQ9e/bIGKMf//jHga8/cuSILr30UnXv3l3//d//rXXr1unRRx9VfHy8Ro0aFXjupcYFsKKiQl/72teUkpKi3/72t1q7dq0mT56slJSUoAWwe/fu6tevn37961+roKBAM2bMkDFGzz77rKT6/wn4zW9+I2OMHnzwwcCf8d69eyVJffv2Vb9+/fS73/1OGzZsUF5enu68805t2LChyX++AIKjAAKWNaUA3nPPPTLG6N1333XcPmvWLLVr1y5QeBp+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VHPnznV8EGLr1q26+uqrFRsbK2POfB3ABtXV1crNzdUVV1yh+Pj4wD8FN2rUKD3++OOOUnSmAlhbW6u77rpLvXr1UkxMjDIyMvTHP/6x0fPy1esALliwQL1791ZUVJQGDx6sN954w/GYLVEAJQVesb3rrrsa3XfHHXfIGKOrr7466NceOXJE9913n+O5T09P15133qkDBw4EjjvddQCvvfZaxcTEqGvXrpo2bZqefvppGWMcl+hpagGUpN///vfq37+/IiMjZUz9dQD379+vqVOnqn///urUqZPi4uI0aNAgPfbYY3wYBGgBFEAAcKmhADbnAtTh5KabblJ8fHyjC4kD8C4KIAC45KcCmJOTo9/85jd666239NJLL+mWW26RMUYLFiywfWoAmoECCAAu+akAPvTQQ0pNTVVsbKyio6OVlpamxx577KwXsAbgLRRAAAAAn6EAAgAA+AwFEAAAwGcogAAAAD7T5gUwNzdXl19+uc477zx1795dEyZMaHRh15qaGmVnZ6tr166KjY3Vddddp4qKCscx5eXlysrKUmxsrLp27arbb79dtbW1jmMKCwuVkZGh6Oho9enTR8uWLWt0Po8//rhSUlIUHR2tjIwMvf322y3/QwMAAHhImxfAMWPGaOXKlfrggw+0detWjRs3ThdccIE+//zzwDEzZ85Ur169VFBQoJKSEg0fPlyDBg0K/FuaJ06cUFpamoYPH66SkhIVFBQoKSnJ8e9w7ty5U7GxsZozZ47Kysq0fPlyRUZGas2aNYFjVq9ercjISC1fvlxlZWWaM2eOOnXqpPLy8ib9LCdPnlRFRYWqqqpUXV1NCCGEkBBIVVWVKioqfH1RcetvAR84cEDGGG3YsEGSVFVVpcjISK1evTpwTGVlpSIiIvT6669LktauXauIiAhVVlYGjlm1apWio6NVXV0tSZo/f74GDBjg+F4zZszQVVddFfjvIUOGaObMmY5jBgwYoHvuuadJ515RUXHGf8GBEEIIId7Nqe8u+on1Avjxxx/LGKPS0lJJ0ptvviljjA4dOuQ4Lj09PfDvP95///1KT0933H/o0CEZY/TWW29JkoYOHarZs2c7jsnPz1eHDh107Ngx1dbWqn379srPz3ccM3v2bA0bNqxJ515VVRUYINv/N0MIIYSQpqXhBZyqqqqmF5YwY7UA1tXV6brrrtM111wT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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Local Net Graph Weights')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.hist(local_net.graph_weights.numpy().flatten(), bins=200)\n",
    "ax.set_title('Local Net Graph Weights')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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ZsyYeOSRRyIi4mtf+1pkWRZXXnll6etv2bIlNm3aFF/72tdi3Lhx8Ytf/GLgs04GQB5++OEYN25cnH322QOfDx0Aueiii2Ls2LHDfudrr702siwb9F+C2HnnneOEE04o9btsG7jYNpTRyo033hhZlsUll1wSEeUHQCIiTj/99JbDG9t+x8mTJ8fTTz898LPNmzfH7NmzY//99x/4WdkBkIiIgw46qO1/8WSoT33qU5FlWTz11FMREfFHf/RHMXfu3IiIWL58eYwbNy7WrVsXEREnnnhijBs3btDAxK//+q/HPvvsM2yI4pRTTonJkyfH2rVrI6L1AMghhxwSM2fOHPRfkVm3bl3svvvuLQdApk2bNui/9vLkk09GlmXxuc99buBnF110UWRZFqtXrx60nsWLF0eWZfGjH/2odG0AAAAAAIDhDIAAAAAAAEAFZQZADj/88JgzZ86wn3//+9+PLMviiiuuiIiIP/iDP4hJkybFli1b2l7z3nvvjfe9730xderUyLJs0HbPPfcM7NfJAEjEf/2XOCZOnBhPPPFERAwfAHnHO94Rb37zm2PTpk2DthdeeCHGjBkT55577sC+qQdAli9fHlmWxV//9V9HRNoBkGOOOWbYz7cNfGwbYtieAyDf+ta3Isuy+Md//MeIiHjTm94U5513XkRErF+/PsaNGxc33HBDRETsu+++8ba3vW3g2A0bNsS4cePirLPOGvbvZenSpZFlWdxyyy0RMXwAZN26dZFlWZx11lnD1nT88ce3HAA5/vjjh+37mte8Jj75yU8O/DlvAOSRRx6Jvr6+mDt3blx99dXx2GOPla4RAAAAAADw3wyAAAAAAABABWUGQPbbb7/49V//9WE/X716dWRZFhdccEFERLznPe+J17/+9W2v98QTT8TOO+8chx56aFxzzTXx3e9+N1atWhWXXXbZsEGITgdAnnrqqdhpp53iwx/+cEQMHwDZf//9hw2evHr76Ec/OrBvlQGQj3/845FlWTz00EO5+1x++eWRZVksWrQoItIOgJx88snDfn7FFVdElmVx//33R8T2HQBZu3ZtjB07Nj72sY/Fs88+G2PGjIkbb7xx4PPDDjsszj777HjiiSciy7KB4ZCIiMcff7ztv5NXD5YMHQDZVquLL7542JrOPvvslgMgZ5555rB9p0+fHieddNLAn/MGQCIi7rjjjjj66KNjp512iizLYr/99ou//du/LV0rAAAAAADAAAgAAAAAAFSS4r8AsmDBgogo918AufTSSyPLsnj88ccH/fzKK69MNgASEfGnf/qnMXbs2Pi3f/u3YQMgc+fOjTe96U2xatWqlturhyCqDIAsWbIksiyLiy66KHef+fPnx/jx42PNmjUREbFy5crIsixuuummQfutWrVqu/wXQLYNNQz9r5R87nOfG/EASETEW97ylpg1a1Zce+21MW7cuFi/fv3AZ2effXYceuihcdVVV0WWZXHzzTcPfLZ+/foYO3ZsnHTSSbn/Xp577rmIqPZfAPnQhz60XQZAXn2+lStXxu///u9HlmWxZMmSCtUCAAAAAIBmMwACAAAAAAAVlBkA+ZM/+ZPIsiz+9V//ddDPTz/99BgzZkw88sgjERHxta99LbIsi69+9au55/qbv/mbyLJsYAAiImLr1q1x+OGHJx0AWbduXbzmNa+J3/zN3xw2AHLBBRfETjvtFI899ljhuadOnRq/93u/V7hfRMTmzZtjzpw5MWXKlIGavNrixYsjy7I45ZRTBn62Zs2ayLIs/vqv/3rQvv/7f//vYQMgf/zHfxxZlsV//ud/Djt3lmUxefLkePrppwetZ/bs2bHffvsN/GzRokWRZVn84Ac/GHT8EUccMWwA5NBDD43DDz+81O++zTnnnBNZlsUHPvCBYccuXbo0xo4dG7/9278dfX19sWHDhkGfv+td74pDDz00XnnllbbXGDoAEhFxyCGHxIwZMwYdu27duth99907HgD54he/GFmWxU9+8pPC3/vZZ5+NLMviT/7kTwr3BQAAAAAA/osBEAAAAAAAqGDbAMgll1wSS5YsGba9+OKL8cwzz8T06dNjr732ir//+7+Pm2++Oc4444wYM2ZMnHbaaQPn2rRpU7z73e+Ovr6+OPfcc+PGG2+MZcuWxZ//+Z/HokWLIiLioYceigkTJsS73vWuWL58eVx//fXx3ve+N2bNmpV0ACQi4ktf+lJkWTZsAGTDhg1xyCGHxC//8i/HF77whbj11lvj5ptvjiuvvDJ+93d/N+65556BfefNmxf/43/8j1i6dGmsWrUqHn744bZreeihh+KXf/mXY+rUqXHhhRfG7bffHjfeeGOcdtppMX78+Jg3b168+OKLg455z3veE7vvvntceeWVccstt8RnPvOZgXq8egBk27+r/v7+uOeee2LVqlXx8ssvR8R/DYDsvffeMWfOnFi0aFEsXbo0jjrqqMiyLBYvXjxwjnXr1sXUqVPjTW96U3zjG9+IG264IY499tjYd999hw2AnHDCCTFx4sRYvHhx/OAHP4gf/vCHhf8uli1bFlmWxZgxY+LTn/70oM+ef/75GDt2bIwZMybe8Y53DDv2hz/8YUyZMiXmzp0bV111Vdxxxx2xdOnS+MIXvhBHHnnkwH6tBkBuuOGGGDNmTBx55JHxzW9+M6699tp461vfGjNmzIi+vr6B/aoMgNx6662RZVmcdtppcffdd8eqVavihRdeiC9/+ctx3HHHxVVXXRW33357LFu2LD7wgQ9ElmVx2223FdYIAAAAAAD4LwZAAAAAAACggm1DBXnbtoGAJ554Iv7X//pfsccee0RfX18ccMAB8bnPfS62bNky6HwvvfRS/Pmf/3nMmjUrJkyYEHvssUcceeSRcffddw/sc8MNN8TBBx8ckyZNiunTp8enP/3puPHGG5MPgLz88ssDgw2vHgCJ+K8hkD/7sz+LAw44ICZMmBBTpkyJN73pTXHWWWcN+q9o3H///fGOd7wjdtppp8iyLObNm1e4nmeffTbOO++8mD17dkyaNCl22WWXOPzww+PLX/5yy/+6xZo1a+KDH/xgTJ06NaZMmRLHH398/Mu//MuwAZCXX345Tj755Nhzzz1jzJgxg/79bPsdL7/88thvv/2ir68vZs+eHV//+teHXe8HP/hBvP3tb4+dd945pk+fHv39/fGVr3xl2ADI448/HvPnz49dd901siwr9e9i/fr1MX78+MiyLL797W8P+/xXfuVXIsuyOP/881se/+ijj8ZHPvKRmD59evT19cWee+4Z73jHO+Kiiy4a2KfVAEhExHXXXRdvfOMbo6+vL2bMmBGf+9zn4rTTTos999xzYJ8qAyBbt26Nc889N6ZNmxZjx46NLMviu9/9btx1113x27/927HPPvvExIkTY4899oh3v/vdsWzZssL6AAAAAAAA/80ACAAAAAAA0Dithlya7uWXX44DDjggfvM3f3O0lwIAAAAAALRgAAQAAAAAAGicpg+AbN68OU466aRYvHhx3HHHHbFo0aI44ogjYuzYsYP+qzIAAAAAAED3MAACAAAAAAA0TtMHQLZs2RLHHntsTJ8+PSZMmBC7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4YcfHqeccsqgn82ePTvOO++80mvRQANQB/IqPTUFoA7kVXpqCkAdyKv01BSAOpBX6akpAHUgr4AmMwACUBNDB0AeffTRyLIs7r333kH7vf/9748Pf/jDLc/x8ssvx7hx4+L6668f9PMzzjgjjjjiiNJr0UADUAfyKj01BaAO5FV6agpAHdetZ/gAACAASURBVMir9NQUgDqQV+mpKQB1IK+AJjMAAlATQwdA7rrrrsiyLJ588slB+33sYx+L+fPntzzHk08+GVmWxV133TXo5xdeeGG84Q1vyL32xo0bY926dQPb6tWrNdAAdD0PfEZODwBAHekBRk4PAEAd6QFGTg8AQB3pAUZODwBAHekBgCYzAAJQE3kDIE899dSg/U4++eT4jd/4jZbn2DYAcvfddw/6+QUXXBAHHHBA7rX7+/sjy7JhmwYagG7mgc/I6QEAqCM9wMjpAQCoIz3AyOkBAKgjPcDI6QEAqCM9ANBkBkAAamLoAMijjz4aWZbFvffeO2i/97///fHhD3+45TlefvnlGDduXFx//fWDfn7GGWfEEUcckXtt/4sfANSRBz4jpwcAoI70ACOnBwCgjvQAI6cHAKCO9AAjpwcAoI70AECTGQABqImhAyBbt26NvfbaKy655JKBn7388ssxZcqUWLBgQe55Dj/88Dj11FMH/ezAAw+M8847r/RaNNAA1IG8Sk9NAagDeZWemgJQB/IqPTUFoA7kVXpqCkAdyCugyQyAAHSxF154Ie6777647777Isuy+OIXvxj33XdfPPHEExERcfHFF8eUKVPi+uuvjwceeCD+4A/+IKZNmxbr168fOMeRRx4Zf/u3fzvw58WLF0dfX1989atfjR//+MfxqU99Knbeeed4/PHHS69LAw1AHcir9NQUgDqQV+mpKQB1IK/SU1MA6kBepaemANSBvAKazAAIQBdbsWJFZFk2bDvhhBMi4r/+KyD9/f2x1157xcSJE+OII46IBx54YNA5ZsyYEf39/YN+dtlll8WMGTNiwoQJceihh8add95ZaV0aaADqQF6lp6YA1IG8Sk9NAagDeZWemgJQB/IqPTUFoA7kFdBkBkAAqEwDDUAdyKv01BSAOpBX6akpAHUgr9JTUwDqQF6lp6YA1IG8AprMAAgAlWmgAagDeZWemgJQB/IqPTUFoA7kVXpqCkAdyKv01BSAOpBX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NPLlL3/Zpb6maeTss892qWv3Oufm5pLnrVq1SpqmWbC94x3vcO0PAAA1qGkMICLyne98R9atWyerVq2SpUuXyk//9E/L2rVr5X//939d+wQAQA1qGQfceuutwXkA5gMAAAirZQwgIrJt2zZ573vfK4cffrjsvffesmLFCvn1X/91+frXv+7aHwAAalDTGOD73/++nHvuubJixQpZunSpHH744fKhD31InnzySdf+AACA4WABCAAAQEtNkz2rVq2SX/iFX5A777xz3nb//fe79gcAgBrUNAZ4+OGH5fnPf7688IUvlL/5m7+R22+/XdavXy/nnHOObNmyxbVPAADUoJZxwLZt2xbMAdx5553y5je/WZqmkZtuusm1TwAAlK6WMYCIyHHHHSf77LOP/Mmf/Inccsst8vGPf1xe8IIXyH777ScPPviga58AAChdLWOAJ554Qn7u535O9t9/f/nIRz4i//RP/yTvete7ZI899pBzzz3XtT8AAGA4WAACAADQUstkj8hPFoCceOKJrm0DAFCrmsYAr33ta+Wggw6S733ve67tAwBQq5rGAW07d+6U5z//+bJq1SrZsWOHa58AAChdLWOA//qv/5KmaeT3f//35+3fuHGjNE0jl1xyiWufAAAoXS1jgGuvvVaappH169fP2//2t79d9txzT/mP//gP1z4BAIBhYAEIAABAi2Wy58c//rG8613vkiOPPFKe+cxnyv777y/HHnus3HjjjQvOfWqy5/LLL5fDDz9cli5dKmvWrJFrr712wblbtmyRt7/97XLQQQfJkiVL5JBDDpELL7xQnnjiiQV1sgAEAABftYwBHnjgAdljjz3kwgsvtF04AACoZhwQcvPNN0vTNIwNAAAIqGUM8OCDD0rTNPKnf/qn8/Zv2rRJmqaRyy67LFoeAICxqWUMcM4558gee+whP/rRj+bt/+xnPytN08gHP/jBaHkAAFAmFoAAAAC0WCZ7tm7dKm95y1vkE5/4hNxyyy1y0003ye/+7u/KnnvuKR/72Mfmnds0jRx88MHyohe9SK699lr57Gc/K2vXrpWmaeT666/fdd6WLVvk4IMPllWrVslf/dVfyT//8z/LH//xH8uyZcvkLW95y4I6rQtA9ttvP3nGM54hixcvljVr1siHP/xhefLJJ/OCAgDACNQyBvj4xz8uTdPIX//1X8spp5wi++67ryxbtkyOP/542bhxY35gAAAYgVrGASG/+Zu/KXvuuac89NBD2WUBAKhdTWOA1772tbJixQq55ZZb5Ac/+IF84xvfkFe96lWycuVK/h9CAQBoqWUM8Pa3v10WLVq0YPHI5z//eWmaRt74xjcaIwIAAErCAhAAAICWLv93r08++aQ88cQT8ta3vlVe+tKXzjvWNI3svffe8q1vfWve+atXr5YXvOAFu/a94x3vkGc84xkL/kHGhz/8YWmaRu699955dVp+8HnnO98pV111ldx+++1y4403ypve9CZpmkZ+67d+y3xtAACMRS1jgA9+8IPSNI0885nPlNe+9rVy0003yfr16+UlL3mJ7LXXXvLv//7v5usDAGAsahkHtD366KOy1157yatf/eqscgAAjEVNY4DHH39c3va2t0nTNLu2l7zkJfLAAw+Yrw0AgLGoZQzwF3/xF9I0jfzLv/zLvP1/8Ad/IE3TyAknnGC+PgAAUA4WgAAAALRYJ3s+/elPyyte8QrZd9995/2gstdee807r2kaOemkkxaUn5ubk6ZpZPPmzSIictBBB8mv/MqvyBNPPDFvu/feexf8X7R3/a9+ivzk/wa2aRq5++67O5UHAKBWtYwBLrroImmaRl70ohfN+3/9euSRR2SfffaRN73pTalQAAAwOrWMA9o+8pGPLPivjQIAgKfVNAZ461vfKs961rPkz//8z+X222+XT33qU3L00UfLoYceKg8++KAhGgAAjEctY4DvfOc78qxnPUvWrFkjd911lzz66KPyyU9+UpYvXy5N08jatWuNEQEAACVhAQgAAECLZbJn/fr10jSN/MZv/IZ85jOfkTvvvFO+/OUvy2//9m9L08wfYjVNI2ecccaCOj760Y9K0zTyla98RUREFi9ePG/SqL390R/90bw6uy4AueuuuxZMHgEAgHrGAJdffrk0TSPr1q1bcOznf/7nZc2aNdHyAACMUS3jgLaXvvSl8pznPEcef/zxrHIAAIxFLWOAf/zHfwwu+nz00Udl+fLl8pa3vCUVCgAARqWWMYCIyL/927/JmjVrdtXx7Gc/W6688kppmkbe+ta3GiMCAABKwgIQAACAFstkz6/92q/JoYceKjt37py3/01velNwssfyX/s44IAD5IQTTpAvf/nLwe3hhx+eV2fXBSB33nmnNE0jl19+eafyAADU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4102jnf5ejvm3o4X0+rt+uJ4l6234y2lv2PmeAEAu4QfgADAjnvooYfK/v37yyc+8Yny1FNPlXvuuaccOnSovPDCC6WUUu64444Lfgzy6KOPln379pWPf/zj5emnny4f//jHy0UXXVS+9KUvTd723m4mON5l43iXjeMF2urtGuN4l43jXTaOF2irt2uM4102jnfZejveUvo8Zkynt+uL4102jnf5ejvm3o4X0+rt+uJ4l6234y2lv2PmeAEAu4QfgADAAjzwwAPlsssuKwcOHCjXXHNNOXHixOv73vnOd5ajR49ekP7v//7vy5VXXln2799frrrqqvKpT31q4hb/P2fOnCn33ntvOXPmzFbqnxrHu2wc77JxvEBbvV1jHO+ycbzLxvECbfV2jXG8y8bxLltvx1tKn8eM6fR2fXG8y8bxLl9vx9zb8WJavV1fHO+y9Xa8pfR3zBwvAGCX8AMQAAAAAAAAAAAAAAAAAAAAAACAmeMHIAAAAAAAAAAAAAAAAAAAAAAAADPHD0AAAAAAAAAAAAAAAAAAAAAAAABmjh+AAAAAAAAAAAAAAAAAAAAAAAAAzBw/AAEAAAAAAAAAAAAAAAAAAAAAAJg5fgACAJiFW2+9tVx66aXl4MGD5ad+6qfKb//2b5eXX355283aiG984xvlfe97X7n88svLj/zIj5Sf+7mfKx/96EfL2bNnt920jbnvvvvK9ddfX970pjeVw4cPb7s5G/HAAw+Uyy+/vBw8eLBcc8015ZFHHtl2kzbixIkT5Td/8zfLT//0T5fValX+8R//cdtN2qj777+/XHvtteXiiy8ul1xySXnPe95Tvva1r227WRvzl3/5l+WXfumXypvf/Oby5je/ubz97W8vn/3sZ7fdLCwccwDmALuOOcAyMQdgDoDNYw7AHGDXMQdYJuYAzAGwecwBlj0HKGX584Be5gCl9DUPYA7AHACb19McoJQ+5wHMAZaDOQBzAADA/PEDEADALBw/frx88YtfLC+88EJ59NFHy/XXX1+uv/76bTdrI/75n/+5/M7v/E7513/91/L888+XT3/60+Unf/Inyx/90R9tu2kb89GPfrQcP368/OEf/uEiH/Y89NBDZf/+/eXBBx8sTz31VPnQhz5UDh06VF588cVtN625z372s+UjH/lI+dSnPrX4hz2llHLTTTeVvb298uSTT5bH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\" width=\"3200\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, 'Local Net Output Weights')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weights = local_net.output_weights.numpy()\n",
    "fig, axes = plt.subplots(2, 5, figsize=(32, 4), sharex=True, sharey=True)\n",
    "for i in range(2):\n",
    "    for j, ax in enumerate(axes[i]):\n",
    "        axes[i, j].hist(weights[i*5 + j], bins=1000, range=(weights.min(), weights.max()))\n",
    "        axes[i, j].set_title('Label {}'.format(i*5 + j))\n",
    "fig.suptitle('Local Net Output Weights')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "252\n",
      "268\n",
      "235\n",
      "216\n",
      "225\n",
      "247\n",
      "229\n",
      "259\n",
      "242\n",
      "211\n"
     ]
    }
   ],
   "source": [
    "for i in range(10):\n",
    "    print(np.count_nonzero(np.histogram(weights[i], bins=1000, range=(-3, 3))[0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "gd_net = BrainNet(784, 10, num_v = 1000, p = .5, cap = 500, rounds = 3, gd_output = True, gd_graph=True)\n",
    "gd_net.input_layer = local_net.input_layer\n",
    "gd_net.input_weights = local_net.input_weights\n",
    "# gd_net.graph_weights = local_net.graph_weights\n",
    "gd_net.graph = local_net.graph\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = torch.optim.Adam(gd_net.parameters(), lr=1e-2)\n",
    "losses = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Accuracy: 10.270%\n",
      "Epoch 0 Batch 0: 27884757.343\n",
      "Epoch 0 Batch 100: 483806.024\n",
      "Epoch 0 Batch 200: 227434.505\n",
      "Epoch 0 Batch 300: 174776.196\n",
      "Epoch 0 Batch 400: 136372.358\n",
      "Epoch 0 Batch 500: 120577.788\n",
      "Test Accuracy: 86.330%\n",
      "Epoch 1 Batch 0: 96663.620\n",
      "Epoch 1 Batch 100: 86318.125\n",
      "Epoch 1 Batch 200: 78649.034\n",
      "Epoch 1 Batch 300: 71967.114\n",
      "Epoch 1 Batch 400: 59313.716\n",
      "Epoch 1 Batch 500: 60476.905\n",
      "Test Accuracy: 84.530%\n",
      "Epoch 2 Batch 0: 55449.246\n",
      "Epoch 2 Batch 100: 39780.608\n",
      "Epoch 2 Batch 200: 49330.376\n",
      "Epoch 2 Batch 300: 46332.476\n",
      "Epoch 2 Batch 400: 39666.605\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-11-3a4d7e72e800>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m20\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m     \u001b[0;32mfor\u001b[0m \u001b[0mj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrainloader\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mj\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m             \u001b[0mlocal_correct\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m             \u001b[0;32mwith\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mno_grad\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    361\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    362\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__next__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 363\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    364\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    365\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_kind\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0m_DatasetKind\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mIterable\u001b[0m \u001b[0;32mand\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    401\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    402\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_index\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 403\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_fetcher\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    404\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    405\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_utils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36mfetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torchvision/datasets/mnist.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, index)\u001b[0m\n\u001b[1;32m     95\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     96\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtransform\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 97\u001b[0;31m             \u001b[0mimg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtransform\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     98\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     99\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtarget_transform\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torchvision/transforms/transforms.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, img)\u001b[0m\n\u001b[1;32m     59\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     60\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mt\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtransforms\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 61\u001b[0;31m             \u001b[0mimg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     62\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     63\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torchvision/transforms/transforms.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, pic)\u001b[0m\n\u001b[1;32m     90\u001b[0m             \u001b[0mTensor\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mConverted\u001b[0m \u001b[0mimage\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     91\u001b[0m         \"\"\"\n\u001b[0;32m---> 92\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mF\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto_tensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpic\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     93\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     94\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__repr__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torchvision/transforms/functional.py\u001b[0m in \u001b[0;36mto_tensor\u001b[0;34m(pic)\u001b[0m\n\u001b[1;32m     82\u001b[0m     \u001b[0mimg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpermute\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcontiguous\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     83\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimg\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mByteTensor\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 84\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfloat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdiv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m255\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     85\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     86\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for i in range(20):\n",
    "    for j, data in enumerate(trainloader):\n",
    "        if j == 0:\n",
    "            local_correct = 0\n",
    "            with torch.no_grad():\n",
    "                for inputs, labels in testloader:\n",
    "                    outputs = gd_net.forward_pass(inputs)\n",
    "                    local_correct += np.count_nonzero((outputs.argmax(axis=1) == labels).numpy())\n",
    "            print('Test Accuracy: {:.3f}%'.format(local_correct / len(testset) * 100))\n",
    "        inputs, labels = data\n",
    "        optimizer.zero_grad()\n",
    "        outputs = gd_net.forward_pass(inputs)\n",
    "        loss = criterion(outputs, labels)\n",
    "        losses += [loss.item()]\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        if j % 100 == 0:\n",
    "            print('Epoch {:d} Batch {:d}: {:.3f}'.format(i, j, np.median(losses[i*600 + j-100:i*600 + j+1])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GD Net Test Accuracy: 87.490%\n"
     ]
    }
   ],
   "source": [
    "gd_correct = 0\n",
    "\n",
    "with torch.no_grad():\n",
    "    for inputs, labels in testloader:\n",
    "        outputs = gd_net.forward_pass(inputs)\n",
    "        gd_correct += np.count_nonzero((outputs.argmax(axis=1) == labels).numpy())\n",
    "print('GD Net Test Accuracy: {:.3f}%'.format(gd_correct / len(testset) * 100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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acCAATLG6IknnnDcX19fr9zcXA0YMECxsbGaOHGiXn/9dccxBw8e1OzZs5WYmKjExETNnj1bH3/8seOY1157TRMmTFBsbKySk5N17733qr6+3nHMhg0bNGLECMXExGjEiBHKz89v18/CAAFtZ7vYEAog0Ij9baEAbtq0SXfffbc2btzYbAFctmyZEhIStHHjRpWVlenKK6/UgAED9Mknn4SPmTZtmjIyMlRUVKSioiJlZGQoKysrfH9NTY369eunmTNnqqysTBs3blRCQoIeeuih8DFFRUXq3r27lixZojfffFNLlixRjx49tH379jb/LAwQ0Ha2iw2hAAKN2N+W3wI+uQDW19erf//+WrZsWfi22tpaJSUl6fHHH5cklZeXyxjjKGrFxcUyxmjXrl2SpEcffVRJSUmqra0NH7N06VIlJyeHXwX8zne+o2nTpjnO59JLL9XMmTPbfP4MENA624WGUACBk7G/PVYA3333XRljVFJS4jhuxowZuuaaayRJK1euVFJSUpPHSkpK0qpVqyRJV199tWbMmOG4v6SkRMYY7d69W5L0hS98QcuXL3ccs3z5cg0ePLjF862trVVNTU04lZWVgR8goDW2Cw2hAAInowB6rABu27ZNxhhVVVU5jsvOztbUqVMlSYsXL1ZaWlqTx0pLS9OSJUskSVOmTFF2drbj/qqqKhljVFRUJEmKjo7WmjVrHMesWbNGMTExLZ5vbm6ujDFNEuQBAlpju9AQCiBwMgqgRwvgvn37HMfdcMMNuvTSSyU1FMBhw4Y1eayhQ4dq6dKlkhoK4Ny5cx337927V8YYFRcXS2oogGvXrnUc84c//EGhUKjF8+UVQKD9bBcaQgEETkYB9FgB9PpbwCdjgIDW2S40hAIInIz97bEC2HgRyAMPPBC+ra6urtmLQF555ZXwMdu3b29yEUivXr1UV1cXPmbZsmVNLgL52te+5jifadOmcREI0MFsFxpCAQROxv62UAAPHTqk0tJSlZaWyhij5cuXq7S0VBUVFZIailpSUpLy8/NVVlamq666qtmPgcnMzFRxcbGKi4t1/vnnOz4Gprq6Wv369dNVV12lsrIy5efnKzEx0fExMNu2bVP37t21bNkyvfnmm1q2bBkfAwN0AtuFhlAAgZOxvy0UwC1btjR7IcWcOXMk/feDoPv3769QKKQJEyaorKzM8RgH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nHc9nvOux3Pe9XjOI1egC2Djx8CsXLlS5eXluu2229SzZ0+99957tk/N1/gLo+vxnHc9nvOux3Pe9XjOI1egC6DU8EHQKSkpiomJ0ejRo7V161bbp+R7tbW1ys3NVW1tre1TCQye867Hc971eM67Hs955Ap8AQQAAAgaCiAAAEDAUAABAAAChgIIAAAQMBRAAACAgKEAosvU1tZq5MiRMsaotLTU9ulErD179ui6665TamqqYmNjdc455+jHP/6x6urqbJ9aRHnkkUeUmpqqUCik0aNH66WXXrJ9ShFryZIlGjt2rM444wz17dtXdzlWsAAAA/ZJREFUl19+uXbt2mX7tAJlyZIlMsZowYIFtk8FHYQCiC4zf/58fe1rX6MAdrJnn31W1157rZ577jm9++67+vOf/6yzzz5bd955p+1TixiNnyG6YsUKlZeXa8GCBerZs6cqKipsn1pEuvTSS7V69Wq9/vrr2rlzp6ZPn67Bgwfr008/tX1qgfD3v/9dqampyszMpABGEAogusSmTZuUnp6uN954gwJowYMPPqghQ4bYPo2IMW7cOM2bN89xW3p6Ov+KUBf58MMPZYzhc1u7wKFDh5SWlqaCggJNnDiRAhhBKIDodB988IEGDhyoHTt2aM+ePRRAC+6++26NGTPG9mlEBP4dcfvefvttGWNUVlZm+1Qi3jXXXKPbbrtNkiiAEYYCiE5VX1+vadOm6b777pMkCqAF77zzjhITE7VixQrbpxIRqqqqZIzRtm3bHLcvXrxYw4YNs3RWwVFfX6/LLrtMF110ke1TiXh5eXnKyMjQkSNHJFEAIw0FEKclNzdXxphTZseOHXr44Yf1la98RceOHZNEAXSjrc/5iaqqqjR06FBdf/31ls468jQWwKKiIsft999/v4YPH27prILj5ptvVkpKiiorK22fSkR7//33dfbZZ2vnzp3h2yiAkYUCiNPyn//8R2+++eYpc+TIEV1++eWKiopS9+7dwzHGqHv37rrmmmts/xi+0tbnvFFVVZWGDRumq6++WsePH7d45pGFt4DtycnJ0aBBg7R7927bpxLxnnjiifDf1Sf+3d2tWzd17949/D/18C8KIDpVRUWFysrKwnnuuedkjNGGDRv4P/hOtHfvXqWlpWnmzJn8Rd0Jxo0bp5tuuslx24gRI7gIpJPU19frlltuUXJyst566y3bpxMIn3zyiePv7rKyMo0dO1azZ8/mdy8jBAUQXYq3gDtf49u+F198sfbu3av9+/eHg47R+DEwK1euVHl5uW677Tb17NlT7733nu1Ti0g33XSTkpKSVFhY6Jjnw4cP2z61QOEt4MhCAUSXogB2vtWrV7f4O4LoOI888ohSUlIUExOj0aNH85EknaileV69erXtUwsUCmBkYSMAAAAEDAUQAAAgYCiAAAAAAUMBBAAACBgKIAAAQMBQAAEAAAKGAggAABAwFEAAAICAoQACAAAEDAUQAAAgYCiAAAAAAUMBBAAACBgKIAAAQMBQAAEAAAKGAggAABAwFEAAAICAoQACAAAEDAUQAAAgYCiAAAAAAUMBBAAACBgKIAAAQMBQAAEAAAKGAggAABAwFEAAAICAoQACAAAEDAUQAAAgYCiAAAAAAUMBBAAACBgKIAAAQMBQAAEAAAKGAggAABAwFEAAAICA+f8/HnnJXLT9IwAAAABJRU5ErkJggg==\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'GD Net Graph Weights')"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.hist(gd_net.graph_weights.detach().numpy().flatten(), bins=200)\n",
    "ax.set_title('GD Net Graph Weights')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAADIAAAAGQCAYAAABshfojAAAgAElEQVR4nOzde5DddXk/8G82CUk0EglFhYCJcgkKTapiAbWT8QJSEdsqTp3iqMi9oVLwWmmJlsqItSpeEC8jReSiaL0gGIWAKBbb1IhSlF6ppBKKCIGAXBJ4fn8wu79sNrvnfPf7OefzvbxeM8+M7rns7rPH7/s5n93HFAEAAAAAAAAAAAAAAECtFbm/AAAAAAAAAAAAAAAAAKZmAQQAAAAAAAAAAAAAAKDmLIAAAAAAAAAAAAAAAADUnAUQAAAAAAAAAAAAAACAmrMAAgAAAAAAAAAAAAAAUHMWQAAAAAAAAAAAAAAAAGrOAggAAAAAAAAAAAAAAEDNWQABAAAAAIAB+clPfhJvfvOb45nPfGbMnTs35s6dG3vttVccf/zxsXbt2nH3XbVqVRRFMVbz5s2LRYsWxaGHHhof/ehH47777uvrc55//vlRFEXMmTMn/ud//mfC7StWrIj99ttvWt/PRRddFB/+8IdLPeaRRx6Jc889Nw466KDYcccdY+7cubHvvvvGO9/5zrjrrrum9XVERNx8882xatWquPXWW6f9HGVcccUVsWrVqr7uu3LlyiiKIjZs2DDu47/+9a9jxowZMWvWrNi0adO429avXx9FUcSpp55a+mtbtGhRHHPMMaUfFxHxwhe+MJYvX97zfuvXr49Vq1bFT37yk2l9HgAAAAAAoDoLIAAAAAAAMADnnXdezJo1K/bbb78455xz4uqrr441a9bExz/+8XjhC18YRVHEf/7nf47df3QBZPXq1XHDDTfEddddF5dcckkce+yxMXfu3Nhjjz3ixhtv7Pl5RxdAiqKI17/+9RNur7IAcvjhh8fixYv7vv8DDzwQK1asiJkzZ8ZJJ50UV1xxRVxzzTXxvve9L3baaafYY4894pZbbpnW13LZZZdFURRx7bXXTuvxZY0udfTjy1/+chRFEZdccsm4j//DP/xDzJ49O2bPnh3f+ta3xt32+c9/PoqiiG984xulv7Z169bFf/3Xf5V+XET/CyA33HBDFEURF1544bQ+DwAAAAAAUJ0FEAAAAAAASOz666+PkZGROOKII+Lhhx/e7n2+9KUvxS9/+cux/z66APKrX/1qwn1vvPHGWLBgQTz96U+Phx56aMrPPboActhhh8XIyMiEpZFhLoAcf/zxURRFXHrppRNu+7d/+7dYsGBB7LfffrFly5bSX0udF0DuuuuumDFjRpxwwgnjPv6Wt7wlXvCCF8TBBx8c73jHO8bd9uY3vzlGRkZi48aNyb7mflgAAQAAAACA5rAAAgAAAAAAib3iFa+I2bNnx+233973Y6ZaAImI+MAHPhBFUcQFF1ww5fOMLoBcc801scsuu8TLX/7ycbdvbwHksccei0984hOxfPnymDt3bjz5yU+O17zmNeP+VYkVK1aM/csiW9dkNmzYELNmzZrw+bd21llnRVEU8eUvf3nsY0VRxKpVqybcd/HixfHGN75x3Pe4bZ1//vnjvsfvfe97ceCBB8bcuXNjt912i7/8y78ct2xy7bXXbneJ5NZbbx33fG984xu3+/luvfXWSb+3ZcuWxdKlSyd87N3vfne8613viuc///njbnvmM58ZBxxwwLiPbdy4MU477bRYsmRJzJ49OxYtWhSnnnpqPPDAA+Put2jRojjmmGPGfeynP/1pvPSlL4158+bFb/3Wb8XJJ58cX//616Moivj+978/dr/RBZAf/vCH8YIXvCDmzZsXz3zmM+Pss8+Oxx57LCIirrrqqu1+/2eeeWZERPzHf/xHvPa1r42nPe1pscMOO8RTn/rUeOlLXxo//elPJ+0PAAAAAABQngUQAAAAAABIaMuWLTFv3rw4+OCDSz2u1wLILbfcEkVRTPhD/22NLkesXbs2zjnnnCiKItasWTN2+/YWQI477riYPXt2vPWtb43Vq1fHxRdfHPvuu2889alPjTvuuCMiIm6++eZ44QtfGE972tPihhtuGKvJXHzxxVEURXzyk5+c9D4/+9nPoiiKcf9SRj8LIHfeeefY8sgnPvGJsa/lzjvvHPsed95559htt93iox/9aHz729+Ot7zlLVEURaxcuXLsOftdAPnP//zPOPLII6MoinHf+1T/Gsspp5wSRVGMLQGN/qsg3/72t+Nb3/pWzJw5M+69996IiLjtttuiKIp4+9vfPvb4TZs2xW//9m/HLrvsEh/5yEfi6quvjg9/+MOx4447xiGHHDK2nBExcQFk/fr1sdNOO8WSJUviggsuiCuvvDKOOuqoWLJkyXYXQHbZZZfYZ5994lOf+lRcddVVccIJJ0RRFHHRRRdFRMS9994bn/3sZ6MoinjPe94z9v3/7//+b0RE7LXX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ryiKWLlyZZLn2vo5V61a1dd9L7nkkli+fHnMmTMndt111zjllFNi06ZNSb8eAGiDNs0AF1xwQfzxH/9x7LPPPjFjxoxYvHhx0q8DANqmLXPA7bffHqeffnocdNBBsfPOO8eTnvSkeO5znxuf+tSnYsuWLUm/HgBog7bMABERxxxzTOy3336xYMGCmDt3buy9997xtre9LX71q18l/XoAoA3aNANs7Y477oiFCxdGURRx2WWXJf16AID6sAACALCNNh32fOELX4iiKOLYY4+Na665Js4777xYsGBBHHLIIUm/HgBogzbNAC972cti//33j9e//vWx1157WQABgB7aMgdcfvnlsccee8Tpp58eV1xxRXznO9+JU089NUZGRuLoo49O+vUAQBu0ZQaIiHjd614X55xzTlxxxRWxZs2aOPvss2PHHXeMZz/72fHwww8n/ZoAoOnaNANs7TWveU3stttuFkAAoOUsgAAAbKMthz1btmyJXXfdNQ499NBxH7/ooouiKIq48sork35NANB0bZkBIiIeffTRsf98+OGHWwABgB7aMgfcfffd8cgjj0z4+MqVK6MoirjtttuSfk0A0HRtmQEmc+6550ZRFLFmzZqkXxMANF0bZ4Avf/nLMX/+/LjgggssgABAy1kAAQDYRj+HPQ8++GCcdtppsXz58thxxx1jp512ioMOOii+9rWvTbjv6GHPeeedF3vvvXfssMMO8axnPSsuueSSCffdsGFDHH/88bFo0aKYPXt2LFmyJN7znvfE5s2bJzxnr8Oe66+/PoqimPB5HnnkkZg/f34cd9xxUz4eALqmLTPAtiyAAEBvbZ0DRo3+8cc//uM/TuvxANBWbZ8BLrvssiiKIq677rppPR4A2qptM8Cvf/3reOpTnxrnnHNOXHvttRZAAKDlLIAAAGyjn8OejRs3xpve9Ka48MIL45prronVq1fH2972thgZGYkLLrhg3H2Loog99tgjnv3sZ8cll1wS3/jGN+Kwww6bcOiyYcOG2GOPPWLx4sXxqU99Kq6++uo488wzY86cOfGmN71pwnP2Ouw577zzoiiKuPnmmyfcdsABB8TBBx/cRzcAoDvaMgNsywIIAPTW1jlg1Bvf+MaYNWtW3HXXXdN6PAC0VRtngM2bN8f9998f119/fey7777xohe9KLZs2dL34wGgC9o2Axx11FFx0EEHxaOPPmoBBAA6wAIIAMA2pvPPvW7ZsiU2b94cxxxzTDznOc8Zd1tRFDFv3ry44447xt1/3333jb322mvsYyeccELMnz8/fvGLX4x7/Ac/+MEJixz9HPa8733vi6IoYsOGDRNuO/TQQ2Offfbp+/sDgC5oywywLQsgANBbW+eAiIhvf/vbMTIyEqeeemrpxwJA27VtBrjhhhuiKIqxesUrXhH33Xdf398bAHRFm2aAb37zmzF79uy46aabIiIsgABAB1gAAQDYRr+HPV/60pfiBS94QTzxiU8c9wuVuXPnjrtfURTxyle+csLjV61aFUVRxPr16yMiYtGiRXHEEUfE5s2bx9XNN98cRVHEueeeO+45+10A2fqQadShhx4aS5cunfLxANA1bZkBtmUBBAB6a+sc8KMf/SgWLFgQL3jBC+Khhx4q9VgA6IK2zQD3339/rF27Nq677ro455xzYtddd40DDzwwHnjggb4eDwBd0ZYZYOPGjbFo0aL4y7/8y7GPWQABgPazAAIAsI1+Dnu+8pWvRFEU8drXvja++tWvxg033BBr166NN7/5zVEU40esoiji2GOPnfAcn/zkJ6MoirjxxhsjImLWrFnjDo22rb/+678e95y9DnvOO++8Cf8vIaMOOOCAOPjgg6d8PAB0TVtmgG1ZAAGA3to4B6xbty4WLlwYBxxwQGzcuLHvxwFAl7RxBtjaD3/4wyiKIj70oQ9N6/EA0FZtmQFWrlwZS5YsiTvuuCPuueeeuOeee+Lyyy+PoijiggsuiHvuuScee+yxEp0BAJrAAggAwDb6Oez5oz/6o3jGM54x4bDkqKOO2u5hTz//bx9Pe9rT4tBDD421a9dut375y1+Oe85ehz0/+MEPoiiKuPTSS8d9fPPmzTF//vw47rjjpnw8AHRNW2aAbVkAAYDe2jYHjC5/POc5z4m77767r8cAQBe1bQbY1pYtW2JkZCROPPHEaT0eANqqLTPAihUrplwoKYoi7rnnnl7tAAAaxgIIAMA2+jnsefWrXx1Lly4d97ENGzbE/Pnzt3vYM2/evLjjjjvGPrZly5bYd999Y8899xz72LHHHhu77bZbX3+Y0c9hz5YtW2LXXXeNww47bNzHL7nkkiiKIr71rW/1/DwA0CVtmQG2ZQEEAHpr0xzw4x//OBYuXBjLli2Lu+66q+f9AaDL2jQDbM+aNWuiKIr44Ac/OK3HA0BbtWUG+PGPfxzXXnvtuPrwhz8cRVHEe97znrj22mtj8+bNPT8XANAsFkAAALYxethz9tlnx2WXXTahHnjggfjc5z4XRVHESSedFGvWrIm///u/jz333DP23nvv7R727LHHHvHsZz87LrnkkvjGN74Rhx122IR/neP222+PxYsXx7777hvnnnturFmzJq644or4xCc+EYcffvjY/yvI6HP28wufCy+8MIqiiOOPPz6uvfba+PSnPx1PfvKT45BDDknWLwBoizbNADfffPPY1/285z0vdtlll7H/fvPNNyfrGQC0RVvmgFtuuSV23nnnWLhwYVx++eVxww03jKs777wzad8AoOnaMgNcfvnl8apXvSo++9nPxlVXXRVXXnll/PVf/3UsXLgw9tprr9i4cWPSvgFA07VlBtiea6+9NoqiiMsuu2za/QEA6s0CCADANkYPeyarW2+9NSIi3v/+98eSJUtizpw58axnPSs+85nPjP0TrlsriiJWrlwZ5557buy5554xe/bs2HfffeOiiy6a8Ll/9atfxVve8pZ4xjOeEbNnz46FCxfG8573vDj99NPj/vvvH/ec/R72XHzxxbFs2bLYYYcd4mlPe1q85S1viU2bNk27PwDQVm2aAUa/nu3VdP9fQwGgzdoyB/T6Ps4///yqrQKAVmnLDPDzn/88jjzyyFi8eHHMnTs35s6dG/vuu2+8/e1vj1//+teV+wQAbdOWGWB7LIAAQPtZAAEAAAAAAAAAAAAAAKg5CyAAAAAAAAAAAAAAAAA1ZwEEAAAAAAAAAAAAAACg5iyAAAAAAAAAAAAAAAAA1JwFEAAAAAAAAAAAAAAAgJqzAAIAAAAAAAAAAAAAAFBzFkAAAAAAAAAAAAAAAABqzgIIAKU9+uijsX79+ti4cWPce++9SimlVC1r48aNsX79+nj00UdzR2drmAGUUko1ocwA6ZkBlFJKNaHMAOmZAZRSSjWhzADpmQGUUko1ocwAQJdZAAGgtPXr10dRFEoppVQjav369bmjszXMAEoppZpUZoB0zABKKaWaVGaAdMwASimlmlRmgHTMAEoppZpUZgCgiyyAAFDaxo0bxwbo3NvcSiml1GQ1+guKjRs35o7O1jADKKWUakKZAdIzAyillGpCmQHSMwMopZRqQpkB0jMDKKWUakKZAYAu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e+yxac2aNWn9+vXpqquu2u22Dz74YDrrrLPSkUcemVavXp2OOeaY9K53vSv9+Mc/3u0xbQABgFhjmQHuueeetM8++6R3vetd8/3iAMBo5oA9ueGGG1LTNGYDANiDscwA9957b2qaJv3Jn/zJkq/ffffdqWmadNllly17fwCYmrHMABs2bEj77LNP+uEPf7jk65/85CdT0zTpve9977L3BwCGyQYQAIBdzLPYs3Xr1vSGN7wh/d3f/V268cYb03XXXZd+7/d+L+27777pIx/5yJLbNk2Tnva0p6VnP/vZ6aqrrkqf/OQn02mnnZaapkkf+9jHdt7uwQcfTE972tPS2rVr01/91V+lz3zmM+nd73532m+//dIb3vCG3R5z3g0gT3ziE9PBBx+cnvCEJ6T169en97///WnHjh15TQGACRjLDPDRj340NU2T/vqv/zq95jWvSQcddFDab7/90otf/OJ088035zcGACZgLHPAnvz2b/922nfffdN9992XfV8AGLsxzQBnnnlmOuKII9KNN96Yvv/976cvf/nL6WUve1k6+uij/R9CAWAXY5kBzjrrrLRq1ardNo98+tOfTk3TpN/6rd+asyMAwJDYAAIAsIuV/O9ed+zYkX784x+nN73pTem5z33uku81TZMOOOCA9O1vf3vJ7detW5ee9axn7fza2WefnQ4++ODd/iDj/e9/f2qaJt11111LHnOeD3ze8pa3pA9/+MPppptuSp/4xCfSa1/72tQ0TXrd61439+8GAFMxlhngve99b2qaJj3pSU9KZ555ZrruuuvSNddck0444YS0//77p//8z/+c+/cDgKkYyxywq4cffjjtv//+6ZWvfGXW/QBgKsY0A/zoRz9Kv/u7v5uaptlZJ5xwQrrnnnvm/t0AYCrGMgP8+Z//eWqaJv37v//7kq//wR/8QWqaJr3iFa+Y+/cDAIbDBhAAgF3Mu9jzD//wD+mFL3xhOuigg5Z8oLL//vsvuV3TNOlVr3rVbvfftGlTapomLSwspJRSOvLII9MZZ5yRfvzjHy+pu+66a7f/RftK/9XPlP7vfwPbNE267bbbVnR/ABirscwAF198cWqaJj372c9e8n/9euCBB9KBBx6YXvva185qBQBMzljmgF194AMf2O1fGwUAfmJMM8Cb3vSmdNhhh6U/+7M/SzfddFO6+uqr08knn5ye/vSnp3vvvXeObgDAdIxlBvjud7+bDjvssLR+/fr0xS9+MT388MPp7//+79MhhxySmqZJp5122pwdAQCGxAYQAIBdzLPYc80116SmadJv/uZvpo9//OPplltuSbfeemt64xvfmJpm6YjVNE1685vfvNtj/OVf/mVqmibdfvvtKaWUnvCEJyxZNNq1/vAP/3DJY650A8gXv/jF3RaPAIDxzAAf/OAHU9M0aePGjbt97xd+4RfS+vXrl70/AEzRWOaAXT33uc9NT3nKU9KPfvSjrPsBwFSMZQb41Kc+tcdNnw8//HA65JBD0hve8IZZrQCASRnLDJBSSl/60pfS+vXrdz7Gk5/85PShD30oNU2T3vSmN83ZEQBgSGwAAQDYxTyLPb/2a7+Wnv70p6fHH398yddf+9rX7nGxZ55/7eOpT31qesUrXpFuvfXWPdaWLVuWPOZKN4DccsstqWma9MEPfnBF9weAsRrLDHDzzTfvdQPIC17wgvSzP/uzy94fAKZoLHPAT7vttttS0zTp7W9/+9z3AYCpGcsM8N73vjc1TbPH/9PH8573vHTyyScve38AmJqxzAA/7Z577kl33nlnevTRR3d+TvCRj3xk7vsDAMNhAwgAwC7mWez59V//9XT88ccv+dqDDz6YDj744D0u9hxwwAHp29/+9s6v7dixI61bty4985nP3Pm1N7/5zemII45IDz300Mzn2GYDyLnnnrvkXxkBAP7PWGaAxx57LB111FFp3bp1aceOHTu/vmXLlnTAAQf4F78AYA/GMgf8tPPOOy81TZPuvvvuue8DAFMzlhngIx/5SGqaJm3evHnJ1//7v/87PfGJT0y/+qu/OvPnAMCUjGUG2JPHH388vfrVr05HHHFE+uEPf5h9fwCg/2wAAQDYxeJiz/ve9770sY99bLf63//93/ThD384NU2Tzj333HTDDTekv/3bv03PfOYz07HHHrvHxZ6nPe1p6dnPfna66qqr0ic/+cl02mmn7fZhzAMPPJDWrl2b1q1bly677LJ0ww03pH/5l39Jl156aTr99NN3/qsgi485a7HnyiuvTK9+9avThz/84XTDDTeka665Jr3mNa9JTdP4370DwB6MZQZIKaWPfexjaZ999kmnn356+ud//ud09dVXp+c85znpkEMOSV//+tfDegYAYzGmOSCllB555JF06KGHphe+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n57xjGekiy66KD366KO1n9rgXXrppemYY45J++23XzrppJPS5z//+dpPaVQuueSSdPLJJ6eDDz44PeUpT0lnnnlm+spXvlL7aY3aJZdckpqmSeeff37tp8KEmAG6YwbojhmgW2aA8swA1GAG6I4ZoDtmgG6ZAcozA1CDGaA7ZoDumAG6ZQYozwxALeaAbpgBumMG6JYZoA5zAEB3bAABYHI2btyYfvmXf9liTwc+9alPpTe84Q3p05/+dPrGN76R/umf/ikdfvjh6e1vf3vtpzZomzdvTqtXr06XX355uvvuu9P555+fDjrooHTffffVfmqj8cpXvjJdccUV6c4770y33357Ov3009PRRx+dfvCDH9R+aqP0pS99KR1zzDHphBNOsNhDUWaA7pgBumEG6J4ZoCwzALWYAbpjBuiGGaB7ZoCyzADUYgbojhmgG2aA7pkByjIDUJM5oBtmgG6YAbpnBijPHADQLRtAAJiUf/3Xf03r1q1Ld911l8WeQv74j/84Pf3pT6/9NAbtlFNOSeecc86Sr61bty5deOGFlZ7R+H3nO99JTdOkm266qfZTGZ3vf//76dhjj03XX399evGLX2yxh2LMAOWZAdozA5RnBuiOGYBazADlmQHaMwOUZwbojhmAWswA5ZkB2jMDlGcG6I4ZgJrMAWWZAdozA5RnBuiWOQCgezaAADAZ3/72t9ORRx6Zbr311nTPPfdY7Cnkne98Z3re855X+2kM1qOPPppWrVqVrr322iVf37hxYzr11FMrPavx+9rXvpaapkl33HFH7acyOq9//evTBRdckFJKFnsoxgxQhxmgHTNAHWaA7pgBqMEMUIcZoB0zQB1mgO6YAajBDFCHGaAdM0AdZoDumAGoxRxQnhmgHTNAHWaAbpkDALpnAwgAk/D444+n0047Lb373e9OKSWLPYV8/etfT0960pPS5ZdfXvupDNaWLVtS0zTpC1/4wpKvX3zxxem4446r9KzG7fHHH09nnHFGetGLXlT7qYzOVVddlZ7znOekRx55JKVksYcyzAB1mAHaMwOUZwbojhmAGswAdZgB2jMDlGcG6I4ZgBrMAHWYAdozA5RnBuiOGYBazAHlmQHaMwOUZwboljkAoAwbQAAYtE2bNqWmaZatW2+9Nf3FX/xFeuELX5h27NiRUrLYk2vePv+0LVu2pGc961npTW96U6VnPQ6LCz4333zzkq+/5z3vSccff3ylZzVub3nLW9LatWvTwsJC7acyKvfff386/PDD0+23377zaxZ7aMMMUIYZoB4zQHlmgG6YAYhmBijDDFCPGaA8M0A3zABEMwOUYQaoxwxQnhmgG2YAumAO6J4ZoB4zQHlmgO6YAwDKsQEEgEH77ne/m7785S8vW4888kg688wz07777ptWrVq1s5qmSatWrUqvf/3ra/8avTdvnxdt2bIlHXfccel3fud30mOPPVbxmQ+f/+VrWRs2bEhHHXVU+uY3v1n7qYzOxz/+8Z3n3Z8+D++zzz5p1apVOxfjYV5mgDLMAPWYAcoyA3THDEA0M0AZZoB6zABlmQG6YwYgmhmgDDNAPWaAsswA3TED0AVzQPfMAPWYAcoyA3TLHABQjg0gAEzCfffdl+64446d9elPfzo1TZP+8R//0a7+YN/61rfSsccem17zmte4eAtyyimnpHPPPXfJ19avX58uvPDCSs9ofB5//PF03nnnpSOOOCJ99atfrf10Rul73/vekvPwHXfckU4++eT0ute9Lt1xxx21nx4jZgYoxwwQzwzQPTNA98wA1GIGKMcMEM8M0D0zQPfMANRiBijHDBDPDNA9M0D3zADUZA4owwwQzwzQPTNAGeYAgHJsAAFgkvzvXrux+L95felLX5q+9a1vpQcffHBnsXKbN29Oq1evTh/60IfS3XffnS644IJ00EEHpXvvvbf2UxuNc889Nx1yyCHpc5/73JLj9oc//GHtpzZq/nev1GAG6IYZoBtmgO6ZAeowA1CDGaAbZoBumAG6ZwaowwxADWaAbpgBumEG6J4ZoA4zALWYA+KZAbphBuieGaAecwBAN2wAAWCSLPZ044orrkhN0+yxaOfSSy9Na9euTWvWrEknnXRSuummm2o/pf+/fTs2gRgIgiCYfxRK9SN4T8M2oiqCM84YFvpT/v3b53mun/Zpjj1csAE2bIAdG2DLBrhhA3DBBtiwAXZsgC0b4IYNwAUbYMMG2LEBtmyAGzYAV+yA99kAOzbAlg1wxw4A2LC+AAAAAAAAAAAAAAAA4gQgAAAAAAAAAAAAAAAAcQIQAAAAAAAAAAAAAACAOAEIAAAAAAAAAAAAAABAnAAEAAAAAAAAAAAAAAAgTgACAAAAAAAAAAAAAAAQJwABAAAAAAAAAAAAAACIE4AAAAAAAAAAAAAAAADECUAAAAAAAAAAAAAAAADiBCAAAAAAAAAAAAAAAABxAhAAAAAAAAAAAAAAAIA4AQgAAAAAAAAAAAAAAECcAAQAAAAAAAAAAAAAACBOAAIAAAAAAAAAAAAAABAnAAEAAAAAAAAAAAAAAIgTgAAAAAAAAAAAAAAAAMQJQAAAAAAAAAAAAAAAAOIEIAAAAAAAAAAAAAAAAHECEAAAAAAAAAAAAAAAgDgBCAAAAAAAAAAAAAAAQJwABAAAAAAAAAAAAAAAIE4AAgAAAAAAAAAAAAAAECcAAQAAAAAAAAAAAAAAiPsBDENNnoM7SIgAAAAASUVORK5CYII=\" width=\"3200\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, 'GD Net Output Weights')"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weights = gd_net.output_weights.detach().numpy()\n",
    "fig, axes = plt.subplots(2, 5, figsize=(32, 4), sharex=True, sharey=True)\n",
    "for i in range(2):\n",
    "    for j, ax in enumerate(axes[i]):\n",
    "        axes[i, j].hist(weights[i*5 + j], bins=100, range=(weights.min(), weights.max()))\n",
    "        axes[i, j].set_title('Label {}'.format(i*5 + j))\n",
    "fig.suptitle('GD Net Output Weights')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "394\n",
      "388\n",
      "395\n",
      "391\n",
      "397\n",
      "389\n",
      "382\n",
      "395\n",
      "377\n",
      "383\n"
     ]
    }
   ],
   "source": [
    "for i in range(10):\n",
    "    print(np.count_nonzero(np.histogram(weights[i], bins=1000, range=(-max(-weights.min(), weights.max()), max(-weights.min(), weights.max())))[0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Appropriate samples found\n"
     ]
    }
   ],
   "source": [
    "from AdversarialExamples import adversarial_example\n",
    "\n",
    "idx = np.full(10, -1, dtype=int)\n",
    "for i, data in enumerate(testset):\n",
    "    input, label = data\n",
    "    with torch.no_grad():\n",
    "        local_pred = local_net.forward_pass(input.reshape(1, -1)).argmax()\n",
    "        gd_pred = gd_net.forward_pass(input.reshape(1, -1)).argmax()\n",
    "        if local_pred == label and gd_pred == label and idx[label] < 0:\n",
    "            idx[label] = i\n",
    "    if np.all(idx >= 0):\n",
    "        print('Appropriate samples found')\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 3,  2,  1, 30,  4, 15, 21,  0, 61,  7])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([10, 784])\n"
     ]
    }
   ],
   "source": [
    "inputs = []\n",
    "for i in idx:\n",
    "    data = testset[i]\n",
    "    input, label = data\n",
    "    inputs += [input.reshape(1, -1)]\n",
    "inputs = torch.cat(inputs, dim=0)\n",
    "print(inputs.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n"
     ]
    }
   ],
   "source": [
    "local_adv_ex = torch.Tensor(10, 10, 784)\n",
    "gd_adv_ex = torch.Tensor(10, 10, 784)\n",
    "for i in range(10):\n",
    "    for j in range(10):\n",
    "        print(j)\n",
    "        if i == j:\n",
    "            local_adv_ex[i, j] = inputs[i].squeeze()\n",
    "            gd_adv_ex[i, j] = inputs[i].squeeze()\n",
    "        else:\n",
    "            local_adv_ex[i, j] = adversarial_example(inputs[i].reshape(1, -1), torch.tensor([j], dtype=torch.long), local_net.forward_pass, lr=1e-3)\n",
    "            gd_adv_ex[i, j] = adversarial_example(inputs[i].reshape(1, -1), torch.tensor([j], dtype=torch.long), gd_net.forward_pass, lr=1e-2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA+gAAAPoCAYAAABNo9TkAAAgAElEQVR4nOydaZhU1bX3i26GbobLKCAdbcSQEC4EuBghGGS4egMBJxRBccZLNCgqCBoHFDEMEiQOYIDkYogR7wVDomFQQEBRkBYH1BhRRARBUEZBRbp7vR/yrs2qXat27XPqVPch/f89z/rQVafOsM7ae6//7j0kCAAAAAAAAAAAAJVOorJvAAAAAAAAAAAAABDoAAAAAAAAAABALIBABwAAAAAAAAAAYgAEOgAAAAAAAAAAEAMg0AEAAAAAAAAAgBgAgQ4AAAAAAAAAAMQACHQAAAAAAAAAACAGQKADAAAAAAAAAAAxAAIdAAAAAAAAAACIARDoAAAAAAAAAABADIBABwAAAAAAAAAAYgAEOgAAAAAAAAAAEAMg0AEAAAAAAAAAgBgAgQ4AAAAAAAAAAMQACHQAAAAAAAAAACAGQKADAAAAAAAAAAAxAAIdAAAAAAAAAACIARDoAAAAAAAAAABADIBABwAAAAAAAAAAYgAEOgAAHMfMmTOHEokElZSUVPatpHDllVdScXGx13GJRILatm1LpaWlKd8nEgkaPnx4qHv41a9+RQsXLgz8u88//5xq1qwZyrc9evSgHj16BL7m8cTKlSspkUjQypUrc/ZbPi6dzZkzJ9S9x42qEC8AAAD8gUAHAIDjmH8lgZ5IJOh3v/tdyvfZCPQ6derQlVdeGfh3Dz74oLmn6667LtBvq4LgOnDgAK1du5YOHDgQ+LdBBfqECRNo7dq1KbZ79+6Qdx8vqkK8AAAA8AcCHQAAjmP+VQR6nTp1qHv37lRUVERfffVV0veVIdDbtWtHTZs2pR/96EdUv379lHtyURmCq7S0lL755pucX+fbb7+lo0ePZnWOoAJ9/vz5WV0v7kCgAwAAkECgAwDAcYyvQN+6dSsNGTKETjjhBKpZsya1adOGfv3rX1NZWVnScd988w2NGzeO2rRpQ7Vq1aJGjRpRz5496eWXXzbHPProo9S9e3c64YQTqHbt2tSuXTuaPHkyffvtt0nnCirQX3nlFUokEjRx4sSk7zWBfuDAARo1ahS1bNmSatSoQS1atKCbbrqJDh06lPQ723yE0Lp16yiRSNCoUaNo1qxZlEgk6I9//GPKceXl5TR58mQ6+eSTqVatWtSpUydavHhxkuDavXs31ahRg+66666U37/33nuUSCTooYceMp/t3LmThg0bRkVFRVSjRg1q2bIl3XvvvUmieMuWLZRIJGjy5Mk0fvx4atmyJeXn59OSJUuorKyMxo8fT9/73veooKCA6tevT+3bt6ff/OY35vcffPABXXXVVfTd736XCgsLqUWLFtS/f3/auHFj0v2xQJ47dy6NHDmSWrRoQdWqVaP33ntPFdklJSU0aNAgKi4upoKCAiouLqbBgwfTxx9/rJ43KoH+0ksvUfXq1WnUqFFJn3PZkKMyfGO3R48e9O///u/0yiuv0I9//GPzPP/zP/9DRER/+9vfqFOnTlRYWEjt2rWjJUuWJP3+nnvuoUQiQa+//jpdcMEFVK9ePfq3f/s3GjJkSMp//jWBfuTIERo/fjx9//vfp5o1a1KTJk3oqquuSvntihUrqEePHtSoUSMqKCigk046iQYMGECHDx92+gwAAEB8gUAHAIDjGB+Bvnv3bioqKqITTjiBfvvb39LSpUvphhtuoEQiQddff7057ujRo9SrVy+qXr063XrrrbR48WJ65pln6I477qB58+aZ42655RZ67LHHaOnSpfTCCy/QtGnTqEmTJnT11VcnXTeoQCciuuCCC6hBgwa0Z88e870t0A8fPkwdO3akJk2a0IMPPkjLly+nhx56iOrXr0+9e/em8vJyIiJau3YtFRYW0s9+9jMzLPrdd9/NeD///d//TYlEgt599106ePAg1a5dm3r27JlyHIuwoUOH0pIlS2jWrFlUVFREzZs3TxJcF1xwAZ100kkpnSFjxoyhmjVr0hdffEFE/xTnJ510EhUXF9PMmTNp+fLlNH78eKpVqxZdddVV5ncs0IuKiqhXr160YMECev7552nLli00ceJEys/Pp3vuuYdWrFhBS5cupd/85jd07733mt+vXr2aRo0aRQsWLKDVq1fTwoUL6fzzz6fCwkL6xz/+YY5jgVxUVEQXXXQRPfPMM/S3v/2N9uzZo4rs+fPn09ixY2nhwoW0evVqeuqpp6hHjx50wgkn0Oeff55yXl+B/r//+7909OjRFJNMmjSJEokE/fWvfyUionfeeYdq165Nl112WdJxvrHbo0cPaty4MX3/+9+n3//+9/Tcc89R//79KZFI0Lhx46h9+/Y0b948Wrx4MXXt2pVq1apFn376qfk9x0ZxcTGNHj2annvuOXrwwQepTp061KlTp6QOAVugl5WVUZ8+fahOnTo0btw4WrZsGf3ud7+joqIiatu2rRnNsWXLFiooKKCzzz6b/vKXv9CqVavoT3/6E11++eW0b98+p28BAADEFwh0AAA4jvER6LfffjslEgl69dVXkz6//vrrqVq1avT+++8TEdHcuXMpkUjQ7Nmzva9fVlZGR48epblz51J+fj7t3bvXfBdGoP/jH/+g/Pz8pP+G2gJ94sSJlJeXl/LMCxYsoEQiQYsXLzafBR3ifvjwYfq3f/s36tq1a9L9VatWjT788EPz2b59+6igoIAuuOCCpN+//PLLKf+pf+aZZyiRSNDzzz9vPistLaUWLVrQhRdeaD77+c9/TnXr1qWtW7cmnfPXv/616TAgOibQTz311JT//Pbv3586duzo/bx8L99++y21bt2abrnlFvM5C+Qzzzwz5Tc+Iru0tJQOHTpEderUSRolENUicdu2bTPHlpeX089+9jNq0KABvfPOO9S2bVtq06ZN0ogKG1fs9ujRgxKJBL322mvmsz179lB+fj4VFhYmifE333yTEokEPfzww+YzFujSn0REf/rTnyiRSNATTzyRdC0ZL/PmzaNEIkFPP/100m9LSkookUjQjBkziOhYvL/55ptOPwIAADi+gEAHAIDjGB+Bfvrpp1Pbtm1TPn/11VcpkUjQY489RkREl1xyCRUUFKT8p9fm9ddfp3POOYcaNWqUIprWrVtnjgsj0ImIhg0bRrVq1TJC1RboZ5xxBv3whz9M+Y/ql19+SdWqVaMxY8aYY4MKdPbnrFmzzGerV6+mRCJBd955p/ls8eLFlEgkaMGCBSnnKC4uThJcR48epebNm9Mll1xiPlu0aBElEglatGiR+ayoqIjOOeeclOd69913k4QZC3Rb/BER3XfffVStWjW6/vrraenSpeoibkePHqVf/epX9IMf/IBq1KiR9P769OljjmOBLMW1/Z0U2V9++SWNGTOGTj31VMrPz086r1xoL6hAnzx5MpWUlKSY3TnxxRdf0EknnUQFBQVUWFiYMmSfyD92e/ToQSeeeGLK70888UT68Y9/nPTZkSNHzJQIhgW6FPhE//R99erVaejQoUnXkvEyZMgQatCggZnvL6158+Z08cUXExHRhx9+SDVr1qTTTz+dHn/8cdq8ebPTnwAAAI4PINABAOA4xkegn3rq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N6YePXrQM8884/QrAACAeAOBDgAAAAAQISzQ5f7vAAAAgA8Q6AAAAAAAEQKBDgAAICwQ6AAAAAAAEQKBDgAAICwQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAAAAAAAIAYAIEOAAAAAAAAAADEAAh0AAAAAAAAAAAgBkCgAwAAAAAAAAAAMQACHQAAAAAAAAAAiAEQ6AAAAAAAAAAAQAyAQAcAAAAAAAAAAGIABDoAAAAAAAAAABADINABAAAA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Z/jSSy/RSy+9RA8//DA9/PDDdMUVVxi+8sor9Morr1CfPn2oT58+9OWXXxpK/rFw4UJauHCheE6o8EzLdiG0k9lJkybRpEmT6K677jKsXbs21a5dm84880w688wz6fTTTzfEsTPOOIPOOOMMevzxxw2/+uor+uqrr3LaJZttQmN3WrZzBbovt2/fTtu3b6dx48YZduvWjbp160a33HIL3XLLLfSf//zH8L777qP77ruPevXqRb169aIFCxYYphnH8mU7rtMC34sT3u63tEXKBx98QB988AHde++9hvXq1aN69eqZuHb22Wdn5VNPPWWI3UK4NksS45JgkjoS0vK7WC5ZsoSWLFmSYYNLLrkkgy1btjTEb82bN6fmzZvT//73P0Pkdpzt8L3T/KdGDOBHtv+E5Cd23EH7cMcddxjWqFGDatSoQbVq1aJatWpRtWrVDOGLOPboo48arl27ltauXSsOS/f9p4bPeYrigQr0EoTbsKlAz7/tOKpAV4FeKKhA/4cq0ONtF0IV6JlUge4HFeiVV2dtqkBXga6oXKhAL0GEBju3AbQDb6dOnahTp05GAHXo0IGuvfZauvbaa+n666+n66+/nm644QZDnIO/L7vsMkNch+ecrEPcJb766quG6LS47rrrDCHQO3bsSB07djRC/ZprrjFi6qqrrqKrrroq4xhEQRp22bp1K23dujX1vTK5+4R835EjRxrCdrYIP//88+n888+ndu3aUbt27ahJkyaG6BCCQIeIb9++fQW/82Wsb1YGbGGEZKBq1aqG7m/4m/vNvg4C6ocffqAffvihUt5NQmwdwLddunSpITqC+vfvb9i3b1/q27ev6ZwcMGCAIc4fOnQoDR06lB577DHD4cOH0/Dhw/MS1woZ67gYjST1gQceMHTF+JlnnllBhNt0z7Gvq1+/PtWvX98s/OgruDnR7jN8PC3bhcSL0aNHGz744IP04IMP0q233mqI35D833///YYQ5vj7xhtvNOzRowf16NGjqGMdrrW/q8+ibeB///tfQ/jMOeecY2jHNpfoIIJAh6/Vr1+f6tatS3Xr1o3uaOEIIcgNy09iu7179xqig0cqBwT0s88+awih3aJFC0P8BlFuH8M/EnDMtjnaaFf45vIpnwVr0/I73C92mh3qVo8ePYw/IX7Vrl3btJmnnXYanXbaaaIf2tfB7xDvfMvDvYPUOZ3Edor8QAV6CSK0EVGBHm87lyrQ/RtZlyrQ46ECPe7bqkD3s5MK9Ny2U4EeZjsV6PG2U4EeDhXo8bZT5Acq0EsQoY2ICvR427lUge7fyLpUgR4PFehx31YFup+dVKDntp0K9DDbqUCPt50K9HCoQI+3nSI/UIFegnCDcui8b4jIm266yQif2267zXDEiBE0YsQI0zDY8wefe+45eu655yqIo2uvvdaIzHfeeYfeeecdsTFO0igiKUtiu1i++OKLhpizZQfmsWPH0tixY813wRzDW265hS6++GK6+OKLzd8Qm23atDEdHosWLaJFixZlzDnGXHLM2+bKZe9VL5UfK+0nsd3mzZsNQ1Ycffrppw3RqWPP8YJ4x2rxtiB66KGH6KGHHjKJgt25gQ4P2N5+ZnnA6u+5iASgMmC/7ymnnEKnnHIKNWzY0BDifd68eTRv3ryM88EGDRpQgwYNMvwV89KR1BUbYPtdu3YZhnyzl19+2RDz7sePH2/4xRdf0BdffGHOnzVrliEEFvzKXqcDIn7Hjh20Y8cOL7+xk9EJEyYYZotvf/75p1lDIQbuvHxb3GLeKJfg4Vy7nYC/XHDBBYaYE7x48WJavHhxxpoIuA4dbLZ4h4gaMmQIDRkyRIzx3DF3nvqxY8cqrKqfdFVj6Tty5XDPnTx5siFi1xNPPGGIOeXYMWDixImGWPvgkUceoUceeSRDOEC4SvP4k8a3pLbDPWzRCtrtmjvvG3OYmzVrZsiJH9gTHW/2+chh6tSpQ3Xq1DHz1e056+hc48rFCUpp3jVnR9wrid+hDcy1a4pLu6MH74t/wnTq1MkcW7VqFa1atcp0BvXq1ct0GqHzHLnhpZdeajo54KOhvoVccvv27Vnr6YkT/+S0SWyXy7ezdQzYHWHVq1en6tWrZ8Qt1MGPP/6YPv7444x/XOE6dGjUrFnTEPdCO2THd3fePFd2rsOBewfdB734oAK9BOEGMxXo4baLpQp0FeiVARXoKtBDoQL9/85P4nfcd+TK4Z6rAl0FehK/U4Eeb7tcvq0CXVEoqEAvQWCojLRXtrSXKFYM/+mnn0xCj0Rzx44dWfdJtQPCoEGDaNCgQRkCHcO6uZWO3evtPWRj946Mgc9Ko3bihWFmnO3ef/99ev/9973Le/DgQTp48KBJwOxpBZhOENoo4xv7DjlLIjJ9ymMPzXOP2Z0IGGIslZvbZxirbtvJAzo5MLQ/1I98WZkNIHYMWLFihRHTdgedhP3799P+/fuNeOKGxqNTrdiQ9JvZ/oXh7FJc4ohV8xHzBg0aZIa/c8MQfe4pCeO0Yh2uldoJKf6hQ3D9+vWmowxTIX744QfxPeFz6Hyzh7gj4UXb4/v9ODHuviNn43z5nd1OuN/Sjl3YbSJ0yteMGTNoxowZdM899xhCnKa5OwVXpny3E7Yt8O1gr6+//toQHRJ2rHPzGvs7YEePyy+/nC6//PKMFd0x1BgdcL728dkP3SbKly/bSfZEB/yePXtMZ7bdGSLFARxDxxA3/B0rkoeWS+pMs89HbpvEdr5TZvC+iOH2Lh34R4LvPz4QEzGFBau516pVy7Sxc+bMoTlz5njXwdBh+irQiw8q0EsQKtD/jzFQga4CPZYq0AuPpN9MBboK9Hz5nQr0eNupQI+3nWRPFegq0BXFAxXoJQgV6P/HGKhAV4EeSxXohUfSb6YCXQV6vvxOBXq87VSgx9tOsqcKdBXoiuKBCvQShE/jwAUiqaHxTR4wzxxE4G7VqpURXW7ACF1N05dp246jmzTbDWDovbp3707du3c3yYM95+nJJ5+kJ598MhW7+CRvSWxnd1JIDYzPPElf8fDoo4/So48+ajqDsNJ7u3btTAOYDx9Ly3aFhl334G+Yb27P58T89GIFZ3/X10KFj3S+fQzCCmtG2HPQQzvnQogOS7vTMi3bxRJxkKuvXP3FuhDwMzthRWdkGuWS5gLnW2Ry3yzED7P5Hea6Yt0Xew76mDFjaMyYMWIZ0vzuSWznWy/dnAWd6HZHunQviLqjR4/SRRddRBdddBFVq1aNqlWrlhHrMD/dpwzc87D6u+8K8IWwnbsuBxc7JH+zf+vSpQt16dKFmjZtSk2bNjUrvjdv3pwaN25MjRs3Fsvnu76Q1BGZhu18abeR2TpZffMT5CJ2nAMxT517rk853V0ObBtzHV2K4oEK9BJESGN34oQKdF/b+TQmKtBVoJ8MUIGenSrQw6kC3e+bqUBXgV5I26lAr2g7X6pAV+QbKtBLEFwl9gnKdvB2z7eDxo8//kg//vgjrVy5klauXGnE0aOPPmpW58XQbCRiV111VQXRJpUvV5CShr/jWBLbSbawiZViQ22OVVLtlcghxpEwYL/Rli1bGlG9evVqWr16dXBjw3HTpk20adOm1BpAd8VR34Q0tJNmzZo1tGbNGrOq7IMPPkhXXnklXXnllaxAl/YXjU2Y4WMbNmwwTGK7QuHNN9+kN99804jyyy+/XNwHHcPmixWx31Qalmgn9PgNifd7771niN0a+vXrR/369ctY8ThbmY4fP+6VqHIJLobS24lYkmGLXKzz6dxwh21nGzKKsk2bNo2mTZtmdvZo3749uzc6KO1G4WMz7jeUmZsWk5bfSZTs5Nr12LFjxt8OHDhABw4cMDunjBgxgm6++Wa6+eabzSr5//nPfwxjd0HxEUU2IZBjgG9iD62G/3FiB8dQRttfIZzt74p7YgqAvVPFWWedRWeddZYZzm4PcUeHsVsmrg2Xpghy53GdCjHgvpPPt/PZTcLmJ598Qp988knG7j0Q4/iHi71jA6YOcPfasmULbdmyhT0m/TMDx7CTwZEjR1Kvs9lWPz9+/HiFY65gz8apU6fS1KlTM6bZccIc5KZ8xlLqVNAh7sUHFeglCK7iqkAPs50K9HCoQI+3XaGgAv3/qAJdBXqS+hpaNhXo/0AFerzfqUBPt86qQFdUJlSglyC4YOMuFiZVci5BtYlgiUVGuP26IY6WLFliGBt0uMW9pOFlhVyEJXQxHpQbC+bZHRhIXrEHOPZXdvfudukmNfZ3x+Ik9vlSp0LaDaBL3wVaOCJZggi3F9ED4XfvvvuuYcgzcg1Zk5INiL5iBBZQcvc3t4e0u3ueP/vss4n27C0EOJ8PqYebN2825HwAHY9YQM7uFMJiSVgYDkmqnaj6JM+hZU+rvoYsDGeXE39zYteu31jQsnbt2lS7dm1WjMP3Bg8ebCgNS5dsx9nQtT/XUVJIv8Mz0cn9448/svfCftRoG7D420MPPWSEORaGW7dunWGs/3DvMHPmTJo5c2bqfucT/yUBzO0vb9sOHTz2Hucg9uuGUH/ttdcMpcUNXZ/k9nAPfZ8kfudLtJnS0Hu7IwJ5H0Q4hq43btyYLr74Yrr44ouNUJ8yZYoh7hUaU5A/2d9PWgg3jQ5J7n7u35zI5X6zbYfFbxHT7L3OIcax5zkWs33ppZfEXDukfHZ5pPikKB6oQC9BcJVTBXqY7UIbGN/zVaCrQK8MqEDn66EKdBXohfQ7Fegq0JPYLvS7qkCXbacCXVGZUIFeguAqpwr0MNuFNjC+56tAV4FeGVCBztdDFegq0AvpdyrQVaAnsV3od1WBLttOBbqiMqECvQSBpJpbTZuj2/gsXrzY8LvvvqPvvvuOvQ5zL+2VUDGP+rrrrqPrrrsuY4XZ3r17U+/evWnjxo20cePGjEbLFbqckLODEt5L2uc7Bj6C23flTikRGTBgAA0YMCBjnhJEOwSobTuIgfHjx9P48eMzvu327dtp+/btYgIjEfPhV61alXrykI+Vg7F6se13EOjo3LCPwYbYZxTzOg8cOGAEVYgosHmyNIDwV+yuYNvHnYN+7rnnGmLV4wkTJtCECRNo+fLlhsUAn2+ExGnv3r3ieZizan9TxBvsQPHEE08YQphjLjpE1f33309z586luXPnsh1kIOI0l7zbiR86V6S6FAMpRkjH3PU/7Lnr3N7fbdu2pbZt22bMu4RAx97n8LOLLrrIrI0wceJEmjhxYsZ+66FzpfNVX3Gt3TEsraDslhvtzKFDh8Q2dsiQITRkyBBq2LChYdeuXalr166mM9JeAwbtBOqr/Y3QpnMCFPEB4mjnzp0VzuPqURLbSXWCI+qiXV+knWfwz4I6deoYQqBDsNu7zGAdE9i8rKzMEM+WnmfPM3frM5czxCB0vRbJ/7k2D98eaxrY7cQll1xCl1xyibGX/c+FTp06UadOneizzz6jzz77LGNfeqwkL/k5R2mdkBhw8RP2jD1mE3Uc9fL00083RNyDYLfn76Nejxw5kkaOHJmRj7lrjdh5MZeD+nR+KYoHKtBLECrQ4wORCvR0Ey8V6MUBFegq0F2oQE8e61Sgx9tOqhMq0HmoQI+3nQr04s1PShUq0EsQUmDmjkmVGse44YwQiF9//bUhVkuFULeHH6PBbNKkCTVp0iRDCLgrnObaT9ynoUrLdrFjzAnYAAAgAElEQVTE0CW7oXfPmTVrliGSLLezw17ZHR0fdmLhfheIAlsY+HYqFIvtQG74JnzZPoZhn61bt6bWrVtn7NGKVXpxDFMzrr766gpD/+wGUBID7jBZu/6cDMBq7m+++aYRRtw+6NmGwZ966qlGNFUmfIYX298odig5kkxbMLzxxhv0xhtvmKHGzz//vCFEPDqTMES+b9++Fe5t3zO2nsSAuw98XhJxXHvBCXQcQ4JrD4lFRxoSVwyDr127tkli8bftj+4UE/t5seIlLdslpS32MfwdtrOnTwwcOJAGDhxoOh7tlbbRuYF4aO8SInUWud+KGyabVqxzxW4uv4ffSedKQ83RqT1+/HgT990h7/Xr1zfthO1vIIQnV2d93iHtIe72t/DpBHdXQbfrjnTdfffdZ4j2FJ0ddqca8jhXdDZs2LDCs20/d/dp5757PussfJGLd5I4dq/nhqHbOy8gV+N8K1tHeZUqVSrkPvbzpLydi4V4R0XxQAV6CYKrsCrQ420XSxXoyakCPT9QgR7mhyrQVaDnsl1SqkDnqQK9ot+pQI+3nU0V6IrKhAr0EoQUcLmK6yavdhA4fPgwHT58mK3oPkkH9lFesWKFGRLPLfL16quv0quvvsreAw2gtCBPWskDruX2LZUaXh9b5CKGXeNv7EX6ySef0DPPPEPPPPOMGUpmC3QEc9/n+Az3LYTfud8y14JLUoPt7iWKhfCWLl1qRBKG2kIcXHbZZaZThLunJETStl1lAvULQxIx1G7kyJFZ90qvUqUKdenShbp06VKpZZd8h0tcXbHBXWf/Brp1k+OaNWsM3377bXr77beNmHrqqacMv/jiC/riiy9YX8JvklBKy+ekZ4VO+fAZEs+dD9GIIdkTJkwwnbwY/m7z9ttvp9tvvz2VeIsyJPE7ibnimUR3ATlpT2742MCBA2n06NE0evRo6tatG3Xr1o169uxpOHv2bJo9e7Yo6OwODx/hl7btpPZUqi++doUvQjSOGjXK0B0Sb++RjnbXLWe2svp0JiSxHedbsdO0Qol3s23ning7P8HUPe5ePkOy056WwlFqK/C3nReHTt3Dt9m/fz/t378/o4McQ+LRIWlPBUoz3qHMiuKBCvQShFRJVaD72U4Fev79TgV6cUAFugp0FehxfidRBXq47VSg+9lOBXq6fqcCXVEZUIFegpAqqQp0P9upQM+/36lALw6oQFeBrgI9zu8kqkAPt50KdD/bqUBP1+9UoCsqAyrQSxCxFRjBwxanUiIbyzFjxtCYMWOoc+fOhmgApXnnoYxBbIOBOeZIvr/44gsjKKXkigvi+Jvbjx6Jv72CKpLX0FVSpQQjBpx/cHPfslGaq5+L0vxKlAurQmO/+fbt2xsBunXrVtq6dav386Tz/01AMoZODm7/9Hnz5tG8efMqpXxSTOL8G+fDz7j9qG1K8QB1Wuo4wt7e9urvmLcpJfFcjNm0aRNt2rQpNZ8LXREd5eGuS7qnOncv7HRh75teo0YNqlGjBi1ZsoSWLFnibTvpO8YA19orzPt01qLcdoIu2YIrt2RrnL9gwQJasGAB3XHHHYbdu3en7t270+bNm2nz5s3e30ralzoGqDecyEX57XnKOBY6dz2UeDbm7NsCHbEOnb7c9Vy5pHLGIDYHQ6c8tz4NR2mFd6kujRs3jsaNG0ctWrQwbNasGTVr1oy++eYb+uabb9jruH+IpG07+I+0Hg8XO1xR/tdff4n7kft8I+76Xr16Ua9evTIEOvzu448/po8//tj7e6c9f1+RH6hAL0HENlAq0FWgJ7GdCvR/XwOoAl0FulsmFegq0JPYTgV6vO1UoMfbTgV6vO0U+YEK9BKEVHGlfdGlVXDTWC0X7NOnD/Xp0ydDZGKFbS5ZRlDkVpJ3G9e0hrjbRALGHZOCMTeU3BXq9r7SPrbDKtEYjnfDDTfQhRdeSBdeeKFX5wLX4KYVxHGtr9CGfbghxe7+ysePHzffoby8nMrLy707PkDsEdy4cWPDli1bUsuWLUWRxjXaEOj2vsH/xgYQSRKGHXOrzmJl7cqA9L0530AdmT9/Ps2fPz/jGJIaKc7Y+/v6+Bz2Skfy1atXr+ApKSCXsOJ90radFNfstsAV61wcjh2GjB0s7BXesa+w9A24cknPKaTtuGOuED1x4kQFsSJNxbCFIX578cUX6cUXXzQrvffo0YPuvvtuuvvuu9lyxXaMpm27kHrw66+/isO6Q1dah+2aNm1KTZs2pWrVqhlCqGMlfa5zgRNraXeCh/pd6FBs913Q6c91/HM+iR0t0K62bNnSrJgPP+diRDH6HSeipdzX53zueyBWXX/99XT99ddntLEQ6lKuJpHLkRTFAxXoJQipwqpAD7edCvQw26lA//dABXrmPVWgq0BPYjsV6CrQ82U7Fejp+p0KdEW+oQK9BIGgaQfCffv20b59+9jGy6ei59qXXGokQAhRDGe396PGPqNpDaMvVBAPtYUUaJEkucPaT5z4Zz9wJK2wYadOnUzSIJVFEh35tJ0kfF1CsOdawA6+bPu3lJAvXLiQFi5caBZjsf1uw4YNtGHDBvF5O3bsMPSx8b8J2MeV2wcdCxhWJkJjkEtMe5g4cSJ7HP4lLRLHJW2YLtS/f3/q379/xh7pBw8epIMHD5p7Tp482TA21sTAHbLuO9ydS67xGzd8VEpKuftjsTh7aDu4bNkyWrZsWbSd8hnrQigNs7VtxrXl0n1XrlxJK1euNMm+vY+1z6Knvt87Ddvla6i6RDyPe6e33nqL3nrrrQr7op999tk0a9YsmjVrlvdzIMylWFRIv0PbdOjQIUMcs6fSuVMa7XtIdXbRokW0aNEiI8rtPdLnzp1Lc+fOFcsXOoUyie1yCe0QSkPipfPt38aPH0/jx4/PGNoOSlN5OOZrYUdFfqACvQShAr3wDaCvLVSgZ6cK9OKDCnQV6Nlswv2mAt2PKtBVoBfS71Sgq0BPYjtFfqACvQShAr3wDaCvLVSgZ6cK9OKDCnQV6Nlswv2mAt2PKtBVoBfS71Sgq0BPYjtFfqACvQSR70bODebSue+//74h5nO1adOG2rRpkzEHPR/lTGK7XKs7ZyOXeNlBHPOwuHnn7p7z6LT47LPPjLjE6uO33XabYWjS6q6szpW5MvwO5cq16ru0pzr40UcfGdqC/Oqrr6ZbbrnF0L23NNfTN4k4WYHkFSuPDx48uMJ884YNGxoiDlQm8h3rfL47jmEu/pYtW8wc4H79+lG/fv1MR8eIESOC51+icw5/251tqAtJbBeaHIO+wh7ncCIT5X/99dcN4XPYnaJmzZqGoTHZp3zF6HewE/yJi0E4x945BLa799576d577zXrbjzyyCPBZeA6iovBdr7+ys3/hr/Bdtg3fvTo0UaMQ6DbQil0xwN3TYCTzXY+62xAWI4fP54uueQSuuSSS4xAx+4ol19+eQWflurpsWPHvHaESGI7bl62j018hb2Un+Ad//e//xmibcU6G/C/+vXrGx/27VDwOU9RPFCBXoJIGsRzUQV6dqpAj6cK9MqFCvSKVIGenSrQ80cV6H51UjpPBXq87VSgV6QKdEXaUIFegghtTLI1bHbjZgd2JANu4P37779N4og9f+0VKTt27EgdO3Y0K0JLZci1Qne+ApGPfXyFJBIcbliZ9M4Yum7brkuXLtSlSxezR6v9PWKHLlaG7ThyjaNPg2nv6YpGHfaxbQdh/t///pf++9//BpfPd+j9ydoAYjj2ZZddRpdddlmG7TCcHclWsSFk2ka+CGH54IMPGmLF9kmTJtGkSZOiRXCuuoAOvxiErvAslYMT4VI7hKk+6HC0fQ7D2Vu1akWtWrXyLp+b4P/5559561DzsRN2eti6dWu0b3HCHFNLXnrpJXrppZcybNetWzfq1q2bmU5h30sSPj4x2G6TcSyJ7WKHuHP5ia8N0cGDXMS2HUQRdkex7yHFGc52Ut1KYrvY1c+l7yvlWnZ9hi9jpXZ7dwXsJINj9j3c6WH299i9ezft3r1b7Ozj/CSJ34V2uPsyW+fjH3/8YTo82rZtS23btmVXasc/YXyf53Y22c/m6nqSHT8U+YEK9BKECvTkQVyiCvR423FUgV65UIGejCrQVaBzdlKBLttOBXo4VKAnr7Mq0BXFAhXoJQifpDV0T3Gp8ZkyZYohxBAWqWnevLkhklWuMQgNmCifJE5j4BMYQ/ff5hqfTZs20aZNmzJsB5shQbj00ksNsYANF/xjG5SNGzfSxo0b82o76XvimM8id7bd0fExY8YMw5tuuoluuukm0/ljD2nHMDwfm/h2pkgLJp4MQEfGY489ZgSRO5y9atWq1LNnT+rZs6dp8IsNPjEitn7YhCCw90GHQMJCcPZe56jfkihC+d5++21Dn7Jw8TkGkoDGsdAklpsug78ffvhhQ0yTqF69OlWvXj1jGDtsyIkw3Cv02xZiqLFPrJPiWnl5uSHec/Xq1bR69eqMKRIYRox9ze29zqdNm0bTpk0TfQW0FweLLXNatvMhnsn5GCfa8fdzzz1n2KRJE2rSpAnVqFGDatSoQXXr1jW89dZb6dZbbxWHKIf6m5SLFdJ2Uhsr+ciYMWMMMR2xRYsW1KJFC2PDGjVq0PDhw2n48OFeZfnpp58MQ2NKkoVYuXcMyeO4Dirp/Mcff9zwnHPOoXPOOceI8dNPP90Q/zjw+UeLbzyW3ktRPFCBXoJQgZ7fBlAFur/tVKAXJ1Sgh1EFugr0XH6nAj3edj5Uga4CXQW6CvR/E1SglyBUoOe3AVSB7m87FejFCRXoYVSBrgI9l9+pQI+3nQ9VoKtAV4GuAv3fBBXoJQip4sYmrc8884zhyJEjaeTIkUYMXXnllYbnnnsunXvuuXTnnXfSnXfeGTxfLA2uWrWKVq1albrtfOy5bds2Q/wGm5x77rmmkwLzK+39zDE/CckW5pf+/PPPxoY+qxivXbvWMPR90lgVOnaVVI5YDfvFF1+kcePG0bhx48xc6WuvvdYQOwMgacVe0wcPHjT38lkd1m4AYXvJTsXYAKJsDzzwQAVChJ9yyimG+K1p06bUtGlTWrFihWGxg/tuSeelY9X0devWUVlZGZWVldGzzz5Lzz77bEbHRteuXalr1640ffp0mj59uuhPPrEjhmnMBU6Tjz76aAWiA8ies4rf6tWrR/Xq1aOvvvrKMPbZISvK2yyE7XyEwIcffmi4cOFCWrhwId1111101113mTm+F154IXXo0IE6dOhg2hAu3vo8L1dHvOtjmzdvNkwS67hnxO6HDqHXuXNnw759+1Lfvn0zVsN2iR0CvvzyS0Pc0ydf4YRSaGdWEtvZ/2BJWo4hQ4YYvvzyy/Tyyy+bfAUdGk2aNDF1FR0ZWEdi586dQd/Md4ccvIMt0NExnpbf+ZBr61Ge+++/37B3797Uu3dvdj9zEHa125iYssSsJJ8kt1PkByrQSxA+jXJokFKB7mdPFegq0CsbKtBVoIfYLk2qQOepAl22nQr0MNupQE/H73yoAl2RL6hAL0FwwVmq1NIxDN9EUtChQweT0GPVyfPPP98Qw4m5BOHrr7+mr7/+2isQxa7wmrQBDCnjiRMnqPz/D0nkji1ZsoSWLFliEvmuXbuavVYxJNsexo59Mbl7YaXt0D3PC2m70Ge4HRk2sU88OoGuueYaatasGTVr1oxdgXfChAk0YcIE9l5Jh8UWIvFKExgKaw9Vd4ev27bDkGLUt5MJPt+IEzCcmMOOAPaQWNho6NChNHToUHrqqacMly5dSkuXLjXX252R77zzDr3zzjusL7m/FVN9dcUrV4+46zDEFcLbnjIB2sPY+/TpQ3369GHbHtRTdyV2zla+e7Fz1ydZ1TjNWItdUTCdpGfPnkYEoWPNHsa+ePFiWrx4sbneFmtr1qyhNWvWiHEwtHyoO9xuLTHgBHC24em//PKLmAdMnDiRJk6cmCG+Xb+ziXyGawvwPJ96GdompFVnMQza/haYpsB1TO7bt4/27dvHPh+dQBiy3qJFC9MJhF07bNu98sor9Morr7DvjZXauWHaaca5tDskY/PisWPH0tixYzM6HTFdxx6+DqJTVxLOPu+fRKAn8TtFfqACvQShAj0+EKlAj7dd6DNUoOcHKtAzv4cKdB7cfVSgx9sulirQVaD7QgW6CnQV6P8eqEAvQahAjw9EKtDjbRf6DBXo+YEK9MzvoQKdB3cfFejxtoulCnQV6L5Qga4CXQX6vwcq0EsQqIjl1qqwbiX1TWzee+89eu+99zLmmd92221022230T333EP33HOP98rXkkBy54FJq8zbTHu1SqlRkFY9lxpArLrbsmVLuv322+n2228386p952OFNF72b5IIlhgDqSHGd9q1a5dhqN/deOONdOONN9KAAQNowIABGasQp7XOQZLEK0nykCawVoSdXCGJQGcHOkCWL19e2cVNBOl7QPj4xiD4Jeaw9u3b13SazZ49m2bPns2uIJ20nnJJF9fxIJU9ie182wKJiGe2z2HlYnRG2vMuY+uYVE6pLZCel8R23Dxun9WYbWLNFHseNeazvvbaa/Taa69l+J1Pp6HPMW4Vd9956WnYjuuEx9+cT3J2xfxfiKPq1atT48aNqXHjxiZPQbu9ceNGsZ2Q3tvNReyySx0I3DomaazzYu8m4d7X1+/QqQ17NW7cuMI6ONw886Qd3aF1Pm2/42K4ZDsurrzwwgv0wgsvZHQ6Yp451hSy413sjjuxHQjS+YrigQr0EgQqZLkK9GjbcQ2MCnQZKtBVoBca0vdQge5nOxXo8bZTgR5vOxXo8bZTgR5vOxXoimKBCvQShBQkQxviw4cP0+HDh+nVV181xDDwNAMu9g1OI4AVy9BFdFogmL/wwgu0ZcsW2rJlC5ULQ+NDGbKXpy8r23YYmjd48GDDDRs20IYNG7wEfmWysoGpFV26dDFEMvZvg1vnfVekls5Fx9r/Y+/LY60qsq8V7E4jEEAJg4RmCgaJBI0dIBgMEAgYjRBAFBUUaIkiP3AAJSoIrUFAhiigESEtpB0iGBwCbQBbwAltARWU2SfymEcRRYX39vfH17vct96+davqnPve1btWsv549557Tp1du3btVa+GVatWRSdWLtqnC/hSExf5jnW+4p13/eddx2+55RYzzd9l69A+JHQgwb4+rTPk0/QHFgtLly41PHDgAB04cCC6j3UNbqdxekC+bMdl8z395dNPP6VPP/2Uhg4davj666/T66+/Hu3fmuC2bVZVU9zTnH7Pwlsu2/nggw/ogw8+qCD+tfv7vufevXtp79690XbS/gGUlt9xfOccyjVYKn/HSw35tKJBgwbR4sWLafHixYn7DFl/oQLd59lA4QACvQjhE1Qh0P1tl7RjgUAPJwR6PCDQs9cNBHpF27kIgR5vO19CoFcsGwS6Dgj0dP0OAh2oSkCgFyHsxqo1WN9plfwdnzd66tQp85mWBIR0ZK7porwp2qFDh8xn2pmlrkQkBq778VREV/DT7Pr+++8b2pu8JOn4stmTzwqV1BIRLoM2TS+J3+XqdLK9JyelBw4ciLaBD2WSbpdFLq1gIaUl9WxL7X2AyoNPPce2o9Bp7C7fdvm/NtXY9z2SLKtwxS/tvHD7mXLzPU04h4jp2CVNWvlcsU6r5yS2055lbzYm6zp0MDV2GjtT67ftckoRLMvMv3NN2U/L73xo+9rPP/9syi/brD1NXqtzlw1sn9HaXq78yeXLabdZm77LyJi54k8u39R8UMYGtpMrjsl64H9iuOJHWrazhbBWr9p3Wl5tv6/Ldr6bvdm+KH/niiWusgKFAwj0IoRPEIBA1wGBnm4H6ONbTAh0IBQ+9RzbjiDQIdBz2Q4CPR2/8yEEOgR62n4HgQ5UJSDQixA+QQACXQcEerodoI9vMSHQgVD41HNsO4JAh0DPZTsI9HT8zocQ6BDoafsdBDpQlYBAL0Ls3r2bdu/endFgfXaW3b59O23fvl39TkugfBJg37WhLmo7xPusT4uB636lpaVUWlqa9/d1cd26dbRu3To1GLt+p50FbdtS2jMGPkmJq4yaMNq6dauhy+/s8stdbnmX/KQDINqzIdCrFmnUaVrkc9QPHz7svK4k4f4TJ06cMEzicxwP0tiZPrbNu36n/d5HjPveO4ntXPdzraPmGCm/s3fJlnTVixYHec+YNOrPtTt5GrYLfV+7XNnKxt+xrV1CUqsjrT+1n5dLYNnfyTIn2TfCJwfRyG2d/eP48ePGPrns6fI3ux24fs8xiwX4jh07vH6Xdpt1Da64ypFLvIfUh2+emDS3064DCgcQ6EUICPTkQVwjBLobEOjxtgPiAIEe73MQ6PG2c90PAt3PdqHva5cLAt2fEOgQ6BDohQcIdAAAAAAAAAAAAAAoAECgAwAAAAAAAAAAAEABAAIdAAAAAAAAAAAAAAoAEOgAAAAAAAAAAAAAUACAQAcAAAAAAAAAAACAAgAEOgAAAAAAAAAAAAAUACDQAQAAAAAAAAAAAKAAAIEOAAAAAAAAAAAAAAUACHQAAAAAAAAAAAAAKABAoAMAAAAAAAAAAABAAQACHQAAAAAAAAAAAAAKABDoAAAAAAAAAAAAAFAAgEAHAAAAAAAAAAAAgAIABHoRory8vALLysqorKyMzp07R+fOncv47vTp03T69Gn1d99//z19//33GZ/98MMP9MMPP9CZM2fozJkz6u9CeerUKTp16pT63U8//UQ//fST83ou0w8//GA+iwHbST7Lfs9ffvnF0C7r7t27DX/99Vf69ddfneXW7qWVwYdsJ36GfA7Xu1332ZiW3/38888Z1Oyq2cl1L+27s2fP0tmzZ1PxxWz1LuvLVb60bMf+7Gqfmq9on2ntOBtDfYWfx/5nt9VsPHz4sGESvwPioLWZED/JxRMnTtCJEye821YIuR2y78XEyyQ+l2aciW13vvEgn7+LgSuOa3Rdr5Wbr2cfkf1PiN/xtZIuX5TX2eXitnb27FlzTVp+51N37FeufKOsrIyOHTtGx44dy4t/a8+L9ckYuPqmH3/8kX788Ue1/n19MjamuX6nlStbWXzbFFA4gEAvQrgaJwdnbviy8buEkit5kOLYTvBkMGah4ZPEyw4tNHjzdzHYtm0bbdu2LTjI7tixg3bs2KGKY42+ojTbu0mbu5I6vv748eOGBw4coAMHDqQexEPfJWlHFtox5ZtpC/Q0k+19+/bRvn37Klwjr3P5kY/PsCA7ceKEei/+TD6befLkSTp58mSU7YA45Ls9JBWbHCNlTOX+i79jvzxw4IBXnyA/YzGSL9slEdz2oFyu/jAkZvA10nah5ePcoVD8zldMJ/0d12cu0e+qh3wJ9HwMUof6cKw/+ZYh7T7WRTtH479j8jaX3/n4jH2NvM53wIPzbqBwAIFehHA1Ugh0NyDQ/z/T9rs0CIEe5iPyMwh0wEa+2wMEOgR6ZfkdBDoEetp+B4EO5BsQ6EUIVyOFQHcDAv3/M22/S4MQ6GE+Ij+DQAds5Ls9QKBDoFeW30GgQ6Cn7XcQ6EC+AYFehNDWEXID5kSHE4DTp09XCMCaeE+Dro7EJWpd635d38XAvm+2e2ejlkj52tOuB21NbxqC1LU2NIntkq4r1WwXm3D5PtO2p2/C5uoQYyDfPVuiJb/zqUMWINqaQtdz0lgLG1o3XBag8sCDivmoY62eXX4lk0x7LxGXD3Ffl2TdfAxCnxE72KaRRQLf07e97t27l/bu3ZtqfceA69B3gDVN2/G9XLFIs6WrnD79hNYuYqCVzb6vjO0lJSVUUlKSap2H8uDBg3Tw4MHgOvrmm2/om2++Ub+LgczDfPIxvsZnsCVJ3uN6juufWa4BGdf7AYUDCPQiBAR6fCCy7wuB7g8I9HjbQaBDoFc2INDj22voMyDQfwMEerztINAh0O16dt1T+w4oHECgFyG0XZ/tKUK+02J86Dut2yd42IFYlk9O67aTOC1RiwHbR4pjFkM8DVeWLWTXavleti00e8jncFK2f/9+2r9/v9e9fcvy7bffGiaxndZR2X6nlSONQQfXPexddkOnxstO2Od3MdDus2vXLtq1a5fqd/a7cRKUKxHiTj1UhJeWllJpaWmiOvIhUHlgm8ulCfau+lUxkGPHp3zcU943ie00ugYYXPFDm0IbG9ND+uNstAfw07Kdr+DJNlAauyt7LvvbZQj9Xa572PdKy++4nuy2K8l5g9bXS3JdpzWVO4acD7lsmMR2Ws7FeZz2Hf8t411o3HPliXwvn1xS+6eN7yAB1ylQOIBAL0JAoMcHcQj0eNtBoCdPHiQh0IF8gm0OgR5vO40Q6G5AoEOguwiBnvs+EOh/DECgFyGSdlDa9b5TCV2db2wy5/M7TXTFgN8xjeSTBZavfVzkTtXn91oi5ZruLJc7JLFdrNB22dmVqPkmcfxZ6KaDPu+Tlt/52Mk1qKbZQG4C5bKxXf7vvvvOMFtdyXtpyRzb2lVmzSeByoPLr0KX9/AgUmjb12IQl2XPnj20Z8+e4AE1V+xOazAyH5thud4z1Ab2xnm5+gyf+tM2lYtB0inBaVCzic/SJpe/afXlqr8YuMrBbVbWuavutevsWC4FoW0X2U/Ygzix9aH9lgce5OBDDGKXbfr+ziW0fZZBxCyplOWTgwj2Zpq//vproo0dgfwAAr0I4WrMEOhuQKDH2w4CPd52PnaCQAfShMuvINDdgECPtx0EerztXOWAQHcDAh0CvdAAgV6EcDVmCHQ3INDjbQeBHm87HztBoANpwuVXEOhuQKDH2w4CPd52rnJAoLsBgQ6BXmiAQC9CuBozC1C5btxer6atw5ECnTvzmjVrUs2aNZ3BTAYIu4OSa8lZzGoiyifoy441yXmP2r19zhfVxK8rCahevTpVr15dvRfbRK4N5e+0Neh25yU71RJlF1ef9WVp2c62gUxU+Dtfoc3JYf369al+/bkMWIkAACAASURBVPreHaBNeU/2OzsJkevNZfJg+4IUA2msLfRNrlz+oJE77GrVqlG1atWCkwCtrnbv3k27d+9Wy3no0CE6dOiQ8z247Pv376ejR4/S0aNHo2yXT3AC2qpVK2rVqlUq99y8eTNt3rzZxNOqguZztn/LJDx013duUz4+5/IT9rPdu3ebnci5zcny7du3j/bt2+d8jmyv27Zto23btkXZzqdtugYKcp1Bzra74YYb6IYbbvBq21pyL2OdbR8tFofWbRK/843RdnzVxK70nyNHjtCRI0eoQYMG1KBBg+BYp5H9z9VXuahdHwPNFvazZM7FMcbV50vbcRmvuOIKuuKKK5zvJPMTuyxywM3VLrX9DXzyrSR+52ovss3a+7VodShzLe7D6tSpQ3Xq1MnYvyPEV2T+XfK//E3LRXzuKcuXJD8B8gMI9CKEq8FCoIfbDgI93nYQ6GG2g0AvLECgQ6BrgECHQIdAh0CHQAeSAAK9CJFGh+TiG2+8QW+88Qa1aNGCWrRooe4+q9G18/rcuXNp7ty51LdvX+rbt29wmdLqAGNt4juVbN26dbRu3ToaMGAADRgwIJX6WLhwIS1cuJDuvfdeuvfee1Mpc75s5+srWtlee+01eu2116hu3bpUt25dtf61e9vJg/SVadOm0bRp02j48OE0fPhwb9vxc9L2O5k82DbQRIxvYr1y5UpauXIl1ahRg2rUqOH9nvbgjxTVS5YsoSVLltDMmTNp5syZiXyYE71CA7etJk2aUJMmTVK552OPPUaPPfYYjRw5kkaOHJnKPWOg+Vxs/WlTpFevXk2rV6+m/v37U//+/TO+s5Nf+Z3rvO558+ZlMInP8RT6JLZLk7J9v/vuu/Tuu+9Sr169qFevXhnXhZ4rzXzxxRfpxRdfNP6X63rur12+kbbtYpdJyTjMcalWrVpUq1Yt5/Wa/bV7PvXUU/TUU0/Rgw8+SA8++KB3ufh9ZL/H90xiO9fgj+/grsb33nuP3nvvPercuTN17tw54zv2A01AswjXvlu0aBEtWrSIJk+eTJMnT85ZPh/hmcR2rsGNJLbj/ETzO76nNv3d/ueAFNXctz700EP00EMP5SyDa4f3JH4H5AcQ6EWI0MASSgj0ioRAh0BPw3YQ6IUFCHQ/QqAnJwQ6BLqv7SDQ420HgQ4UCiDQixA+wUROvwk9M/WOO+6gO+64w0zlCQ1kWhkWLFhACxYsoH79+lG/fv3UoBN63nq+bOdirs3lONBeeOGFdOGFF6rX2NPaZeeoJcIl/5sGdeutt9Ktt96as4wcqF22TGI72QHanXroZkeS3bp1o27dulGbNm2oTZs2zmu152gd/+uvv06vv/66mgjbSzO0KZWaXdPyO34G+5O29IS/0zbZkvfixPLqq6+mq6++Otj2PB1XG9wYMmQIDRkyJLjdy894WmohQCZp119/PV1//fWpCnQWrh07dqSOHTtmCOTKRNIYl+s6jnV9+vShPn36qNfs3LmTdu7cqX7HsU62P3twQ16vxbN8J/tae421q+SYMWNozJgxzuUB9pTgXNOCeYnC7bffTrfffntUnVaW7TRBq/1O++7mm2+mm2++mS677DK67LLLvN/FNXX4o48+oo8++kjtJzQRZN9Dfpakrce2R1/f5EH+Dh06UIcOHZzXyiWK9nNkHvTEE0/QE088QUOHDqWhQ4d6i2DXe6Xtd1q5Q9vCbbfdRrfddhs1b96cmjdv7nye7Mu57Wqb0b3yyiv0yiuvmH5Iu6cU9NnOd5ffAYUDCPQihE8wgUCPt51PpwKBDoGe1O8g0KsGEOh+MS7XdRDo8YRAh0D3tR0EenK/g0AHqgIQ6EUIn2ACgR5vO59OBQIdAj2p30GgVw0g0P1iXK7rINDjCYEOge5rOwj05H4HgQ5UBSDQixB2gIsJNjZ5XeDevXvpggsuoAsuuMCsafMVzjKgy6BeXl5u1o3F7jKdVhAP6Thy2ZUDL+9ofejQIdPxLV++nJYvX57Ke37wwQf0wQcfGBGhXSNFAJfLtRY8id9pz419N7mDM/vGCy+8QC+88ILa0ds7/8o60t536dKltHTpUnNv3zXymi9wWfLld6GUu+zy+02cOJEmTpzofJds72dz48aNtHHjRnNvrW1r9kw78UobW7ZsMeTTFmbNmkWzZs1K5f4vv/wyvfzyy+beMlmrTLDNXXsbyLjP32m7uXOdyn1F2C/eeusteuutt4L9VxOdmzZtok2bNpkBTlfZy8rKvM4rj4HWXu3P5A7zPu/L63j37dtHrVu3ptatW9OyZcto2bJlqq1DY+v69etp/fr10QPrmq2T+J2kLWhdA6zad/xu8v24n3DdS76TS1S/+eab9Oabb0b3E5Jpn/bh8yxXffIJNMeOHTPvx/sMufzbdU/5Ge9/wgPrucpu9zPad2n5Hdehqz27Boh44Oajjz4ytuN9SzS/Y7FsDwxks8XTTz9NTz/9tLm3b+6prXWvikFgwA0I9CKEFuhCOxGbEOh6B+K6DgIdAj1NvwslBHocINAh0HMBAj3dfgICPcx2EOjp+B0EOlCVgEAvQnDjlI3ZZ6qflhBxws2i/IILLoieJmsn7zKh52myHIi0nYVlMLMDn9ZhxiD0nVzk8vNZtpKuziL0OePGjaNx48Y5p/T5duj5tp1vssTC8q9//athly5dqEuXLsZntHtp09JdvsLLAnhneM2PtOmJrvdJy3axgxtcfl4S0K1bNzP9zuf32lR6rhcpOkaPHk2jR482Z4Rr95JT7+3vtKmgVQnenZ7PT27QoAG1a9eO2rVrl2pywydVFIpAD6UWR9jnZIzTplJnozYApF33wAMP0AMPPECdOnWiTp06qddoU75dCXgS2/lOL3eR2wAveejYsSMNHDiQBg4cqNon9jncXtu2bUtt27Z1xg4ZQ133jIGWi9jvpsUGLo/8jvuJP//5z4acn9hnUOfKf1zxieMn9xNy8DO2307id7nao893/G7XXHON4U033UQ33XRT4gFj2U9wm3X5nXZ6iasMMXC1U1fb0srBy2+472vVqhV17dqVunbtaq7R+lHtO1tMy7bOfnfxxRfTxRdfnDGYopU5X2fIA/kBBHoRAgI93Q4wlhDoFQmB7m87CPTKBQS6HyHQIdCTtFcI9Hjb+bZHn+8g0LP7Xy4bQqADaQACvQgBgZ5uBxhLCPSKhED3tx0EeuUCAt2PEOgQ6EnaKwR6vO1826PPdxDo2f0vlw0h0IE0AIFehIgNqrx2UH7GnboUStou40w7Gc+25txmw4YNM+haM52rM0wj8fKlHRB5zeOBAwdo9uzZNHv2bLrqqqsMXbbzoSZ2Lr/8crr88svNM3Ld49tvv6Vvv/1W7RCSBHH+bZKd2pljx46lsWPHUo0aNQx5Hb+r3CF1dvbsWapZsybVrFnTDAzJxMunvrXvYqD5tb223df/p0+fTtOnTzciplOnTmZta1IxIclrCmvVqkW1atXKEOOu+ncly1UJ3hlc+hy3laSQu+med955dN555xmf+70JdI3z5s2jefPmUaNGjQyPHz9Ox48fjxYwGtu3b0/t27c3g5Fyzbt2PbedXbt20a5du1LzuaTvIWPkk08+SU8++SRdccUVhtkGteQ7hT6zWbNm1KxZM2ratCk1bdo0lfpIy3aumOAaqGQBIwfVDh48SAcPHvR6jquvkv0EC3NXPxE6EBAD37XL2Sh/98wzz9AzzzxDf/vb3wxdJ4G4vnOVhfdT0PYX0vpv1/uxfZPYzndQjf2OY7PMN3ggQ+asmzdvps2bNyduU9KPLrroIrrooovUf1zZe1HkGsxPsvcBkB9AoBchYgMDBDoEOn+WxHYQ6OGAQI/3u7QAgR5PCPQwQqD7xwQI9N8AgQ6BDoH+xwEEehGCG6RMCl0N156G8+mnnxry1JqePXsa2r8PPZ+cyWefL1iwgOrXr0/169c3IpOnEJ08eVJ9BzvAVtVu2qWlpVRaWmr+5kRw165dRjgPGzbM0K4bLYDyd7Ij4XLxO/LOyG+99ZaZYsXnDifpHJKITLtj++WXXyrsvKu9L//9+eefG/KO9C6/k8lVSGLEO6M+/fTTVLt2bapduzb16NGDevTood7fJYzzOcWdyUJHfmb76Z49eww52eLkVU5tdw1o2L6mtQM+N/711183UxarOuFPgo8//tiQd3/mkxY6dOiQ2nNYhD355JMm2RowYAANGDAgI3ZVJpLWFS8J2L9/P/Xu3Zt69+5Nd999t6HPPXzE+6pVqwxZwE6ZMoWmTJmScR33F9o9+DvNtyvDdvZu7nIKMLdXXuY1ZMiQCr+XPsI293kun6P8yiuvmEENnnIsr2NRGzplPwbcN2ixU+sn7Ni+YcMGQx4Mkv2Efb2sc/7OFQf5Gh5gnz17tokN3bt3p+7du2fUR+xgdFp+F5KzyFMZrrzySrryyivNUhS5HMXON86dOxfkF7zr/Ztvvmn6Cf4Hj2+b1Xw/X/980fIHOy/+8ssvDTk/6dWrl6F9T9/82+Zzzz1nWK9ePapXr55ZtiF9WVvK6vMPC6BwAIFehAgNEBDovwECHQLdvj8E+m+EQI8DBLpOCHQIdAj0ZH4HgR5vu2w+Vl4OgQ7kHxDoRYiYDVEkH3vsMUNOJj/88ENDTqqybYCRi9xB83TF9u3bmySfp+LK63mKvJz6IwcFTp06lTGVnqdixcAO2Jod5ZRUe2qRtB1vvMJnvC9ZssTLLj7J0nXXXWdon0OtTfvUgrc2FZA3IIkBJyqujkKzK78jT2sfO3asead3333XMCYh0eqNp2a3adPGdIDbt2+n7du3q4mB/MweEJB1lGQKmStRcbVntsXkyZMN+Z0+++wzw2y/k0krT+fW6o+vldMheeri4cOH6fDhw971oLXxqkoepKDkTdv4DOA33ngj8f15Guwll1xi+Kc//Yn+9Kc/0datW2nr1q0pvEUcQuvNJk+RfeaZZ0x75WmevlM97cRba9e8qV7fvn29poCHMgZJpxo/9dRThmy7t99+25Cvi10ewHaVAoI3PNTqXXsfFnKumBED1waedszT4p7WT/znP/8xTJr/cD/RvHlzQzum+sZn7V2T2O7o0aN09OjRYD/gv3n50/Tp000cev/99w3t32t+4RKBmt/xPyq4fuT17N+yH3X9syfJZp0+fiFFte2b48ePN2S/W7t2raFPfbgEO5dPbsjMU9zXr19P69evz3kvtg9/p21GBxQOINCLEBDoEOgQ6NkTLwh0CHQGBDoEegwg0CHQfeIzBDoEunZ/7TsI9OIDBHoRAgIdAh0CPXviBYEOgc6AQIdAjwEEOgS6T3yGQIdA1+6vfQeBXnyAQC9CcJCUotUV9GyhLXdE1XbedAVxnyD18ssv08svv5yx42+/fv2oX79+XuUrL9d3nLe/iwEnfrzu1177m428Nql///6GnBDFJnEaV6xYQStWrDD3bteuHY0YMYJGjBgRXUdpr6OWyZXP+jz2V7mLMa8Nd/3OlcRpndYLL7xAL7zwgtmRt27duuZs9aT1Iu2YxHaxlAM27BeajbXfupK+I0eO0JEjR2j58uW0fPlyI8pbt25tdj13+Ztv+Vm0VxbYb1q2bGnIAj1NzJo1i2bNmmXuXb169dTXt8ci1tc40ZNrVzt37kydO3dOpR0xeWBO7glw55130p133hl9TxkHk+zQz/djsXv48GEvn+drrr/+esNLL72ULr300lRtx/uT8Prftm3bmp2ntevttdm51rEmEZn2PWT81uK5PSgv+4kLL7yQLrzwwlRtp/UTvM9L7D21d40B+4/vzt02Oc/q16+fiXvye3vATO6/4vJv/o7zEzkIfscdd9Add9zh/F3od0n8TtrOJZjtdiDjEAtnX7u7/pnFZVi4cCEtXLjQDAbVq1fP+Ln2u8rc+wDIDyDQixAQ6BDoIXUEgQ6BDoEOge5LCHQIdAj0MEKgQ6BDoAM2INCLEHaACxWIvGNpnTp16MEHH6QHH3zQ+x4+Z55PnDiRJk6cmHHe8IQJE2jChAneQcYecEirA9SEf8jupby7Z5MmTdSdhl02dA2i8O94V1kp0OfMmUNz5sxxlouF1pEjR5zXJdnF3Sex08gJgPQ7nkrmew/urFz25WmR8jnjxo2jcePGBZfV1TnGIOQdtefyQFq1atXMbuG+fmfv3q5dw9MiWUxceumlNGPGDJoxY4azzL4JPz+7ssADcVI4jx49mkaPHp3qc+zp89WrV6d77rmH7rnnnlSfE4PQ6dO2f8gYNGnSJJo0aZLaVlz3cvkc72TMu01feeWV9Oyzz9Kzzz7rXWZeYuDywRiExjibsh1xTJffHzhwgA4cOOCMA677c9uUz+E2HFrWtIVS7GA1D5gn6Sd8yP0ETwH/05/+ZD7ja3INDtv9kbZcLQahAyk25YCNK2+wp7NL2uehy7pkv5PP4RNTQushX202NB/m95V9LJ+YEzpQ4vIZzrVZ/F900UUVTuaRU9Zdz3ENPACFAwj0IoQWiCDQ/QCBDoHuU1YIdAh0H0CgQ6BrhECHQI8BBHryNguBDhQKINCLEK6G6xKBnMzwVLibbrrJTGf1DTI+5CDXuHFjw3Xr1tG6deucnZ3rvHVtw7gYsA20zsrn3Xja78iRI+muu+6iu+66y3k9b9R28OBBr+fwFCs5hezrr7+mr7/+2vk72SnZU/dlJ5NkkzjX833OQe/Tp48hbzDjey6vyydZKLDfyQRv6dKltHTpUlOWXM+zn5PW5j+amLETFDmd1i6X3Oxs+PDhNHz4cLX+XUmPtnkbl4uXovCGP5dffjlt2bKFtmzZ4lxu4iJvjCc3x6ss8Ht17drVsFOnTtSpU6eMjYJioSV1zGXLltGyZctSfJs47Ny5k3bu3Bm9BGfMmDGG9jnKudp+Nh+X5Pq46qqrDHljPV9xYl8nN9Dkc8hj4BNrNRHHfsVT9e+8804aOHAgDRw40NsudtzWvuNNpvjs88suu8ycHe6qa22DURfTtp3mK1xeFiayn+D8JFawyt/Z/QQvs6pdu7ZZbqHVrWsjOPu9JGPg+qeLTz8p/W7YsGE0bNgwL1+W3LVrF+3atUu9vkWLFtSiRYuMwbuQTdQ0yn6P87MYaL7FNvPJaeXGd7ycLDR2auKay8C+JgX6/Pnzaf78+Wp9hMQIOZ0fKBxAoBchXA0WAt0NCHQIdAj0iraDQA8DBLq77WfzcUkIdAh0aU8IdAh0CHQI9D8SINCLEK4GC4HuBgQ6BDoEekXbQaCHAQLd3faz+bgkBDoEurQnBDoEOgQ6BPofCRDoRYjQAGgHGF4jPnHiRNNZDR482JATcyaf0bh+/XqTQLHwkfcaOnQoDR06lBo2bEgNGzbMEOh8xnpsEK+M5EELknZHz+sJZ8+ebXZ+lbvB8nnbvMZQCvTS0lIqLS2lN998k958882MM9VZ9PMZ1HJd5jvvvEPvvPOOV93m03ZahxGy0+gDDzxgyPaSu+Jv2rSJNm3aRKtWraJVq1aZv+VnixYtokWLFtHDDz9syINN7Mt/+ctfDO0z1nPRfp+0Eq9Qv7OTc17n9/TTTxsBze1t6NChJqnasWMH7dixg7755htD9rsXX3yRXnzxRbN3wpQpU0x9tG/fntq3b298ulWrVvTFF1/QF1984e1jPklQZUM7B10mYh999FFOzp07l+bOnWvWsI8ePdrs0C3XntvnrFc1YveM4HjF68GfffZZE5fuv/9+Q+4TONbJ85b5M07e5ZnqjzzyCD3yyCNGWMpYx/HT1+dcA9Jp9BP8HgcOHFAHuGyyCJw2bZoh76YtxVNJSQmVlJTQxo0baePGjbR7925D3n2e4748U50HhVm4yj1RPv/8c/r888+d61Mro73a9z9z5kwFcekSPrKf4IHWG2+80ZDfk/uGlStXGvJnWj8xaNAgGjRokOl7atWqZaid4R3ST6RtO82nfMolfYX7CT4FZsSIEWbQik8BYF/79ttvjU/yTu2yz+GBOl53LgdyN2/eTJs3bw6OM642nsR2cgA2ZPCf14M/9NBDJpeQ/8zik3yY3HY3btxobMAnGD366KOGt956K916663G7+Rg7po1a2jNmjXeNvNp20DhAAK9CJE0EEKg+9kLAj0TEOgQ6D6JTiElDxDoEOgx4N9CoMfbDgI93naaT/mUCwIdAh0oHECgFyFCA6FNnp55+vRpuvnmm+nmm282U5datGhhzkjnsxovueSSCuSETe7myd/xdFkZiOzzN7Wpdr5T3NPuALnTCrXj888/T88//zx1797dkMUNJxYycWdb8PQmeWYpCyS2K0//7NSpk7MMsUl4DDSxau9m60q85GAFn50qp3vxFDA++1YKbbYn71gszxJl8jVy6qJdBm2ndO0zbXpjEttxxxo73ViSk6Zu3boZcsLOU4Wl6OFEin1U+l2zZs2oWbNmxv/kGcR2OeV0Op93KITpd4cOHTJkcVOzZk1DTWDb5LgmxRBPMdau54S6qpHUzyT57GjpcyyweVmOnKrOPscDGX379jXk6/majh07GtrP1ZakuHbY5sGo0tJSI6hjkNRe8nzpqVOn0tSpUzPaFve1TZs2paZNm5r227p1a2PXHj16UI8ePTL6Av6Olz/JXdztMshY4yva0+gnQgdy7e+kaGRxwzlFo0aNjNDhNiyXNPF3bB/ZZu1+QuYnPv2Ei2n1E65nhJyWUVZWRrNmzaJZs2Zl+A/7GOds0gb8We/eval3794ZA5ncVrV+wi5Drh3w8+V3PvUl44kdH2WOyTuuy5yX8xT2H9mP8HfcFuUSgPr161P9+vUr+F+dOnUSxxk5GJHEdkB+AIFehEjaqCHQMwmB7gcI9HjbQaBDoFc2INAh0CHQIdAh0PV4AoEO5BsQ6EUI3iRNBhvX+eQshLUNLPh3MrHZtm0bbdu2zUxnl+Rpr9pzHn/8cXr88cdNQHN1gJIh50zKQBoDLVDbnYlMrnw6Q97Y5MSJEyYpZNHPf+/bt8+cU64lzi+99BK99NJLRpxyEtuhQ4cKz9MSA9cGY/lMHlydok+9yvPbeRo7T2GUU8hWr15Nq1evVu/x97//nf7+9797CXSt/nyTsbSnuLsElD2gpSUZcpCLBz7Y72SS65qay2flsuDkBKx9+/ZebVFOAXb5BL9PIWDv3r2GH3/8cU5quO++++i+++5TBXqhgH3HN57xBpLad5rPsV/t37+f9u/fn+FzbF/tXgsXLqSFCxdWSPp9fS50w7AYuGJniHCTlAKAlwfwtHaOfatWrXJuCsqii5N+Kex94q6W0Fem7WIp+wnuEzgXkWQbavfg5QUs4rV+QvMrTWy64nMatsvm7+fOncvIXewcRttkTMY7u31yfyH7DK0MPCisTXH3qT9XfpKW7Ti/DfVxF48ePWpoL/3kae2S2j14CSiLeNlXJC1fWrYD8gMI9CIEBDoEOhMCHQIdAj0MEOg6IdB/gyt2QqDH2y6WEOgQ6LkAgR5vOyA/gEAvQkCgQ6AzIdAh0CHQwwCBrhMC/Te4YicEerztYgmBDoGeCxDo8bYD8gMI9CIEJ0gyaLt2s3V12LwWXSZedqfj29G+/vrr9Prrr5tOj5OI+vXrm4EArUPj5DF07VIM+LdSOKcVzHPRVQ+82zGvMZTrxkJ3ImeyT3DHJQdnYqCtPef6stcmS+Hr8qPQOtcSqH/961/0r3/9Sz0HnXcy18rO9wpNwpP4nezw7fPqpe1cA25pkv2O18vJxEsb0GO6kjk7eZX8o4B3N9cEOgvWqgbXB5dn//79FepK2xPBtfOxjJshfiafwwMfvO6c12E3bdrU7Bdgx8yQAVz7mUlsp717aDm4HUmRwmVjW8v9OVy2+/e//03//ve/zRr2iy++2DDkfHPt/mnFOju+2jE2W1x1lSO2n5DPXLx4MS1evFgdyOUB9lDb5aufCKVW95o9bfHue3/ebZz3NZF7H2Rb0y0pB+98npfE76RAt+nTTqXI9x0MdL07//NF/sOKefLkSTp58qSzr9Xoeh+gcACBXoSAQE/eAUKghwMCPbnfQaD/MQCBDoHuSwh0CPQkfudDCHQI9CS2A/IDCPQihC3KNWHOCb5M8vlv+TsW6FqwDxWuS5YsoSVLlpjgw7vBN2jQIOOZp06dciaGZ8+eVctVFR2gK/DylFBJVwDld9fE1/Lly2n58uXm3Phm/9tdu1mzZs7yxSYWSWxnT7mTnZdL7Mpk25Vs+STk8tl8vjfv+M7LBC688MIKZZD30HZqt6cKpm07LdH0OatVo7bDtavcmg044deWpfC9sgmHmDbzR8G8efNo3rx5atJVKAitm2zXlpWVmfgWKpS05/GZ02wvLdbZQuLcuXPmjHStDWhlTqO9ut5JDlbwIDNPF5anB4Tax/5MvhOf9822k6ev2IMw0nbaYFm2QZu0Yp1LkLv8SIvH2m9D46Ut0Hmqe926dZ331N7BZ6A5Bq72yd/5Lllhatdr/uD6J8+yZcto2bJlaj/BfqT5GrcPra9iyuWV+WqzPpQCPenSDPm+r7zyCr3yyivG7+Sgmk95tIEuLT4msR2QH0CgFyEg0CsviEOgV7QdBHq87SDQ/xiAQIdAh0B32w4CPRwQ6Plpsz6EQAfSBgR6EcJnyo0U6HbQ18S7Fhi07+wgLoPxjBkzaMaMGUZkyjMkfabsugYcJHkAIQYsaLVEjoVh6OY2WpDcs2cP7dmzR02StGSAN53SEn5XoqCRp3VzB5FWEPexhZZcadR+y99pyQfbThPvM2fOpJkzZ5opxjLx8rGZLJdrcIDvFQMtIbI7c5evu37vS3tKfXn5bxs78vnVMuHnazRhxOQpeidPnqzgY3/k5ME1xb1Q4NrcSovf/Jk2uBjrc7yhkvxsyJAhNGTIEHWTuF27dtGuXbu87+9Trhi42r8rhrjKKGn3CXLwkp+jDWazyOSlUPKcbx9baGWokxoO2gAAIABJREFUDNu57MSfaQJPi9E+cUZ732nTptG0adPoz3/+M/35z3/O6Cd8bOebF6TRT7jury1Z44Eh+c+C2Dar9b/vv/8+vf/++2YpCp8z36ZNG+e9tL7NNQCVtt+xX/A7adPe+dmaXUOp2ZzzE94kTi799LmnLJfPPy+AwgEEehECAh0C3UUIdAh0jRDo6QEC3Y8Q6BDouewEgf4bINDT9TsIdKAqAYFehIBAh0B3EQIdAl0jBHp6gED3IwQ6BHouO0Gg/wYI9HT9DgIdqEpAoBchXI3TZ914LoHOHaG9ZlpSC7x8vi2Lct911Ey5k7zruiTnoIeuq7d33WXx+80331Swubwvn9kq78Vn3mrPeeedd+idd94xHWCtWrUM7c4miUhLEsSTJjHyO9e7aGvWXc+cP38+zZ8/36zxatSokaHrd/bus772zJftJEOSUPkubDvZqdsJl6wHXh/Hu7g3b97c0L4+V5ntd+TBMDkg9keBPSgk22uhIDQmZBuwlO3P1VZkfdvXS//lHaE7d+5MnTt3pquvvtrQVT6ffUnSaq8hbTOGdv+r7Y7PtuPB3j179tAbb7xBb7zxBrVs2ZJatmxpdtW+8sorvcrHg3T2QF1l2S6U/C7a4G7ogMmcOXNozpw5RpTzPxIaN27sVZZca+PTsJ2r7nzicK4+k/sC3h9BG/jgHEy+L++Rw/2EZLY6k/27VhbtOy5fvvzOdw8N1zWhIp7zE153Lv9xZdeb7z1dZQAKBxDoRQhXw4VAdwMCPT6IQ6Dn13aSEOiFDQh0CPSYuMuEQA+LgxDoEOhp+B0EOlCZgEAvQmjTwEPOTZZBPGQ30FwBghMFTlpXrVplaP9em84uP/N5nxj43Nd3OnHs7tt2Z/Trr7+aBJWnGn/++eeGrntou7hX5rTPkB11facI+k6JZ7Zu3Zpat25tpi6+/fbbhvazs5XHJttQK3MS20mf4rqPHWzRBJHmk6423r17d+revTt16dKFunTpQps2bTJ0+ZM2LZCnuqftd4UITrD4lIrXXnvNsFCg2Z8HHENjV6yPas/p06cP9enThzp16kSdOnUy0+C3bNlinrNjxw7asWNHzvOT7dMztDKnZbsDBw7QgQMHgm0QOijsYrdu3ahbt26mv/j0008NQ+vPFlGaeI+B9iw7hsrYbn8XOpXcdyCXp2Tz9OIVK1YYZrt3rjLL3brtJWVJ/E5biuAS7z5CWPtey3W053Tt2pW6du1qllNIv3OVSxtU0/55YceLJLbT2l5InpI2+bz4Vq1aUatWrcwJIPPmzTPXcB+tTbOXvsjvY+82nzQ/AfIDCPQiBAR6fCCCQI+3nXYfCPQw20Gg/zEAge5HCHQIdBlr+W8IdLffQaDH205rexDoQFUAAr0IAYEeH4gg0ONtp90HAj3MdhDofwxAoPsRAh0CXcZa/hsC3e13EOjxttPaHgQ6UBWAQC9C2I1a7k7J37l2RNe+40Aqg6lrR3XuEOW97r//frr//vvNjqJpBDdXcpPEdlpn7CoHd16andIgr2m11yH6UuuE7Y496W7aWkdsJ0kuUZ0ryXDVhyuJ69u3L/Xt25dKSkqopKTEeW+ZSMXWVVp+56It3nn/ArmHgWz/LB5YgGm2Zt+SCe3UqVNp6tSp5rtcg1I+Psh/79y50zCJ7QoRvBP51q1baevWrVVdHBVJYxLvqL5r164Kg0ragI+rbXGf8N1339HDDz9MDz/8sBnQ0XyO/Ti23ci2k8R2WjtK2j5CB+dknzN+/HgaP368U+SE0tX/JbGd5g+ufT9cO7z7xBv5LraQ/vnnn2nQoEE0aNAgKkmxn9AGk9P2uxB/08qt+bDr3Xi/g6NHjxpOmTKFpkyZYvoZbVAkab8qy5rEdrJsIevFc+3i7vMdl1/uS3TPPffQPffcY+waem9fJvE7ID+AQC9CcIOEQI+3nSQEuh8g0NP1Oxch0AsbEOgQ6LHtAwIdAj3E7yDQw2wHgQ4UCiDQixBa43RNF/dp3DIJSGOX2mzkMmlCLnRQIS3b+Uxn16aSM2XyGdIJ5dpNn2knUJrwdu24LO/FNk9iO20qeOgupC7au8qeO3cuehpkNhv6Mu0p7ho1wWNPl9R+V/K/RLOkpMQ5OLN3717au3dvtO3Y91k0yQEA7VQDF4HKgxbf7PqQU8h9psnKc+9d9Wz7nCacffxFGxCV/pttEEoOciax3cGDBw2ztVvZdkPjoCZq7Kn0UnTZ9aAtc7FPHslVp2m311xxVApoTXxrole73kfQa7HOVQaf77S4qV2flu1shgpu33vxoE9o/ufjRy7baXlQWraTovvHH3/09iPXO2li2hbo8pn2vbRTf/hvrY24yqXdCygcQKAXIbSgAYEebzsI9DDbQaCn43dMCHQgH9Dim10fEOhu20Ggx9suWxyFQA+znU0IdH/bQaADVQkI9CIEN0RfEW4HP99prNzw5XM4AMV2CC5hoL2P6zkxcAlpTShxsuSbVLquS0vEyoRNex+2sUv8xyBp+X2FIdtQu17zB+7IQsvnKotramUMQp9ht8FQW8vpiT7PsafPa/6WxPeTbP4DxMGnjuSgC/sax0HfJSlMPlv50KFDzuti40js1PIYlJaWUmlpqbcNuK2FvluogOZN3GJtERpjYhC6yWeIeJfXZ/t9NnFjDypr99Z+Z081136rDZDHwK77NOo4tB0XApPYzjVVXeZOUtzKjdc0US19g6/J9lv7uXyNKzZov+MyaMsWXL4BFA4g0IsQ3BAh0MMBgR5vOwj0eNuFPsNug6G2hkAHfOoIAl0HBHq87SDQ421n1z0EerjtINCBQgEEehGCGyIEejgg0ONtB4Eeb7vQZ9htMNTWEOiATx1BoOuAQI+3HQR6vO3suodAD7cdBDpQKIBAL0JoDd0WttraFJeYl+vpXMKOr/HpeDVqO6BrCYLPeegxcJUtdPd5TdDbgTO0c+R7yg6fg7PL5qEdehLbyWdx0uPqfLjcWkcjkzGXEHSJaR/R7ysyfZK4tPzOZ/8BX/oII432ucdpUPN3XhcMVB609rp9+3bavn27s/60tqy1B3uttHyOa88O+1xz39jlGkT6/vvv6fvvv1djUxLbae/Lvqz1sXyNXBvO7cFXsHL5XaeFpCnQKyPWheQLmp20etWuT9pP+DLbOmbJGGh1YZ+w4dtmtR3zXf2gq45c7dkug2TsAHMSv5N5Rsju6Fp79qUt9uV3sTu0h+bY/GygcACBXoSAQE8exDVCoPvZDgI9Hb+DQAfyCa29QqCH2U57Xwj0cNtBoPsBAj2530GgA4UCCHQAAAAAAAAAAAAAKABAoAMAAAAAAAAAAABAAQACHQAAAAAAAAAAAAAKABDoAAAAAAAAAAAAAFAAgEAHAAAAAAAAAAAAgAIABDoAAAAAAAAAAAAAFAAg0AEAAAAAAAAAAACgAACBDgAAAAAAAAAAAAAFAAh0AAAAAAAAAAAAACgAQKADAAAAAAAAAAAAQAEAAh0AAAAAAAAAAAAACgAQ6AAAAAAAAAAAAABQAIBABwAAAAAAAAAAAIACAAQ6AAAAAAAAAAAAABQAINCLEOXl5Vl57tw5OnfuXMZnBw4coAMHDqjX//LLL/TLL7847/Xjjz8a2teUlZUZusrlovZ7+7Nff/21AtO2HfPUqVOG9nenT5825Gt++uknQ77uzJkzFZjUPswffvjBkK/RPnO9W9q2O3v2LJ09ezb43fh38rf2+2q+FfudfN6qVato1apV3rYvLS2l0tLSvPldKEN9i9u6qz27/Ej+jttAaN3mw26hMei7774ztD9jG/3yyy/mnseOHaNjx47Rzz//bOhTHi0Wa7Tjs3wfth9QuYiNY/z3999/b8ifsR8dO3Ysus3b/bVvrOPPfH04tr3G2C5bX5uL3L5ccVCzAfPbb7819Hmebx/LdVwZtuO65/fPlYvw9fY1GjW7+vQ38neuGMh5XGX6HZfHJy7nsvmJEycM7fvLPNH+/Y4dOwzte8aWKantgPwAAr0IYTfqsrIy03FzgJAdE5M7F61TTyN5qGzGwE6afMm/c3X4rmCuBd80OovKtF1ll/HQoUOGVe1rSW3nMwgV60eSrqQn9F6h9LlnKLT3cQ0q8gDCwYMH6eDBg95ld9mtKm2axOeAePjUpewz81n3kmn2F7a4SGNAjcjdT9iC8syZM2bA4PDhw3T48OFUbZGvfyDkq826nuUzIKFRDjqG2CffMY2pDSok8Tv5TxzXQP+2bdto27Ztwe/oyv9C7xXanvPRxwL5AwR6EUILoBDofoBAj7ddZZcRAt3PjyQh0CHQgeSAQI/3O592AoEe7ncQ6H5+B4EOFAog0IsQWgCFQPcDBHq87Sq7jBDofn4kCYEOgQ4kBwR6vN/5tBMI9HC/g0D38zsIdKBQAIFehNAaJXdyW7ZsoS1btqhr4Ox1L7ka/PHjx+n48eNqgHMJXZ/1TVoZPv30U0Of3yWxnbZGyGULnzW38t01+/D9XQGe1+P5do4c4OXaQteaPi5XWn6XJjnpWLt2La1duzbvz3MJvcr0uzTIvsL3rqzkSr4P0+Xfafpc7L4HdtJWVlZGW7dupa1bt6rXa/GM293+/ftp//796u9cyde6desM7e+0PTCAyoXLf1ziyHcgjmOPNijOMdpu0zJmhPaxdps5e/asMz7wd0lsp+UgseXV7O/KZ0pKSqikpESNg1r79ynLN998Y+iKPVy3SWznWkuuPVMbRHS9m8t/XHEr1O/4eima+TOtfPyOMeD7hf6zyXWt5iO7du2iXbt2edvO5X8+z3PdS/snD1A4gEAvQmgNFwI9zHYQ6On4XZqEQI8nBHq4rSDQgWxw+Q8Eup/tINDjbQeBHg4IdPQVhQYI9CKEa1d2F0N2LJX873//a8if8VTSkydPGro6Bp8pWVpw0jpCfv8YcMIgBa1rCqu9a2to0uGaxi7fl+/ps0usRtkB2t/JOkqSeMUugWCx4SpjLtqDG9J2XI+xyaDvsoU0ktZQagI4xF6yLWk7t/M12nexIsDFyrKbq56177iNuhJ6GTPs6biupF9+5uNnMmbw84DKhUuk+Exxle01dCDQlYRzP+qKxa5d2n2XVfE1adsuV6zK54Cia+D66NGjdPTo0VSew7E0Bq6Y6/Ij31Njku6ubovrmPqyd5zXromB65m8nEMrNw+6aP7v+04um7nihU9/4Nv3JxncAPIDCPQiBAQ6BHq2DgICHQI9W1uCQIdAB/wAgQ6BHksIdDch0P2+Y0Kg/34BgV6ESKMTyRZ4f/rpJ2dwWrFiBa1YsYJGjBhBI0aMoE6dOhm2a9eO2rVrR126dKEuXbrQI488Yjh//nyaP39+9LRUraxJbOcS6NqmKr6dkT1Y8fXXXxsuWbKElixZQn369KE+ffpQ06ZNDevUqUN16tShhg0bUsOGDem2224znDZtGk2bNq3CvbVAX4gi06c8ZWVltGbNGlqzZo35Tp67/eGHH9KHH35IDz30ED300EN00003Gfbu3Zt69+5N1113HV133XX05JNPGrK/plnWfNnO1RFr38k6twU2J5xHjx6l5557jp577jnq1asX9erVi6pVq2ZYo0YNqlGjBjVo0IAaNGiQYdfHH3+cHn/8cXUqqRY37O+0ZDHWblJY2G1TmxJuT6eU5XOJaFn+9evX0/r162nYsGE0bNgw41/XXXcd9ezZk3r27Eldu3alrl270n333Wf49NNP09NPP23uow1whvL3AHm+PNvgyiuvpCuvvDLD584//3w6//zzzd/dunUzvPfee+nee+81m0NWFXzqxCWGtIFrLZbw3x9//LHhsmXLaNmyZTRw4EAaOHAgtWjRogKbNWtGzZo1o9tvv91w6tSpNHXq1ApnXsvnhG4wFoPK3vhU9uWrV6+m1atXm76zffv2hpyftGrVilq1akWjRo0y5BjJsUX2PZXZZn3u64q5vj7Lf/PSnq1bt9K8efNo3rx5JrbJNsu86KKL6KKLLqIBAwYYTpo0iSZNmuS17NG3zElsJ/3epw61DeVC7fr+++/T+++/T3feeSfdeeed1LlzZ8MOHTpQhw4dqGPHjtSxY0d64IEHDBcuXEgLFy50ts9cscS+DigcQKAXIfLRyUGgQ6BXhd9BoP9GCPTsdoNAL3xAoFfsByDQ808IdH9CoFckBDqQL0CgFyHy0clBoEOgV4XfQaD/Rgj07HaDQC98QKBX7Acg0PNPCHR/QqBXJAQ6kC9AoBchXI1006ZNtGnTpozPeP0NJ/ifffaZIYtHFtwjRoygBx98MIMcYDp06GACddu2balt27b0t7/9zfDVV1+lV199NXqNfGV2gL5Juk25Bp2T7gULFhhyYsAiR3Zu9evXp/r165u/GzdubDh79myaPXu2c4dQpiZIKtN2MiEKsZ38HfvI888/bzh58mSaPHky/eMf/6B//OMfdPXVVxty53bzzTfTzTffnJEgsLDPx5ppySTrMvkevMeA3GfAp9wyYXzhhRfohRdeyBiIYLuw39WrV8+Q/a5WrVpUq1YtMwjUsGFDI6S0uJGPNaGhcJUhRGiUl5ebmMdJ/OrVq2ncuHE0btw4E+tke7322mvp2muvNQNqnLj27NnTnDSQNInXqMWmqsby5ctp+fLlNGXKFEMprLt165Zhu+rVq1P16tUr/F29enV69NFH6dFHH6XNmzfT5s2bq/rVVLjqwofc5544cYI++eQT+uSTT+jFF180HDx4MA0ePJiGDh1KQ4cOzbAdi28evP3rX/9qyP2M1sfGnkrh8sG0bVfyv93VXc+W/QSLxzfffNNw5MiRNHLkSCOuWXC3atWKLr30Urr00kvNwNDll19uuHTpUlq6dGmF89/zxSS2c51d7oqBUuCxaGThPW/evIx+c8CAAaoIZ8o+ZPTo0TR69Gh1sDYfAzJJbKfR558XchCBYxMPli1btsz0FSyupa1YjNv5SseOHU3s9BHZvntEuNoYUDiAQC9CuBosBLqf7SDQ420HgR5vOwj0MECgx7fXNAGBDoGehu1KINC9bAeBHm87jRDoQFUAAr0IERv0OFGQn/Xo0YN69OiRMSWHP+NAxAJozZo1tHv3btq9e7fZRfbgwYOGIWXxnZJdGUHcJwHTruEEqkmTJoatW7em1q1bm6SepzAtXLjQ2H/jxo20ceNGVazFMlQ058vvXAmt7Hw4QbjxxhsNeUond4QbNmwwZB/j5ErznyNHjtCRI0cS2zKXz+bLdnIauz1NVdpOCmwm+x8nqnLgg6fOvvPOO/TOO+84p9KnMbVTI/t5Gnaz/UuWmZOg0tJSKi0tpS+++MKQl0Jcc801hizCx48fT+PHjzeDjK+++irt27eP9u3bZwbD5BTukHfXbBp6okFVw56WXq1aNTPgwwJdindOSnmZwO8NIfFAxiB7l+xz585Ry5YtqWXLlhlLmvizIUOG0JAhQ+ill14yXLduHa1bt86cuqLF1MqaRp4v20nu37+f9u/fX2GJ3blz54zQvuyyywy57bIfvv3224Ys6Nl2nK/s3r0777aqCttli4nl5eVGXPO09Isuusj8Q4D/wSLFO/vdypUraeXKlRn3ynYme8gAaVXYLnaQmX1MLuHkpZucp0i/27ZtG23bto2OHz9Ox48fV2NDIbdZID+AQC9CxDZcCHQI9LRtl81OEOjhtoNA97MbBHrlAwI9ezyAQA+3nSQEerztssXE8nII9Gx28SEEOpAGINCLEHbwyRWAXFNrWDyysGzdurXZqCcfwSPNaXhJbBdLKW4mTpxIEydOpEsuucTw1ltvpVtvvbXC+2rvLAW6T/B2TWuX097ZJ1ziPy3bxXaAPG1M+h1PcedrXIM4nIB9++23Qc91LW3wfY+0/S60TfBGebzBW40aNUzS4PN7l2DUfF3z/dj2k6bdNLoG/ebOnUtz586lCy64wJA32OJr5EBX0in+vgmZz3VVDd78SE5VZ2H+R4QrdoT6AW+2KAc3eGq7z2AYD4ZnO/c8n0zLdrHkpV9yqvrw4cNp+PDhan3kUwRp/YQrdiexnRTAriVQLpE8duxYGjt2bIbf8cA4X+PqY31FeMhAo2RlnoMe+s+gOXPm0Jw5czLiHS8BZR/zXWqYtB+RfudzL6BwAIFehHB1GBoh0CvaLpYQ6Ol0PhDo8W0CAj07IdDzAwh0CPQktoslBDoEehp+B4EOVAUg0IsQrg5DIwR6RdvFEgI9nc4HAj2+TUCgZycEen4AgQ6BnsR2sYRAh0BPw+8g0IGqAAR6ESK2gbuu4bN+hw0bVkFkakHcXu9cFawM2/mQ1+z36NHD7GjP4lEm/HZgd3WAMhjzNaFCztW5pmU7Xt+rfecj5ni9+bhx40zipV3Htkva2RWS37nqx/We/B2vievSpYs545dPGEhzLXmaa9LTsFs2n8g26GJ/x+Jo6NChZjft2Pfhe/vuuhzrv1UN9gE5oNaoUSNq1KjRH/L8XZ/2Gpo4X3fddYbcbrVB1Mo+R1x7nyR+p92b+8PYd+P9I3r37m32jeDvSv63M3xJjt3hfd43DXIcSGI7uaO4q59wfcdtVq6j5nX8fApAkjPVk1ITzfw+afkdv2doW2XKkzt4r5yk7+27/8jvta8AfgMEehEitMFCoMfbzocQ6BDoMbaDQI+zWzafgEDPHyDQIdCT2A4CPcx2EOjp+B0EOlCVgEAvQvD529qZiVu2bKEtW7YEN2q52zgnXqGCkM/wdk09Y3Eaet5jWoHIFfRip+++9dZbhnxeLQslLeBqSZnPbu5Jd70vL/+t007bdrHT3ORU9X79+lG/fv2CO63KTmhj4EqkfOpe69Tl2cAXX3wxXXzxxWYX2dB30mzIto4V6NopBaFIs95YSPKZ75s2bTK79ab5nDTaaRo+lw/wOdwLFiww02Z5Z/s/EtKsQ56evnr1akPezT22veaD+RToTM4RQsv2wQcfGLLfufIT/i42z/AdcHPZMQYusRzax7IPv/7664a8m/vhw4fp8OHDwae/uN6X+7jQEyrkPyqS2M5Vz7y7f2hdcq793//+1/zzJfSfU59//jl9/vnnwe0iNq8BCgcQ6EUICPT4QASBDoGelDGAQI+zXZr1BoGeHBDo4YRA/40Q6G5AoEOgMyHQf/+AQC9CQKDHByIIdAj0pIwBBHqc7dKsNwj05IBADycE+m+EQHcDAh0CnQmB/vsHBHoRwm7AaYiTzz77zLBz587UuXNnOnToEB06dCjjOp91USFBvaysLDoZigELBrlG1yXMbYHBwluKbymUmjRpQk2aNKHNmzfT5s2bM3b6ZIHA32nPS7pLdnl5xf0BtD0Ekvjd+vXrDZP63caNGw1vuukmuummm5yC1eXvlbU+PQZcr9Lv5a7op0+fDk5s3njjDcOGDRtSw4YNTTIgd362mcbay9h1i7E+xwOPW7ZsSbzWW/ovrwXmhNXXNjHrGX2pxfVCwQsvvGB4/vnn0/nnn09r166ltWvXGqGuUfr27wFaPYcINq0tv/vuu4bNmzen5s2b0/bt22n79u20f/9+Q+5ffAbuCjHW8W/lAJ1rF3qf/p99bO3atdS2bVtq27Yt7dmzh/bs2ZMh8Jjcnk+cOGHoamd2Ow6NxWnZTq4Jz5ZruXZ412LSkiVLDFmgc5+7b98+QxaxX331FX311VfOd0uyRt5l1zTW72sDwy5qMZw/kwNDHTp0oA4dOlBpaSmVlpZm5FV8vUu88zU8KKcNzIX2P2n5HZAfQKAXIbQOJmlHDIEOge7rdxDo4YBAj7Md/w4CvTAAgQ6B7ms7CPRwQKBDoEOg/3EAgV6EOHLkCB05ciSVDpgDojwrk6dp887kfN5tt27dzJRQ3hV0/vz5hkePHqWjR4+ae8vpy6GJrDZFnMmdSwy0cys5qGodh885l127djWsX78+1a9f39iSBXuTJk3MWen8Xa9evQy5U3S9dxrk+8dgw4YNtGHDBrWj4OQptDyjR4827NOnD/Xp08fslirJ57f279+f+vfvT6+99pqh3RmnOXAlB1g4IYmBltyzMA+dQs7+ylPu/va3vxmBzstT+O+GDRtSgwYNqEGDBlSvXj2qV68e3XLLLYY81Zvt5XvWeegAHd8zFFy+NMWwbJNt2rShNm3aUMeOHaljx4509dVXG3bv3p26d+9uRPyUKVMMOanle/Lg28mTJ4PLySJWG/TgXYirGtou7hzH+Jxg2YfYn/E56nfeeacZHClkaP6d1P+uvPJKw7/85S/0l7/8hVq2bEktW7Y0fe5f//pXI6JatGhBLVq0oAkTJhjaU2F9z0hnkep7tjXHvBjs3LmTdu7cqQqR2IF97hv69Olj7MPnovPO5Jdddhm1b9+e2rdvT82aNaNmzZpltNkvv/ySvvzyS3NP10kXVbUET4sB9uCD9p32OxaPsi/g9lijRg2qUaMG1a1b17B27dpUu3Zts1xq4MCBhvY/FVy7v2sDJr424zLHgNtnbN1pAzacdwwYMMD0rWw77jvatGlDV111VQbHjx9vuHfvXtq7d2+0H/mSB1iAwgEEehECAh0CPZYQ6GGEQNcJgQ6BDoEeRgh0CPRcgECHQI8lBHrhAQK9COEKbD4BUQbO+++/n+6//3664oorDEeOHEkjR46kZ555hp555hn68MMPDVlwP/roo/Too4/S3XffbciJLIt5V1Itv9uxYwft2LEjY8oQJxQcMNOepu3aBEYrtzYNr2/fvtS3b1/TsdWuXZtuu+02uu2222jq1Kk0depU+vjjjw3nzp1Lc+fONYkYi4KOHTuaz1g4aFPpOZmQU7hcG865NuRLy+98qCVBkyZNokmTJmUkXpMnT6bJkyfTqlWraNWqVer07OnTp9P06dMzhD2L9htuuIFuuOEGtQycTPhOXXRNu0zbdi5BrE2N53OAOZGSydSoUaNo1KhRGX7HU/R4sEOKUFvE8yAgMci/AAAgAElEQVSbHGgLHUBwvU8adgvZpEfGuvvuu4/uu+++jAFHHqhYvHgxLV68mJYuXWrIg06333473X777RkikxMzFvEu3wmdcpmWzyWFFDAsLKUIZxvee++9dO+999Ly5csrkK+Rwp6nxtubzMmp8FWN2HrSfJPbprRdu3btqF27dvTAAw/QAw88kLHUhwel2O+4vV977bXUuHFjaty4sRHvcgCRn8f9howZdpsuLy9XP0sz1ml9LPfrWn+ucdiwYTRs2DBjr3bt2tHQoUNp6NCh9Oyzz9Kzzz5rlgls376dtm3bRtu2baN77rmH7rnnngyBxbbntqsJSC6T78BHvmwXSu7fpF35HyzS79gWPODz8ssvG3I/wf0pT+nu0KGDEfF8H17+KJdA2oMF2aa/+yyPSmI7e/lRWVmZeebXX39tyNfborysrIzuuusuuuuuuzLyYs6VFy1aRIsWLaJvvvnGkAcwuP8dNGiQIS/J4H9qab6v9Q+cF/8e+gpABwR6EUJrlBDoYbaDQE/H73wIgQ6BHms77R4Q6JUDCPRwQqBDoOern3ARAh0CvSr7CkAHBHoRQmuUEOhhtoNAT8fvfAiBDoEeazvtHhDolQMI9HBCoEOg56ufcBECHQK9KvsKQAcEehGCG6IWbHyShi+++MKQg/hLL71kaP9eE6ya8OYAxkJLCoExY8bQmDFj1E6ZP+Mgt3nzZvrkk0/ok08+cYqDJLbTgrj2nR04ef3/kSNHzJryxx57zDAkkMpObsaMGTRjxgzTMfAazurVq5tkTDvL05XkcOKW9uCG5huhnQgnrXIn8pDfy3fixJYTNin6n3jiCXriiSe8y+7ajyBt24WQ1yIfOHDAiOoHH3zQ0Oed+G85SDF79myaPXu2SYRlMnf99dfT9ddfryYPWuLFwjzNwQ3tHvZgkxTAtliRIoH3iXj++ecN7etcdcB7MGzYsMEMYrKfXXfddYZjx46lsWPHmkFN167L5eW/nZPL9aTFpKoAJ4g7duwwPjFixAjDEEix/+qrr9Krr75qBjilz/GeChwXqwpsd7m3QMh6Wrn+muM3D0pOmjQpqy/L2Ka1O+5bWbzzWutmzZqZATjtd/aJEadPn67QVrQzsZPYzpd225PtmdeUz5w50zA2hnKbZRF16aWXGt5xxx10xx13eIsiW7zns48NoRSNvFaf49HYsWMrXK/VuebD8+bNo3nz5tHgwYNp8ODB6p5F/FytXNI+HANdA61JbCfjp2stuv2dtAX/s+npp5829LG/1vdxXsx9Be/jdM011xi/0wbVtNzeZ3AaKBxAoBchuCFCoMfbDgI93naab4QmEhDoYYRAz55YQaDnBxDoEOhJbOdLCPR429mEQIdABwoHEOhFCFfj5CRCnm9pX6NNn/YliyEtGNrXygSPO0eePqWVwbWDNJ89WVpamigQJd0lXZtSmAbte/73v/815KmhPM1UJo2x5Urb73z8IQmz+bJGOU2bB06GDBlCQ4YMCX6uNiU+X7Zz+b9rx+FcdAkLOzmWU+NbtWpFrVq1MlP0tDOFXbv5puF3Pj4hB8046eK24Jus8TUHDx405O+0KZC2TXfv3m1oT6XVylcZPvd7gTYlnndMltPfKxOueordiTyW0n/s7+SgEdusZs2aVLNmzYw+1mc6uTblOwax78lxJM1TOFxtnU8TWL9+vWmz/A+F0B3IpTBOYjvtHHT7WZp9Qs9st8VyrvPMbcrzwTmn43gnlwe4/C5fAl0j5wOyXu2YL/9x5bK17UehuY6Md7wsj5ew+Po+59VpLV8E8gMI9CKETycLga4DAj0/HWDSTisXIdAh0LP5BAT67xsQ6G5CoKdLCHQIdAh0oDIAgV6EcDVcV6DmYMnnMmY7m9EWf7HUEnrevIU3U7vtttvMdHbXdKu0grgWUG3RLqfFuqbf+ZRRCmcWWDKohiQiHMTl+dfvvfcevffee+ozXZ1H2n7n01HJZFvr5Ox6kP7AvhubuPGZpLyh1b333mumjIfeKy3b2X7kEui5kgEfn/QR+Jo47N27N/Xu3TvjHOctW7bQli1bnPfS3icUPn6lJdP8O21gT5LFjS3scw10sY3Y7lr98HIVeZ6wqw7STlh/j2D78HnCvIzokksuqdTz033iwOHDhw1tv9N8X8Yze4q0NmAdGuv42TyVtnPnzoafffYZffbZZ8Gbn6VluxAhk6ZADxXaPOWYhdMNN9xgbOcqaz5tZ9M1WBs6YKrlXKHnmLM/9erVi3r16mXOp7/88stp5cqVtHLlSrWMafud5mMhfif/oeRzve+Gs9mWUkpyXszLVG688cZKzU+A/AACvQjhEzS07yDQIdCT2M6nE3JdA4GeSQj03IBAj/e53yMg0CHQIdDdhEDXAYEebzsgP4BAL0L4BA3tOwh0CPQktvPphFzXQKBnEgI9NyDQ433u9wgIdAh0CHQ3IdB1QKDH2w7IDyDQixDcEGUSwALGFQT4Oy2I52PtsPYc7gx4V/cxY8aY8yJ5N+PPP/88b4HIXo967tw5k2THJgWxZ2tLsW8nZ1IoMDkZlGe7Nm/enJo3b55xVj3b3CXakvidfF8egEnTdzSBZN9fDp7Y9SZPA7B/N2XKFEM+T1cOWHHi40pMktjOlVy5BLqrPWt2l8mVy7/t58ny8XecKMiklddszpkzx9CnDcTaTbMNv4/rTGWZgGpryUP8Uu5qzEk721aexczrhdk/eRff+++/35yFu2LFCkPXM7kOiw2cKMsz63mNNe8C/+qrr+bt+Wx/KWizrQPX2qTcB8PVXjmmu9YVy1hn/176JH/Gz5WD4Ox3vAv85MmTzfWufVmS2E7uy2DfVxus1WJ7bB+ixSJ7YOLbb781ZH/jGHPnnXcasv/JwV0ue2UMgnN/7hOzfAW6z/nkrtMn5HM4vvJAqMxPeF26dnJG2n0s22fPnj2G9j+bfAd/kuYz0rfse8l9TjjXYVtIH+Od3nft2mXI/sl9TVq2A/IDCPQiBDdECPRwQKAnTx4g0ONtB4EeZzcI9OICBDoEOgT6/ycEuh8g0ONtB+QHEOhFCNdUSJ/AIhMF3ilcm/bus/Or69naFCmepih/xzu8827Rbdu29XpeDDT7xO7K7kpsWOTIqYuczHOnYU998q032cnwWcJNmjQx9PGFGGRLqGLICZQmvFzP0fzH5d/82dq1a2nt2rVmOcUnn3xCEyZMoAkTJlC/fv0Mbd9Ny3aus4lDbReyxEKzeejvOFmWU3r5zG8WTY0aNfJKqkPhUz6tvrVBEJ6WL8k20Zb8uBI5jsH2VHc53V373ejRo2n06NFGMHXq1KnCchftfYoVcsCIp71Xr17dMF8IbSOuvtLlDy4fc8VI+7nawK+8rmfPntSzZ08zoNu8eXOv94pBbJxhyvcNXRLi04+yvbSBABZOcuCDz5yXS8v4Oa53TcvvXO/kEuOuPsy1W3zIFHntnjKWsd9dfPHFhvnyu5B2KtuLPfglba0tAdCmwfP7xk5L13yZl0hddtllhvmyHZAfQKAXISDQ4wMRBHq87SDQ420HgR5nO5/yQaD/cQGBDoEOgQ6BHms7n/YCgQ7kCxDoRQitUfL5jT4bQWkdkwzU2iZmSTdtcXVoS5cupaVLl2ZMZ3R1SnwWe1q2c9nMNbVauz7pOeuhHDVqFI0aNSpDKPm8V1q242lcPmXVNg2U5LNBubN6//33DUN8zNd2LNp5kKNv377mOy254funZTtOpGOFuqTdwftOdeRkJbQM06ZNo2nTptGFF15oaL+X9q6hCEm4NYHke348P0cbVHQluq64yN/JJSFvv/02vf3229S1a1dDLjtPTYZA1/Hwww/Tww8/bJZXVKtWLW/PcvlK7ACZpD3d2nfzNp9Bc3vKe3l5OT333HP03HPPUYsWLQz5O9cAdRLb8UB0GhvOSmabNp8vzpw5k2bOnGkGiK666irTnvft20f79u1L3XYy5+I47qp7eyq6r2gP3VTORS1OPvnkk/Tkk0/SRRddZOhzryS2K1SG5ieLFi2iRYsW0dVXX23I32ltPIntgPwAAr0IoTVKCPR420Ggx9sOAj3edhDouQGBHt9e/2iAQIdALy+HQNeeBYEOgZ7EdkB+AIFehNAaJQR6vO0g0ONtB4EebzsI9NyAQI9vr380QKBDoJeXQ6Brz4JAh0BPYjsgP4BAL0JwQ/zyyy8N7UbqWmujNWpfEe6zvixEtJWXl5v1v3LnVJ/yJbGda11f6C6y2hm2WtLjEu+u9at2kiM7VT6XWltH7eokktjOdT6qaz299p38zOV/oZ2bD++++266++67zVr0CRMmmO/s89dlO0piO0n2P343TUym8d4+4tvnObLN8BpgXmPYs2fPCtdrpxukYbcQ+u7vUFns3r07de/enR544AFD+xoZ6zgOFSsOHTpk2LhxY2rcuHHGWuB8IbZ+ffsNl9jyOXXBZ/8SuX6W+4mbbrrJ0Kftp2W7pOvSY+kavPNl7969qXfv3jRixAhDn98lsZ0sN/e1Wj25ziv3eW/525B/wrgGMuXJM7yLuzYwlC/buXJZ14BEGv+IctHVzrS66ty5M3Xu3Nn8E2bUqFF5sx2QH0CgFyG4IUKgx9sOAj3edhDo8baThECPs1sIIdB/34BAh0BPQgh0CHRJCHSgMgGBXoTghrhp0ybD2E7rq6++oq+++iojEeKpdhxQQjs5LXmQyfqvv/6acS7m9ddfT9dff71358LTpGOQxvRE5urVq2n16tXqQIkmxl0B2hZRcldo7uw42Xr00UcNW7ZsSS1btswQd/bggKwHLlcSv5Nli7UdD+LIztyn7n3oGkBYtmyZ4S233EK33HJLxlRMVx0lOZNaq4ukfhfb/l1+J/2I/Y2vGTdunCEnW75nt3OdhoJ3jfdtRy4hsHPnTtq5c6d6YkU++fLLLxvaSylyMclynjTxyiuv0CuvvEJr1qwxzCe4Pf797383rFWrFtWqVSvjNIF8wdVeWYRrZ5Br/PDDD+nDDz+krVu3GvI9ua+NFZJaLGaRIc8859NRZPt2tSO+JontfGODixs2bKANGzao56Yn7SdcMWXGjBmGvBQltE6S2C6Nqee8ZIxtuGHDBqfYz2YT7TrtjHQm73p/++23U8OGDalhw4bOc++1/jqJ7Vz16ks+5YN3ZQ/dmV3La3zIS1Gee+45uvbaa+naa69Vr9P6uWIfzC1EQKAXIbhBQqCHAwIdAh0CPbvfQaCnTwj0cECg+xECHQI9GyHQIdCBqgUEehGCE2dXAJUdvj1t9ptvvjHkaTSvvvqqoR0st23bZmhPt+YEcuPGjeYzFl8yKHNn16tXL+rVq5eZXnz33XerG624OvY0pmn70n5fPgNzx44d1LRpU2ratKnZRGbmzJkV6kYL2q7ncTL30ksvGfJU2Lp161LdunUzNjXbtWsX7dq1S32Oa0p9ZdjO7pBlMtmnTx/q06cPffTRR4bcwWu28+lojxw5QkeOHMkYbHr22Wfp2WefpUGDBtGgQYMyEn7X5l/auaSc+Caxne+mZfY1MrnnpGf27NmGrvbik+hxHfA58+vXrzfT6nhDLm67vXr1Ch4Y4IQi1m7aebTadES7TuXyk2uuuYauueYaeu211wxDfdomx1EW/zt37qQ5c+bQnDlzzFnxgwcPNmQf1e7FYi2t5TxJIX2BfUAODsaCfZsFhCQPmmnT2T/55BP65JNPUnzD7LDbTq72Yw8k8UZmu3fvNraTybfdvl0baGri/dNPP6VPP/00o//lfqJDhw7UoUMH6t+/v6HWT7hiKre1JLbzpV2O/fv3G3LdS9GXtM1u376dtm/fnpHXPPbYY/TYY4+Z5TrcXwwaNMjEXS2eVcY56C7aInnlypWG9erVo3r16tH06dMNY0U/x6P33nuP3nvvPVq3bp0h53E8CCSXPW3evJk2b94c/D75sp3Mme165U06jx49Sh07dqSOHTvSkiVLDF338nk2t0EZG5566il66qmnTF8hl1Fog9N2+0zL74D8AAK9CAGBDoEOgV6REOgQ6BDo6QECHQI9ie18CYEebzsI9DDbQaADlQkI9CIEBDoEOgR6RUKgQ6BDoKcHCHQI9CS28yUEerztINDDbAeBDlQmINCLENraKzvwakkeCzd55iqvr7r44osNb7zxRrrxxhvprbfeorfeeovuv/9+Q97tesGCBbRgwQLq0aOHIe8U265dO2rXrl3GWb+33XYb3XbbbSbA5wqe/Jn2rpV5DjoHQu6IpUDnxEvajpOjkSNH0siRI02yPmfOHBo+fDgNHz6cxo8fT+PHj6dLLrnE0L6X/I53Z//nP/9J//znPzMSmNBOKe3kgc8S9ymHFKfcIUnRx8KZ11jLc9BnzZpFs2bNMj45YMCACuT73HzzzYactNqDSL5lTasD1DrykPWZUqCzr9SuXduwffv21L59+4zBIiYnuWPHjqWxY8dmnCPNu7E3aNCAGjRokPEd25PPPM+194DdVrU1qGn4nJYw2+QESAp0Hozs1q2bIQvC//znP/Sf//wnI8F94okn6IknnjB7ZVx22WWGvLNznTp1qE6dOhlxcNiwYTRs2DDTNqTQdZWZ1xCm1V6TQpb7vPPOo/POOy/DPxo1akSNGjWiRx55hB555BFzTvnDDz9sBuC4TcvfnX/++XT++edX+Pv8888350xPmTKFpkyZkhEzKhOumOCTlMsknAdymzVrZsi+KPdiYXLfwTFS/q5Vq1bUqlUrqlGjBtWoUSPDrmxzHtj1jXX2buH5WAtcUlJCJSUlznJwXyv7tyZNmlCTJk0y3pPb3sKFC2nhwoVmf4RXXnmFHnroIXrooYdM7Lv88ssNWUBym5XfsRhfsWIFrVixwtt2LqZluxBRzYJ48+bNVLNmTapZs2aG7Vq3bk2tW7c2Psa5yPjx440o5VyP/yFQt25dYzM+y1zmPBz35s2bR/PmzcvIL11ldQ2Qp2U7bWAqm//LcvMgOPer7du3N3mY3MeGyXkx53qdOnUy5JyQYxvbuWPHjubUIu5ztH94hb4XUDiAQC9CQKBDoEOgQ6BDoGe3FwR6ckCg6zEBAj3cdiUQ6NG2g0CPtx0EOlCVgEAvQvicKSqnl7umw/A1coo7T/caMmQIDRkyxASWq666im644Qa64YYbzDRHFuoLFiyg0aNH0+jRo03ACz1PnKd/alNA00pafZIr1zRkOd2QbTd37lxDDtAsijjBaNKkiZlie9ddd9Fdd91FzzzzjCEnFrzbqna2ukb2BblrqM/vYhCbqPDUTSnw2IYsYiQ5eeCEs0+fPjRx4kSaOHGisbP2u5hdU8vLy+mzzz4z9Lm+Mm0nRS6Tl5CwH911111mAIMHyVhwN2jQwOwGO3ToUBo6dKi5dtasWSax5aUc2lRbn92etTaTL4Fus+R/yX9JDgHAZeEBoNWrV5tBLx7kkdMzx4wZQ2PGjDHTEGVC5iO4NbqS0rR9Lk3wKRVyijvTHmSsVq2aiX+8FEdezzFP9lHM2KUQaUOrg9gzknkJlxTh3E906dKFunTpkiHC2Rf/7//+j/7v//4vo5+YNGkSTZo0qcIJHzFxz6aczp9kl3yfZ8mBbju+yKnjHIvkshQegOBchIV327ZtjeDh/nTx4sWGLIK4DYbmJ67TQbRlCPmynS95+Y2c4s7kgQk+GaFWrVpmQJZ9kuPeU089ZQZp5QkKrinYms2y2U4uX0pjGZmk7Vuu3eQluT/kfwi89dZbJj8eOHAgDRw4MEO880Akn5og82n+JwO/m2tphJbnhp7PDhQOINCLEBDo8YEIAr3ykwcIdAj0WNv52KgEAj3vgECHQE9iO5sQ6PG28yUEOgQ6ULWAQC9CQKDHByII9MpPHiDQIdBjbedjoxII9LwDAh0CPYntbEKgx9vOlxDoEOhA1QICvQjhasxMLTn26WgkQ9ftVjaT2E5SCsds62ulrUN27oylFsRdiZhvEGefiIHrvdmfQjuTUHtUpb9xMpeW39ntUxO5bPNcu79zYq3ZXibecpd8WZch6+GztR2f69OwG/OLL76gL774IuN9ONGLFcK+dLUFH/+X9SHbzLlz5wpmDXoxw1V3Wv1WRp+Qhm/Knaq5jbhOzUjbdnzSgfYdr9mXn4XG/bTafZJ+LInttPJznAh9t5DBB/kc15p3134F9vvHtId87eKunRTEtPeWyFZu13d2H+ibL/rYSQ5gZNujKenAEJAfQKAXIXwCIQS623ZacIVAdwMCHQLd1XZ8rk/DbkwIdCBfcNUdBHq87SDQ3YBAh0C3CYH++wUEehFCa8R8LrFPp8KJ7RdffKF+n9aUOS2wp3nPGMSeA+qia6pcmoI1RAjlCvZp+V0sfToml/gLTQLSHDSIgcv/fZJQbaq7tIHt164BOtd3GjmB0Xw59F6xPudb33wN29uV3OTbfzW6/MD1HVC5SDogmOZArpaEJ036fRmDpG2JxdS+ffvUftVnajVTi08++U0a9VcZtrOZS2Dbfh06zV+jz8BBrnJVpe24nrdv326otX9bcIe2yzR9S2OS3A7IDyDQixBa44RA9wMEOgR6VfgdBHqc7ULrGwIdSAMQ6PF+l7QtQaDHEwI9nBDoQL4AgV6E4AaZpvjTgoY2LSjkecePHzfMFsgquwOMHXxwJc/au2jvxvdwCW256Y9PWX02hNM2nEvidy4bpNnhaPSZXpqvafb5sp2LaUzZZIHt8jvXND/X1HoXtQGWWLtp5Upj2UPag2eafX3PBWbKZJZjBlC58Ikl+Uq0Q/xV863Q6bUuwZvEdlVJ3+Vgtj3T/EfC79V2TNc09lDBLekTt5PYzjcf8/ku5rpstnL9nm0SOhCt+TBQOIBAL0JoHU3SYAyB7iYEOgR6vmznIgR69jYGgQ7kCz6xBALdbbuqJAR6ckKgx12XzVYQ6MUHCPQihNbRJA3GEOhuQqBDoOfLdi5CoGdvYxDoQL7gE0sg0N22q0pCoCcnBHrcddlsBYFefIBAL0K4Oh2tcfPaFF6nrv1eimmfoBOyDkyWz3UNny28fv162rp1K23dujVvQVyjJnbTWPedlK5z7O2yf//99+YMTzv4y04xbdtpHXmIKMlFlwhPKmLlWjI+K9d+rnx22rbT6il2V3UX83FPSR8hnw+7SfLZv6G/27JlC23ZssV5jTbQ5eOruWifAaz5BFC58Kk3KY4PHTpEhw4dMt/Jtb2xA1xJ46e2RlbGTZ9+JV+2k7TXQHMbztWO04xnoQN1Pn1O2razd1mXO7uHnqISsk491/WucrrKXtV+Z7OkpMTQdZ1Pe66KwTusQS88QKAXIVwdDAR6uO2YEOjxtoNAj7edVk8Q6P52k4RAB9KAT71BoMfbThIC3c92EOjp+p3NEgh0IGVAoAMAAAAAAAAAAABAAQACHQAAAAAAAAAAAAAKABDoAAAAAAAAAAAAAFAAgEAHAAAAAAAAAAAAgAIABDoAAAAAAAAAAAAAFAAg0AEAAAAAAAAAAACgAACBDgAAAAAAAAAAAAAFAAh0AAAAAAAAAAAAACgAQKADAAAAAAAAAAAAQAEAAh0AAAAAAAAAAAAACgAQ6AAAAAAAAAAAAABQAIBABwAAAAAAAAAAAIACAAQ6AAAAAAAAAAAAABQAINCLEOXl5amxpKSESkpKMj4rKyujsrIy+umnn+inn35Sf7d161baunVrqmWR/OWXX+iXX36p8Dz5zLRsd+bMGTpz5oz5e9++fYauMp47d47OnTuX8dl3331H3333HZ0+fZpOnz7tfDe2c1lZmZdNXPWh8ezZs3T27NmMz/i90rLd0aNH6ejRo3T8+PEK9Hk3aQP+3alTp+jUqVPq9fwdP/fo0aPOe/o8W3528OBBOnjwoKk/9o0zZ87QsWPH6NixY1G2+/HHH+nHH39UfeXEiRMV6Co3l0N+tn//ftq/f7/5+9dffzW0bcbvls0/s/krl/e7776r0D41fv/994aHDh2iQ4cOpeJzdr1xu8jVNlzXcP1I3+H2w7/T/Cq0TbrIZZDkGBODH374gX744YeMcttty9cXXNf8/PPP9PPPP6vX27HVl1oMcMUFzXb8HVC5+Pjjj+njjz9OVNd2W+e2aPdn5eW/9cOyL96+fTtt377d+VwZ233KKcvg6l/WrFlDa9asibKd1pbs9+Zr7Ot82qX8bbbf29fI63zifi6y7VzPiYHLj7ie+Zps1zE5dmr1wH1aqC+nSa0MbFegcACBXoRwNdxsoqW8vNyZ/Pt2gJz05zsA+TAGPsJbY4kykJHNXr8HpuV3sR2SjxD1Fawufw0ZAMmn7TSB7kMtIdKSB05AtEEjpo8tpNh13cv1W+05/F0oNAHM7+ojuLUyhNaBT935DhJUps/Z9V5WVmZs53onLXnXfC7UP7JRDuTIgaWQfiZNnwOSIdYPXH2JzE/swSvXPV19gWwXscxXm5XktuAjynO142zXhNw3bWoDLDFw1YkWv/JBLsPJkycNXde7xH4sgcIBBHoRwtU4IdDdgECPt512Hwh0P0CgQ6BXts/Z9Q6BDlQGYv0AAh0CPYntINDjbQfkBxDoRQhX44RAdwMCPd522n0g0P0AgQ6BXtk+Z9c7BDpQGYj1Awh0CPQktoNAj7cdkB9AoBchXIGBE3oOSFpQ8u1gYq+PDWqha2OT2C5fHZNP0qCtIU6Tu3fvpt27d+fNdvmiLRq0jtvHdtrvmFL0c/1L/+Z18IViO63d2WJLW0vJcUDudZCPOst3m+Wk3FWnru9y2TLGL8vLk68919ZKu66LQT4GU0P7Aq0PshNX1+Cwqx/TKMV+rM8ByRDq46F0DYxzHHC1T/ufDVob0fID1/plGYOS7Bvhen5lUXuuq83bsde1tlx+71rPnsR2WgxwMXagUYtb2vuG/BMjNN6lZTsgP4BAL0JojRICPcx2EOjp+F2ahEDP3ja0zyDQc9d3LupsjJcAACAASURBVFvG+GV5OQQ6BDqQDaE+HkoI9PwSAj3MDyHQgWyAQC9CxAaPWC5YsMBw3rx5NG/ePGrTpg21adOGrrnmGkPX8+wALzvHDRs20IYNGzKSv8OHD9Phw4fVe3HwTct2rqlvSW23atUqw0mTJtGkSZPoiiuuoCuuuIIuv/xyw8rujGOQjyn9LnElO9qOHTtSx44dqUWLFtSiRQtq3LixoZ3whyY3Usz6XJeW32XzvzT44YcfGk6fPp2mT59ubCcZIq6TkHfHj7VbGgmrj1iQp0WMGjWKRo0aRQ0aNKAGDRpQkyZNDH0Gcpgy1oUK+yTTtPkerr5ATsX08UOXqJG269GjB/Xo0cPYq1q1aoYhybMcAApNXDkx/j1g7969hoMHD6bBgwcbe9WqVcuQT1EoZKQZN3zqXC4vWbRoES1atMjkJDfddJOhy79dPhkq4LitVYbtfHZj19ov/8151uHDh6l///7Uv39/ql27NtWuXZsaNWpk6MrHfOJFaD6axHbawBDXvW85fKany8H+nj17Us+ePTP6CGZIvNMEuu+SH65voHAAgV6ECOkkINBz2w4C3Q8Q6BDosYRAh0CHQM8OCHSdEOhuQqBXtB0EOlAogEAvQqTZAfoE16lTpxqyMOfkYdCgQYaLFy+mxYsXV1r50rYdn9UsA2Jo52xPZ3rssccMWZhfcMEFdMEFF9B1111nyCKqkG3n2rCNp1hLUW1PR5cDH3yNFOhsf77+wQcfNLQT/fbt2xvOmDGDZsyYEWwDLWFzdYRJOkBXgsD3lX535MgROnLkiLGrPF9eE3l8z5L/bWb4j3/8w7Bly5bUsmVL6tChA3Xo0CFjcGP+/Pk0f/58p5206Zsh8UPaMxTafTn5YjvIhMwlgF1nHvPvR44caVi/fn2qX7++8bm2bdsaTpgwgSZMmOC8l68f+oj2GLjuF1pGn4GcMWPGGF5yySV0ySWXUNOmTf8fe18ea2WRvK34SVQwCE5YJGwSCBAIEgwYCAYIBohEjcAF2UEh4u4gYhRQhIgIIxEUIjMGh4BORg2oASaDC6uiKIIgguxwWRRw3HGUS31/zO9p6vSt06e73/fce/DUk9Qf97xbv/VWV9dTt7uaGjRoQO3atTOC8cLVx1x26LK1tHRX0eDj6EUXXZQh0OVVV11F9913H913332V3VwnQpJXMWJ/64ULFxopKSmhkpIS02cffPBBIytXrqSVK1c6k7G+heCWLFlCS5YsqdA+K00dDyXotowYMcIIiHm1atWoWrVq1KxZMyOjRo2iUaNGpfL9XP04yRgr3Y8vS/jhhx/E8Veagi6Rah7bfP/99xn+jicz6tata8baDh06mHPyrTstill4UIJehMjXwJdtIFSCrgSdSAm6EnQl6ErQs5+jBD0eStD9RQm6EnRf3SlBV1QmlKAXIfI18GUbCJWgK0EnUoKuBF0JuhL07OcoQY+HEnR/UYKuBN1Xd0rQFZUJJehFiNgO7BKpEjTWwgwbNswIAtR169bRunXrRAchOTR7AIx1TEn3ynTdL03BmtvrrrvOCIIGrInj52PNk4tESBKrz7TtLg0BoQdRtwPViy66iF577TV67bXXMoITe/D10VdMnQEEhmnrLml1cU60jhw5QkeOHKGbb77ZSKdOnahTp04miOV93VXp3RXg+exPj7YcOXIkurJxqE5c/celZ6zt5bYGgj5v3jyaN29ehr6xJlO6p08QVVn91UVkY+sR7Ny5k3bu3EnXXnutESTUULuE6w42IfVJ/CYFzT7VkKVK24UMrNnnwT3sD4lHJOtOnDhB+/bto3379lV2s51wfR+fXThC603wRDcI+pYtW2jLli3BtuwSV8wg2XAMfMg3J5mxdTlgRyDj1apVM/EJauXw+A193HVPnzou0nnSuyaxO1e1fembheru6NGjdPTo0Yy6GpCJEyfSxIkTM2pnIGGVj1oz55u/KzYoQS9C+AwioR1dCXq6ogQ9XJSgh+lLCXp5UYLu1p0S9MKCEvTyogRdCXoSu1OCrigUKEEvQqAj8mmvaXZ6CIhlw4YNjaCKu3T+rl27aNeuXeZvqSKl5KTsqc2+kkR3Bw4cMJIP3TVu3JgaN25MtWrVMoLp2vl4nmsgSUt3CO653dkBi8smfaulY7Br2bKlkUcffZQeffRRsbqq/TyJuCIA4DbpM2BK75PE7lx9glfUxTGfPX+5/jHtn+8QMG3aNJo2bZohr64AxrdirEt3OMYDL/wWCl6hORu55QkH+5xcezGjXSBHPNjC1FjX9T5TxUOnovJ3TaMitKSD0B0ZJHuB7jB1netu/PjxNH78+OA95PEcl5/gdm/rjgfGSXZdyDegA+wQwBNDI0eOpJEjR0b3mcpGKBHxSZRLvg62NmTIECOvvPIKvfLKK159z+VTfEUa6/K9D7rvOCoJrrv00kvp0ksvpYsvvtgIdq2Qnmsvw3L5+9A2pTFOEFG56ezS+Mb9Q+w3v+yyy+iyyy7L8HcTJkygCRMmmOfyhA3Ge59xVdIr/832p9L7KAoHStCLEPbgoAQ9XHdK0MOhBD253SlBD4MSdCXoLrtXgl54UIKuBD1ElKDLogT9/IcS9CKEb2eG2PuM53IMIEGdO3emzp07mz0eb7jhBlq9ejWtXr3aqw18j91s5yaZ8pOW7kKcJR/Upem0x44do2PHjlGbNm2oTZs2GcXMcJ0UkNgDLp/WaDtj3+/nmu6blu7wDIkAu9ooDVZLly6lpUuXUtOmTalp06YZA+D7779P77//vjmX70Fq39vVBt/gRrJNvGvadof9j13n8HZL77Zx40bauHEjNW/enJo3b55hd6WlpVRaWiqSMtiiVHAN59jXZyN2tl55H0eyKE29xe4pzn9777336L333itXEK5KlSq0e/du2r17t9e9Jb0lDf7z0V99xNfPbN26lbZu3WqSG3Xq1DGCaexSP0Lfh71IQabvnueuPYYLeR/0zZs30+bNm8VlPOfDNHYXQu3N9incbxw8eJAOHjyYcT78Pqa1c1+3Zs0aWrNmjTO2iN3T2+X/pHElie58C8HZ5+d6h/Xr19P69eupRo0aVKNGjQx/Zy89kQR9V2qfT1zjeyyJ7iRfHLp0UJLly5fT8uXLTcFGrrsPP/yQPvzwQ/E62xalZJPPlPxcfjFJMleRHyhBL0L4OAEuStDduvMRJehK0JWgK0HPJkrQlaCHQAn6OVGCXl53StDjdacEXVEoUIJehPBxAlyUoLt15yNK0JWgK0FXgp5NlKArQQ+BEvRzogS9vO6UoMfrTgm6olCgBL0IkZTY5lp7tXbtWlq7dq1Zgw7C1LRp06xOh/8mkS84D1fbfSurIyiLgeu+rrb5Ovi5c+fS3LlzzZ7nfO/kbM/jz8TfvAI2CJL0PAQbqEJ96NChjPva74N192nrTtKPy8YkG0GVcezbjXVdEyZMMO+CKsDS+0nrAV1Vg+1K3Ln6FBIfaesOElq9mPeXyZMn0+TJk00/veWWW4z49P+TJ0/SyZMnvX2I3a9///130y8lW4gNHnCd1GbJvhD02YmHbD4PervyyivpyiuvpFtvvdWI6715EMj3X8/lW6XzXOvYk+xt67qva025tGewRNqxRh+642uBfXSHYJPr0bWmHOfwNaaugBX3KkTMmDGDZsyYYQL8O+64w8j5DsmHwY7wDX19LnZD4bb4ySef0CeffGL6KSdK2cYZae0vKpPv3LnTtEUijai0z3+z69fw/ox7xiB0LLDXf3M9Se8yadIkmjRpktnz/LbbbjPiOzZlE9sHc5HOl75Lkj4buwbex0/+8MMPtGDBAlqwYIEh6D179jRifw9eAR9jEf7m/0BwEXOcw8d5l98r5IRksUIJehFCCboSdIgSdCXoStDPPUcJ+jkoQVeCXhlQgq4EXQm6EnSFEvSihI/T8a3GbDuWsrIyM9hdf/31dP3112cMPnAU9v7JZWVl5Ui4NAhjqit3UqHVLSExcCUA4OCS7JGOwQ6VjTHl/dixY6ZavaQnu5K9pDu0ae/evUZAyitCd6774Z2kSuS+MmjQIBo0aJCxP0wpW758uSHaEARux48fd+5kgEEb5JoPuD578krvk7bufCTX1PwxY8bQmDFjzFRt/p524MLfCWTaTq7x/ojrQeJPnjzptUyAJ41idee6v5QI8KmqzoPYBg0aUIMGDUw17Q0bNhhxLWXxuX8oea+I/prGVE8IdAabw/Kn1atXl3sOt0f7G7nGKj5OuKbeu4LzQgFPNmC/eExr3759u5HzHS6bcVUBt0ky9y/cZyGRcdNNN9FNN91klqm899575vzYfdDRhk2bNhnZsWMH7dixw3mdFDPEQPKrrqnuPqSUJ8BatGhBLVq0oOrVq1P16tUz3jPb8zjxl86xkwSh0/Pz6e/s7yP5aR97KCsrM8Qcwv2dXT2e+zRXEtE+hxN7n2nv0nI+ReFACXoRwsfBKUGXoQQ9PwOgEvR43fmIEvTyogQ9XHdK0CsPStCVoOeCEvR0/Z39fSQ/7WMPStAVMVCCXoTwcXBK0GUoQc/PAKgEPV53PqIEvbwoQQ/XnRL0yoMSdCXouaAEPV1/Z38fyU/72IMSdEUMlKAXISQnbhNnqTOD1EnHsM7qyy+/NEFrSUkJlZSUZATacLj2+hqJzLpIBV9jHbumPgY+FbO5ZKsUzgUVtDdu3Giqt2NtkqQDqQ32bxK58dUTEgK2bSQNHnAtCHE2Uhwijz32mJGGDRtSw4YNqUOHDtShQ4eMAQ/ng1Tzd7J3CnDtHpAkgZBEdz7EkRNgn3Z88MEHRtq3b0/t27enbt26Ubdu3TLIoB1ASffySZKhFkK2eggQe31mEt35EFqQQU4IXTURZs+ebQTrp1H3QLJtnzYkId+2SFWIY+BTjd13LTD64fTp043wtb9VqlQRdefTBtcYwgNW6VrXWk4cKxQsXrzYCHRWs2ZNqlmzZoa/P98h9b1s/ph/f5dNwqccOHCABg4cSAMHDqSxY8fS2LFjxf4Pgs4TuSF9kJMv/JZrF4ukvo7o3DpqTvDs+IETXxyT/DeOvfHGG0Zgd4jxpPFQGifs7yHFNa7kQq7f7OekZXc+Ivk/+HLUiuD1Ilq3bk2tW7cWfZPP7hOuXWa47YcmN6B/ReFACXoRQgl6/ACoBD1ed7hWCXo4lKDH6U4JerzNKUFXgl4ZUIIe32eVoCtBV4L+x4ES9CKEzyDnckB8ijSumz9/vpFOnTpRp06d6KGHHqKHHnooero8/82e1o29Xvft2yfeA9P9pGNJKn2GOu9s5JqT6b///e9GMLV9+PDhNHz4cDN1nU9fx/WSXiUi5xPAuL6DFFgk0R0nkgjIfRIZUgA/b948I6hAPnLkSBo5cqS4P7JLfJYl5Nqn3f7eUpvTtjskVHy/KwRV7xcuXGj2Ab733nvp3nvvFc/fv38/7d+/P4MQ4XlSxVj7+thgl0us3nhfCZkuLp33+OOPG0HQhYr3Ejm2+2auREu2avPZ2mpXhOeEA5KWzeF7S1Mx7XOl/jdz5kwj1apVo2rVqlHz5s2pefPmIlHyIdc+fTpXv+ZttdtcKBg/frwR2F2XLl2oS5culd20VIGx5u233zaCb4FEtutbYk/pDz/80Nxr5cqVRqA7JIpc9+JjH2x/27ZttG3bNtFeIZ999pmRivJ1RCS2266Ezp+RbTkSP++JJ54wgj6LGC/JNHSI3b5cy7HQn6Wp8HifJLqLFekfAtzfYWo7EkTS+a7lnS77xN8um+R+Lm27U+QHStCLEC6nJx1Tgu7Wnc/gg7+VoCtBT9vulKDn1psS9HRsTgl65UEJuhL0XJDarQQ9THexogRdkTaUoBchbOf822+/mcEkdprlsGHDjIBkYsp76NQuXxIOkabL285N2nM4BgcPHqSDBw9668WeLi5J3759jYAo2furcqKMqf2SM5YGS3vKcC7nj2N4TlpOXCqqZpPL0AJ7PXr0MNKkSRNq0qSJsWWQfk7805pan0vspAr/LQawcR68QJ+xfZbv2Y3iP9BdKNn3tS0fwVTdNJZWSITYlSy0dSmRavTRtm3bUq1atahWrVrlCsPx/cl99jXnv9nP8yX2LomBNO3b1Q47+ONkF2S6c+fORurUqUN16tQxpIuPR/a+va4xRHpOqH6k63DPQgGmFTdo0KBcIcw/EtatW0fr1q0Tkz+wi9Ck//3332/kuuuuo+uuuy54uVo+RXqfGISSZZ/zsYyiZs2aZv9zTN+X9irH35L/9pmyzgm3FAv4FBiNgeTvXEsr7PO5H8IYiERGp06dDEH/+OOP6eOPP864F97T5b9wb7ugXLZCcLFT9hWFAyXoRQhpUFCC7gcl6PFOXAm6EnQfUYKuBF0JenkoQVeCngtK0NP1d0rQFZUJJehFCGlQUILuByXo8U5cCboSdB9Rgq4EXQl6eShBV4KeC0rQ0/V3StAVlQkl6EUI2/mdOXPGSaBth7j//9ai7mfrUTnJRPDw7LPP0rPPPpuxzyh+wyDJCVb37t2pe/fuZp9S7Hl+9OjRcm3yJQKSgwfZiUGa+wBD+vTpYwS6mzZtGk2bNi1j7Rx+wx64IAe1atWili1bUsuWLc3erl999ZWR2H3iJUKNASEG0jPs9VahyZxrrrnGyGWXXUaXXXYZTZgwgSZMmECvvvqqkUmTJtGkSZPM3ssXX3yxkRo1alCNGjXMN8Aaw23btkV/U0l3qHablu5i+wSkf//+RrCvLfT0r3/9y8jgwYNp8ODBJsCA/XHp168f9evXL8Pu0uwj8AOh8En2cALsOh9k+pJLLjGC/oq1+3/729+M3HfffXTfffeZfb55xXL8huDto48+MmJ/w1zrPH3W1MfA9Uxei8EOKl1BI96b6wM1I3iV8nHjxtG4ceOobt26VLduXbP2tVq1asYOu3btSl27dk1lva8kSXxdPlC/fn0jF1xwAV1wwQU0dOhQGjp0KD3zzDNG8Bv0i3MvuOAC8xvW/a9atcoI7K6yAf1LBA82zomhi0RhLHnggQeM4N1ha59++qmRl19+mV5++WUzFmC9MJd69epRvXr1gnf0CE0+x8DVZ2PJO8bHGjVqGPu588476c4776QXXnjByJgxY2jMmDGGxNu7NFSpUsXsFsKr3NvryEPbJ/2WxO642P84kM5xxYSSDuDbuL8bMGAADRgwwPRv7ifh75DY5GNFUt9WyP5OoQS9KKEEXQm6jyhBV4KuBP2cKEE/J0rQKx5K0JWg54ISdCXoIb6tkP2dQgl6UcI1eODvzz//3IhdSVeajoU9z0tKSgz5xjRQ7K3crVs3U2m7d+/e1Lt3b7rrrruMIOC64YYb6IYbbshwaj7VW10OKO1K5Fxip5+iPdjzvGfPnobwXHHFFXTFFVdQo0aNjNjTG0eMGGEEU5QxALZq1cqINKXKFmnfdJedpKU7W0KDHlQx7tKli9mLGvrB3/y3iy66iC666CLq1auXEeyfDsKOqfJNmjShNWvW0Jo1a5xtkCq1o0o9tzsEkpWhO4nA3XjjjUagAyQ7sJd8hw4dzG9IboCwDx48mJo1a0bNmjUz1/Pp30jKuRIufJqevRwhjT7r6q+wZa4bBP2uqec8KYQgCnbFfRb0hb95Ik4i7fa05VB/4vIxaduc9E3tatf8GKZnwj+1b9/ekG8EoNBX7dq1TaAKnWC86N27d7ljPJhFUslXPz6EqVAgTXGH3bmE92XXeYsWLaJFixZV9muaPphrxwxbkBiUiDB2WbjlllvMeIG+OGTIECO33XYb3XbbbWYXlccee8wI/pGAMYWPsZs2baJNmzaVW2LH+4HULpwjVS5PojuuF5vISs9ykV3EFi1atChH1F3C//liX8cTbkuXLqWlS5cG+zYXoY+Ba/cgl+5cU85537P9Fpcrr7ySrrzySvM3/4cXlgJJ17377rv07rvvButO6ldJ/nGlyA+UoBchfAIVJej+ulOCHq87W5Sg50d3StDL91cl6PE2pwS94qEE3S1K0JWgJ9GdEnQl6IUGJehFCKnDuqbGgnyAlPMpoXBgfLosppAhoHruueeMoCiYNC0Iv2HPTdynefPmZiqoRCJxnTQowomDHH333XeJSCbe1zXYuhzjfrY8AL9hWvpNN91kyA2m+z/11FNGUDBPKnSGKdWzZs2iWbNmZThx3NOHgPtKWnZnt5//duLECTpx4kQ5O+TvjqRO165dzYAP8vTwww8bQfAmFR1E8bYpU6bQlClTMnSHhBIKHkpt4GInrqRCdTGQbMsnAHQJTwwhIYHk2kMPPWRk69attHXrVlq/fj2tX78+4x7//ve/6d///rfp61x3SDbZuuf6dxV2hK/g/iLW5jgJx72kpR8+BdratGljBMWTQCzHjh1rZMuWLbRly5ZyRRrPnj1LH3zwAX3wwQdmWqgUrG3fvp22b9/u3SfTnuIuFd9M6je47kDQ8d5YJnDvvfcam5MKVZaWllJpaSk9+uij9Oijj2YQV5B96A7vkG0vddsO+W+FNuVTIuiwv0GDBhlZu3YtrV271uiAJ7rwG+xOIuqwzcpCqE352CaWzd1xxx0mMYulFUhMLFq0yKuI6Pz582n+/PkZfRbkX5puby8j5PEDfB6f4p2EKOGZ0pRxn+JqEgHlcRimr8MOuV6RpMA/dvj74hiWGXDdITEuLVPxWZ7H3xVtj0Goj7O/tUTQO3bsaAS+CcsReeHCHTt20I4dO8TChVgKAH/HdYd77tq1i3bt2pWzcJzLFpSgFx6UoBchpA6rBN0PStD/J2nZnd1+/psS9HNQgq4EPZcoQVeCrgRdFiXoStBzQQm6EvRCgxL0IoTUYZWg+0EJ+v8kLbuz289/U4J+DkrQlaDnEiXoStCVoMuiBF0Jei4oQVeCXmhQgl6EcHXc2D2MERSsXbvWkOm33nqL3nrrreiBdvTo0UZAJODIpIHEJWntMxqqF5dg8OJrerG+DdXHXd/IVfEcwcfIkSOpdevW1Lp1a9q8eTNt3rw5uJ3SYB8DKfjBYCLtG+4jPKhHFXcEUPw8e80VJx12IoCv/8LauXfeeYfeeeedjHva1/Fvg2N8XTjIZlp2Z/dVnqBykTWcwyu1Yy3lkiVLaMmSJc5kl6sNfF17u3btqF27dmYtOr8n1ujze9nV348fP24E3y8UrnWKUu0IV0VenP/iiy8aQaA0c+ZMmjlzpvdzIAjyeLIkdi26nYDg75GWzSUVvrMC3nPOnDk0Z84c8XyfNci8ngTWeSJx5Psd7OfxZxYK/vKXvxiB7hC0hwL9gtdTAEFHZenKgl3LQIpH3n77bSP2MWlc5JX+kciIXb+LNvEEMAjs3r17ae/evWJSi7dr586dtHPnTudzYuDyd4h/pL3LXe1A4nrKlClUtWpVqlq1Kk2cOJEmTpzovE6K0aC766+/3ghsedmyZbRs2TLv72CT8qTr913ENjQuRnuwK8DLL79skmn4Z1WsD+X/0EGtIoyxvraLd00rLlbkB0rQixA+HTjUaShBDxcl6ErQk9idEvTcUIJeGL4OogQ9HkrQz4kSdBlK0ON1pwS9sPydQgl6UQKDhO/0P58A55NPPjGCacGPPPIIPfLII9GOCGRhyZIlZpqQNM3WHoCkKVFpkUzJUdvTMKUAQZrCDeH7WqLCMch1rO4WLlxoBPfEXq++99hvTcXnDj4G0AGf9m1P+cM5XFec5ELQjn/+859GEJxjGp40YOJv17TdZ5991ggSJuvWraN169aJNiYFkngHPkUaBCoGeG9ux/YzpbaB4ErfFwmbzZs3myAdyQ5+nj3tjr8v1+OZM2dowYIFRkD6YdvoJ7yv8HshuJWOxU5dxL2kKvb2/uHSMakvr1ixwggSOJjiKvkjH1/KlxQg6HrzzTfpzTffzNlPXUmZJFM+XXudQ6Qplfhb6hcgRe+++66Z4i7pzkXMUREef/M9wLE8wJd8ufpQoU355Psmg9SgInksJkyYYKRQCLq9JMj13fi3g82ArLz33nvGL+1nS8tgb6jO7rIHSeB/p02bZqRfv37Ur18/k2TE7h98BxDJn2Hqt/ScGNh7ivN4B3bN/bUPQUeV9aVLl1L16tWpevXqZpmKazySdIa/n3zySSMYr0HQff/5knYVdx9/J8XMOFc6hkThv//9b7MMCsvIpPv62B9P1GGpQWyySVpipigcKEEvQihBj3fiStCVoCtBV4KuBP1/ogS94qAEvfx3U4KeCSXo8bpTgq4EvdCgBL0IgYISvKOiCJY0mBw9epSOHj0qOg/89uGHHxrBFPdRo0bRqFGjggda/I390G+44QZTCEwqnBQ6/QiOPQbS/fZbRJYPMD5tw7T9HTt2mOnoKLwiOVPXvfBcXjwNxbqkKbOxxZ9iIO3R7SrK40pqQDjJxF7ct956K916660ZtmUH9TwQh85ALPje6iiehiJC/NkgbjypgKnb0nePLXRGROUKHJ45c8ZMmZf0Ik0htwWFuLZu3Wr2uR06dCgNHTrU2S+57vAbnsf7LEg/ppbaZD6b3bn2TQ8FSCtPlNjTv6V3dQkPvrH/Nqb1+/RNHniCjPC9hkGUkCTK1R7XcoYk/RWBJyfhtu64Xn2mo/NxwkXQfQodoU9gKUW7du1MwCotSYmVQgEIzLJly+iCCy6gCy64wOyxzBNJPkDSrV69ekZA+iuboEv9LOk3xBKqr7/+mm6++Wa6+eabDUGPLYLIC/Nhv++DBw/SwYMHM3yK5FvgP9NOqvnsg85tJRuZ5/LGG28YAZnG+7qeIwmWfuGfOE2bNjV2Jy1Ng/Bv5EPeYwCf4yLooYKCix988IH5BwKWz4XeC+3DP1zat29v+u6qVato1apVfyh/p1CCXpRQgq4EPeSeaTlxJehK0JWgK0FXgh4HJejxogRdCXouKEEvLH+nUIJelFCCrgQ95J5pOXEl6ErQlaArQVeCHgcl6PGiBF0Jei4oO0BovwAAIABJREFUQS8sf6dQgl6UsNecSIMI9vDdsmWLuBctBNdxJ48qlajSydcwZbuePxtrMfkekqhw7FpT6wq0pWMxcDk23J8HrbbukOw4evSoeI958+bRvHnzTMDJ15K7iAsEa4i5E8cAuHv3btq9e3ew7qQAJgYuwo1jfJ25Td6lPcW5zJ07l+bOnWsGfl5tG2TWlWRCUkQKHrZt20bbtm0T9SStm8e3kvZNj4HUbruKPPaHLi0t9VrHKekOpJqvd/W5fsSIETRixIiMqtAgS/v/L4HF7chlywheQcD4XrOh8Gm7VCfAV29Tp06lqVOnGqI+Y8YMI64gD74Suzfg+j/96U+mUjLW7vu2BSKtqY+Bj6/jft9OguXakxd6wl6+s2fPNuLyQbAPJJMkkomxK1R3adUqyTfGjRtH48aNM8kc1Ht55JFHjH4koD/17t2bevfuLe6DjvWslQXJN9iJIcmv+gqSN0iq8boI2XwRryWBded8x4qBAwfSwIEDxX3QIVKCLs1kJJFM0G3bdv2Wi6xPnjyZJk+ebIj6E088YSSbjygrO1cfo6SkhEpKSsz1l19+uVnX7qri7mpXWn3Wx3ZcCUlO7KXxGjt9wN/xWjcuu4GNoC4RxtUGDRqYe6FSfGhfkHy0onCgBL0IoQQ9v0GrEnQZStDjdacEPU53Pm1Xgh6uOyXolQsl6ErQJShBz4+/gyhBV1QklKAXISQH6tOZc03bsp0YAig+3RqViXEOSMaJEydo2LBhNGzYMDOtmO8PvnHjRtq4cWO5qfhJJInu0hBMMzx06JARHOvTpw/16dMnY/omCBP2l+f7RGPaHnSHaaO33HKLqSJqB9CVpTs+xc5lR65p2q7dB7p3707du3enOnXqGEFl8T179tCePXto3759RhDUN27cmBo3bpwxTXvlypW0cuVKrynjXEDY0yJL0hRMab9giE8yR5Ju3bpRt27dTJXeNm3amJ0UkFji1dj79+9P/fv3N3aHwL937960YcMG2rBhg7i0weVfXMFKKBCw8sAqzT4MwTISTrRBQLGkCL7ryy+/NH0alX1x/bXXXkuvvPIKvfLKK8HTbl3JhRikqR/X3tZYEoVgk5N1TBlGdeyvvvrKVEG+5JJL6JJLLqHOnTsbwVTcNHwd2lmIAGGFz+IEG0QdSUW+S0ijRo2oUaNG5lxc37hxY5Okq2zYNsN3+ZB8nW1PuaqA49jdd99Nd999tyGNJSUlZjoyzuH+G7HIgAEDaMCAAXTXXXcZ8dnXnItd+Rzj0p49e1Lps7mIto/Yy/T48iaMDdjFokaNGqYqO/4R8PnnnxupVasW1apVy5zLx5fp06fT9OnTvRII0rG0CXpoXBwqWD4n+TvEgdDh7t27zViBKfJ8CR78nZQIdY0fSCTAj/Dkl6JwoAS9CBHriJSgK0FPQ3dK0MOhBD1Od0rQC8PXKUFPF0rQlaC7dKcEPV53StAVhQIl6EUIH5LLAyL85pp6KgU2EAxoAwYMMNNfMWWdCwI17GkbGkhJU7HTnkLmMwWWJx3sNvq+E8gEiPfNN99syCYCeU7e27ZtS23btqWxY8fS2LFj6f333zeCe6LtklOWnLdrKn4MfN6b6w7JB5DjXFNmoWNcxxND2B8ZU9ebNWtmBORy/PjxNH78eBPc//TTT0YXoWQJBJ3bJN4rie6kKZfSdHY7oJKOSe1G4gNEvVu3bmYveOxrzu0Oev3zn/9Mf/7znzMKHuI59v7m/DtLe6O7dJ2mzfkkGX2/N6bbcqLNybotIOZIJrmm7EpJHh/f8fPPPycimbGFkly+RRLYLw887SnrfFonfsPyJ2k8ii1+mZavqyggoOdE256yDn1VqVLF/IYp2Tw5XCgI7au2SD7FdU8sbbrjjjtMYhzxCi8Eh77qKmbmaicS62+99Va55Rr8PCRTYuBTQI0nPvCbi+xKgqQrJ9qYsg4b4+Qdcvvtt9Ptt9+e8c8F+96uPdx5YVIckxIyadmdLVKMibbmik8gGGO5v+P+zRaQ+Pvvv5/uv/9+cb91l4QWLVYUDpSgFyGUoMc7IiXo+R0AlaC7dacEPT2bU4LuhhL0eF9XUVCCXl6UoCtBT8vubFGCrqhIKEEvQihBj3dEStDzOwAqQXfrTgl6ejanBN0NJejxvq6ioAS9vChBV4Kelt3ZogRdUZFQgl6EcAV7oVWMQwepBx98kB588EFDxp9++mkj2C859rmceLragLU9MQBpjd07VRKsRT98+HC5Y3xgAkHCXukTJ040smnTJtq0aZPXd0ljjVUMQFp5NXZ7zTTIeK713ggQXAEFJzYgTQhiYYcPPvigWXfooxM+2EnPhf253iEGdsKHS5pkBML1OmvWLJo1a5ZJbiBQuP/++519Fu0KCSbStjtuAxCfABQEN3QtJ7dt1NQAKR81apSRFStW0IoVK8R72D5YSspI50tJBfwWAxD00ASBq60u4QEuqpRDd6NHjzaSreK27/15tWUk4qS+j/PPB/AdHGB3IErYd7lv3760aNEiWrRokembhYg0bQoiJc0lQTXsXr16Ua9evTLiE9SSkJL+PmNHqC+JgUS0fdoG/UrXudrN9QobAxkfMmSIkRdeeIFeeOEFr/fOpSccQ5t5LIZjMeD+x4do236C/+aTKOF+CP8cABkfM2aMEew64NOWXLEd2iW1+Xzyd8UCJehFCCXoStCVoCtBd4kSdCXoStDPn4BVCbpblKArQc8FJejnj78rFihBL0JIg13otETbIfBpU66gHecfOHCADhw44BzkXI4ag+WuXbvMb9xR+5CWGPhMfcWe28eOHXO2I7bStkswtc+XhPsELWnpLum7hSZFpP3JXcTZtU+7lEAA8eR7t+fL7nze11W9WNKFpM9YP+AS11IJ7jfsKdUSMQ0F3s9VxZ0TULy/7xR313ku4mxf7yLBuZak+EgMoHv+jezq6C4/w9sdmkTC+a5q7NAdX5KCY7Cl0GA7Ld0p4uHzTdasWWPEXoYk+TqX7/G1g6RJApctSv0oBq6p6lIfxDN99k//9ddfnVPjbULvuleuSvuuNuerz3LCDLGXznCfhvE/1r9wn+/zjxN7j3XpPN526R46xf38ghL0IoQS9HhHpAQ9XndJ300JuluUoJeHEvR4m1OCHq87RTx8vokSdBlK0ON1pwRd/V2hQQl6EUIJerwjUoIer7uk76YE3S1K0MtDCXq8zSlBj9edIh4+30QJugwl6PG6U4Ku/q7QoAS9COHTcRFUS4G1b9DjMwBykuByHtu2baNt27ZFD45pOSLpPnayQarIjHfzDbbTXFecdL05FwxKMQCJdd2fB1d2u6Xqs5K9SQGCKxHh0640dZ2W3WX7Nt9//73RBSqo+1Y2xjpWX1sMWVMp6Uki6PZ35PcPhQ/R5uTdDph4G/KRvJDEFbiGVpdPYnM+31ZKLEhrvV02kJRAc3HtLuIjaSSFFMng4zfg1/juEFJtAmkHCR97tp9XVlYWNCZL5Et6D5dPSaI7m/D5/uPDRfC5+MR2Ul/KR70ULvCdadsdRIp9bcKehLS7RNKdz248vveHnSgKB0rQixCuzom/laD7604Juh+UoKdrd9m+jRL0c1CCHm9zStDjdaeIh4/fUILu1p0S9HTtDqIEXVGRUIJehJA65+bNm2nz5s1eTpzvdSw5rnw4YXvqtsvBSINSWntlpkl27XeTyNPXX39txH5P3/sXStCaps4grumMrr2lc5EHW3yrWNuBizSNPC3d+QRJkq0gIcF1Z78fP4YgQNKz3Qap70HPvA9CJ3wHg3wkN0LtyW6DREBDq5q7+lSorVUkQZfuY9sy9/s+CQzffufaAcD+zTUFX7qnK8EsJVAVFQvXt7N3aZH8hWQPEqGH8Ar4dvwgLZ+oqGVraenOFQv5TNuXYsHQqfQ+9w9tg+tYWrqzfQ33HfYzXclK7muge8kX+oyBkn1K5/mMUVIbFIUDJehFCKmjKkH3gxL0dAfApKIEXQl6mjanBN2tOyXoinzD9e2UoIfrTgl6vO6UoCsqE0rQixBSRw9xoNJ1EhFJSmZDi4KFnh+D0Heyp7/76lx6D5/9wSVxTW32Cfh5EbQkuou1g4qWJN/IFr4vdhLdhQZ+aBuCAd93gvDEkGsf85jpn6HvwJe/pGFzts27Chbl0ptrGmu25+bqb0nJP28z7CYG0r3tYJN/I5vY5lqSYkto0sz17mnYH8Y9RcUCNuPrs6Sp7S5x7SuNMdblz/KRpJckBi47lo75FocLIcex/cx1TqgvSUt3rrHPPsYJunQdjkn7rbuek0+RkgqKwoES9CKEPdAoQfeHEvR0B8BCFCXoStB9bUEJuhJ0RbpQgv4/iYHLjqVjStDdulOCrqhMKEEvQtgDjRJ0fyhBT3cALERRgq4E3dcWlKArQVekCyXo/5MYuOxYOqYE3a07JeiKyoQS9CLE7t27affu3cGd2bXG0F67VVZWVm7ttHS+dEwaHDGQSG2Q9of02WMzBhU1OCclPHzdOAi6j04kkdbIx4Cva/bZpzZNXdvJDb4+HW0BkfYNDF1Eyq5MnnSNF649duyYEVcfDNWPz3WhuzK4zpN2iEAbXMFKrN58yXHsGm/XWkDbXiSbkSrJx9o6v1cSgo7vIa2jTHOtbVLxrQngOkcaQ/CbomKR1B5y+UE7Tgm9r3Tso48+oo8++sj7Xj6xVAxAdnnSMSmBlnQlxRKuf+S41rrjOsmnhPwD6ddffzVjTxK7i00Uhl7H9WP7V6n2gSRJq8Xz8Rr3UhQOlKAXIZSg/09ioAQ9XndK0ON1h2uVoMfpTQl6OJSgK0GvDCS1ByXoStCT2J0SdEWhQAm6QqFQKBQKhUKhUCgUBQAl6AqFQqFQKBQKhUKhUBQAlKArFAqFQqFQKBQKhUJRAFCCrlAoFAqFQqFQKBQKRQFACbpCoVAoFAqFQqFQKBQFACXoCoVCoVAoFAqFQqFQFACUoCsUCoVCoVAoFAqFQlEAUIKuUCgUCoVCoVAoFApFAUAJukKhUCgUCoVCoVAoFAUAJegKhUKhUCgUCoVCoVAUAJSgKxQKhUKhUCgUCoVCUQBQgq5QKBQKhUKhUCgUCkUBQAm6QqFQKBQKhUKhUCgUBQAl6EWIs2fPpiZlZWVUVlYmHjtz5gydOXPG+14+5//yyy/0yy+/JGoXJC3d/fbbb/Tbb7+los/ff/+dfv/99+h3SnrvXPf/6aef6KeffkpNd9988w198803dPz4cTp+/HjWNvm8N84Ltbtsz8v1TLTd9xtB/0l0x9uGvnD69Gk6ffq0eW/+7q7+gvZks4lsdoN78vu6dI7+wa/z7ce2xOrtv//9r5GQ5/36669GQvsKzsH7S9/n+++/p++//z5YD742F6s3rjvXN/XtF7ES883Onj3r9Cc+Np5P3fmIb99MU58hNu07DikqFq7v5Ppu8MeSj6oo+4vtIxXRZ+0xgEsaPtznG7meg2/m6zd+/PFH+vHHH7XPFjiUoBchXI4z1oG6Bm5+LK2gQ3peaFATgx07dtCOHTuc9/3uu++M4LdDhw7RoUOHgklgrPzwww9GfPXo0540SGZFSRpBbrYgJ8l3qwjdudoIQl/R3yOX2KRdIvIVZXOS/mITcdK97N98kxZ2Eso3kK4Im8vW1pg+EzIOISHwzTffmG/kep6UdHG1P1+6S0KGQsi0y4aT+DMf36qoWCTts38USaI7kNcff/zR/EMi1v5d/T60P8eKb2yufbbwoAS9CCF1YiXoflCCrgRdCXp+RAm6EnSIEvRwm4qxYSXofywk7bN/FEmiOyXoikKBEvQihNSJlaD7QQm6EnQl6PkRJehK0CFK0MNtKsaGlaD/sZC0z/5RJInulKArCgVK0IsQUicuLS2l0tJS45COHDlixNWpfRyLFIh8/fXX9PXXX6fipGKvS6K72ODq559/NiIdd5GnfK4N47Jnzx7as2ePU9dp2Z1tB6GkOvR8l+59hCexJLvL1meS2p1EDm1bwd+nT592kr001oKnJXiv3377zStxkIbN2fLPf/7TSDZ7Lysro1OnTtGpU6fE47Hv77reRVK5/9myZQtt2bLFef8YSPc7ceIEnThxwvzNybHrXdBWHvza5+Rj3fX5klCDfkLbGkLUpUSjdL5PYtf3OYqKhfRdbB9/7NgxI2n1My4+ya8k9o37uxKfMfAZY6V/fEjvaxN8ieRL/8iR3on7xWy+0Teu0aTa+QUl6EUIqVMqQQ/TnRL0dOxOCboflKDH6c6nDUrQ/XWnBD09u5P0owRdkQTSd1GC7gcl6NpnCw1K0IsQaU7fhLgI64EDB4xIg3lMAIWEQmlpqXhPHzIbg3wMaKGONJ/ToaRnc+KXRHexFYR9rsulj5MnT9LJkyfFY/a7cdLo0z4kGb7++muvtiSxOxe5dhFu32m9uD5XIiJGJDsKTRKEImnbJb8m2ZyrKi7OjV1CxIOzWAKXxOZ4f7ATaqH+m+sT18Eu+bG0lmFICQSJoOCYFAgn0Z3rm+TSj4/d5WMsCE0Eu9qgqFiEfh/bx/h+63zHID5tsH1i0sQQruXE2ec9pYSWTx/yTaj7fEe0lycQcL4rKap9trChBL0IoQQ9uRPPtyhBPydK0JWgx+pOCboSdCXocTYfamNp9FdFMoR+H9vH+H5rJejnRAm6Il9Qgl6EcHX+o0eP0tGjR/PuXEOvcwW2sdMi09JdIUmsfl2DblpBa+x3ciVz+G8YpL799lv69ttvneSPk2r7WOjyBZfu/vOf/xjB9Pe07Q7vKJFwvIdEDqUAQdKXrQuJaEviQ7Zc9+LH8F6xepOSLj79J1cwmtYSAZceQqd+S++ats1hnEgSrLuCfdtWXf0VSw9OnTrlFYi69Cn1/SS6S5PMVDQx8n2eEvTCges7YRq0rz9xJa18bGTbtm1GfOzNNeaGtiEt3eGZ2IOci63XXO+X7Xp+zOd9ucDPu5alZHtmtvMUhQMl6EUIlzNWgh6uu0ISJehK0JWgl9ebEvR0bU4Jup/ulKArKhKu76QEPVx3StAVlQkl6EUIlzNWgh6uu0ISJehK0JWgl9ebEvR0bU4Jup/ulKArKhKu76QEPVx3StAVlQkl6EWI0IHatXYVpENasyo5jZAAmBMOVxuwxlByrK6BIC3d2e1Psr8tZOPGjbRx40bvgcxn/18IX6ck3Stf6/d9BglfkSqjYl2pXRlVshFud3ZQzwdHu838OpACTq58ElwxkIi0fV9+DH1RIn2udezS+fjNZVuu66TkGtdZtnV4/BiCoFi9hdq3JJJd2YIdELLtgmDbkdS+Xbt20a5du7zb5ZN4iIH0vW375r7ZpVcpyYa+5bPzgUv42ONqy/Hjx+n48eMZv+F8abzAt4lB7LtUpqRJ/nEvRcVi+/bttH37du+6FUmTa/w3F1F1Jc727t1Le/fuFeNFaYxFAt7VvhjAH6WRmIJwcuyqCA9JswK+z3jFk7lJ4mJFfqAEvQgR2tGVoLt1pwTdD0rQ43WnBF0JejZRgq4EPQ1Rgn7+Qwl6vL9Tgq4EvdCgBL0IEdvhJSIsiR2Q+1Yv9pkuikHn8OHDRvbv30/79+93ToVOy4nH6i6UFMROB086oHDJtn9nmroLqdbsO1UrTcF3A/lHkG8H+iGSRHeuqdCuyu65pqX77JvuIvuu98U5UuLKdypfLFkK7Q9oi1QVt6JsDoKglgdR8KOh096T2Fzo1GpfX2dPWfddOuEzDmG/dtc+xPyZ0jHoPInuctmbpGOfcyraFmNFUbEI7UsVZWM+08BB1H37Qdp2Z/d7Kekp7V3uK67v4YprcMzl713XS0lR7bPnB5SgFyFinawSdCXoaetOCXqY7pSgJ7c5V39Qgl5ed0rQ43WXy94kHStBV8QitC9VlI0pQVeCrgiHEvQiRKhjQcC1b98+2rdvH02aNMnI/Pnzaf78+TRr1iwj9lShNBy8ixTFFmqKQew7wbl++eWXRjAd7auvvjISq5+kupYGRemeSaYuuvQikRGcgym/jzzyiJE5c+bQnDlzaPHixUYQlNt2K5EFTJPLNVXOHoz5vsoxe1rH2p3rfq6B/8MPP6QPP/yQunfvbmTKlCk0ZcoUuuuuu4xgmrFrKqI0zd6nAJxrSj0X11Tt2Ol3sf0B7Xz11VeNrFu3jtatW0d/+9vfjKQ1FVISe6/uJD4gbZtzPQvjBO+v8+bNo3nz5tGLL75oBOOEa1onvgP3T65A1SbvuZJ6Lh+Q9lKopCL5aJ/lDWnaZKhUJODrBg4caGTcuHE0btw4mjhxopHdu3fT7t27zfTpPxJcY7bLjj766CP66KOP6KmnnjLyj3/8g/7xj3/Qm2++aSSE9POx0nUevgf+lpZLVoTd8djD7lcuH4L45N577zUyffp0mj59Ok2bNs0IEpI+yQq+d7lLB2iX5Aek65Sgn19Qgl6ECHV2StDPQQm6EnQl6ErQlaArQc+H3fnoXAm6DCXoStCT2J0S9Irvswo3lKAXIUKdnRL0c1CCrgRdCboSdCXoStDzYXc+OleCLkMJuhL0JHanBL3i+6zCDSXoRQiXo3ZJSUkJlZSUUMOGDY20atWKWrVqRc2bNzfSrFkzatasGbVv357at2+f4bjuvPNOuvPOO+nuu++mu+++m8aOHWsE5/Tt25f69u2bcR3Of+KJJ+iJJ57IGexDXANKEt2FyiuvvEKvvPIKPfPMM0bgxPmgiCQHSOeyZcuM4N1BFDg5XbNmDa1Zs4Y+/vhj+vjjj+mDDz4wsnr1alq9ejVt3bqVtm7dKrYP1ZlzVSBPW3c+AzHsgdvY1VdfTVdffbWxtWbNmlGVKlWoSpUq1KFDB+rQoYOxmbvvvpsuv/xyuvzyy42tjR49upwMGjSIBg0alGGTo0aNolGjRhndY3DlA6y0ywDvW7ZUhN2hb1x33XV03XXXUa1atZwC3UFuu+02I506daJOnTqZv3kADGnXrh21a9cu4zoce/jhh+nhhx+mkydPGrH7J++jLsIWqzfffdAhjz32GD322GM0fPhwIyNGjKARI0bQHXfcYQS/9e/fn/r3759BQHHsr3/9K/31r3+lBQsWGJk7dy7NnTuXHn/8cXr88cfp+eefN4Lk06pVq2jVqlVioumll14yYredr0+HJLG50HGiT58+1KdPH3FMaNq0qRHYWo0aNahGjRoZ/n7IkCE0ZMiQjL5oy5gxY2jMmDF0zz33GMEx+FZpzSjfU91OgqS1h7yPvkL3Y5d+qyiiHSsVCdjahRde6CVXXHEFXXHFFdSrV6/UBPHNwYMHjVQkbP/v+48LjHNdunQxgvita9euRhDvIdnLEx/jx4+n8ePHm7/5P3Lw2/3330/333+/8a+PPfYYTZgwgSZMmGCSeLnqa8DmpXGiIsdYPB+6ueqqq4zUrVuX6tatK46x9evXp/r162eMLbjH0KFDaejQoSYWGTRokDln8ODBNHjw4Izrhg0bRsOGDaPJkyfT5MmT6T//+Y8Rly24iLqicKAEvQgRG3gpQVeCnrbulKDnx+6UoGfqTQl6vM0pQQ+HEvR43cVCCboSdCXoStD/SFCCXoSIDbwwJeyTTz4xgqnnGzZsMIJpjT179qSePXtSmzZtjGAgg6PngsCtdevW1Lp16wzCYAd4b7zxhhEELb7V4pM4oqQBi1QVmgdepaWlVFpaagarqVOnGsFgB7L46KOPGpk5cybNnDnTBKavvfaakb/85S8ZgmeUlpaa54baQkXqDnb33nvvGUEygdsd3q9q1apUtWrVDDIAu2vSpAk1adKEqlWrZgQDaIsWLahFixZ0ww03GMFvuA/XK9rHB0UfHcZAui++nSsQO3DgAB04cIBWrFhhBNVyly9fbgQDfNu2balt27ZUs2ZNI0h4QE8gVDVq1KDq1atT9erVqXbt2lS7du0MveIY+jCWw8yfP18MHlz7oMfqzhXg+Xwr6Grv3r1m1wiQumPHjpnkF5IQPHjC9FokNhF8DR061ATEIPE8YOXnDR06lHbs2GEktg/FANdy0uqjM/RXniSEvvhvsLlrrrmGrrnmGtPXWrRoQb1796bevXubv5GQu/rqq6lx48bUuHFjM26ASLRv354aNWpEjRo1MufyJCbah+UcR44cyfC92fxgEt2lIbFk35WclipR8/4WWv07TbuLBfoIkuGvvPKKSUrz30ASYUectMNuXMT+4osvposvvjjjHxX2OU8//bSRikTsd4Lv/fzzz41gevoXX3xhZOHChbRw4UK66aab6KabbqLrr7/eCMgiyCY/BkKPY7j+pptuMgngzp07U+fOnTPGebSP78Zgx0+S7SfRnWtpnCTwJbzdGHf5b0hS4H1B4uvWrWuSIvXq1aN69eplkH2Mnw0aNKAGDRoYH9eoUaNyiXV8n4ULF4pt9fnngqJwoAS9CGEP/ErQw3UXK0rQw0UJuhL0WN1JOlGCHqY7JejxuktDlKD7QQm6EvQ0+qwSdEWhQAl6EcIe+JWgh+suVpSgh4sSdCXosbqTdKIEPUx3StDjdZeGKEH3gxJ0Jehp9Fkl6IpCgRL0IoTL2WDdlHQstmIsArZTp06Ze+BvXk0bJEeqJA3HDvL+2WefGanI4CFpwBK6NsxVWZSLK4hDFdF+/fpRv379cj7Tp+prEt3xABm/+VSslgZO6V4Qac0z7I4fQwV9BK38fUFOkSD69NNPjYR+e7xjDGAz0oAau4uBRI6hg0OHDhlB8IMAGMHHgQMHDHm1z/3999+NzkD0QWZXr17tbBcIAv8O+C3W5lx2HprYQ8Xjjz76yPyGwIfbaKy/xBpuEHRpXaFLeAXgNPqry5ZDfRF/F9jJnj17aM+ePWJ/BUngYwhEWkeJ4BfEPtc4Ye9GIPnbtHXnI7kSSK5jrvW7PhK7O4UkhQx8c76zCnwrT4rZAnvl9UiQoARB57VjKhLQu1R7wYd0SnYn1VGBf+HEGecNUr0+AAAgAElEQVSjX3L9oM9Kvh3+rlu3btStW7eMpGis7SfRnTQeuNZsc13bOuf/kME94Duluj88nrEFvpCPsUiog8zzBKirH8O38XgC7VMUDpSgFyFcDloJerzufEQJuhL0GChBV4KuBF0Juo+OlaD7QQm6n90pQVeCrqgcKEEvQoQ6PclBQ+B4XeeETp+G8KnYmMKDKaE7d+40It0bTkc6BjIRg9D3cO0r7RJXkGWTKT4gSNehuurSpUtp6dKlqbQhie5C7SFkulk2CQk6OTnFFDRUlc6lH7yXtH8zKkfHIMm751Psb7Nt2zYjmBKP5QKSvfpOqY0l6LG2A79WUXrkQRemO2LJRq5rYV/bt2+n7du3ZxzDtPyKtLkYX8+vC/UPvGI2kkJSf3U9M1uS7+zZyp/iLuknDZ+YtA0+5/+RsXHjRiOIT7BrBk96ViRi+6NkTz79MTa24/+Yufbaa+naa681u6n42qCrzfnSnTSGuQSkVyL3oTuLQPAPha+++srEJz169KAePXqI5/PnuBINSCQoCgdK0IsQoU5cCfo5KEH/nyTRnRL0cCR593yKEvR0RAm6EvQQ/ShBr3woQVeCnkuUoCuSQAl6EQIdku8HGzJNNnRKaKiAXKPIXM+ePU2RLlcgxad2gthLA0mSgRP3S7uYTlqCIP/VV181MmPGDJoxY0Y5/fJp0lKhFdfAm0R3roE/1x6oPm2L/UY4VyoShynduQISV+CcL4Iu9V30z1gb5bqzpwFL5+N5vHAS9p63C/5I9vr7778bvUrPgb2mYXM+749zeUE4n+/N9eZjxziX763et29f6tu3r7O9hVgQ07V/PY65Alyua5ct2IJlKB06dDC2hwSbdD6feuu6f5IlKaG6y2Z//Pv7Fq9yneM6FrskI227K3RgSjcKetWrV48uuOACuuCCCwxhryy4bMllD65zXH2WJyJCbPPGG280gkJyrqQo93f4x4x0HpazpKU7e/o+F7tYXRJB3Ip7usYrLPNs3bq1KYiLArC5nuMi6DrFvfCgBL0IgQ6pBD1ed0rQ43WnBD1ed5IoQQ+zOZ/3V4KuBF0JenL5I0IJ+jlRgq4EXZE/KEEvQqBDKkGP150S9HjdKUGP150kStDDbM7n/ZWgK0FXgp5c/ohQgn5OlKArQVfkD0rQixAIXnyDVvscKWjlTvzEiRN04sSJctf7BscI6Pn+6R07dqSOHTtmkEsInD4PvHyC1xiEVFPOJTFrt7hIRBtO9qmnnjIyZ84cmjNnjldbpPakvc9oPnQhyfHjx43YOkNF1G+++cYcQ0ID61ibNWtG7dq1o3bt2okk2EVIJIldR51Nd7HV2133kr6DTdSl77ZkyRJasmRJxp6sSKq59lwObV+aNgfxJbv43ryy7htvvEFvvPEGbdiwgTZs2ODsR9IxVCseOHCgkTFjxtCYMWOcBJ+3GZJ2Qs3uH2n3U9xfquxsB/uS7v71r3/Rv/71r4w90rEGWOqbob47SUJNSkLmw8dJNuLas97+jY8hPgkl17pZ6R3/iHj++efp+eefz9j3/Morr6Qrr7wyUVInDaT5jxPJ36PaPf7mtYBs+5ES5OvXr6f169dTy5YtjWA/dGlMcPWZtP2dRF6TknCpirv0nhgjXXVtZs6cSTNnzqQ6deoYgQ6ltoeslU+qO0V+oAS9CKEEPd4RKUGP110+dSGJEnR/UYKuBN2GEnQl6LYoQVeCrgTdX5SgK5JACXoRwtU57anhvk5SGpxdzgZ/82AXjqxVq1bUqlUratSokRE7IZAr4PEhAGnrLlTSDNhwr1mzZtGsWbOMM585c2aqbU5SAT9NXfDpntmCeX6+nTTiA+emTZto06ZNZnosiGXTpk2dU8IkybZMIGnQGvLsmD2QXWQ/21T306dPmyrh2AcYldtr1apllgWkYXexU9xd0y5ff/11ev311xPpDXqQSAuShUgS8emgCKR79epFvXr1okGDBhnx6ROhiYC0bc7uT7lEaqtP8Au/z8cJBJ7NmzcvJ0n7qyRp6y4NCfGXrqnxEomKHZf+6AQd+59jWjEn6KiqXdmItfFQgT1J/ygBiT958qQR+L2uXbtS165dzT9cOnbsGL0MK22C7tKdz9Rw37ZJfRFjBXwbj0/g91CxHWNt7dq1y+2j7iuuZISicKAEvQjh6rhK0ON1l+YAE3svJehK0JWgn4MS9PzYnBL0eN2lIUrQKx5K0MvblBJ0JeiK/EEJehEi1OnZhUQQnJ04ccI4MD71DR09dGB455136J133jHT2uHMu3btmurgkoYT9y3Yk5SEc/JgFyzhAREc/PTp02n69Om0efNmIzjfVQSIB2o+xYIq0u5c13G7c03vk6brQlBgBQXhhg8fbiQfhQBjwL+PLT7PzJXQcunaVSRu7ty5NHfuXLrooovooosuyih25tOufBc7Cy18ZResc+mK62vr1q20detWr8RRWVkZLV68mBYvXmzsDIm1WbNmOftErD+JARILKN6Uxr7w/HtD1/YyFH6edI9ly5bRsmXLTH99+OGHjaTZT5PoLo0+6XN+mknefLT5j4TZs2fT7NmzDSkvKSkxgr5e2fD5dqHf3BXrSPYg+Yo1a9bQmjVrTEE4FK6dMWOGKZCWpk3GAHErH1tDlrHl2iMd8RvIMW+3XUSTX4flY1dddRVdddVVdNdddxlJc5nbH7HPnu9Qgl6ECHXiStDL604JesXZnes6JehK0F1Qgh5vc0rQ43WXRp/0OV8JesVBCboSdJcoQVekDSXoRYhQJ64EvbzulKBXnN25rlOCrgTdBSXo8TanBD1ed2n0SZ/zlaBXHJSgK0F3iRJ0RdpQgl6ESHOQxhrU2HWcvJr26NGjafTo0WaPRzi0bPtQVoYjin3WggULaMGCBWLldamiuEvv3377LX377bcZx15++WV6+eWXDWHKh77yoTvXHtMQVF92Baj8N9ghBv4ff/zRrOOS7o9K7Y0bN6bGjRvTunXrjPjowkXGeL9AW9LSnSt44Oud7QHcTmjw/dJdCQC8I0+K3HLLLXTLLbeY9XHYh/azzz5z6ixkr/uysrK8VHGX3gfPk4j92rVrae3atWIbXfaI786fg0Ta0KFDaejQoVnf2w6opYrnrndE4i4tm3MJAk8pQJcSF673dMntt99Ot99+uxkneD8PbbOPJNEd7/8h7+mbAI6VUDuqSN0VEnifBbm85JJL6JJLLjE7MOzdu7eym2kgfQMfX+vqP1IS1eWb7HPKysronnvuoXvuuYd69OhBPXr0CE7MVkRiSLq/T00L13puHsPGJuMGDBhAAwYMMAR948aNRnx8SLH12T8SlKAXIZIOukrQw0UJuhJ0JejnRAm6EnQl6GE+JU1Rgu4HJehK0JWgKyoLStCLED6OwfdY0inAmNb+zjvvmP2TJ02aRJMmTUocHHBBtUte8TIt3WGQDm2Tz/RbkHGbkJ89m0nsp0yZQlOmTKHt27fT9u3bE+nKZyBJojtekdm+LyeGdiAvDT4ukZJGOPbMM88Ygd1hmmwaQSuul5IvadldPgNrl/zjH/8wAt1hyl2S+9rJBJ5gQF+J1Vu2ZIUt2PvadY6LPEn7k+MYpsFv3brV7Nu9aNEiWrRoUcY9XImXUH+bZOqt676hVdyTyrvvvmsENjdu3DgaN25csH5c/RvBNt+vOG3dhYrU1pC+z/1g7D7ZxRrsz58/3wimtg8ePJgGDx5c2U0TEWpHoZJtPJVsAwnNtWvXUtu2balt27b01FNP0VNPPZV6u9KwO8kHuPxD6PTyEN+EZTzLli0z/u7ee++le++9N1U9Se+qKBwoQS9CxDpxJehK0NPQnRL0dOxOCbq/3pSgp2NzECXo8boLFSXolQcl6LIt2XahBD23KEFXhEIJehFC6qggTK6BGFON+W+YosyJlc/URZCWZs2aGUHRH1ehDZdTQ1ukKdNSe9LSXZpTEX0SJBgkp02bZuTFF1+kF198Mfp5c+bMMZKvAVB6N6lAVDb95ipWZeuHH0NgCvto2bKlEQyAPnbHp6zB3nlxGNsWeAAD8peW3dnT2LmgbdCFNHXdtSxFIrTY6/f//b//Z6R+/fpUv3592rJlC23ZsiXjOlsX0j19i92hnWnoDffyKejGp+xL00BxnusdYHv9+/c3MmrUKBo1apRXX+PBms/5q1atMpKkv0r35lN+f/vtt4w+CZ+ORChfzgPbd9kcvy9+Q3/l40T79u2pffv2XvuoS9/WtaRIakNauosVabmMfU5oP3KNM6Hjmete5yvQ57mvq1mzJtWsWbPgprVzxNrRjh07aMeOHRljGc7hU/l97AGED0sCrr/+eurZsyf17NkzuGgnZOfOnUZ8zo8BlgNJ98MxaQyDXrnvQB+SCse5+umBAwfowIEDdOmllxpBMhfjr7RM0iV8T3W7bytBL2woQS9CSJ1YCXq87pSg+0EJuhJ0JehK0JWgx/loJegVByXoStC5KEFXVAaUoBchpE6sBD1ed0rQ/aAEXQm6EnQl6ErQ43y0EvSKgxJ0JehclKArKgNK0IsQaQYPkqCyO/6Wgp6BAwfSwIEDM4jSk08+SU8++WQ5x5evdbZJdOdae8UF6+t922QPnJIOsG4VlaCnT59u1rZKBBZVQGP1lFZyA/fItV9o0nZKx/CtOnfuTJ07dzaD3tVXX01PPPEEPfHEE+J1IFfQK4gGX6fsqtQsBUNJ7M61lloi6pJOpADBFTRAdx07dqSOHTvSFVdcYQTrMaW1ra4Egmv9HtoinRert3yJbceSXxgzZgyNGTOGhg0bZgRr+H2ekcvX2N9YqluRxOZCd+jw9dk+FZJ79+5NvXv3piZNmhiBDu1EcFlZWblEszT2cPEhDEl0l6bw98yWWHK9I3/PNMZVn2Ty+Qb4G/yzAOvOL7zwQlOJvJCRj28ZKuif2B2lXbt2tHDhQlq4cKFoy/ht3759tG/fvpy2b18n9YMkuovdFYIT4Vjdde3albp27Ur16tUzYtfGka6LjafSSkgq8gMl6EWINJywS5SgnxMl6OegBD253SlBj9NbvkQJelg/5KIEPc6/KUHPH5SgJ7dTJehK0BXpQAl6EeLQoUN06NAhZ8d17YPMAzb8BlJ++PBh5zRfOCDsYduvXz8jPgMI2iRNZ8d75Xo3kIkYhAx2vgMepjUdOHDA/Cbt/75+/Xpav369Idy8wmy2KbplZWXlyJPvdEiXxEAiZfZULdd0Y36dtNzCFn6vkSNH0siRI81eojfffLOR/fv30/79+533ck1/k0h72roL/T4+yQqJAEtEu2/fvtS3b1+zFIBPXbSXuEjPs5MFvF2+1dVjdbd69WpavXp1sI5cIgU10pRDLDvBXucTJkwwEkJ4JfElzfjWMci2XCibuCqEQ9dSX5FIZpcuXahLly6GKN16661GoGvX8hhJN3zMCHm3GPj0zTQS0K4EnGtKcz4T3/z+5wP4d+jWrRt169bNkPJWrVoZQZK2kBE7hdzl51zxAtcdlu9cd911dN1111FJSYkRl73ZU9f5PTE2+MZ2Sfqs5Idi/bSUSHPpDkvFateuTbVr1zb+r0uXLkb3rm8rfR+0XUocuN5VUThQgl6EUIKuBF0JuhJ0JehK0F1Qgp6f/qoEvbCgBN3t55SgK0FXVA6UoBchfJyOtFc1nAkPUH2IEg8QmjZtSk2bNqU2bdpQmzZtRHIqCRx1rMOUgrIY5CugyaYz/tvjjz9Ojz/+eLmlAJLw4lYup+z77DQGQJ/3loIBKaDNVuTJtjcIpsc2b96cmjdv7hzw+XOSTsWXpsvFAO+BRAFPFtiF4XIlXnzO4e0GMce0dqlgD9rAfYNrOrtPG/i1SfdBd90/9Jv6Ti3GVM8RI0bQiBEjvAPd0P5qy7p164zkq7/Cl/qSTJ9ikNI4gX7LxyPoRRp7kNiUvq1PO9MeJ3xtxSU+7Q5N2MS2JVTOB5w4ccIIn9J+4YUX0qeffmrkfECaiZfQe2EJFJK30lKbfEhahc5cpFUqsppNX2VlZV7Ld/j4VrduXapbt675B4JUmM+nf4cuR9Ip7oUNJehFCCXo8Y4onwONpDP+mxJ0JehK0NOzOSXo8bpTgu6nOyXohQ8l6PF2x0UJuhJ0RbpQgl6EUIIe74jyOdBIOuO/KUFXgq4EPT2bU4Ierzsl6H66U4Je+FCCHm93XJSgK0FXpAsl6EUIV4ctLS2l0tLSjMDCdtS+RAAdHwE+l48//pg+/vjjYGeM9iVx6Aj00tadJHaFcClgcznVN99808gDDzxADzzwgPgcrMuUvp99rpQUCV0XmUR30qCAtmIdq7SWle9B7mob9gu96aabjIBcbty4kTZu3BhtO7wNLtKB9YqSPmNgryvN9X1CySfuj75Rq1YtI+izK1asoBUrVjj7v/T9cC4/5iJQUl/APWJtTnqOdAxJCdv3+Qaqkq9z1SeIJUyudvFj8B0xcAWZdvL27Nmz5ZJmrv3Gz549SydPnqSTJ086dYe6G6H6AeHiv/msO+e2jfNjEONbctmmS1zjiq8dpbl+GVLIQPIVyaCmTZsaYr5kyRJasmTJefMuANrqW7n/4MGDdPDgQacdcYH/hm8Asaxbt67ps1988QV98cUX0TbDk+eucUyKExDXxMDV93z2HXfFLpKPQb2Dbt260WWXXUaXXXYZvfvuu/Tuu+8G6wy2zJMVroryUnIT5ysKB0rQixCujq4EPV53kihBL687JejhUIKuBF16ByXosihBV4KeC0rQlaBzKEFXgl5oUIJehMhHYMB/w7SmlStX0sqVK8204ubNm9Pll19Ol19+eXTgBQmdypNW8ODjgF3Bc6524xgG1xkzZhh57rnn6LnnnnM+22fJQcw3TUN3se0Jtc23336b3n77bWrcuLGRZs2aUbNmzWjPnj20Z88eUed4ju9+piAB0jRuV8Ijbd2FVuRHe6R2T5s2jaZNmyYSdJ/AS7qna4p7LtKe1O54wJnNrqU+GUqckRTCbgEjR46k4cOH0/Dhw805/F1dNu1KQoVUMs5nf40lc0hcnTp1yvz21ltv0VtvvWX6aLNmzahhw4bUsGFDs5zD5VOlwBjt41XjQ6vSp627NKcfF7rgXQsZs2fPptmzZ5eb1n7hhRca4nq+wfVNXDuRhNrrBx98QB988AF17tzZyLXXXkvXXntt4mVhXLZu3Upbt24Nbl8S3aWx3Mh1/quvvkqvvvqqmc5+1VVXmTF206ZNtGnTJue9pSn9+JuPZVKC1U6wpKU7RX6gBL0IEersQh2REnQl6L525yNK0JWgx+pOCXp+bE4JerjulKAXFpSg+31D6ZgSdLcoQVekASXoRYhQZxfqiJSgK0H3tTsfUYKuBD1Wd0rQ82NzStDDdacEvbCgBN3vG0rHlKC7RQm6Ig0oQS9CoCNK65RsByM5mVzrlEASO3XqRJ06daJGjRoZadmyJbVs2bJcZWuXkztz5ky580PXhqbtxCWR1gnHtnHBggW0YMECeuaZZ4zMmjWLZs2aFT0wpDG4JNGdi/TGrvnlgsAAgUKDBg2MYI0hyI/0HJ/17VykdvoQ+xhIJNxFaO3zpXXjvH9t3ryZNm/ebAKF6tWrGwFRl9b12vfPVrXdR+z2ScQ5Db25JLbtd999N919990Z66dLSkqopKREtBPo3bXe3vU87rvzZXOhOrCFk2P8hrWcv/76qyHM7du3p/bt22foDkTdRaqxhl16TqxIY1sS3aUxTvkIf45PEjlN/cAO09JdvoFkWo0aNahGjRp/SIKeL7uDr+nVqxf16tWLrrnmGiNdunShLl26lKvjwe0BO8tISbU02xsDKYERMh4g/siWnMA/pfDPqiuvvNJInTp1qE6dOs6q9yDVaewM4fIhisKBEvQihD2wKkEP150kStDdUIIerzsl6HG6U4Ieb3OhOrBFCboS9EKEEvR4UYKeXZSgK9KGEvQihKtzptHRbUeEPc/btGlDt912G912223i81xtcDmu0Laj0nkS3aUxxV4S3HPOnDk0Z84cmjJlipGXXnqJXnrppVSfFysxyHegigqomB7LE0MDBgygAQMGeFVjlcSHBOVTd6HE0TWAgwBysgTbsqe1V6lSxVTplSp3+0ga5B3vEwppKn3Ic6VAl/+GKecDBw6kgQMHUr9+/YxMmjSJJk2a5LxvvvoCJHb/eCI/gu67oweEf4c1a9bQmjVrTPIM/bZhw4bG9kITLD765Tsx2OMK3xM7SX/N93e19en77jjmE+DnInmuJHQhB/vwdRIxb9WqFbVq1crsPnC+Id/2tmXLFtqyZQu1bduW2rZta/Y+79ixI40ZM4bGjBkTHBcltUWerExid9Jz7X8MuRJUud4TSz6rVq1KVatWNaS8Tp06JuFh72yRy3+54pLQMQbJBUXhQAl6ESKNzuwSJejxogQ9XpSgnxMl6P+DEnQl6LYoQVeCrgQ9TpSgK0FXVByUoBch0CFBVJPuK27Lhg0baMOGDVS/fn2qX78+jR492oh9ritod5Hgo0ePGpEcl087Y5APUi4536lTp9LUqVNp9erVRkLu41q+gKlcP//8s/lWLseexlRjbneuwQTLI6RCd9h3PNve42vXrqW1a9eaZRS33367kRDduaaq8TZgoJZ0jcCf6zpfupP6UujgvHTpUlq6dKnZL/7GG280gnu5yLUP8Q4lczwoy8c+6LEkmV+LKdgjRoygESNG0LPPPmvEvk4ifxBXAuHDDz80IrXBtj3eX2P1lkt3+Jvvde5D5vhvIOhNmjShJk2amKJ6vLBeUkHAy4NenphyXZtGciNXgseHMLsIcD6ns6chhQiboPNCZ/Bj5yt8vomv/UuCom3Q14MPPmgkm93mItX2MYkEh/5DJInu+Phvj1e+Y6zUVhB0ewmUtAyKF4JDksDV132KoXKxi5XyZysKB0rQixDoiErQw6EEPfkAKIkS9HjdSX1JCXp2vSlBT647/K0E3a07JeiFByXoStBdulOCrigUKEEvQqAjKkEPhxL05AOgJErQ43Un9SUl6Nn1pgQ9ue7wtxJ0t+6UoBcelKArQXfpTgm6olCgBL0IETvYghBLnTq0siQSA9K9fPYJ59fZ++rmM3gIfUZo0BoyyIVKmsFcDGyyJRE1PjAh8HfpwndtsWutFkhW6N7OqBwdur45id25Elr8GNoTG4hJErt+PPRermOxenOJRGil81xEKbYvu97VdU8pyMY7pFVN23U/iHRMSrDFVh12fQ+fmghS1XjpPNexGPi8m0uvvuQ9n5LG2KOoWMT+A0EaH6VEko+9SMdsX+LbL2LHrxjgWhDiXLsM2SIl412JCEnSHGPxPUITMorCgRL0IkRsh1eCrgQ9ie6UoCe3OyXocXpziRJ0GUrQk/dXlyhBV6QNJejJ+6wSdEWhQAm6QqFQKBQKhUKhUCgUBQAl6AqFQqFQKBQKhUKhUBQAlKArFAqFQqFQKBQKhUJRAFCCrlAoFAqFQqFQKBQKRQFACbpCoVAoFAqFQqFQKBQFACXoCoVCoVAoFAqFQqFQFACUoCsUCoVCoVAoFAqFQlEAUIKuUCgUCoVCoVAoFApFAUAJukKhUCgUCoVCoVAoFAUAJegKhUKhUCgUCoVCoVAUAJSgKxQKhUKhUCgUCoVCUQBQgq5QKBQKhUKhUCgUCkUBQAm6QqFQKBQKhUKhUCgUBQAl6EWIs2fPBslvv/1Gv/32m3hs165dtGvXruB7SlJWVkZlZWXisZ9//pl+/vlnOn36NJ0+fTrnvX755Rf65ZdfzN+///67kV9//ZV+/fXXvOnuP//5j5HS0lIqLS2N1smKFSuMoN2h98B1Bw8epIMHDzp1L+mfH5s1axbNmjUrNd3he7okV3shZ86coTNnzjifg3P/+9//GvHRoXSu1D77N94+HIuB1Ae/++47+u6770zfwN/fffed811OnTpFp06dMvo6c+aM6Rs4hx+DLeM63+fgvX/44Qf64Ycf6MSJE0akvmJfz5+De6Rhc7a8//77RmL7KfoY/A73Pfbfvvc6dOgQHTp0KLgtUt+IgeRv7H6Qq5/a9iQdg+2F+gCXSNfZNu66jl8bA1yLfptt/IQcOXKEjhw5In7DEJvJNT64dMD7fLZvFeo3Y7B582bavHmz97f+6quv6KuvvoruH998840R+1zX95N05dLdmjVrjNht5npdvnw5LV++PEp3inhgfOPfDL4b3xXnnDp1yqtfhwrG8ly+zLYb13js6rOSDSsKB0rQixChTkMJepjulKD7604Juh+UoCtB9xUl6ErQs4kSdCXoChlK0OP7rCI/UIJehJAGfnTSw4cP0+HDhzMGsL1799LevXudjuKTTz4xgt++/PJL+vLLLzPOCx188ykxmD9/Ps2fPz84GFi8eDEtXrzY6OTLL7+kdevW0bp161J9J5sMclLqe4+pU6fS1KlTU9cdBrRcQaD9LlL78W6cECUN6u17nz59OigY5W1OW3fZSGw2sYNtLiC7/HwM8D/++CP9+OOP4j3x/fg3CQlSJOLIj3/77bf07bffiu+AoCgUq1evptWrVwd/Pyng+fzzz+nzzz8Xr7N9n6Q33+8Va7dp2xxsP5Qs+iSu7H4WQ6Ylu/LxAZzMus5LklDzaTdPGtt2IB2T+o9ELF197MCBA3TgwAGv9uUi4z4JpHzpTvJr+/fvp/3794vn//TTT0bwTtlIeTZdhthirt9sX5qW7hTxwNjn+81hP6HxlZQIcPko13knT56kkydPej9bGvvV7goXStCLEErQ4x2REvR43SlBj9edEnQl6EkkBkrQlaArQVeCXixQgq52V2hQgl6EUIIe74iUoMfrTgl6vO6UoCtBTyIxUIKuBF0JuhL0YoESdLW7QoMS9CKEFPxgwNi5cyft3LnT6aR8nYfLcSUlUdJzjh8/bsTnuhjEDtyu4FsimTgmBWr2Pfl9QwIwSYdlZT5KBXoAACAASURBVGX02Wef0WeffZY33SX9zlznoetVfb6Za92hZPuhSYEY4DuHrgF16eD777834qNrF8GOJZd8nXm29Zxc0rS50IBMkhAiyQXvYyfReBveeecdeuedd8Rj3EZd3ykNm/N5D34e7FPqR6F9ReqHPt9KWtce21/S1p2rPfb6Vv7uWKd+5MgRo2M+PtjvjOuQdD98+LD5zVUXAc/wXT+fNsnEta76FKHt8BVX7Rr85kpi4tyPP/7YCI599NFHRnzeQ1GxgP6RKObJYpe4SDKOScd5LGH3M16vxceu0edD+wwIOyftisKBEvQihBL05MGDEvR43SX9zkrQlaCnYXNK0P1szuc9lKD7604Juhu4Vgm6oiIB/StBVxQKlKAXIaSO6gooXMd8nAdI/86dO72uk47ZbTh27JgR14Dpep8YoG08MJWISzYiEyr7/2/a3v79+40Ttqs8Hzp0yIsoSBVCbZ1LbeW6TuLEfaaThh5zCSezuAcGQhexl4IyV0XriiDo0n3QRtihi+z6BtsQV6X20CrusbbPBdNTY/XmSnSl0WZ8f76ExT5HCoZc/Q82x6s/x+ovBq7kgf3ep0+fjib00r2y6cJ3F4vYvimdHwPX+0rvz/tnSEICCWnX2MP7q499Q8++fcb1nZPoLvaZoeOu63xXopKfB//kun9F9FlFPFzfHH6bV3HHMSnZ5eML+b18llu4EvOIgaXkQkX840qRHyhBL0K4BrfQY0rQlaD7Qgl6vO6k+yhB99ebEvRwKEFP3l+VoMfrLvaZStAVMXB9cyXoisqAEvQiROwAmIbAcUkDmg9pTzPoT6K70KJOvtOSfe4ZW9wmNthKS3exRFtKiuAYXx7go2OfNqQxLdb+7rxdSezORbT5N4eeEFhI78QLJ+E3iQThnrFT6/EMqQ0uAiNN14vVm29SIVZcfsmnT7t8my9Rcn2fJDaXht91XZ+0r/kmEFz3cJ0Tg9glH2mObz4i+Se0wTU9N5+6i9VBUp3zZ65YsYJWrFgR3QZXou7sWb9CYYqKRWwf8i3UBtvw+fahgj4ojXPS+CFN4UdcoSgcKEEvQqTpGGIHMCXobv24zlGCrgRdCXqY3pSgx9ucEvRwKEGP150S9HjdKeIR24eUoCvyBSXoRYg0HUPsAKYE3a0f1zlK0JWgK0EP05sS9HibU4IeDiXo8bpTgh6vO0U8YvuQEnRFvqAEvQjh6ujY8zx0QELl71zVv+31OmlUpY6VtHWXpkjBhs/evVIFT9fazWXLltGyZcsqVHdSQOSqKiwJdCCtM5fOx4DE133ZAyUGMV9CIq1nt8/h98I5SXQnEXTozvVOrjX3uewHtQtQR8JV/T3bu4cE3BJBxzeO1Zurfb7tqiw/JemmIvur1O/QjiTJLNix5J8QZCL45bbtY1fSemSfOheSpKU7u92usQ9J2GyJWJct4hj0KgXtku5s25J0HOobk+guNjFk6zmG7Fd0oiStPluZQJ0avtsA5HxArN35nmuP25Jvgg75Px7yaWNff/21kfPV7v7IUIJehHB1WCXo8bpLU5Sgu0UJuhL0EL252ufbLiXoStCT6E4JepjulKCfX1CC7ufvpOcoQVdIUIJehIjtzJ9//jl9/vnnwdd99dVXRnr37k29e/emG264gW644QZq166dkYceeogeeughGj9+PI0fP57uvvtuIw8//DA9/PDDtGrVKlq1apWpWvnjjz+WqzCezwEwVnebNm2iTZs2BV/HydCYMWNozJgxdM8999A999xDXbp0MTJ//nyaP38+LVy4kBYuXEh/+9vfjCxevJgWL15M27dvp+3bt3s/2zXwpKU7e+qVa8olH7Skttm/YR/pd955h6pUqUJVqlShmjVrUs2aNenyyy83cuONN9KNN95Iffr0oT59+tBNN91kpGXLltSyZUuaOXMmzZw503svW4kMpE3Q8b5S0gFT2117okqEHrJ27Voj1atXp+rVq1Pt2rWpdu3aRpdVqlShgQMH0sCBA2nAgAE0YMAAc2716tVp6NChNHToUFqwYAEtWLDAu5qsVOkc7xEKV8Vs6dmvv/46vf766+bdQ/srEpx79+6lQYMG0aBBg4zPa926tZGpU6fS1KlTadq0aTRt2jR66qmnjDz++OP0+OOPm8rtuZKYPgFiEpuTnuXSoUS4ffYlX7JkiRHYV7Vq1cpJjx49qEePHuX6bZ8+fUx/nTFjBs2YMYP27dtnREqo2b9J75qW7nwEex9L7XAtq/rggw+M1K9fn+rXr290UbduXSMjR46kkSNH0vDhw2n48OHGRgcNGmR++/vf/05///vfcyYJfEhwDEJ2mzh79ix98skn9Mknn5jv7Drnk08+KedneAID+oFf475u9uzZNHv2bHryySfpySefpAkTJhh5/vnn6fnnn6ctW7bQli1bvNuOf2pwPSapgF9RwDd64403jFStWpWqVq2aoTNIp06dqFOnTtS5c+esMnnyZJo8eXLG8gD4koqAT0zBl33AJ7umrLt27ti4caMR6Al9l+sOY8awYcNo2LBhGb4QfRaxXq5lKejP9h7r/B0VhQMl6EWI2OBBCboS9LR1pwQ9THdK0MOgBD3d/qoEPV53PqIEXQm6EnQl6ErQFURK0IsSoUGDzxRGaeotSA13wnA6PXv2pJ49e1LXrl2NdOzYkTp27Ei9evWiXr16Ua1atYxcf/31GcKvA2ENfa+K0J1LMBBLRTxWr15Nq1evpttvv93I2LFjaezYsYYM4b3vueceo1ccgzMfNmwYPfjgg/Tggw9S//79qX///vTnP//ZyLx582jevHliuypCd7AtnwA+l2CgGT16NI0ePZouueQSI5deeildeumlVKNGDapRowZdccUVRqA7/hvEJvT8GJJMfI9m13ICJBfStjs8kxd9swddTvIQMEh99oEHHqAHHniArrrqKiPQT7169ahe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Tnb23Pteu3ZtWLt2bbj55pujnXHGGeGMM84onR2/6iCK97s6e3nn+CB1jK2fOcdfffXV0U488cRw4oknlo7H6taLT9oUd7Vps2fPjjZp0qQwadKk6AOAEBDoPUndzrlOB49AR6CX7WxlCHQEelkQ6PXLHAK9uu88fyDQy/tOhkCv7jsEejtAoEMuCPQepE7nVkagP/roo+HRRx8N99xzT7Tbb7893H777f2e256/yjXLdNCD4TtZrlBYunRpWLp0aRg/fnwYP3582GGHHaLtuOOOYccdd8yeql7VFKA2PWXWC57VmauD9QLkHAG6cePGMG/evDBv3rzwpS99KXzpS18KW265ZbSddtop7LTTTn2mweecdyAre66my11qP3QvoPXu9Xe/+1343e9+F7761a+Gr371q2HnnXeOtueee4Y999wzWZfK7GmbW/6seFc5KUu3p7MvWrQoLFq0KBxwwAHhgAMO6Kivw4cPD8OHD49BVyqBnFfucwYucq3pMpfz/gb6bMmSJWHJkiVh3LhxYdy4ceEzn/lMtG233TZsu+22WfWqauK5wfZdTl+WqsvWVq1aFVatWhUmTpwYJk6cGPbaa69o++yzT9hnn3264os2ljvVL6+t88Ti888/H55//vlw5JFHhiOPPDJ8/vOfj1Zs67z31+S0cA0E2CRxaiOqkJrinrrv3EHE+++/P9x///3hoIMOCgcddFCMSXbccccwYsSIMGLEiHidVAK5sn4se3wbUTw8evToMHr06I74RCZ/AYSAQO9JynYiCPTqvpMh0BHo3Sp3CPT+QaB3p8zlvL+BPkOgl6vL1hDoHxsC/WMQ6NXLXbdBoENZEOg9SNlOBIFe3XcyBDoCvVvlDoHePwj07pS5nPc30GcI9HJ12RoC/WNDoH8MAr16ues2CHQoCwK9B+l2p6yg9b777gv33XdfuPPOO6PNnz8/zJ8/3+1M1bnkiPY696dzdMt3nmBOZce2xytA8Bpv2QUXXBAuuOCC8M9//jNa6n6Kgt47xmb5znmeOr6zaymL79OKmP7WxNt7tMdLGElYKsjfdttt43faKcArW1VzGaTWhja1N3DOfaQE4EC27777hn333TfstttuYbfddusob7vuumvYddddwxVXXBGuuOKK5LVzyqEVnamcA02Uu9S5ctYrp3Iz/Pvf/07W16233jpsvfXW4cIL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\" width=\"1000\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, 'Local Net Adversarial Examples')"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(10, 10, figsize=(10, 10))\n",
    "for i in range(10):\n",
    "    for j, ax in enumerate(axes[i]):\n",
    "        ax.imshow(local_adv_ex[i, j].detach().reshape(28, 28), vmin=0, vmax=1, cmap='Greys')\n",
    "        ax.set_axis_off()\n",
    "        \n",
    "fig.suptitle('Local Net Adversarial Examples')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA+gAAAPoCAYAAABNo9TkAAAgAElEQVR4nOydabgVxbX3m8N04IAMKqOAckRRMYAoIipRrmM0apDBqKgg6ksQHEDxiYIgXsULxguIRJSAExrFIA6RR2YkQiSRSQREBUFBxQGZp8N6P+Susnbttdeu7t0bGs7/9zzrA6d7d1evXlW1/kVVdUAAAAAAAAAAAAA46AQHuwAAAAAAAAAAAACAQAcAAAAAAAAAABIBBDoAAAAAAAAAAJAAINABAAAAAAAAAIAEAIEOAAAAAAAAAAAkAAh0AAAAAAAAAAAgAUCgAwAAAAAAAAAACQACHQAAAAAAAAAASAAQ6AAAAAAAAAAAQAKAQAcAAAAAAAAAABIABDoAAAAAAAAAAJAAINABAAAAAAAAAIAEAIEOAAAAAAAAAAAkAAh0AAAAAAAAAAAgAUCgAwAAAAAAAAAACQACHQAAAAAAAAAASAAQ6AAAAAAAAAAAQAKAQAcAAAAAAAAAABIABDoAAAAAAAAAAJAAINABAKCUsGTJEurevTs1btyYCgsLqbCwkI4//ni69dZbaeHChSnnPvjggxQEgbFKlSpR/fr16aKLLqKRI0fSli1bvO45fvx4CoKAKlasSGvXrk07/utf/5pOOeWUSM/z0ksv0RNPPBHpty1btqQgCGjYsGGhfsd+OdwJgoAefPDBvP7Wji/Xbrzxxkj3ThqlJV4AAADEB3oNAAAoBfz5z3+mcuXK0SmnnEIjRoyg6dOn04wZM+jJJ5+ks88+m4IgoM8++8ycz8Ji6tSpNH/+fJozZw69/PLL1KNHDyosLKQGDRrQ4sWLs96XBXoQBHT99denHc9FoF922WXUqFGj0L9btGiRKVPTpk1D/ba0CK758+fT+vXrI/02jEDv2LEjzZ8/P83sWDyUKS3xAgAAID7QawAAwGHOvHnzqKCggH7729/S7t27xXNeffVV+vrrr82/WVhs2rQp7dzFixdTtWrVqGHDhrRr1y713izQL7nkEiooKEgT9QdDoPfq1YuCIKDLLruMgiCgf/zjH96/PViCa8eOHXm/x/79+2O5TxiB3qtXr5zvl2Qg0AEAAIQFvQYAABzm/OY3v6Hy5cvThg0bvH+jCXQiov/5n/+hIAjoueeeU6/DAn3mzJl09NFH08UXX5xyXBLo+/fvp9GjR1Pz5s2psLCQqlevTldffTV9/vnnKb+TpkZnY+fOnVSjRg1q1aoVffrppxQEAd18883iuW+//TY1b96cKlSoQMceeywNGzYsTXC1aNGCzjnnnLTf7tu3j+rVq0e/+93vzN92795NQ4YMoRNPPJEqVKhARx11FN1000303Xffpfy2UaNGdNlll9Hrr79OLVq0oIoVK1L//v2J6D8DKa1bt6YjjjiCKlWqRMcddxx169Yt5fnuvvtuat68OR1xxBFUo0YNatOmDb3xxhtpZWSBPGbMGGratCmVL1+exowZY47ZIvu7776jnj170kknnURFRUV09NFH0/nnn09z584VrxuXQN+0aRMdc8wxdNZZZ9GePXvM35cvX06VK1dOmZXx3nvv0RVXXEH169enihUrUnFxMd16661pMczvcMmSJdSxY0fjp7vuuov27t1LK1eupIsvvpiqVKlCjRo1osceeyzl97NmzaIgCOiFF16gu+66i2rXrk2FhYXUrl07+uijj8R7ubzyyivUpk0bqly5MhUVFdFFF12U9tvPP/+cunTpQnXr1qUKFSpQrVq1qH379rRo0SLdsQAAAA5pINABAOAwZt++fVSpUiU666yzQv0um0BfuXKlKm4ZFugLFy6kESNGUBAENGPGDHNcEui33HILlS9fnvr27UtTp06liRMnUtOmTal27dr0zTffENF/BNrZZ59NderUSZkanY2XXnqJgiCg0aNHExHROeecQ1WqVKGtW7emnDd9+nQqW7YsnXPOOfS3v/2NXnvtNTrjjDOoYcOGKYKLn+nTTz9N+f3f//53CoKA3nzzTSIiKikpoUsuuYSKiopo8ODBNG3aNHr22Wepfv36dPLJJ6f8z3WjRo2obt261LhxY/rLX/5Cs2bNog8//JA++OADKlOmDF1zzTX097//nWbOnEnjx4+nrl27mt9u3ryZbrrpJnrhhRdo5syZNHXqVOrXrx8VFBSkDaYEQUD169enX/3qVzRx4kSaOXMmffzxx+aYLbJXrlxJPXv2pFdeeYVmz55Nb7/9Nt18881UUFBAs2bNSruur0D/wx/+QHv37k2z/fv3m/PmzZtH5cqVo7vuuouIiLZv304nn3wyNW3alLZt22bOGzNmDD366KP05ptv0pw5c+i5556j5s2b04knnpgi7jm2TzzxRBoyZAhNmzaN7r33XgqCgG6//XZq2rQpjRw5kqZNm0bdunWjIAjo9ddfN79ngd6gQQO68sor6a233qIXX3yRjj/+eDriiCNSBpIkgf7f//3fVKZMGerevTu9/fbb9Le//Y3OOussKioqouXLl5vzTjzxRDr++OPphRdeoDlz5tDrr79Offv2TfM3AACAwwsIdAAAOIz55ptvKAgCuuaaa9KO7du3L6MoyibQd+7cSUEQ0KWXXqre3xbou3fvpsaNG9Ppp59u7uUK9Pnz51MQBPT444+nXGf9+vVUqVIluvfee83fokxxb9++PRUWFtJPP/2UUr5x48alnHfmmWdSvXr1aOfOneZvW7ZsoZo1a6YIru+//54qVKhAf/zjH1N+37lzZ6pduzbt3buXiIhefvnlNKFHRLRw4UIKgoCeeuop87dGjRpR2bJladWqVSnnDh8+nIIgoM2bN3s/L7/jm2++mVq2bJlyLAgCqlatGv34449pv8smsvm6//Vf/5UyS8Dnt/Z5meyFF15IOfexxx6jIAho8uTJdOONN1KlSpVo6dKlGa+9f/9+2rt3L3355ZcUBAFNmTLFHOPYdmOsRYsWFAQB/e1vfzN/27t3Lx199NHUoUMH8zcW6KeddlpKnVm7di2VL1+eevTokXYvZt26dVSuXDnq3bt3yr23bt1KderUoc6dOxPRf+IqCAL63//9X9WHAAAADj8g0AEA4DBGE+jNmzdPEUX2jubZBPqOHTtCC3QiookTJ1IQBPTKK68QUbpAv//++6lMmTL07bffpv2vaps2bah169bm3LAC/YsvvqAyZcrQtddea/62bds2qlq1Kp199tkpfysoKKDbb7897Ro33nhj2v+IXn311VS/fn0qKSkhIqIff/yRKlasSPfcc48557rrrqPq1avTnj170p7LFmZE/xHorpgmIpozZw4FQUAXXXQR/fWvf6WvvvpKfM5XX32V2rZtS0VFRSnvt7CwMOW8IAjSxLV9zBXZY8aMoZYtW1LFihVTrututBdGoHfu3JkWLlyYZj/88EPKufv376fLLruMCgsLKQgCevbZZ9Ou9+2339Jtt91GxxxzDBUUFKSUcejQoeY8jm13AOT3v/89lSlTJmVQhojorLPOolatWpl/s0AfPnx4Whl+/etfU3Fxcdq9mGeeecbUBzcOunTpQrVq1TLPW1xcTPXr16fHH3+cPvroIxNfAAAADm8g0AEA4DBGm+K+fPlyWrhwIb355puhBfqKFStCT3En+o/wOO2006i4uJj27NmTJtB79Oih/s9q48aNzblhBfoDDzxg/of0p59+MnbddddREAS0YsUKIvrP/9YHQUAPP/xw2jX69++fJtDfeecds+M9EdHo0aMpCIKU6coXXHCB+lzt27c35zZq1Ih+85vfiM/wxhtvUPv27Y1IPuWUU2jixInm+Ouvv05BEFCnTp1o8uTJNH/+fFq4cCF17949rdw8xVzCFdmPP/44BUFA/+///T96++23acGCBbRw4UK65JJL0t5BvjaJe+211ygIAqpTp07aZoclJSXUvHlzOvroo2nkyJFmWcCCBQvSypMptm+88UYqKipKu68boyzQX3zxxbRzu3TpQtWrV0+7F/Pwww+rcVBQUGDOXbt2LXXv3p1q165NQRBQzZo1qXfv3t6fOAQAAHBoAoEOAACHOZdddpm6SdyaNWtCC3SecuxORXZxBToR0bRp0ygIAnryySfTxM99991HZcqUoXnz5on/s2pPaw4j0EtKSuiYY45RxRH/j/e2bduoTJky3v+DzhvCdenShYiITj/9dDrzzDNTzrnmmmvoyCOPFJ9p4cKFtHLlSnMubxKnsWvXLpo9ezZdfPHFFAQBffDBB0RE9Lvf/Y6OO+64lKnXRGQGIWw0geyK2pYtW9J5552Xdt7ZZ599QAT6hg0bqFatWtSiRQsqX7582hTxJUuWUBAENGHChJS/r169Om8CPcr/oP/5z3+mIAho0qRJGWNBYtWqVTRkyBAqW7Ys3XbbbeI5AAAADg8g0AEA4DCHP7N2xRVXpGyWxYQV6PyZtWOPPTbjZ9sYSaATEV144YVUq1YtatWqVYr4mTdvHgVBQH/961+zPleHDh3MlOBs8KZtvXr1olmzZqXZKaeckrJm3HcNOtO/f3+qWLEizZ07l4IgoKeffjrl+IsvvkhBENCCBQuyltVHoDOLFy+mIPhl07sOHTrQiSeemHLOxo0bqUqVKjkJ9NNOOy1tB/4lS5ZQQUFB3gX6vn376Ne//jXVrl2bNm7caNbi2+v5ly5dSkEQ0Msvv5zy2379+uVNoLdq1Upcg27PKnEF+po1a6hcuXJpO8P70qJFCzrjjDMi/RYAAMChAQQ6AACUAsaMGUPlypWjZs2a0ciRI2nGjBk0a9YsmjhxIl199dVpopKFxdSpU2n+/Pk0d+5ceuWVV+iWW26hwsJCatiwIS1btizrfTMJ9I8++ojKlCljpmnb3HrrrVS5cmW655576K233qKZM2fSSy+9RD179kzZTI3L+NRTT9E///nPjP/7SPSfdeLlypVL+da7zciRIykIAvM5svfee48KCgronHPOocmTJ9OkSZPojDPOoAYNGogCfdWqVRQEAR1zzDFUqVKltI3c9u3bR5deeinVrFmTBg8eTO+++y5Nnz6dJkyYQDfeeGPKxmSZBPqAAQOoW7du9OKLL9Ls2bPpjTfeoPPPP5/Kly9vdl//y1/+QkEQUM+ePWnGjBk0YcIEKi4upiZNmuQk0AcOHEhlypShgQMH0owZM+ipp56iOnXqUHFxcU4CvWPHjim78LPZywPuv/9+KigooOnTp5u//fa3v6Xq1avTF198QUREe/bsMWWZOHEiTZ06lXr16kUnnHBC3gQ67+L+9ttv00svvUTHH388Va1alT777LO0e9k88sgjVK5cObrtttto8uTJNHv2bPrrX/9Kffv2pYEDBxLRfwY/zj33XBo5ciS9++67NGPGDOMHd0NCAAAAhxcQ6AAAUEpYvHgxdevWjY477jiqWLEiFRYW0vHHH0833HBDyqfPiH4RFmwVK1akunXr0kUXXUQjRozwXgebSaATEV177bWiQCf6j9A888wzqaioiCpVqkTFxcV0ww030L/+9S9zzo8//kgdO3ak6tWrG7EvsWnTJqpQoQJdddVVGcv5008/UaVKlei3v/2t+dubb75Jv/rVr6hChQrUsGFDGjp0aMbvWhMRtW3bloIgoOuuu048vnfvXho+fLj5vnuVKlWoadOmdNttt9Hq1avNeZkE+ttvv02XXnop1a9f33wX+ze/+Q29//77KecNHTqUjj32WKpYsSKddNJJ9Mwzz4jlDiPQd+/eTf369aP69etTYWEhnXbaafTGG2/QjTfemJNAz2S8aR8PlLjX++GHH6hhw4Z0xhlnmFkcn3zyCV144YVUtWpVqlGjBnXq1InWrVuXN4H+wgsvUJ8+fejoo4+mihUr0rnnnpsSn/a9XHhw5YgjjqCKFStSo0aNqGPHjmYQ4ttvv6WbbrqJmjZtSkVFRVSlShX61a9+RU888QTt27cvq28BAAAcukCgAwAAAAB4wgL9tddeO9hFAQAAcBgCgQ4AAAAA4AkEOgAAgHwCgQ4AAAAA4AkEOgAAgHwCgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAAkAAg0AEAAAAAAAAAgAQAgQ4AAAAAAAAAACQACHQAAAAAAAAAACABQKADAAAAAAAAAAAJAAIdAAAAAAAAAABIABDoAAAAAAAAAABAAoBABwAAAAAAAAAAEgAEOgAAAAAAAAAA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q+QLw3VstN+kfZcY/6o907pP8xV58mKiYUCCXoOwHGHqORJ0EvRKIEEnQW9skKCn99fQpknQ40GCToJOgl5enyToJOhEZZCg1yBiO2x4Trvmb3/7m/vb3/7mxo0b52X//fd3+++/vzv88MPd4Ycf7g466CAvzZo1c82aNXMtW7Z0LVu2dLfeequX9957z7333nv1HMa2bdsyrXosnaHm1HGsKN3heUiatHZrK5yuWLHCrVixokR3PXv2dD179nRHHHGEO+KII9wxxxzjpUuXLq5Lly5eh3fccYeXhQsXuoULF5oBTXPYVsHDCoh5dKetBGy9S/v2zz77rHv22WfdZZdd5gV6adOmjWvTpo07+uijveDcscce64499lg3ePBgL/fdd5+77777/LPlsHRtCkD4O+SxmMSnKSALPY888oh75JFH3CmnnOJljz32cHvssYfXE/7Wjo0ePdoLbLhaERaAYkXrF//85z/dP//5T3fOOed4gX1169bNdevWzeuqWbNmrnnz5q558+buwAMPdAceeKC77rrrvKxatcqtWrXKP1srTGmEXSO1MUQ3BTF60si7RnqXLVvmli1b5i666CIvBxxwgDvggANcu3btXLt27Up0Fx4bM2aMl6VLl7qlS5f6eGQVMTUyorXZSmZTkDo0VvN1y5cvd8uXL3c33nijlyOPPNIdeeSRrk+fPq5Pnz6ubdu2XhAn8Pddd93l5csvv3Rffvml2YbUgktD2l24+rk1LUXmKg8//LB7+OGH3bBhw7yEOYiUVq1auVatWvlrhg8f7uXll192L7/8sjks3dJFVtKeR3eyUGjZFvycRpZvu+02d9ttt7mJEyd6gV5gf7LPwu569erlevXq5e68804v+A6pdpR1R4gUaHZfzsZkQV/7x8Pzzz/vnn/+eTdq1Cgv0FOYC0tbxN9nnnmml08++cR98sknpi40u5IFgyx9mqgekKDXILROSYKerjsS9Gy6I0FvfJCgpyWE8hgJen0hQddBgl6s3ZGgZ9MdCXp2kKCn645oGJCg1yC0TgnHEuMEr7rqKi9HHXWUO+qoo0oSBBwDUTr00EO9wAF17NjRdezY0R188MFeQOzRBkmUYobvNVXyYA1lDUncX/7yFy9aUo9k/rjjjqsn8joZELt06eKJPb6jtmCPJjF61RLgonQXJs8yyIWLNckEtX379q59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vGikvzf70aNHnS+xhh9XRSE3JMbKOKFNwQvZR9uyT0nM/UXo+BxteL7Uj5W/pvHL2v1C8jGWTp06OenevTt179690tD10HvJ8/mdOMaee+65TngBOus5UndWG9L84wooDkDQyxAg6PGJFwh6vO5C3sk6BwQdBL2qAIIOgp7G14Ggg6CDoFe2TxB0EHQgHCDoZQgQ9PjECwQ9Xnch72SdA4IOgl5VAEEHQU/j60DQQdBB0CvbJwg6CDoQDhD0MoTlGHiVdekkfcc7depUJ0yg77vvPifscOWcQpZly5bRsmXL6OOPP6aPP/7YzYWbPn26m8fFCYOcg857rHMb5B7gSR0ezxmKQezqvDy3nwnf3LlzXQD885//7ISTOU4K5Hvy6u1vv/02vf3223Tdddc54bUA+vfvT/3793ckrG/fvmohIF9gO3z4sJmAcdKexu60FfBDkge5vy0TaLmjAO8Fyvvd8m4A77//vtuf9tlnn6Vnn33WzU0cMmSI2yGAky05B52vt9ouxTqWJgAmtTdf5D7onBjdeeedTnjPbZavv/7aCRNtngvLZGvgwIF077330r333uu+h0xauY+H6q5Y+9umgbYP+g033ODk008/LSisN57D/tBDD9Ett9xCt9xyS86cT3+f9epGSJ+0yC6/98yZM91OEg8++KAT9jPsG+U8ai4qsu5feOEFJ3/961/pr3/9q5ujLRNjtlnN7/u+ptC7pUn22WeH7lThy3PPPeekXbt21K5dOxoxYoSTH374gX744Qfnj/nvH374wcXKZ555ppLwnNUOHTpQhw4d3Orjbdq0cTHdapckrFYs5O8YgxD9aN+VCZ70a+zH77jjDie804kmHEN4zQQZc7jPa3GCY7LflnxFW8sPsp0US3eWjBs3zgnv9tGzZ08nHB/Yt3M+t2zZMnrnnXfonXfecbuhyH/kcJzgldvlWiWffPIJffLJJ64NheazWyQziyJ4qH/w+zPPEZfzxHlXid69e7schIULYlJYd9LuevToQT169MiZe87CdhdaCAgpsAClAxD0MoTldEDQbYCgg6CDoIOgg6DnJqkg6LkAQQdBB0EHQQdBB9IABL0MoQU5n5RpybQfmE+ePOkSBpmYM2lnBy/3M+dkgxNUuQIvJ6h8H7lnOLeB26kRdE70tFXotYCZRneygBEzdO706dMuoEndDR48mAYP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yJFUp04dqlOnjjtn2rRpdPPNN9PNN99MnTt3ps6dO6vVNEtKypL2iki8NAGxrF69upPhw4eXkVGjRtGoUaOcvjhBePrpp+npp5+m2bNn0+zZs2nixIlOHn74YXr44Ydd8ssJ2ZNPPklPPvkkLViwgBYsWBDc5q3/23M3K5IZu060Z8+e1LNnT2rQoIGTevXqUb169ahSpUpOKleuTJUrV6bWrVtT69ataeDAgU6GDRtGw4YNc7bZrVs3J1dffTVdffXVLjHh3wPH8He+fU1DkqEYhKzxlqR79+7UvXt3qlKlShmpXbu2k7p161LdunWpVatW1KpVK+rVq5eTrl27UteuXV3f48e6dOlCXbp0cbr729/+5gTHoHspsZASCmkdfKzucB0GF7dv317GJ0htGT9+PI0fP54uueQSJ/BTF110kRP4uEGDBtGgQYPozjvvdDJ58mSaPHmyG0zicu+995YS7gdxDu4TmihmbXOa79Skd+/e1Lt3b6pWrZqTqlWrUtWqValRo0ZOYHvnnnsunXvuuc7/jxw5skzfHDBggBPYNP4eMWKEk2uuuYauueYa9/14oiut9wdB9yvE8xoIaXSXVOD3L7/8cicY5OA2gj527bXX0rXXXksPPvigE/j7Rx55hB555BGaNWuWE8QQ2BZiyezZs931GGjP19bvvvuOvvvuO/r222/p22+/LVVjIo3dxaJt27bUtm1bOvPMM4ME9oc+nIVcf/31dP311zvCu23btgrVQazdDR06lIYOHUrnn3++E8RVxMyOHTtSp06dqFOnTq6PT5061QlyNQyKINe78cYb3W/o1/j7pptuohtuuIFuuOEGN4CSb7AW8RcD8lJcqUjdIS/m+QnkggsucNKuXTtq164d9ejRg3r06FHqHw7QP/KM8847zwnOmTJlCk2ZMoUmTZrkZMKECTRhwgTq06cP9enTJ5PdSgyFAyPoRQg/ITaCnlx3ScUIuhH0NLozgh6nO1xnBD05NN+piRF0I+hp7C4WRtCNoGfh75KKEXRDecEIehHCT4g5QZeqyML5IdHBHq+rVq1y00X/+9//OpkzZw7NmTPHOXgk+F27dqWWLVtSy5YtndNC0t+5c2cXBJD8Igj07t3bBYYWLVpQixYt3NTd9957L8jpZLVXpnRvJHISifL3+uXJNn5DovPdd9/R4sWLafHixVS/fn2qX7++S1A5gYReedIKIorEDY57woQJTmcYQPn888+dSISyvPa3TZrwQ58gVnx6LCoWv//++04wjbZWrVpUq1YtN9BTp04dRxYROPkx/Na4cWNq3LixS/Tatm3rjuF78CUKaKcWFPkx6DUru8ulr99//92RXCSJ7777rpMvvviCvvjii1LLUu666y666667XNLK9YPBEJ/M161b1/3WsGFDatiwoSP4rVq1ctfhe4AcPP3009GV57PUm7avOb7V+vXrnaAt3OYeeugheuihh8Q+OXbsWBo7dixdeumlZQQJFcg/HxSCrWFgClN3ly9frrYVf/PpoFn7Oi35A8nFcgm+FAD99Z133nGCwQkMWOK969evTzVr1qSaNWs6O0PfbNy4sbOrZs2aUbNmzahJkyZO+ABAo0aN6LnnnnMSkrhKU+mz0h2WI0kxFssC0H+hw127djlb44NM6MsYIMcg2LBhw1ysBbHnU74RQ0AoMZAxfvx4Z7cYbNJ2KpFEqoZfkUA/ffnll50gT+G/geggF+GkHYO7GrHHAGfz5s2d+OfwAZOKRMh34oKcbt26dbRu3bpS3xwDLzxOIPbB3/H8DX4e/VQip7BNPtjUoUMH6tChgxuo47EqZGCaL5NE381ad9I0fDxr8+bNtHnz5lJ5FXSIZYzLli1zA2cYtGzTpo0Tf1CEE3ToB/bar18/J/wfFJUqVaK33nrLScjOC3wXJejaUDgwgl6EQOc0gh6vOy5G0JPpzgh6NnaXS19G0MP0ZgQ9ue6MoMfrzgh6+cIIuhF0I+hG0P9KMIJehEDnNIIerzsuRtCT6c4IejZ2l0tfRtDD9GYEPbnujKDH684IevnCCLoRdCPoRtD/SjCCXoTw19hlVSk4xIFKv0G2/m/Ns5S8Yz0eiDoPJFiLlLRdMUi7FjQLWbt2La1du7bUmj9UCJXOx1ovrNPkSbL2HI3AxCCkCnOohBB8JL0bNmxwv+3YsYN27NhRKtnF4Aiq1/N+gQQYRH3JkiVOYt8nBkmfEUKANb1Ka7Zhd3x9JYjXzp07aefOnaUGX5BwIXn48MMPnWjtk75t7HrgLP0b6lpoA0xIio4dO+ZIMv7m/VUbBAOZwnpNPoCn2T18gDTwGgO/Ynu+ZE+TkO+w9X/+f+vWre432BUX2CX6Kx+YwkARiP7HH3/sRCLGeC+tL6fRnfat8b0kv51FbJZ2F9EID9a6YjATffv7778nqQp8SJXwQgZ8EI8TsAc+MOcL4iIfzEF8AEF/8803nVQkYv19WhvjdoYciR+DL5RsEv+EwWDHl19+6USqZA5702JIDCT/4Is0CCWJ5C/9vscHUvEdQOb5MZB+6bkY8MWAJv9HmdY+yd+lqblhKB8YQS9CGEGPd+JG0ON1ZwQ9XndJn2EE/f9hBD3e5oygp9edEfTChRF0I+gcRtCNoBcajKAXIdAhQWwlcqvtYcn339acpLa/pSR+oOckAdOzUSWVXyclOX7gyXqK+zfffOMkiRPnyUBscJScP6by+Tr55ZdfHFHC9HDpnloiKe0ZnkZ32pTw0P2wQ0Sq9I+/JRID+1uzZo0TTEfDdDPJXvPtKOBLDPykRNKPdCy2+rskIXuW8wShRo0aVKNGDTfNUdrbVUvws6ioHfuu8DtIxjdt2qRW748VvBefaghijp0rkt5T6l8x0PoRRPJ13F+EDGLxe0DQN3G9NiiC6bnr1q1z02sxfVayOele+Duradq4VtspRYq/ko1p08yxp3cWfRoDaTNnzqSZM2eK5yet6P9XxooVK5xAd1iex/tgRQJ6x+DVvn37gvyDZHfakhDtWMhgHgbKd+zY4Yg5dp3JN4DpS9ZV3Hl+68cmafkQ8kq+w4ukn5B3Qs4m+S3odeHChU6Ql0B30sA6F7wP7sX9E9puKBwYQS9CaAmC73SMoMu6M4Ierzsj6MlhBN0IeqgYQTeCHtOnjaAngxF0I+glJUbQDeUHI+hFiNhgLiUd0pQliDQ9Kcm0YOx32717dze1/bPPPqPPPvssb7u0Kd9IMMpLd1pSli/4gPRrSRmKfGlFfLAH8+TJk13hOEyTle7Jp5X53zSr/W1DpmzyhDHpfp5ZTcPFtHY+tR2DKmmmnuK9YhDybjx5jm2jRMR8Mi4l6bB3rjsUkFu9ejWtXr06cV+R3icpknz3kydPusJcSfUm7e8u+b9cNoEEa/To0W7aoubDeBExTP3WnhODkKmckh7xNyfo0jf2STk/lqTv86KOIOggTlJ/5c/045F0LAZJ7ccX3g6p7/vvxN8TRavwtxZzLrvsMicYBNcGorDMY8+ePUH2/VcEvgsvXHjGGWfQGWec4ezuVEHz0SHCr8N3lnyaZJMgrrA1LVbyInHI7b7++mv6+uuvVf964MCBMv9o4TaZxu6k52LQVDrm+zSeu2i6l2IsfsN12uAmimM2a9bMFZmTSDnuxf855beLD0bg+xkKB0bQixBpkwcj6OH68Y8ZQTeCHgMj6EbQuRhB/1OMoBtBr0gYQTeCXlJiBN1Q/jCCXoRImzwYQQ/Xj3/MCLoR9BgYQTeCzsUI+p9iBN0IekXCCLoR9JISI+iG8ocR9CKEv4YmVGKrpXMJSYBRdRfVZLt06UK9evWiXr16uerRoc+TEucsnLgWAHnyjGClJbvaenYuIDqops0DE5J5JGd8j82JEyfSxIkT1erY/De/8rkUaGMgrVsOIZIhpDGf+AmqtI76lVdeoVdeecWR8gYNGrh9cTFooa2fl9qX9XpgLmkHJDTh39xfdy7ZPvYY5nukYx91zd9o69rLex/0JPaST09S/0ZfRN+Ukq4FCxbQggUL3L7offr0cXtVow5CvjbAB8AepO8Tg9hBHm0QNnSAC/eAXqXr0F9hZ3Xq1HFEPelAS9Zr0LV1oJqErB/lpBtr7yW/IB3De8LHV65c2cnYsWNp7Nixwd9dIyFpBjcKHdjPmu97Xq9ePapXr57ri6cKITYmrW/W8qRQwbsjT5Ri33/+8x/6z3/+U2qfb6zfx5r0fM/BABLyAl6/I02fDXlHbXBP6yO8n0ixAgQa34XX/UB/XrRoES1atKjUgCTqC0m5udSP+UBHlnmxoXxgBL0IYQQ9vRM3gp4cRtCzTR6MoMfpLcZe8unJCPqfYgTdCLoR9FODEBszgh6vOyPohoqEEfQiREgA1qaeSo5XqpLuO+x85B6JLKo+d+zY0QmSXS1x0e6dFclME8By6VXTtZQwSoQVuh8wYAANGDCgVMKvVfJOWmn/VOpOEskWERCl6tOSraDaLRIF7KXcsGFDcZpfWqkI3WnJcy5bKykJI8z8fOgH+uIE3SdJoeRMG3wpb72FTNvFntB8X2jNP2GAQqpSjv7KE9ZCtrlY0g6RBinwvUP3GIZdofozn2ocqzvtuTHA/uHaM5NOQ5ZiLJY4SdWbtXtjwPuKK65won1jiYyEtP2vBOzmULVqVapatWopgo7lY6caWfoMiDSFHCRZOibZCga48Q8X5HgXXHBBdA6iTT8vL91J+YbUX+DTpD4LX8Orvvt9XPJ3WArQsmVLJ/4/U0L7J3SX1WCuoXxgBL0IYQS9fJ14Ur0aQY8XI+iyGEGP05sRdF13RtDDYAQ9XneFCiPoRtCNoBsqEkbQixDoiJg6k0VhLf4bSBGIT2gisnTpUlq6dCl17tyZOnfuTHfddZeTkDZIwSLr5OHQoUN06NChxHrC+yOQ5yrWFhIcJcF0WBSEmz17tpOQ50j7e2atO98+stqf2xdperI2He3FF1+kF1980e15Pn78eCeanaPvhAbtNPviIuDH6i7N/vIaoX/hhRfohRdecIMbV199tRP/e0v9IbRd0HVSaIXWNLKJKYB8OmjSacsgaRL5W758OS1fvpyqV69O1atXp1tuucVJyL3hh0J9UQzQZ5LaTmghUOgf9qU9hx+bN28ezZs3z5HyESNGOAlpnzQQINk4/EgMsD85L9AWEmuRoPP3lfz/qlWraNWqVYn7Mqa9X3XVVXTVVVfRSy+95CTkW23dutWJ3+as7K5Q8fjjj9Pjjz/uSDmWogwZMiRV4dksgW8hxaSkRR+lOApfDnsIzRs++OAD+uCDD1wB0dtvv91JSFukaexZ+zut4HGI/+OxWfInfvtDC6SifzZt2pSaNm0aHCtClzT+lfvs6Q4j6EUIdEQj6MlhBD1ed1Igi7U7TYyglxUj6Ln9hnTMCLoRdCPoZb/VViPoRtCNoItiBN2QNYygFyHQEY2gJ4cR9HjdSYEs1u40MYJeVoyg5/Yb0jEj6EbQjaCX/VZbjaAbQTeCLooRdEPWMIJehPCdjuR4+LpxzXHhHL620N8HMzQgTJgwgSZMmEDdunWjbt26ie3T9mjVRAokMQh5Jz7wAYcdW8E8VO644w6644473F7Kae4FQqINJKSxu9BK6CEi2UjIvUHcfvnlFxo0aBANGjTIBUC+njOUbEBCzk+jO2lP4xCCw8W3yXzrzPna8ZMnT5ZKRKC7Ro0aUaNGjUoNKPnP4ddp6/ayXIOO53CiHdLvpJoZ/rrzNHL99dfT9ddf79b/8rWKSOSkdkq/4TrN9tLYnLRuPLTKvS/antyhMnToUBo6dKjbC5jv5Yu+L+lCIsggLdqAUQywNhw7bqxdu7ZMf+V9Sqt9sHv3btq9e7d4LNRGIH379qW+ffvSqFGjaNSoUeK3SRqX0N/Xr1/vJI3uCgncXnv27Ek9e/Z0A7moO7F58+ZT3UwH3ydIAyf4x8m+ffvUwRVtHbUk2mDomDFjaMyYMdS1a1fq2rVrqRxAG3DWfBryUqkqfRrdaVXOpX9qwXfw/oxcU/rnlJSf+O3nAxLYIQBr0OEPcvkETdB2+MusajMZygdG0IsQvgM2gh4OI+jpA6AR9HjdGUFPBiPo6W3OCHpyGEGP110hwQi6EXTJhxhBN1QEjKAXIfxAzqcZhkyf5Q6bT9OBJCE1n3zyiRNU+HzggQfogQceEM/396D87bffovdnz0p3SZ8LSTpV2a+K/fXXXzuB7p5//nl6/vnnVd1JxzixQnCSpkiBuKbRXVJJSpJDBHso833PJ02aRJMmTVLbkNTOs6qSqpEaJFKSTWrknZ+v3d8/hiUBL774okseMLim6cIn4DFT9mNtDslcroFGiJ98SckpT9pDqnVDZs6c6QREyV9KESPat4PPiIH2zJBBMInYx/br+fPnO2nSpAk1adKEpkyZQlOmTBHP59PYfcnXrrQ2x3UXOiDh99t8pAjVm6VBB/9ey5Ytc4Ip2ViaotkT7zMQrkf/OXzQM02cKCTwpWKY2j58+HAaPnz4qW6aCH8AlH+fkB0qtOUf2pTskpI/iT98+4cffuikQ4cO1KFDB7r//vvp/vvvV9vACTdyu9Blkmn2oYeNS++pxShpYAL+hQ8eavki+jF0hz3PFy1a5Cq2T58+naZPn66+f9KlilyvWDJlKBwYQS9C+IHcCHo63SV9bojTl8QIetz1khhBN4IuiRH0srqTxAh6mO6MoJ/eMIJuBL2kxAi64dTACHoRIp9TzOXEMb2cO384FM0xSMfgDC688EInmNouJU/alJ6khe7gUNPojr9TSOK/bds22rZtm3hM2lcZwkk4kuKdO3fSzp073ZQ7LtAFDzJaYIBzXrFihZMQHabRXWiwRVCUyADsjifbfNrckSNHxOQYhQhr1qzp5Nxzz6Vzzz3XJcRSciO1QfotJBmPgZYkaQRdmi6edIo7BEseuO7q169P9evXF+3bHxyQ/EZon43VXex0ao3A8SQWPkCb/o6piiikx0Vrg0bQQgcIMYAQA9yDT+v0SW6o7nC9RI7xHtLSF/g+kPImTZpQ27ZtqW3btq4Qm/RtpHbFLjNKozsu2hTgEJEKA0rT5f3rsCRg6NChdOWVV9KVV17pinZxWwa50UhYqKA/nK7AEoXKlSs7qVOnDtWpU6fgprVzaL7C75+8D2r+WBosyjUFvKSkhLb+r4ggiv127tzZ5SfYSz7UzyUVxLasdBdCduGzpNgcOjDs64LvE49YIQ0g4LuF5FOhYigcGEEvQkid0gh6Mt0ZQY/XnRH05DCCHqc7I+hG0DXbNoJuBF2CEfSyfsgIuixG0A3lBSPoRQipUxpBT6Y7I+jxujOCnhxG0ON0ZwTdCLpm20bQjaBLMIJe1g8ZQZfFCLqhvGAEvQgR4oh4wIdojlRyTtr5WMfFk9X77ruP7rvvviAHxn/TgkXWjki6D5JgyUlqiSzWJiVtN/bAvPTSS51gfaZ2nebEtXWZUuXSGEiJn5+QS0m6pldt3bX07u3ataN27dqVsjvYorTOLKTSbEXYnbRmOxe5liQNOcZ13bt3p+7du1PdunWd3HrrrXTrrbcmriQfIlnYXRbfK62gtsEll1zi5B//+Af94x//UK9Lsu8vl6wqkUt9TFt7jj6G63g7JN+C8zVS3bt3b+rdu3ep/nr33XfT3XffXaaP8nZJz0tKPHF+DJJ+s5CBAj6wyQduv/76a/F82Bjvr48++ig9+uij6nfEAHAWtn+6AXpBnMC68zPPPJMmTpxIEydOPNVNVCHlQv635n4VNi4Navu7Xkg1EqRjiKfQYbt27eihhx6ihx56qNx8bBZ2J/2jx/ejEuHGOTwHhj6lf05pg8bYFYX7O9QrCfFVmm8JrZdkKBwYQS9CSJ3SCHq87oygh8EIerzujKDH6S6L75VWjKAbQQ/tY9o5RtDLH0bQjaBLvhR/G0E3VCSMoBchQjqpRNj8hCpXUoXKm/50vJKSEpo6dSpNnTrVOZ+rr77aSUi7JLImkfbymmqcNFCEJNnS4IbkUG+++Wa6+eabne5uu+02J5ouEEAwhZHvsZn0faD/GCQJElxC90zXpnthv2noDol/79691b2TtW8VQlakKfcx8N+Nv5+kVz9pkEgbv5c2ADF48GAaPHiw012PHj2cwA9IpBwJD9rHdYdjvA3+PaQlCkmR1Na0RCfpNMIZM2bQjBkz1KntWUwnLq9p2iH9jts3+g//bv73k0i71H5MxYa+evXq5cSveKy1i9sXnhe6xCaN7qTp99p3CtlFQdqfGdOt+fn33nsv3XvvvdSiRQtq0aKFGGP9/crzSexOGqcDOIGBjYGUt2/f3gmW+BUyku5o4/dFKRfBPffu3avmfRiIRJ8dOXKkkxA7kgYX8E8M3i6f8EoDdDHQ/tGTdBlliPA8DIM/WqyIXa6l7QghfW9D4cAIehEiSUA2gp5cd5IT1s4xgq6LEXQj6LF9NqmtGUH/E0bQ43VnBD1edxUNI+hG0ImMoJ9OfbZYYAS9CKF15pBp1/mmzPiOjjsiOJ2uXbtS165d6aWXXnKC8xEItWeHOietQEfWustiGrRWbKpNmzbUpk0bGjt2LI0dO5ZeffVVJ3DAsYlUUslKd1rQ8ZNsntxL5AG2IRWkOuecc+icc85x9rd48WInfhu0Kb359jX2A7k00JWV7jSC4k9xz3ed/xvf0xh7nUN3S5YsceI/lwd8f0/efO3U7C12YEi7Z0jCg33Ed+3aFdQ+/ps/PVvTW757hYhG9rOyOf9bagMs+QTJPvrY1v8Vl9q6dSs1aNCAGjRoQNWqVaNq1arR+++/7yTX9UeOHFEJBIQvE/HvVZ66g0jT0pPGDuhJOjZw4EAaOHCgG+R4/PHHnWi2gr3Lk9qdJqcD+F7VfEr7mWeeSV9++aWT0wHat5DIO/Yul86Xjvm+ift77HWO4mYvvPCCE/gNTJuXSLXmj6U4ocWVNLoLnRLuDxRwO5LO94tE8lwCSwHOP/98Ov/88+mVV15x4reLT7MP8RtJ/yFjKBwYQS9CaJ3TCHq87oygJ9edEfR43RlBj9NbiO1BjKCXFiPo6e3OCHphwQi6EXSuOyPohkKBEfQihNY5jaDH684IenLdGUGP150R9Di9hdgexAh6aTGCnt7ujKAXFoygG0HnujOCbigUGEEvQkid0l+jwp2URpghOIefB4d01VVXOUGyin1GkwZ8OCa+Lqoik4e0CYsUmCTBIMfkyZOdNG3alJo2beoSKV4hNIREaMHuVOlOCzCx63OhC1Qd7969u7O7d999l959990yBJav75bWZeGbSboL/ablbXeceGjJjk+gOYlG/8JgUJs2bZzu5s2bR/PmzSulAz+RkZKbUFvLtW6ZH8tCb1ryFbvWEP2V76wAvWH/eH5+iE+N7a/SN8jK5rQBQC1519oP3bVq1coJdIf9uvlAQGwtC2ngw7e1rNZkJm1biG1qgjoRvFYEdhepqDZIUshA7OS+DsTc/6dBob8LkPR7av6b94Vc69JRdZxXHkdux4lhyKBjFuu8EYez0l3Is5L2F/hQ1MXhtXEwGMTjYNr+GFpzA9/KUDgwgl6EkDqnEfR43cU4dSPo/y9G0LOzOyPoYXozgh6vOyPo8bpL8u2SXmcEPTmMoBtBz6e7kGcZQTeUF4ygFyHSBl2JjEsOYcGCBbRgwYJSARBT20OmIqaRkL3Rs9JdkumJoQMLa9eupbVr17rpigMHDqRrr72Wrr322sS6yDLhykJ3nBhquvOrQodOPXvyySfpySefpIYNGzpBAExCjCSbzndeyBKDNLrTyJo23TgfycOx559/np5//nmqU6eOE+yhLFWMznWfGDKptRkSq7dQ0ZbEaPLpp5/Sp59+Sn369HHSuHFjaty4ceJ7+TbKl0lo9i8NaKXZdUH6DtpAlN+XpeUdXHAvkCFeubhGjRpUo0YN2qpM5Q7Vwansr5KE+JJQXwcyxHelAFFPanflIYUMTPv3p7WfeeaZtG3bNtq2bdupbmJiJP0+SXMD9C8MnMHHNW7c2E1t96d+Zy3In6RdGeC/K0J3IcL3nMdvWKrTtm1bJ02aNKEmTZq4OBL7PL7DkpZb4R9y/J8LsTHWUH4wgl6ESOt0jKCXFiPoyXRnBD1ed0bQ4/QWKkbQdZszgp7e7oygFwaMoBtBT6O7EDGCbkgDI+hFiLROxwh6aTGCnkx3RtDjdWcEPU5voWIEXbc5I+jp7c4IemHACLoR9DS6CxEj6IY0MIJehIjt/KHOHOS4efPm1NxtTxcAACAASURBVLx5c6pevboTOHF/zXtJSUmiSpNc4Ij4muyQ69LojidQ/jpGKTEN1R2cK5Ksa665xgnWemnXS2QWQVXTzZ49e5yUl+6SrNOOEaw954k+pHLlylS5cmW1ympIsi4lztIavfKyO4m0hjwz3/krV66klStXOn2BlNetW9f9tnv3btq9e3fO+/r3Tpr8hZwfq7dQwuML/JTvqyDwPT179qSePXuKtqc9F+uE8w1WpZUYIOnl6yG1daK+H8xnc/A30BMqtzdo0MDFi9WrV9Pq1avFPhZShV+qaZC078RA8qVS/8nVB/KtG8Wx9u3bU/v27UsN5EKfIe8mPUezd00kvRYiUBMCO3v8lQh6iI/TbEsilJI/7NKlC3Xp0oVatmzpBHYnxXnkhNI/ZtA/tT5ZkXVeeP4Wm5NqupNiBCS2NhCq40vHeC0A//58t5ZC7rPFCiPoRYhYB2ME3Qh6Gt0ZQU9vd0bQ4/RmBD05jKDH684IerzuyhtG0I2gS8C1RtANhQIj6EUIf7qi5PSSOkQur7/+Or3++uvO6XTs2NHJsGHDaNiwYbRjxw7asWOH6sj4b0mnnoZUBI2Bdj8Ex3xBThNUaB8yZAgNGTKkVCXyUaNG0ahRo2jnzp20c+dO9T7c8R46dIgOHTqktpn/phF1nB8DTSewyaS648Trrbfeorfeeovq169P9evXLzXFvVevXtSrVy814PqJAu8jofvLhxD1GGjEPNbWuO7eeOMNeuONN9y+09j7vF69enTeeefReeedVyaQl5SUTvb8veqTVt3WkpPy2Ac9C1m3bh2tW7fO7QHcqVMnJ5MmTaJJkyZFfxdff/l0uHHjRtq4cWOp39JU5sU9tKnqoRWCJcE+v1hKwafLohL+pk2baNOmTeL1GNAIHSCT3iEkxsVgw4YNtGHDhlT60WT06NE0evRop6cBAwY4wYBuUl1oA7ix71CIeO655+i5554TiTkGPJCDnG4IWcIlkbJQWbhwIS1cuNDFWPzD5YILLnB2B9vn1yG2lucgZFq7g+7S6McXPkC4dOlSWrp0KTVr1oyaNWvm/oHVvHlzGj58OA0fPlwcdPSn7/NjGPBAfODLT0NihhRbDIUDI+hFCCPo8Y4oxNkZQZdhBD3e7oygG0E3gl5ajKAbQY+BEXQj6JrujKAbCgVG0IsQIVPttCCdbzr0kiVLaMmSJdSoUSNq1KgRTZgwwYlfaCrptPSkIjkpPC8G0jP85FBKGLUEh+sT5Puyyy6jyy67jO677z4n2juFSBaF+bZs2UJbtmxJpTuJZIZMb8uX7M6fP5/mz5/vkofzzz/fiX//0MQ51zKGkhK9OKD0jUCk0+hOG8CQgm3olPg5c+bQnDlzXHGuyy+/3ElI/8S9Q/e+TiqxBWykRMtvF6aZ8z2jQxM0TMFGYTgMQA4bNsydoxXXkwaMQJ5CByU1EguJASfmoQNUXL/5rnvnnXfonXfeoSpVqlCVKlVK7eWNKbGSDcEfhPgzaYo7F20QCW1Po7sQPcX0kfXr19P69etd0dWpU6c6WbNmDa1ZsyaTfgfZKhTr03IADBYVInyCzgfB0+yjXQgIsTsp58Lf+frsihUraMWKFa7o7/XXX+8EuYHWz6SBtNh8RhIUkIuB5jPQRvhk7pf9Imu58ozFixfT4sWL3T+u8E+YIUOGuH+iIKeQYrlU+BjP80l5Ln1qx3APQ+HACHoRwgi6EfRYMYL+5zEj6GUTBSPoRtCNoBtBN4J+amAE3Qi6EfS/DoygFyGMoBtBjxUj6H8eM4JeNlEwgm4E3Qi6EXQj6KcGRtCNoBtB/+vACHoRQnNsIfuHaw44zVo7OEXtPjhHCiS8EnJIRfKsdFcI4lfxlNYFS9dJx0LISUXoTlsfCpIqBdOk69ySJNP52qfdK5Zk5tKdX2U7dP2+1r+Srmf37yX5AdyTJw/SN/J1zPtzrO6SfP/QCv5J7dh/P/6OIeQafTtXld59+/bRvn371HvEQNKJv/dwqO0kIfj5dB6yJ3zo9/ZJvvSNYhBrI5IgNmdxL78vxn4Pvt41a7szxEPql0l2Z+GStIJ5EpuSiCSIL++D6J/ISw8cOFCmRlFWlchD3kkbVOOD01n8M8TXizbQ6PtEPpjAz9PqEVmfLTwYQS9CaEmAEfTkuisEMYJuBN0IepzNGUGXYQQ9XnexNiKJEXRDKIygZ9tnjaAbTiWMoBsMBoPBYDAYDAaDwVAAMIJuMBgMBoPBYDAYDAZDAcAIusFgMBgMBoPBYDAYDAUAI+gGg8FgMBgMBoPBYDAUAIygGwwGg8FgMBgMBoPBUAAwgm4wGAwGg8FgMBgMBkMBwAi6wWAwGAwGg8FgMBgMBQAj6AaDwWAwGAwGg8FgMBQAjKAbDAaDwWAwGAwGg8FQADCCbjAYDAaDwWAwGAwGQwHACLrBYDAYDAaDwWAwGAwFACPoBoPBYDAYDAaDwWAwFACMoBsMBoPBYDAYDAaDwVAAMIJehCgpKSkjv//+O/3+++/u7z/++MPJ8ePH6fjx42XO5YJzjh8/XuZeXE6ePEknT54Uz/F/4/eX7pXrHaTrpN9i4OuC3/vIkSN05MgRtY0nTpxw4uvk5MmTQe/5yy+/0C+//CLeN8l98gnu9dtvvzk5evQoHT16NDO743bj6zXXOfw87Zh2r5Bz8p2nfVPtXjGA3qXnS8eOHTtGx44dc7aJc7iEfPuTJ0+6dwu5TmqXZJP4TWsP3uHYsWPRugtpJ3+O/x3Rp0P7daydHD582ElSm/v555/p559/dsd++uknJ2lsLsRHh3x/LtI39f/OZ9uh3zLfPfPdF/EvBkn8R6hI31UT2JMUX7Q4EfqNfR1Leo2BFN9i9fnrr7+WERyTnuMf03IQ7hsQHzU/wPus/2weY9PozhAP6duF9AX4Cek6yX4kW8azpefhfKnPJvHH0vlZ5cWG8oER9CJESMc1gi7DCLoR9JBvqt0rBkbQ43QX0k4j6DKMoBtBD9G1ptcYGEGP150hHkbQze4KDUbQixBax03a4UOchpSYxiZ/2jla+6U2pNGdRLwkQqu9i5Rs/fjjj/Tjjz+qz5ECif+8fEmqL0jyf/7555zJHP8tBrgHfye8SxZEO+11IaLdM9+z8a5p7I5/1xCSgXN4GyW7CLmX1LckEubfS7NDPhCI6/wBAS5JISVK6HdJyZ+mX83PSAQfbdAGKqTET9JbLjsrD1+Xi1zz3yT/JOlaIzMagfRtQtOFdMwn8bneJ4v+ygX+NcQv5xu09f2NZD+S3R08eJAOHjzo7I/rB4T+0KFDdOjQIdUH5CMcaQY3/MHgo0ePliG0ks/1CXhJiUzC/VgZ2vdwfxzj30gbOJaeExIvDBULzc9q3yk0Zw45L+QfLLzPJsmZyzMvNpQPjKAXIfJ1YiPo+XVnBD05jKAbQffFCLoRdOn9jKAbQTeCbqhIaH5W+05G0A3lBSPoRYh8ndgIen7dGUFPDiPoRtB9MYJuBF16PyPoRtCNoBsqEpqf1b6TEXRDecEIehEiC2eTRHiwwv39v7loiVuIw8z3Pvgtje64Y4OEkHIpGQhx2CdPnnTJBhIvnkxKyQkkyWBB6PrGGISQ3FA7SpK8+tfmEsnukrYr5Fgau5MIbYj9hNqidL72HPQl6Zy09RCyIOhaf/XXboeKtJ5V6jvautTy8LN+W3766SfnM9LYnCQhJJP7dG63vg+XfLq2llyzxxACpA1eSuQ9BhIx9AdjNLKLgVo+WAtyffDgwTLt5naNby/VNNBsHjbNY47fh/lzfB1L9Rqysjs8Sxp08Alzvv6Ryw75Mf4uEG3Nuv8dJR1qA0lZ6c4Qj5B//kh+DMdCawmFrFmXjkn3TpoPh/hrQ+HACHoRIqSTZtHh/eBqBN0IuhF0I+ihYgQ9ToygG0E3gp5bjKAbJBhBN4JeaDCCXoQITapyOY3QKTZwKNI9NEeUZCoQv7/kILU2xCBXgpRPtKQnqQNNep1P0Hnyh6RA03sW1bSJ5CqpkBAinE9CphmGHAttlzYFXprOn0Z3/vTvEyf+rNifZKp7PmIjne9/N8kekk5hDrFlqQ1JkWTQKV/7pPfx768l4SF9M5+dob9yO0BbQbCkbx0DfGPpnaTBk7T9WyPxms1pPlWasq59o6x8nfQtNB3gu/qkPJfucD7eg/t0jYBqbfEJKI8J2gAwYiLfiQDfI43utL4nEdosY0jaeC0NrEvfD8ey6rOGeCSNB2klNNdNkheHthl2zv1Emj5rKB8YQS9CJHEGRtBLwwh6vO6MoMfrzgi6EXQj6EbQ/fONoBtBN2SDpPEgrRhBN+SDEfQiRFKnoE1HT+qUfGKv3Ysf84OkNpAQ2q4Y+AnDiRNl9zTVAjaffiolY75IRTxCpubyZMmf6sj1FNJ2ybHHQCO0SZ6dhDDnel6+33yRkjSpLf5v0pTQNHYnPUuz+RBSzkkO7iUljH5xOukc/pt/L8mutbZmMcUdfY1/y5ABDZ/8cv3y9vgkQdKJNL3ef55EJCW71AYOJEIGX5GVzYVIkiU8/N35b0lsh+suhJwmfY+sdAciK9mAP6DHj/kJNO+nWvtR7E0isxIx9OOEtIRKiif+O/A4FwPcI2mhU0nwntKAFgbH8vUv//38e/P90qXrQgbhJDFULGJtzPdZobmptPxBulfIc0KO8eNmd6cHjKAXIYygxzsiXGsEPTmMoBtB9/WitdUIelm7NIJuBN0IergYQTeEItbGfJ9lBN2QFYygFyGMoMc7IlxrBD05jKAbQff1orXVCHpZuzSCbgTdCHq4GEE3hCLWxnyfZQTdkBWMoBch/ETHT0STdGoc40mRRqJASrds2UJbtmyhH374wUkSJxjqILXz0uiOC5IIaSBDexdprR10KAV16AkJ1b59+5xo6z+RLKFNUsV2nsRpiSzOiQH0I5FWjeyGEOFcv0H2799P+/fvp23btpWRENKvHQsZEODnxyBpopqLQHMbkxIE6Xz0VfTd7777zklIG6Rj+P48CYd+NHKVhd60AS4tmZaOaevN9+zZQ3v27HHETKrMrbUldLBROw8+JgbS/XKtA9cGbUpKylYw5yJ9o61bt9LWrVtp06ZNtGnTJtq8ebOTXG2RbE6qys5jVa5BkTQ2R0RitXFtQBbfUPPjoYJ3g75gt7/99puzt1wkm9tM6HOkY2kIut+OX3/91RFh/B0a63E+jznQhfSeaPfatWtp7dq1tG7dOie5yFS+52k6lAbI0/TZUwn4u127dpWR0wG+XfMYGZsXS79Jg/0YTENOsnPnTidJ/qEW6ytsDXphwgh6EQKd0wh6vO64GEEPgxF0I+i+7zGCbgTdCLoRdMnujKCfXjCCrh8zgm5ICiPoRYiQDi6RjFAn5QewN954w0mlSpWoUqVKVLVqVapatSrVrFnTSceOHaljx47Ur18/6tevH3Xo0KGMPPjgg/Tggw+WIgmSwwsJ3lnpzk+8pGmAIdPZuSDB++qrr5xAZ9Bhy5YtnYwcOZJGjhxJDRo0oAYNGlD79u2djB49mkaPHk0zZsygGTNm0IEDB5xIzw6ZkpeV7kKmmYcc44Kkm9sdbKxatWpUrVo1p8NKlSpRr169qFevXtSlSxfq0qUL9e7d2wl+u/XWW+nWW2+ljRs3OgkZJJDamkZ3GrHRSJI0XVRLIhcuXOiE66pSpUpUp04dJ5dffjldfvnlrn+2bdvWSbt27ahdu3b02GOP0WOPPUafffaZE63N/mBBminueA4fjPD1IO1rHjst9d///reT1q1bU+vWral27dpUu3ZtatWqlZPhw4fT8OHD6fzzz6fzzz+fGjdu7ATHnnrqKXrqqadKDWJK38sfbJMG4NLYnCbaMod81/rf4aWXXnLi2xx0WLt2berfvz/179+fLrroIrroootK+Troc+bMmTRz5sxSA3FSbPBtLmtfx/uY/02k/he7w8fnn3/upFmzZtSsWTMXL5o2berkmmuuoWuuuYaaNGlCTZo0oRYtWjhBnPjXv/5F//rXv2j37t1O/KncoWQgK7vz+yefXg7/GrpcC+djsOKZZ55xAt3Vr1+f6tevX0p3Q4YMoSFDhtC5555bRhCH0WdBVvfs2RP0PlzS/AOhooD+8vrrrzvx8xMu3bp1o27dulH37t1zyp133kl33nknbdiwwQl8REVA+xaS70jaR/1lTq+99pqTKlWqUJUqVejss88uI3369KE+ffo436blxVv/N7C5detWcZBQex8j6IUHI+hFiBBHZAQ9XHdG0ON1ZwQ9me6MoMfpzQh6vM1pYgRd150R9Gzszgh6YcEIuhF0Q/nDCHoRQnNE2tQx6ZhGlBDw4XyqVKlCtWrVolq1aomOqHLlylS5cmXRwfvngmhVq1aN2rRpQ23atMk5vTJX27PSXYiAoEtJGSdPaNstt9xCt9xyi0sYmjVr5khR8+bNqXnz5qWOgQyAFDVq1MgJkgj8zYk9EjUpkGiJRRrdacQwDTFHgMFgBbcfbi+++LbG7RXnnHXWWXTWWWeVug4Bky8PwHtpReXS6E4jRKHHNAI1duxYGjt2LNWoUcOJT5J4P8SxevXqUb169Uodw284p27duk5AVPkUO7RL0l1agh6SsPPlF0jeJbIr7Y08bdo0mjZtmmhzeFdOhnAMSe0555zjBOfgPuijTZo0cfoL9TtZT3GH+FPEOdGWpp5Dv9L548aNo3Hjxom6g83xQSEpPviDR9JgEr4DH0CFv9Wmy6fRndbfsPTh4MGDOb9bvqnmU6dOpalTp1L16tWdwFeh/yJeNG/e3B1DvEDsbNOmTZmBNZzTunVrNwCSNO5lbXcQPm3f/y1Ud2PGjKExY8ao+QYGvBs0aFDmHE7e0T8lX9epUyfq1KmT2AbJ7jDQUIhAvx82bBgNGzaMzjzzTCdav4w9p3PnztS5c+dSAzLlBehfy4G1/CSUvMPukAvXqlVLzXc1neEc9Gt+HfI+rjv/HXm7ToeBoWKDEfQihOQ0jKDH6y5EjKAbQTeCbgTdCLoRdIgR9OR2BzGCfmpgBN0IuqHiYAS9CCE5DSPo8boLESPoRtCNoBtBN4JuBB1iBD253UGMoJ8aGEE3gm6oOBhBL0KErNmW1qZoe5jzip1wqpJDGTRoEA0aNIjmzp1Lc+fOdWsFZ86c6aqlfvLJJ/TJJ5/Q4sWLnaAi7f3330/3338/XXDBBU6QmNxxxx1OfKeYNUGXkvSQY7ySs19Z9+eff6brr7+err/+ekcQkSy1a9eOBg4cSAMHDqQ333yT3nzzTXr//fedgESsX7+e1q9fTy+++KITrDefM2cOzZkzh6644gonuPejjz7qRCPoaaq4S0FOI974zd8jmJ+3fft2J1jnJtndgAEDaMCAAW6t4axZs5xgvduyZcto2bJl9NFHHzn59ttv6dtvv6Xp06fT9OnTS613BYnAsenTpwe9YxrdSQTC3/uZEyctUeBrm5FESrrr27cv9e3bl+bNm0fz5s1zffD++++nVatW0apVq+i9994rI99//z19//33dMMNN9ANN9zg1gxfdNFFjjzcfffdTsoj4Ye98j6Waw2/pFt+HeyQ92H0SRAZnnRhsOPdd98tIzt27KAdO3bQ6tWrafXq1fTqq686wc4MTz/9ND399NN06aWXOsE69dtuu82Jb3MSecnK5nxiwcUnotJAHF+bC/8NO+P1SBAnXn75ZXr55Zfp4YcfdoI48+mnn9Knn35ayg9u/d/6y3vuuYfuueceuvDCC51gAASDKdOmTVMT1iwIOrcf/1mo3Hzo0KEyz+T+AnbHiSfsASSQD7pirfSiRYto0aJFpfSDNeWItdwm4QtQQwG2PXDgQDdo9PjjjzvxK/NnVftAGtDwCbe2fl+q/s77bI8ePahHjx6ir7vkkkvokksuofnz59P8+fPprbfecoL6GR9//DF9/PHHtGDBAiewSazfR12TXr16uT574403OtH6VqFVcd/K1jXjnTgxh2CtNNbhc0Hdlg8//JA+/PBDWr58uRPYInI3XscE98ZA1NSpU8vtPUMIuibS+dzfoa6NZHdXXnklXXnllS4v5rVM1qxZQ2vWrKEVK1bQihUrxLwYukHNnC5dujiiruXFPFc1gl54MIJehDCCbgTdCLoRdCPoRtCT2pwR9GS6M4KeHEbQjaAbQTeCbjCCXpRA5+QJve9kpI6rOae77rrLCZwOiDOSrUGDBpUJ4JLk2pudC3c6eN55553npDySfaI/p3jxaZJ+4s6Th5DKskgG5s+f76bMgTjzxAv7YoYkzvw3kBToHksPRo8e7XTXtWtXJ2h7eVU21qaJSc/ypx/zpIyTRX/qOk+S/O+gTZeXjuEb8+QeusPuAx07dgy6VwykfaQ1ciHtMw7Bvf75z386wVRiTEvngd7XvxTgtSQF59x3331OsJyFV/H17yW9a6zNSSL1zZAq2vfee68TTH9FEn711Vc70ZYS+M+RBvWgbwxw3HDDDc7mBg8e7CSkzTHwBzLyTWP3bZ7bAs7nSbs/DZ37IH8XjNB9pX35v/bOPObOqtr/FAqBCw1jLGiYbCBgINwGQomkDTU0F1IipFQRuK1UlDAPFyoEgUuBoEXghkkiSABzsUY0oES5ARQK1JEZGQQRRJChUK8MFoF2//743e9mvftdZ539POe85dDz+STrj77nGdezh/Xd3XttCfVzzjkn309C4t/+7d9GDZ5579oG75vob957RO2fvoMVhOXUWE2bPfzww6v8Eu1SoH7syiuvzKb6aqfLq1/R89mlPv3oJ7z2zKuzZT9ln0Ni9/rrr8+mQSDVWYnyvffeOy1dujQtXbo0/B56hmggXtnyv/jFL44SYbNnzw7boF58NxbYwbFSWNq61MvgvUXL+0499VQ3Phkroj47ioGjdsmLi73yUBMXe+1q+VxefGLLd6d+yJZhGBwQ6ENI2bEh0OtBoPceeCHQm4NAb+e7qK4g0GMQ6L3XV++bI9BjvGdCoH94INAR6PDhgEAfQsqODYFeDwK998ALgd4cBHo730V1BYEeg0Dvvb563xyBHuM9EwL9wwOBjkCHDwcE+hBSNjq1a2w8waa/2YaozLgercPznsEbJNBvTz75ZHryySdHZJnWfex67fL5vMGINih4ifwUddye/ehHP8omgaQ1f3ZtfxlAWasJ9LT+UOuNJ0+enAMvm+24HHDoV/AQdYBRhxQdY9dElpmx7VrEmu8RrYn//e9/n37/+9+PyOqr+9l8CNE1e/FdNEjhCcEa32mN87e//e28llVC3XvuKCN8ZFonZ7OY6z777rtvNltvysEI/a1tmbMDajV1MqrLdj2k1jVrNwVvHa7avii7tCdulBtBQmKLLbbIg542g3R5Ldum9jvvgSwKSqOBCZv7wbY5G2+88QjflYMDtv2O7q3jn3rqqfTUU0+56z2V3Xi77bYb9Z373dbVWrn7g1fPb7zxxmzKUaLcB145Lftca9Hgq+qrXQvsDUaW5drLFt2G6HrlIOOKFStG/c2rvzbXjXYzmThxYpo4ceKIbPr2nqXVfEetE7Z1Vr6zuzGoXpZ1vtdyNxZEAt220b3y4IMPpgcffDD3DRtttNGHItCjuDj6TyPvOE+ge3Gxjm8zCLly5cqcy0Tx3Pjx43N8bPPmdIq17d9gcECgDyE1DVFtp45ArwvqI0Og+4ZA/wAEOgIdgY5AR6Aj0Fc1CHS/bUWgw1iDQB9CahqiKHjwzvv+97+fTUGkGqQ77rgjW9OGpww21NDYTkKC7Mwzz8wWvZd+68V33vRbz2o691tuuSWbggYFXnZaY3SNMuCyAkvCRNm47R6tGtD45je/mW2spsxGAtizmmNsFuJyirvNXlxTxrz7STBor2B7fZU7OyUv6mD1Wy/lLpp+b+9Vlk2vvN75fxl177zzzlweJDhtJvvyPtF0bHsflX0NXlgxpoEom8U9Evlty11UR60IKr+b6oz3mx3YUCApv/3ud7/LFpW10n/2uyqLu7L+2mUuMjswFd2nH/ugez7Qv+1zl772posrs/j//M//5PZb9cm2gzX11Ztmr/fdaaed0k477TSin1DZO/vss7N1Kmf2+r34rqlpUNTbkcGKTNUflb/a8lBTVjRgZkWm+gkvI7TX5qnd7MV3teJY3y5agmOXVmy22WZps802y0LJZmqv8ZPuZwfc9DftJGJ3c5Aot0JX7+UNlAxaFncbg5QC/ac//Wm2tmgnAy2d8AbVbAb8scLbpSgqB6VA9/rFG264IVsZr/785z/PVl7b+w8lz1SOvLhY5XtVxMUwNiDQhxCvgYkaAQT6aN8h0JuDQEegI9D9b4ZAR6CvXIlAt75DoA8GCHTfEOgw1iDQhxBPiKhyRnude+Z1iieffHI6+eSTc0Nhp7Zqz+qo0VFwbPeXLhts2wEq0YY3hdRr5Poh0COzjWuZUKbbuUowpfeUqN5nn33yNOsyULCBpfY8v+aaa7IpINE0XCsy586dm+bOnevunRwFcWPlO0/E1wj1lStXptNOOy2ddtpp+d0kqidNmpSn90fnKzj2pqXpmrYMKtGeV+68Zx6r6cY1wWS348r3tdPitJ95Od3clmeVOxuESrRK/EtUbLrppnl/ZSVlWrp0adX7jLXfJCzK9s0mTbR/KxOQafrs5ptvXiUu/vznP6c///nPIxJylVNj7XT2o446Kh111FGu36L624aaINVLPhglkLOmZQJ6z5133jmb/OKdp/vIvzZpnwSrxLjK4IYbbpjmzJmT5syZ49ZX75n7LdB1T7UDts3Vu6j82XbP6zuOPvrodPTRR2ff7bXXXtnUx3rnlVOrL7roomyaNq8BdjvVeNddd0277rprbkdtW6r36tcyspr+IfJvt3Inoad+0SaXrVkGowE0b6mL10+o3HnL1aJlg4PIWWedlc4666y8P7lNGvjqq6+mV199NTxfbdbpp5+ezdtT9mvjTwAAIABJREFUXSbf2cGasSL65jWxcLdyV8bFdknmX/7yl/SXv/wlPF/xyQknnJBN1yr/U2zNNdfMiZm9pZDRO8LggEAfQhDoCHQEeucOEIGOQEegI9AR6Ah0zxDoCHQEOqwKEOhDCAIdgY5A79wBItAR6Ah0BDoCHYHuGQIdgY5Ah1UBAn0IaRq0dgqQ7Hp02zlrvbiEs200yv2ibcOrzLsS3goY1l577byeRsGvOoqzzjqrat2v15B+GL6zwb3XsKuhLgOwNddcc9ReltZ3jz76aHr00Uezv2zjr4zFM2fOTDNnzkw/+MEPsnnftOwQvN/a0CSzfTfzBLwC6hkzZqQZM2aMGIjYY4890h577JGfQcHEq6++mu6///50//33j8oca4X5tttum7bddtsRYiAS4VEguSrKXY2vvfVzhxxySDrkkENG+EBroXXeCy+8kE1Zi5Ux1p4nf06ZMiVNmTJlxBpaL5hW+1Fm8O5lT+rID6qHNnt49N0kprw18hqsset2y33KbdZe1XNvvaUCXvnNrr9smuW3H3kPvDLjtWdRP6Fj7DeVr7WPsvWB1kHrWlZUP/300+npp5/OdXOttdbKpjKnvAeXXHJJtho/9au+1gTE1pRF3PvN2yNZ5U57nytAX2+99Ub1sdbnGuRVP2oHf1RuNZhucy2o3Hq7FJTv8Prrr/d9MLIcrIiyrHt/8wZlDjvssHTYYYeN2JlDdVbHaH30smXL8q4KKqN2wFH+nD59epo+ffoI8R4NHEQDqIOIBnb0nwZWTO+5555pzz33zO249d3DDz+cHn744Zxjx2v3NJi+cOHCbL0MkjWlaR8bCXOVV9vHqt6ojNmdjqZNm5amTZuWz7d9hcrd+uuvn9Zff/0RPtP58quNi6NdDbxnb7tTCowdCPQhpGlDFAVeCPRmhkBHoK+KcodA717mEOjNyxwCvQ4EOgIdgY5AR6BDLyDQhxBvek4UyEbZJKOpPgp61GlNnz49NyjaX9UGCOX+6WqQ1l9//XTdddel6667zhXcagy9YDGaktQGbwpc7TTilStXjpjWWCOiDjrooGwSifKJDcokkNRQe9nMo8DUE0NewNOL77ws4NE0zrKza9pxKmDYc889sy80ldHbz7wUSFtttVW6+uqr09VXX13VGXuZ1b2BhDZEmc29sl4eY33unV9+B7s/ufyigQ9bZ+0U4g033HBEpvHzzz8/nX/++eG0Ua/d8Mph2712FVB6g4oq07bdiMqhF2iX7c0XvvCFbFpSooFKu4d0GWDZDPcaxJDfbP2TH7x907362ks2bX2H2h0ryu/mtSne3+RzCXUr1iW07TIpu7xpgw02GNEOarp2+T1rBwa97OltkDDxhKHM+4Zl37BixQp36YLeT9c+9NBDs6ntUtnyxJAGb+3e3PPnz0/z58/Pz67yZ832X1Fc0MvAUFnWbbnz9kjXdyqXC7z55ptV09613OaAAw4YtbTMDnSXS07U106cODEP2kb9hFcWy6Vw9r0HGT2j3Z+8rLO2TZOI95YCXXHFFemKK6740N87+nZRhnfvP6mimFTCW//hsvfee+e6qhjPxidlXGzbPi0nq51m7/W7/fiPKxgbEOhDCAIdgV5+IwQ6Ah2BjkC3INAR6Ah0BLoHAh2BDmMPAn0I8SppUxFec95dd92V7rrrrhEJp8rGxpr2rn388cfT448/7nZoXkMUNU7Rb734zgaa5VTwqHOOhLA97qGHHkoPPfTQiKBKgxraI90mQVNgWyah6eaDyLzgpheBrmvUJoDrJHqt8PWO14CEDQLKPdKtX9UpahqeNw3Xe4ZIBKyKJHGRaCrrZbd9VfVs99xzT7rnnntGJIiSeYloJk+enCZPnpyefPLJ9OSTT7rP13Rpg87zBhz64TeJ1qgeeuJd53nf+95770333nvviEFFlSu1b7b8ab/kBx98MD344IPufSIfWXGneqrAr99t3Vjb3Xffne6+++4RSeIU2HvLTjTIoTJXO8gTfe8oAWIbvDLfZNq7faeo3N14443pxhtvHDFIpv6hbN+23Xbb3E8oCZ+3NE3lyhMX3vRxr63rxz7o3vIlr80rn9Hzk/e3X/7yl+mXv/xlrouf/vSns/j2lgCMHz8+jR8/Pj3zzDPpmWeeGTFw0XTpSblcpl91dlWhvc/tYLY3ECTT4JqWk9k+dlDw6l7NgEuUWNk7T3Gx4rntt98+FOGKix977LH02GOPheXba0M6tSv2P7ds/YXBAYE+hHiVFYHezHcI9Pa+Q6C39501BHo7vyHQ2/tuLAyB3rnfQqAj0AcRBDoCHcYeBPoQ4lVWBHoz3yHQ2/sOgd7ed9YQ6O38hkBv77uxMAR6534LgY5AH0QQ6Ah0GHsQ6EOIV1mjSm0bhLIRUINrMw2XjXO5ZnCDDTYYtQZzwoQJeZ25niHKEBw1OtFAwlju0Rqtd9O6PutHZcL+xje+kU3BlRpumxVa2djlOysGFi9enBYvXuzeu9NaVfvM3lrJfmc29gKvSKhH4l3C5rjjjsumAMoLEEphbsXS9773vfS9732v+rlq3iM6rw1Rhx8JD8/+9Kc/pT/96U/pq1/9ajabkbiTlZmyN9poo3TzzTenm2++eZSQXr58efaBJ368NfXlO3prUNuWOa898/Ypj0TuHXfcke6444503nnnZZMfVG9tfVXgKr9p3+XNNtssr8/X/WzAWrPG1ytjkbBvQ1T/m5Y5iZpTTjklm12j2skkOlW3x48fn8ucrt1t8Kl8ZmvRIJL+1ovvojXo1iKhpt0mbLlTfgO1Yfr3lltumcV4mR170qRJ2XcqY7YcRTsZeOvgdZy39ruX9cRe31TjJ2/AVLsl/Od//mc2CW7rs9K0G4od+NDOJ+pPre+i59IxdlAtqlt65w8b7Qxz5JFHZov2LI9Msd0gI//XxsXl97V/004TNi4u4xNvl6Ly3xMmTEiXX355uvzyy1v/51TT94HBAYE+hDRtiBDoo30Xdazebwh0BHovvkOgt/Od9/4I9DoQ6Ah0GQIdgY5AR6DDqgWBPoRElVkdm63U2ttUItJ2+J7Q1t+0N/CPf/zjbArUyuyVtnFS0GqfoRwksBYJ8rGa4m4tmjL7yiuvpFdeeSVdddVV6aqrrhqRWVyBgs2kK79KOP3qV7/KJhHu7S8vizr8KKi2e9gqeIiyb7ehRoTboEf3V2ZmK348oa2/HXjggenAAw/M0z9vvPHG9Ic//CH94Q9/SFOnTk1Tp051fecFXjWCO5ri3q8pZF4AqO/piWMF9Sp3diqiBLd9d+0CcMQRR6Qjjjgi3Xrrrdnuu+++dN99943K6r7mmmvmLMaqs56orslA7wmofpS7UnR4Zc0GzvLlNddck6655poRy3M0xd9m2JUf5DctEbjnnntyW6cpina6rM7Td7LPoLZL//amFXvlz/OtxFMbvDIffb+lS5empUuXposvvjhdfPHFI6Zw6n3t4I6EjzJoa9rsT3/60/T888+n559/3t0jXaYp47ZclRnYvef0TOd75a8Nejav3EWDCddee2269tprR2R4luDWAK0dpD322GPTsccem6fN3nXXXXl5lNpBm+VeU7e9dirai73s6+xAkDeo1YvI9O5bCls7KPPSSy+ll156KfvOTln3xJD6kDlz5qQ5c+aM8N3LL7+cXn755ey7TTbZJJsElsq5ly1e1m2ac42tCvTtLrvssnTZZZeNGKQoM69b004VN9xwQzYtOSmzutt+upf2aKzxvkEnYfvPf36wC4j6WC/jvxcXz5s3L82bN29EXPzcc8+l5557zo2LdZ7ioRrh3a38IdA/GiDQh5CowiLQm/sOgV4HAh2BjkBHoCPQEegR3n0R6GMDAv0DvG+AQIcPEwT6EOJVTnXS6vTs9FdNy/QSu6nx+MpXvpJNU7c9AfOb3/wm/eY3v8kBrp2mrWtJTNkp7m07u2jaext0XZsgpgxKtDflBRdckKe36t00FdYm8TnrrLOylcHha6+9lu2mm25KN910Uw7YbNCha6mht8GCgsUoSZHd37YMwr13bUMk0GUSOkcccUQud2WCt3XXXTeXmWOOOSabgnovacuSJUvSkiVL3KRT8qHObzoFPxJ/nrXBE7mlqDj88MOzeQndSlFtj5eY9MrDAw88kB544IF8vp32Xpa7SIx7Cfa8suiJq7Z1Npqy7tVXvY+W4qyzzjrZ9JttG5966qn01FNPjbrmW2+9lZP6eN9AprptfaO6Fi1N8fwbJS1sg76DNyiq30499dRsqpOanq62z7Z/GrT90pe+lAcnShH2j3/8Iw8KlQMhNthXojPPL96U9ajMeUk8e0lipbrjLdPSdTWQcfHFF6fddtst7bbbbrlvsGJcgxx2v+4nnngiPfHEE/maWkK1bNmynOxSA0teP+GJ8bK/8AYrvL9FU+LboOewZVw+1L/tdH/VTw0+eAO5Z5xxRrY//vGP6Y9//KNbDh555JH0yCOPhHVWAwL2vGgAzWvPynf0pvOPFRrUOfbYY/N/DHjvqT7kxBNPzKYktGUS1ffeey//B0IZz6255ppZ7Gt51SBSI3xt269+1EsCqjbQxsXPPvtsevbZZ91lXoqLo3LnJQBuG/tGx8PggEAfQhDoCPTSEOgIdAQ6At2CQEegI9AR6Ah0BDp8OCDQhxAEOgK9NAQ6Ah2BjkC3INAR6Ah0BDoCHYEOHw4I9CHEq8BloOIFrWWAtO6666YZM2akGTNmpF//+tfZvvnNb6ZvfvOb6aijjkpHHXVU3it58uTJ+Rpq1Gx2Xq3VVIPvPV+0Ftgzu1ZtrLO4y7QW7tprr83vq7XlNpOzhPb3v//9bKeffno6/fTTc+BmRZQCEC9budZqes+jwM37LRIwKgtWrClQ6rfv9F2/9a1vZYsyr0+bNi1NmzZtxJpfZTs97bTT0mmnnZb22GOPbKVQsKZAOFqD7gX8kUD3RE2/y115XWUGP//880e9ow3SJQKUlfyOO+7I5e+cc85J55xzTtp1112z6RpeuVO91rpUK0hKoe79ZgP+sn7ac9tm1I7KnK5t19tr/aUGcuxgxCGHHJIOOeSQLLwfe+yxtGjRorRo0aLs98MOOyyb1ptv/X97ANs16Fpr6A2a1QT70Xp+69NeMpGXZb8s/ytXrkyXXnppNpUJ5TOw9VV7l//kJz/JpvMWLFiQFixYkP71X/81WxSo6lpeBvyyrHXyS6d8B/1ag17TT9x2223ZVDfLNay2bbf1Vf3D1772tfS1r33N3Y/aE0raZ17rqGvLnWdl2bX9RC++i0Sr7Oyzz86md1PdtQJdgxvKSP7oo4/mwXDFNwcddFA2naf6LxE2ceLEnL/Ey80SZeqP8jboPLueXTZWXHHFFdmiejZlypQ0ZcqUdOedd2ZT33zyySenk08+Oe21117ZomupDZQvBpGorCsOjeJi+x9XGhyzcfF3v/vd9N3vfjeXv89+9rPZdJ7qrL2W4mKvftYI75rYwRoMDgj0IcSr3GXFRaDHvosMgd7cdwj05r5DoPdW5hDoMQh0BHpkCHQEOgIdgQ5jBwJ9CKlpiKxpKpk35dhrnLy/lb+pIVLj06kBqnnOKCtu1HD14rtoj3YFjm+88Ua68MIL04UXXpgDzx133DFbKd4nTZqUAzSJcZsZdJtttknbbLNNntKnwZEZM2bk/V7LYMv6U77wpqzb99Gzl5lz7bu2IRpc8abnLly4MC1cuDBn0fXKXbe/lVaK8u22227UVNtIkLSZ9l4e1wZ9O0+YedPKFbxGUxjtftOqjxJXdv9fmc6zQuqvf/1r+utf/+pO2+sUqFph7pUBHeMFHk2J2hCbkVqmgQoNnnmZ160YUuCp+mp3ZCj3o7aZucslBb2YgnzV234JpeieXtmX0C73f+80MKbfVAZthvdyKYqE5c4775ynZ3vT0qNn9splKez7vTzAK98qa7YdPvfcc9O55547aqr7Jz/5ySzeVZ623XbbXCdVX61f1ZfIr5/5zGeyaZpsNGjrfVs9p+cf9b9e3e93uZPZMq7BcMURtg6Wmdu32GKLPHVbA29WhOsYlU2760rZx/ZiKh+qu/36D4SmaKBH9c3uXb7GGmukNdZYo/Xe52obt95661zeBpma9s6a6mxZ1tZee+28RMqLgctY2MbK+reNE5sOnJVmy5bqbjTtHQYHBPoQElVmBHqd7xDozUGgt/cdAr2d76I2BIHe3ncI9BgE+tiUOxkCvT8g0D+gpr1DoMOqBIE+hNRUaq/iSrB9+9vfzqbp7Jp2uMsuu2TRqH/bKe4zZ85MM2fOzFOlIqHbNMlF03PHyneR/fd//3c2TfG009jlMw2G2MD00EMPTYceemjej97r8PVvT6B702m9wY1SvPcrSVyZIMz75p6g1b2vv/76bOoc7RQ7mfZh1RS9KVOmZGGk872ASM/XNOmb9/zRef0qd2WgHIl37XN72WWX5bq73377ZVMwsM8++6R99tlnRFC///77p/333z+f5z1DlLwuShxnzZv2Xl6jKaVQ9Z7dE3i6n/ZDv+aaa/I09rlz52aTKJAo+tznPpdN02Y1pTF6Zzuop3JZ7jdt67X9W7n8pN8CPRqwiqaJ26m0GmyzZU5lzQ7SyjT186KLLkoXXXRR2KZ6SyG8MqT6Z+u+zovqci++s99Vf4uS1cm8JWO2H5XwmTVrVpo1a9aIwTbts3zmmWemM888c0TyvfLdvHbQqzNRv+v1K70kiatZxuG9k97DTkPWQKUGt7fZZpvcn2qQUTHJzJkz8/7nt9xyS7rlllvc99W72T62k3/fe+89d/p7WY/t+/Syh3xbVEbtvuaKMzS13zM7gKG/XX311enqq68e8f0+CpRl3Svv3m96RxsXq+7ZwWz5qYyTZ8yYkcufYkOvXa2Jg71jbPvdKfmdNRgcEOhDSBQYRA0RAh2B3ovvEOgIdAS6/84IdAS6NQQ6An1VgkBHoCPQBw8E+hASBQZRQ4RAR6D34jsEOgIdge6/MwIdgW4NgY5AX5Ug0BHoCPTBA4E+hNRU5qgx8ASW19E3aVi6mc7z7uH9LbqPjm9DtFYx2mfcsyiTZuTrplYGCFHAXfvMbYjEbSSO21oktGvPi3zf9Fq9BPyeyC2/YVS/umVQ7/SdOw0AdDL7njVi3Ptb5POmKOj1fGOFbCTkm9RJr8yVGdW71btozWG060J0rTbouaO9vO29yr9F65U75QzpVE6iATVvICd6Bmu6ZrRmvA1RX6DfvIHPplbjS/v9ylwf9jg9i9eGtH3ONpRl19YF/bs270CNeWVEPogGCex5ZR9r2xuvbSnb4H75DtpTU8+iOtQ0vvWOrzk/iqdt/xPtYBQ9AwwOCPQhJKroCPQYBDoCve21EOgrR13L+xsCHYFelgkEum8IdAQ69IeaeoZAh1UJAn0IiSp9VHFthxQFPWXjYRsI/c0TN23Fe1PrZSpP032LZV6AE/nQCwrKTJzR/ZTp+PXXX6/ySbfpx/0IHppOCS/LWrep552uWWs1gwResNt0UKENNWXE+4beFHTPvzXlLvJZ9AxREOqJq6gd6Iffyvpqs7iXx9i2qxzgsIMJNXXHTnfWeQrsvWeIzBMv5Tex36UNXpmuEYTe9PKovnq+ayK+omn2Ub2x94zqbxu8AZxyOnTUbqifsX2N7VNL/0Z9sr2Pzo+WQzQZQLHWr6VQ3rXLKeSe6Z288uBNR4+Es3e/TksB3n777ez76Dmjfd37Ve6gPd43aCKYo9+6/SdVk2vY2KPm+rUDB73ExTA2INCHkJpGBoHug0BvHzwg0Nv7rqaMINDr/IZArwOB3t53CPT+tnUIdBhrvG+AQIcPEwT6EFLTyCDQfRDo7YMHBHp739WUEQR6nd8Q6HUg0Nv7DoHe37YOgQ5jjfcNEOjwYYJAH0JqKmvTtYJRgNBtzXqn+9QKn0hw9DPYT8kPvKIGteb5bWBTPm8knJuunfWCOQUtXkDoCQYd04bo29V881qB7v3W5Lyastbt/Oi4fvmuZqAmKkf2b+VgiLe+vKZMNh3o8YKH6N5NqRF6VhxH9bvmWlGdbLtu1mvXvGt59bWXddQ1Pug2WNvEB23LlXfN6DtGZdo7vg3eYE4Tcea1x5HAi/pR71qRRb7wnmHZsmVp2bJlffNdk7qxcmXzAdlycM2K97Lueu+rY7y2XXXBE1TetaLBfVi19Fq2mopj7z+xugn5JlYj2il3gw0CfQhBoPceeNU2jAj0D6jpABHo9b5DoHcHgY5Ab1IXvOPbgEDvb1sXGQId+kGvZQuBDv0GgT6ERJW6Jmt1L9N1yoAialC6HV/TEEXWBq/BjjLcRv5s+9w1otwGzm2Fhc63U3P1t36Xu6i81UyN9473BoaiwZwawR3dzzu3X9ONdW5TAeyd55WH8pqe76KpyNEz1Uypr32vtn6LBIx9rmiaufd8Ol711wbhsui9asStHUCQeXWyn36zvqttZ8rn8HYOiPxpv1GnKei2jnnTvaPn0/lRWevXgFrN4HZtmfdEXNlWe0skovYsGnzVb9YXek67dErTub137cfAkP12ZVtky5bqmcqDFdxe+xINlJS+tvW43BHC/hb9B0Qk0L137aXcQXtq2juvjHu/ebFdWU+i6enWvEGfTtfuNv29vFa/+goYGxDoQ0jbRgeBjkBHoHe+HwIdgY5AR6CnhEBHoCPQP2rUtHdeGfd+Q6BDP0CgDyFRg+KJ8JoOv+k0mugaNcdGAssbROhXQ+RdR4GNOnD7bFHSGC/oqfGrZzVJdDyLxGwUyPTLd01EeNPptLXT2JtMVY9+q50K14vvrA/KOusFo56/PFHQSWR1szZTttuY3rGfZa70x/Lly6sGv7xAu2lbV5NYUs+kum3rd9OBmn6VufK7e+LY80U0uBO9UyTso7IalUtbXzsJwF595z1b9M3tMqdOg71NB3Kj+0TPooEfLwmdd3zUxvS73HnfyQ4ud6q7ts56y+tK8eS15zV9rHcP77gy0ahX9mHV0q3OdbPaOhidG4nxqA5GzxDdzyunMDgg0IeQqBIj0Jv7DoHe3ncI9Ga+Q6D3r8yV/kCgdy9z5XdHoPsg0BHoCPSPFt3qHAIdVjUI9CEkqsQI9Oa+Q6C39x0CvZnvEOj9K3OlPxDo3ctc+d0R6D4IdAQ6Av2jRbc6h0CHVQ0CfQipqbjeWpYoUIiC+6gjjPZI936LnqFpY9aL72pNwY7n1+g8bx2RfvPWD0aBXZRlNwryowBjrHxny1EZJHlCOPpb7Teq+R6RRULde582ROW5JmO197daQRT5s8n66m5ZzPVbP8td9L3KOmrrqQLtcuBixYoV7vHee0XfrDw/sm7Cbazauqb7YUf5CLxBpJoyVCPsrdU8s/2WNfult8GrM94uGuVAbtuBVmtq7713k39qBuJsuas53j6/zuuX7zqVNWs1a8vtPug63v4W1akma9drBwyi32DVUlO3org4an+9/+iyv9WsT4+uX3M/r0557wODAwJ9CKlpBBDose9qDYHezHcIdB8EertyF32vso4i0EeCQEegI9A/uAYCffWmpm4h0GFVgkAHAAAAAAAAGAAQ6AAAAAAAAAADAAIdAAAAAAAAYABAoAMAAAAAAAAMAAh0AAAAAAAAgAEAgQ4AAAAAAAAwACDQAQAAAAAAAAYABDoAAAAAAADAAIBABwAAAAAAABgAEOgAAAAAAAAAAwACHQAAAAAAAGAAQKADAAAAAAAADAAIdAAAAAAAAIABAIE+hKxcuXKUvfHGG+mNN95wfyvtnXfeyeb9/tZbb6W33nrL/W3FihVpxYoVafny5Wn58uXhfXTsihUr0ttvv53efvvtquez9u67744y/daGN998M7355pvpf//3f7Ppevrt/fffz1b67O9//3u20l+ez957771s8ln0TpHpvrpOJ//rft5vesd+lbsa+8c//pH+8Y9/dD2uLCP//Oc/s7W9d1PTd/b8K7/2y3f69t699DdbV8s6G/3m+c6WxaiMlMd7bYXqdVTvPb+ORZnrVh9Kf9c+c2nWp2X74LUZ0fPZtlF+1vne8W3wnieqT2U9VZ/yxhtvhN/UK0tN6q31nd7b68+avo/akzb02n7o3p36vPL71pbhTuXWfhv7t/I3+1z6TX2CbRd66Sfs9yytphw0KS+drl9z76bP1fR9eil3XhvttV9N44jymt59vPocXb+mL/GeUf+2/tTfAFYHEOhDSNOgIQo+vUDo9ddfT6+//nrjjkymzl3XsdcqRXG35xurDtALVJoMctT6Wr6wAZB++9vf/patDKhscFwGenZAwOvkavzZhiZlYOXKZkG6tab38fxSmhcsS5BYi55Bx/RS7mrFcVQ3vL9FgVr5t6g+W7EfBWXeb5HAUFloSnTNmqC022Bk229QY9HzeYIsetdeylzTgcDym3kDEt38Ew1IlOXQE7NqM7372PdRnfTqdy/Bvq5hn03PW9NPeO8bWTTIa83zS2nlALLnE1sWvPfph+9qBXT5N/sckThuKtT7dc3aa/TLd1F7UlOvIx9Ewjm6VnS/bu1NGbP0q9wBDBoI9CGkSZDVKYCKOmcEerPniN4FgY5At+UOgd4MBHr7+uqVjSbPj0BHoPfiOwR6f3wXtScIdIDBBYE+hDQJsjoFUFHnjEBv9hzRuyDQEei23CHQm4FAb19fvbLR5PkR6Aj0XnyHQO+P76L2BIEOMLgg0IeQqHGUII4CBG/9dVPzGtcyKLMB3tKlS9PSpUur71teyxM2vfjOBu66l54tWg9ohXNb3zU1ifjIF9ZKsdlv31nTdWvXmcsUjNYGsuVgSs2xb7/9dlXQW+NDe91efBcJlcgX3ppyT3xGAVRUZnSd6BlsvdCzRGvjbaDW6xr0aL29DUCbrK23eSGarGF/9913R90nuka3Ac5ycMUTxm3wvqPKta7fVLw3HfCI2gW1o9Y/qq/6rZt460dzAAAgAElEQVRw1fW9nA36Wxu8e5U5QJr6rlZ0lW1F9Ay2vkY5Kpq0ffbe/fJdVP5rBHQ/rlX7bdrczzu3X74ry0rURteWSW9gvzymdn26d+9O7aQtWwh0WN1BoA8hUcOLQK/zHQK9P+UOgd7Mdwj0dn5DoDcHgY5AR6Aj0KNrIdABxg4E+hCiztlOkY4a45pjagMETbGr6Szs9O6m966xNnjPWmaurfVrjc88/3gdaE121eia0bN436FfvouerQzOu2VlbzL12wbupTCKspp3u9ZYlTvvOgpQaqZx23eq+Q7RtEZP7JYZ22uDeu/46Pma0naZRCm8O/m3TeZs+13Kb2hFk1cnZNFz2d962TlAA0pevfP8qvqqd/MGI6O2x2uzvGPL8lK7C4bOs8811gO5nnnT6ZuW00hE2fb6zTffHLFzSDRIV1PO7bXK4/vVT0RtkPdbUwFdc1zb85qK8Q9DoHvm1c+mS5RK4Rzdx/vN852uaetldK1efAcwaCDQhxAEevtGHIHeX99Fz4ZA/wDvOgj07iDQEegIdAQ6Ah2BDvBRA4E+hJRBgRcY2MRXUcCsRrPptHcJWC/BVlur7Ux7acQjX3hBogJBvaMn3pvu122DpE4Jfew1o2cuO+Pa6ZZtsFPHa/a1L0WJd54NMKNrlsmgvGvVPJP3fF4iqH77LhK9nggv66d3nhVyNaLaBknldb1p6W3rcfTM/fSbZ02FUhmUWp+WfogSu0Vtl3eed7z3rr1MNS7bjxUrVoxq47z2O/r+9l1q+pe2U+mjb2XbRpU1tdP9EujeMqZIANcMmtlnK9ttb+DDS3ap39RvRAMm9je9j+1z1OZ5/XcvywOaiFjP2orx8txOv3W7Z815NQMBbYjqSClwa+tSJLSj46Jjav0aPUM0/R1gdQCBPoSUwQ8CvR4EenvfIdDb+w6B3s53CHQEeukLBDoC3R7X6VwE+sj6jEAHWLUg0IeQMvhBoNeDQG/vOwR6e98h0Nv5DoGOQC99gUBHoNvjOp2LQB9ZnxHoAKsWBPoQ0jbA8QIFT5TWrAX2AuFSbHqdVq/Z462tCt/p+b0gSL6zgxvRYEWN2CjXEy5fvnxUxnNvQMAGY/oO0Z7z/fKdni0SF7XlrqbDl0+iQYLawanymrVrkdtQ8xyReYFT7XN3EuPd1pu3zQDttR969qaUYrlbUFozoBGdX7v3d00Zqs2pUJODoA1ty5j3m9Ym1w7ONXlf209E7YJXh8pM8N7xbZAvojoWCUnbHretR551GkyxIj8qt56g995P1+hXuasR67VCvq3Qjs6vEeir4j8QvO9a3jPKT+P95rWdXl2PBHr5LLWi3yt3Ne0iwOoAAn0I6bWTR6DXGwI99h0CvQ4EOgK927nRd29D2zLm/YZAR6D3Uu4Q6M18h0AH+OiDQB9CvAat01TplSs/2Bu9NlB47bXX0muvvZbPO/PMM7Ntu+22adttt82/RdexU/NKsajzX3/99VF78/7zn//sOJXU/q0X30VTA63gljWdnqmO7Nxzz802ffr0NH369DCzfRT86hvbafbeQEmZ7dgLMNpQiuu33norDFhqAnn7TLq+vvNll12Wbffdd0+77757eC2d55WjcrDDigArOmqmjPdS7iJRHC2ViAJrWyf0buedd162qVOnpqlTp4a+q5kaXjsgUGaG72W6cW19K8tTzbIeL0g88cQTs82dOzfNnTs3vE/km7Isdfr2ZRn1hEAvZa7Wyr3tux0vH6q/uOSSS7Ltuuuuaddddw3Lkf7tDajJrF+8aefyk9rUsfRd2cfa76lnqx2IK6917LHHZps8eXKaPHmye15NP1S2p++998EOJatix4qmgrZGvEfl6Oyzz842a9asNGvWrPze0UBAVJ9rnzM6rl/lrpO47iaOywEb+7yq6/Pnz8+29957p7333nuUkPbEftO2pem1BhnV+bPOOivb/vvvn/bff/+evj2sfiDQh5CaDt8aAn207xDozUGg917uEOjt/Na03iHQEej99h0CvQ4EOgK9U1uBQIdhAoE+hLRNylYjqleuXJmeffbZ9Oyzz6bZs2en2bNnpx133DHbpEmT0qRJk0Z1Al5QUjsdUu9TGzz00gg2mcpsg4Da46+77rp03XXXpb322ivttddeeUBj2223TRtssEHaYIMN8rFNg6XIF7VJ/iTseyl30Tf3zHtHr1w88sgj6ZFHHsm+mzhx4ijzrt8kwZsXNER7qvcreFCn3tR3UbBk7dZbb0233npr+tSnPpU+9alPpTXXXDPbhAkT0oQJE1zBqGtGojq6r71Wjf+b4onWaKCi/H7dgtj7778/3X///WnKlClpypQpadNNN80m/0XnR0nQyinOdumKvUZN0NuGmuni3l7n3nnet3344YfTww8/nAP7j33sY9m23HLLtOWWW44qX7XlxBvE1HPVPrOu0YaabxIl+eyWPPW+++5L9913X9p3333Tvvvum7baaqtsKn+17ViN6Tk933mmZ29D03Y4KmOeKL7zzjvTnXfembbffvu0/fbbj2jr1l577bT22mu7/UuNqPbuG/2t33W2n99cZtumJUuWpCVLluR47l/+5V9GmdemlQnq7PXLxIfdnmGs2ruxZvHixWnx4sU5BrblTtZLvYHVDwT6EIJAR6CXvkCgI9AR6Ah0CwIdgV4+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H/7wh+mHP/xhFlG2EdcgxyGHHJIOOeSQ1gGq96z9mkJmp3vLOk3/9AIam9n06aefTk8//fSIwH3evHlp3rx57rssWrQoLVq0yN1ZQOfvtttuabfddnOD1LY+9PYzboPKcZRV2BN5Xn157LHH0mOPPTYieFCd9d5B5U5l1PpO05QVsHliLsok7z2z3tVbxtKUKNj3MmZHz/yLX/wi/eIXvxiRsfiLX/xi+uIXv+gK2F//+tfp17/+dRZFdtqixPvnP//59PnPf36EH6JBs5oBOM+nbdA1oj25awesbrnllnTLLbeMmMauHSu8gbif/exn6Wc/+1k+xvYTGlTSrgK1ddETIWV57JdQinaeKL+ll8XdHnfzzTenm2++eYTvDj/88HT44Ye776mlYhJOdhD84x//ePr4xz+evvSlL6UvfelLbp30rhlNhe73QG4/BfoDDzyQHnjggREZ2mfNmpVmzZo16t3efffddOutt6Zbb73V3SNdpvpsv230fE0Fei9TmSNB671vWTfs/R9++OH08MMPjxiQ1WBaOei0fPny9OMf/zj9+Mc/zmXN+kznf/azn02f/exnw+ez7ZfuUzslvpdy109+97vfpd/97nd5Ovu4cePS/vvvn/bff/98jG2HbrvttnTbbbflgVt73hprrJHWWGON3MeS4X14QKAPIQj09o24zkWgNweB3t53CPR2vkOgty9zCPT2vkOgt/cdAh2BjkBHoAMCfSipCWLs9DYJbS94ULBvp9+9+OKL6cUXXwzvo4QtapCsSSx4idiizi4SL9Z6mSpUXsObnmjFe6fAduXKlVlk2mmfd999d7r77rvDzlzJ+GzgpYBf+7d653sdmoLrbgljymCsX+Wu/E5WlEWJiRQ8KOD8+Mc/nv0ZPb8SynnT3Q877LB02GGHuefpO3qi0ZsK6j27/N8GletoT+qoPtu/Pfjgg+nBBx/MU4wnTJiQ63E0ACYx6iVR0oBbt4C0V+tHmYsERdl+2CBqyZIlacmSJSPe//HHH0+PP/54+H1mz56dZs+e7Qb7UcAafddIAHjCrw0q015bp3takRIlC7vpppvSTTfdNGK6rAYwokB7/vz5af78+Xlv72222SYvA9JSAi94b2qRr9tQtgNvv/12+IydBnRXrlyZbr/99nT77beP8IFEe01bp6U/m222WR5QO+qoo9JRRx2Vl60t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AAwACHQAAAAAAACAAQCBDgAAAAAAADAAINABAAAAAAAABgAEOgAAAAAAAMAAgEAHAAAAAAAAGAAQ6AAAAAAAAAADAAIdAAAAAAAAYABAoAMAAAAAAAAMAAh0AAAAAAAAgAEAgQ4AAAAAAAAwACDQAQAAAAAAAAYABDoAAAAAAADAAIBABwAAAAAAABgAEOgAAAAAAAAAAwACHQAAAAAAAGAAQKADAAAAAAAADAAIdAAAAAAAAIABAIEOAAAAAAAAMAAg0AEAAAAAAAAGAAQ6AAAAAAAAwACAQAcAAAAAAAAYABDoAAAAAAAAAAMAAh0AAAAAAABgAECgAwAAAAAAAAwACHQAAAAAAACAAQCBDgAAAAAAADAAINABAAAAAAAABgAEOgAAAAAAAMAAgEAHAAAAAAAAGAAQ6AAAAAAAAAADAAIdAAAAAAAAYABAoAMAAAAAAAAMAAh0AAAAAAAAgAEAgQ4AAAAAAAAwACDQAQAAAAAAAAYABDoAAAAAAADAAIBABwAAAAAAABgAEOgAAAAAAAAAAwACHQAAAAAAAGAAQKADAAAAAAAADAAIdAAAAAAAAIABAIEOAAAAAAAAMAAg0AEAAAAAAAAGAAQ6AAAAAAAAwACAQAcAAAAAAAAYABDoAAAAAAAAAAMAAh0AAAAAAABgAECgAwAAAAAAAAwACHQAAAAAAACAAQCBDgAAAAAAADAAINABAAAAAAAABgAEOgAAAAAAAMAAgEAHAAAAAAAAGAAQ6AAAAAAAAAADAAIdAAAAAAAAYABAoAMAAAAAAAAMAAh0AAAAAAAAgAEAgQ4AAAAAAAAwACDQAQAAAAAAAAYABDoAAAAAAADAAIBABwAAAAAAABgAEOgAAAAAAAAAAwACHQAAAAAAAGAAQKADAAAAAAAADAAIdAAAAAAAAIABAIEOAAAAAAAAMAAg0AEAAAAAAAAGAAQ6AAAAAAAAwACAQAcAAAAAAAAYABDoAAAAAAAAAAMAAh0AAAAAAABgAECgAwAAAAAAAAwACHQAAAAAAACAAQCBDgAAAAAAADAAINABAAAAAAAABgAEOgAAAAAAAMAAgEAHAAAAAAAAGAAQ6AAAAAAAAAADAAIdAAAAAAAAYABAoAMAAAAAAAAMAAh0AAAAAAAAgAEAgQ4AAAAAAAAwACDQAQAAAAAAAAYABDoAAAAAAADAAIBABwAAAAAAABgAEOgAAAAAAAAAAwACHQAAAAAAAGAAQKADAAAAAAAADAAIdAAAAAAAAIABAIEOAAAAAAAAMAAg0AEAAAAAAAAGAAQ6AAAAAAAAwADw/wAjj25hmz3ziAAAAABJRU5ErkJggg==\" width=\"1000\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, 'GD Net Adversarial Examples')"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(10, 10, figsize=(10, 10))\n",
    "for i in range(10):\n",
    "    for j, ax in enumerate(axes[i]):\n",
    "        ax.imshow(gd_adv_ex[i, j].detach().reshape(28, 28), vmin=0, vmax=1, cmap='Greys')\n",
    "        ax.set_axis_off()\n",
    "        \n",
    "fig.suptitle('GD Net Adversarial Examples')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABLAAAAH0CAYAAAAt0NQSAAAgAElEQVR4nOzde5hVZd3/8TXAMDMMBIxCwICD4gFLRTIVrCQ1T4FWhimPB0jwVJmmCRrapCBCHlPDY6Z4ShE8oIB4QDKzpEdNNDPz4aeoHUwF1ERh+Pz+4Nrb2bNnzVozc8/me9/r/bqu/YfjHN6stWd977lnz96RAAAAAAAAAMOizR0AAAAAAAAAtIQNLAAAAAAAAJjGBhYAAAAAAABMYwMLAAAAAAAAprGBBQAAAAAAANPYwAIAAAAAAIBpbGABAAAAAADANDawAAAAAAAAYBobWAAAAAAAADCNDSwAAAAAAACYxgYWAAAAAAAATGMDCwAAAAAAAKaxgQUAAAAAAADT2MACAAAAAACAaWxgAQAAAAAAwDQ2sAAAAAAAAGAaG1gAAAAAAAAwjQ0sAAAAAAAAmMYGFgAAAAAAAExjAwsAAAAAAACmsYEFAAAAAAAA09jAAgAAAAAAgGlsYAEAAAAAAMA0NrAAAAAAAABgGhtYAAAAAAAAMI0NLAAAAAAAAJjGBhYAAAAAAABMYwMLAAAAAAAAprGBBQAAAAAAANPYwAIAAAAAAIBpbGABAAAAAADANDawAAAAAAAAYBobWAAAAAAAADCNDSwAAAAAAACYxgYWAAAAAAAATGMDCwAAAAAAAKaxgQUAAAAAAADT2MACAAAAAACAaWxgAQAAAAAAwDQ2sOC1X//614qiSFEUaenSpUX/f+PGjRoyZIiiKNKoUaNK3gfptttu02WXXdbs/4uiSPX19aUNkvTkk0+qvr5e7733Xsm/dlorV65UFEW66KKLEt+3vr5eURT25Xxz3VdKqT3nMe3HtudrjB8/XtXV1W362JY+Z11dndPPiexpz1ogC9cWF1qam6NGjdosa6w333xT9fX1evbZZ0v+tVujrq5Oo0ePTny/pUuXxt6HQ7G57iul1J7zmPZj2/M1ctfL5cuXt/pjkz7nypUrnX1OIE7YP/EgeLkLZo8ePXT00UcX/f/cBb5Hjx7BD0yrRo8eHfsD6lNPPaVVq1aVNkjSRRddZH7QtmYDa9WqVXrqqadKULX5ZOGHzPacRzawkGXtWQtsrjnkm5bm5osvvqgXX3yx5E3Lly9XFEX69a9/XfKv3RppN7DWrFmjp556SmvWrClB1eaRhQ2s9pxHNrCAZGxgwWu5C+akSZNUVVVVNCyOPvpojRw5Up///OeDH5hJPvzwwzb9v/ZqaQNrcwltAysLNscG1n//+19t3Lixw7+Oi+8/NrCQZVlaC7R0XerIWW5xboa2gZUFm2MDa8OGDVq3bl2Hf51PPvlE69evb9fnYAMLSMYGFryWu2A++uijqqqq0jXXXJP/f6tXr1ZVVZWuv/76ZhetH3/8saZNm6YddthBXbt21ZZbbqkJEybo3//+d8H7/eY3v9H++++vfv36qbKyUkOHDtWUKVP0wQcfFLxf7oe7V155RQcffLCqq6s1cOBAnX766akH52233aYRI0aourpa1dXVGjZsmG644YaC9/nVr36lXXbZRRUVFerdu7e++c1v6i9/+UuzLc8//7z2339/de/eXSNGjJC0afHw+c9/XsuWLdPIkSNVVVWlI444QlL8JkFdXZ3Gjx9fdNyXLFmiCRMmqHfv3urWrZvGjBmjV199Nf9+o0aNyv9ZR+NbTnNfb8WKFTr00EPVq1cvVVRUaNiwYbrpppsK3ic3uG+//Xb95Cc/Uf/+/dWjRw/tt99++utf/9riMc79AN/0llsENDQ0aNasWfn7RZ8+fXTMMcek+g39K6+8ogkTJmjbbbdVVVWVBgwYoDFjxuj5558vet/33ntPp59+urbeeuv81zn44IP10ksvSSrcwLrkkks0ePBgVVdXa8SIEUWP0onblPjNb36jESNGqFu3bqqurtYBBxygZ555Jv//L7vsMkVRpFdeeaXoYydPnqzy8nK9/fbb+bc9/PDD2nfffdWjRw9VVVVpr7320iOPPJJ4XD766COdfvrpGjZsmD7zmc+od+/eGjFihO69996i912zZo0mTZqkmpoaVVdX68ADD9TLL79ccF+55557FEVRs1979uzZiqJIf/7zn/NvW758uQ455BD17t1bFRUV2nXXXXXnnXcWfFzuPv3QQw/pu9/9rrbccktFUaSPPvpI//73v3X88cdr4MCB+WvFXnvtpYcffjj/8UuWLNGhhx6q2tpaVVRUaMiQITrhhBMKjp/06bn63//9X337299Wr1691K9fv4L/11ja6097NrBae4174YUXtO+++6pbt27acsst9f3vf7/oB+eNGzfql7/8pYYNG6bKykr16tVL3/72twuuD7nPyQYW2qs9a4Gmcyj3uR577DGddNJJ2mKLLVRTU6NvfetbevPNN1P1/OEPf9CYMWNUU1OjiooKbbPNNjr11FML3ueJJ57Qvvvuq+7du6uqqkojR47UAw880Oy/q7nrUkvXkrhNgqbfb7k5M2vWLE2fPl2DBg1SRUWFdtttt4Lra9LcbO7rvfPOOzr55JM1YMAAlZeXa+utt9ZPfvKTovVQFEX6/ve/rzlz5mjo0KGqqqrSLrvsogULFrR4jHPrgKa3xufyvvvu04gRI1RVVaXu3bvra1/7mn7/+9+3+Hml1s2shoYGXXHFFflrXc+ePbXnnnvqvvvuy79PbgNr0aJFGj58uCorK7XDDjvoV7/6VbP/pqabEkkz7LnnnlMURUXrRUlauHChoigq6Pnb3/6mcePGqU+fPuratauGDh2qq666KvG4SNJVV12lr3zlK+rTp4+6deumnXbaSbNmzdInn3xS8H4bN27UrFmztNVWW6miokLDhw/XwoULC+4r//73v1VeXq5zzjmn6Ou89NJLiqJIv/jFL/Jv+8c//qETTjhBtbW1Ki8v1+DBg/Wzn/2sYNOo8X162rRpGjx4sDp37qxFixapoaFB06ZN0/bbb58/VzvvvLMuv/zy/MenXcflztWcOXN0+umna8CAASorK9NLL73U7Hlcvny5jjjiCNXV1amyslJ1dXU68sgj9f/+3/9r9vO2ZQMr7ddIu4bPSbP2YwMLpcQGFrzW+LcIxxxzjPbYY4/8/7v66qtVXV2ttWvXFi1aGxoadNBBB6m6ulrnnXeeHn74Yd1www2qra3V5z73Of33v//Nv++0adN02WWX6cEHH9Tjjz+ua665RltvvbX22Wefgpbx48era9eu2nHHHXXxxRfrkUce0U9/+lOVlZXpvPPOS/y3nHvuuYqiSIcddpjmzp2rJUuW6NJLL9W5556bf58ZM2YoiiKNGzdODz74oObMmaNtttlGPXv21N/+9reCltxwv/DCC/Xoo4/qoYcekrRpoVlTU6NBgwbpyiuv1NKlS7Vs2TJJrd/AGjRokI477jgtWrRI1113nfr27atBgwblnyPjxRdf1Je+9CX169dPTz31VP6W0/Tr/fWvf1WPHj00ZMgQzZkzRw8++KDGjRuXX4zk5Ab34MGDddRRR+nBBx/UHXfcoa222krbbbedNmzYEHucV61apVNOOUVRFGn+/Pn5ptxv7E844QRFUaQf/OAHWrx4sa655hr16dNHgwYNKtqMaGrZsmU644wzdPfdd2vZsmW655579M1vflNVVVUFG2u5+2R1dbXOP/98PfTQQ5o3b55OPfVUPfbYY5I+XYQNHjxYBx10kO69917de++92nnnndW7d2+tXr06//ma25S44IILVFZWpuOOO04PPPCA5s+fr5EjR6q6ujr/px5vv/22unbtqqlTpxZ87IYNGzRgwAAddthh+bfdcsstKisr0ze/+U3Nnz9fCxYs0JgxY9S5c+fETazVq1drwoQJuuWWW/TYY49p8eLF+vGPf6xOnTrp5ptvzr/fxo0btc8++6iiokIXXHCBlixZovr6em2zzTYF95X169erb9++Ouqoo4q+1h577KEvfOEL+f9+7LHH1LVrV33lK1/RnXfeqcWLF2vChAlFv7XP3adra2t1wgknaNGiRbr77ru1YcMGHXjggerTp4+uu+46Pf7447r33nv105/+VL/5zW/yH3/11Vfrwgsv1P33369ly5bp5ptv1rBhw7TDDjsULOxz56qurk5TpkzRww8/nP+hqLnzmPb6054NrNZe47baaqv8+fnZz36mLl26aMyYMQXve/zxx6u8vFxnnHGGFi9erNtvv11Dhw7VZz/7Wf3zn/8s+JxsYKG92roWkOI3sLbZZhudcsopeuihh3TDDTeod+/eRd8TzVm8eLHKy8u1yy676KabbtJjjz2mG2+8UUceeWT+fR5//HGVl5drt91205133ql7771XBxxwgMrKygquKy1dl1q6lrR2A2vQoEH68pe/rHnz5mnu3LnafffdVV5ent/sSZqbTb/eRx99pF122UXV1dW6+OKLtWTJEp177rnq0qWLvv71rxcd/8GDB2uPPfbQXXfdpYULF+qrX/2qunTp0uwP0zlr1qzJH59zzjkn35T7ZdNtt92mKIp0wAEH6N5779Wdd96p3XbbTV27dtUTTzzR4jlMO7Mk6ZhjjlFZWZkmTZqk++67T4sWLdIFF1xQsPFSV1engQMH6nOf+5zmzJmjhx56SIcffriiKMqvv6TmNyXSzrDhw4frS1/6UtG/5Tvf+Y769u2b3+R58cUX8xs3c+bM0ZIlS3TGGWeoU6dO+tnPftbicZGkH/3oR7r66qu1ePFiPfbYY7rsssu05ZZb6rvf/W7B++XunxMnTsyvEWtra9WvX7+C+8q3vvUtDRo0SA0NDQUfP3nyZHXt2lX/+c9/JG3avBo0aJDq6up07bXX6pFHHtG0adNUUVGhCRMm5D8ud5+ura3VPvvso7vvvltLlizRypUrdeGFF6pz586qr6/Xo48+qsWLF+vyyy8v+HenXcflzlVtba3Gjh2r+++/Xw888IDeeeedZs/j3Llz9dOf/lT33HOPli1bpt/85jcaNWqU+vTpU7C2bM8GVtqvkXYNL6Vf+7GBhVJiAwtea7xozV3MX3jhBUnS7rvvnh9qTRetd9xxh6Io0rx58wo+X+7h6LNnz272623cuFHr16/XsmXLih7lMX78eEVRpLvuuqvgY77+9a9rhx12aPHf8X//93/q3Llzsz+Q57z33nuqqqoqWvy9/vrrqqio0P/8z/8Utdx4441Fnyf3qKhHH3206P+1dgPrW9/6VsH7Pfnkk4qiSNOnT8+/raU/IWz69Y488khVVFTo9ddfL3i/gw8+WN26dctv2uTOddNjcddddymKosTnEYr7U4jcb/y+973vFbz9j3/8o6Io0k9+8pMWP29TGzZs0CeffKLttttOP/rRj/JvP//88xVFUcEjeJrKLcJ23nnngg25p59+WlEU6Y477si/remmxOuvv64uXbrolFNOKfic77//vvr166fvfOc7+bcddthhGjhwYMHiMfcb29xvwD/88EPV1NTokEMOKfh8DQ0NGjZsWMEPi2ls2LBB69ev18SJEzV8+PD82xctWlT0G1dp02Zc0/vK6aefrqqqqoKNvL/85S+KokhXXnll/m1Dhw7V8OHDix7WP2bMGPXv3z//787dp4899tii3u7du+u0005L/e/LXSdee+21ot98587VT3/606KPS9qEaun64+pPCNNc4+LOz+9+9ztJm55TKIoiXXLJJQXvt2rVKlVVVWny5MkFn5MNLLRXW9cCUvwGVtM58POf/1xRFOkf//hHiy1DhgzRkCFD9NFHH8W+z4gRI9S3b1+9//77+bdt2LBBO+20kwYOHJj/E8GWrkstXUtau4E1YMCAgt61a9eqpqZGX/va1/Jva+lPCJt+vWuuuabZ9dCsWbPyj/zIiaJIn/3sZ7V27dr82/75z3+qU6dOuvDCC4u+VmNxf0LY0NCgAQMGaOeddy6Ybe+//7769u2rvfbaq8XP21TczPrtb3+rKIqKfgnUVO4RMa+99lr+bR999JFqamp04okn5t/W3KZE2hl2xRVXKIoivfzyy/n3effdd1VRUaEzzjgj/7YDDzxQAwcOLPoz2x/84AeqrKzUu+++m+KIbNLQ0KD169drzpw56ty5c/5j33vvPVVWVsauERvfV+6///6i+0Tul2jf/va382878cQT1b1794JjKEkXX3yxoijK/2Iud58eMmRI0aPCxowZo1133TX1vy/X0tw6Lneu9t5776KPSbMJtWHDBn3wwQeqrq4umKku/4Qw7mukXcO3Zu3HBhZKiQ0seK3xojX3KkOnn366nn/+eUVRpN/+9reSihetRx11lHr16pX/e/XGt6Y/4L/66qsaN26cPvvZz6qsrKzgoeqNf1M6fvx4lZWVFS1azzrrLFVWVrb477j22msVRVGLD23PbSo0XRBKmzZ4PvvZzxa0RFHU7BNIjho1Sr179272a7R2A+vuu+9u9n3322+//H+3ZgOrb9++RZtSknTnnXcqiiItWrRI0qeDu/GfiUibHsHV9Lw0J24hnvvzs6effrroY3bccUftueeeLX7e9evX64ILLtCOO+6o8vLygvvKQQcdlH+/kSNHavvtt2/xc+UWYWeddVbB29etW6coijRz5sz825puSlx//fX574um9+8jjjhCffv2zb/vggULFEVR/hF6knT44YerX79++Y2zhx9+OH++m36+KVOmqKysrOjPzZq66667tNdee6m6urrguDT+3pg8ebKiKMr/xrXpsWh8X3nhhRcURZGuvfba/NvOPPNMVVRU6J133pG06U8BoijSxRdfXNSdO9e5P7/N3acbbzbl7LvvvurVq5emTZump556qmhRLEn/+te/dOKJJ2rgwIHq1KlTwb+xuXPVeGOo6f9rLO31pz0bWK25xrV0fqZNmyZJmjp1qsrKyvSvf/2r6LiPGDGiYNHLBhZcaOtaQIrfwFq8eHHB+y1evFhRFOkPf/hDbEfuz51nzJgR+z4ffPCBysrKijbIpE83eHJ/St7Sdamla0lrN7B+8IMfNPu+Xbt2zc+B1mxgfec731F1dXXRc3X961//UhRFmjJlSv5tURQVPDotp1+/fjrppJOK3t5Y3AZW7pcZP//5z4s+5uSTT1anTp0Sny8szcw6++yzFUWR3nrrrRY/V11dXf5pHBobMWJEwdqg6aZEa2bYO++8o4qKCp199tn5z/fLX/6yYDP3o48+yv9yq+nny60xFy5c2OK/5ZlnntEhhxyimpqaguPS+Hsj97ni1oiN7yu5dfe4cePyb3vwwQcVRZEefPDB/Ntqa2t1yCGHFHW/+OKLiqJPf/Gcu0833mzKOf/881VWVqaTTz5ZixcvbnaNnHYdlztXTX+h0/j/Nd5cev/99zV58mQNGTJEnTt3Lvi8je/n7dnASvs10q7hW7P2YwMLpcQGFrzW9IkIp0+frr59++p73/tewQZB00Xr1772taLB2/i27777Sto0DAYMGKBtttlG119/vZYtW6bly5dr/vz5RYumuCc4TvOD5fTp0xVFUdEjjxq75ZZbFEVRsw99nzhxorp06VLQ0q1bt2Y/z6hRo/S5z32u2f/X2g2s3CMuGttzzz0LfsPVmg2szp07a+LEiUXv98QTTyiKIt16662SPh3cc+fOLXi/3MIl6Qld4xbi06ZNUxRFzT7f1X777adtt922xc97yimnqFOnTjr77LO1ePFi/fGPf9Ty5cs1bNiwgvvftttum7+PxWnpSdybHrem97Hc/Snu1qlTp/z7btiwQf3798//AJH7jW3jR8nceuutLX6+pPvuvHnzFEWRDj/8cN1zzz166qmntHz5ch133HEF3U3vxzkfffRRs/fN3XffPf9DQe7f0Xjz+Xe/+11id+4H29x9urnNy7ffflunnnqq6urqFEWRunfvrmOOOSb/SIzcbyP79OmjK664QkuXLtXTTz+tP/zhD7Hnqulz7TX+fzmtuf60dQOrtde4ls5P7lFqkyZNavGYb7PNNgWfkw0stFdb1wJS/AZW0yc4TvODZe6aM2fOnNj3WbVqVcGGb2O5OZ+brS1dl1q6lrR2A6vxo6ZzpkyZoiiK8o9ybc0G1n777achQ4YUvZ8kdenSRZMmTcr/dxRteg6sppquO5oTt4GVWzPccsstRR+Tm/NvvPFG7OdNO7MmTZqkzp07J77YR9yTuDc9bk3vY62ZYdKmXz7V1tbmNx133333gl8YvPHGG4mfr6X77muvvabq6mp94Qtf0C233KInnnhCy5cvz2+U5bqb3o8b23PPPYvum2eeeaYqKyvzf7p2+OGHq3///gWPPu/SpUuL3eeff76kT+/TzW1erl+/XpdccomGDx+usrIydenSRfvuu2/B93radVzuXDX3S+XmrhWHHHKIunXrpgsvvFCPPPKInn76aS1fvlx9+vQpuJ+3ZwMr7ddIu4ZvzdqPDSyUEhtY8FrTheYbb7yhTp06FT30vOmi9cgjj9QWW2yh5cuXN3vL/Z37fffdpyiK9Pjjjxd83dxvJVxtYLl4BFbuyVtbapE+fRL35lRUVBQ94kfa9CdUFh6BlfuNeEdtYCU9Aqu536A21rt374LnYsipra0tuP+15hFYbdnAyv35xt133x17H29s8uTJ+cXjVVddpSj69BEA0qePPLjyyitjP9/HH38c+2/51re+pa233rpokX/UUUcVdLfmEViSCn4D/cADDyiKPn2UnvTpI/LOPvvs2O7cn63E/dDa1GuvvaYrr7wy/wTzkvTnP/9ZURQVvdhA7rfnzZ2r5p5Prel5bM31p60bWK29xrV0fnI/kJ911lkqKyvT7373u2aPeeMnw2UDCy60dS0gud3ASvsIrE6dOrX4CKzcGqSl61JL15IDDzyw2XnVdB535COwunfvHvsIrMbrjI7YwGrvI7DSzqzWPAKrLRtYrZlh0qfrxEWLFuUfmXT11Vfn//+HH36ozp07a8KECbGfr+n1vbFf/OIXiqKo6EnBc4/6znW35hFY0qfn6+qrr87/Eq3xo/SkTY/IO+CAA2K7cy+wkPYVnN977z3NnTtX2223nWpqavL3h7TruLh1aOP/lzseq1evVllZWdFzjK1bt06dO3d2soHVmq+Rdg3fmrUfG1goJTaw4LXmFndTpkzRN77xjYIFRdNFa+63Ci39KYD06d/mN31OpbFjxzrdwFq5cqU6d+6sY445JvZ9cs+Bdeihhxa8fdWqVaqoqCh4/qy2bmDtsMMORRtIjz76qKIoatVzYDX+zfJhhx1W8CdrjTX9wWHcuHGqrKwseqWn0aNHN/scWG3dwMo9V0TTV2/MLRZ/+MMfFrw997xTSc9z0fT5LCTlN1Ya3/9yz4HV3POQNf23tGUDa+XKlerSpUvBE9+3JPfcX7Nnz9YXv/hFjRw5suD/v//+++rVq5dOPvnkVJ+vqcMOO6zoeeD+8Y9/qHv37gXdrXkOLOnT59mYPHmyxo4dq9ra2qIngt1uu+2a3RRtKu0GVs43v/lN9enTR5Lyf6bU+HnJJOnHP/5xuzawWnP9aesGVmuvcS2dn9yjQ3OPGmj6So/NYQMLLrR1LSC53cCSNj0H1rbbbtviqw+PHDlS/fr1K3jBmIaGBu28887NPgdWazewTjzxRNXU1BQ0/Oc//1Hv3r1b9RxYjX8ZFTc3peKNmNwv5ebPn1/wfrlNsMbP/9ieDazctbfp85Y2NDSotrZWu+66a8Em1AcffKC+ffs2+2TnjaWdWbnnwGr8YjvNaesGlpR+hkmbHolcW1ur73znO/rxj3+sysrKgueJlDb9BcKwYcNa/KVTnNx9oPHzwG3cuFF77LFHQfe7776b+jmwcvbcc0/tscce+V+iNX1F6UmTJmnAgAGJz9GVdgMr5/LLL1cUffocWmnXca3ZwFqzZo2iKCp6Trfcv9XFBlZrvkbaNXxr1n5sYKGU2MCC19L+0Nl00bphwwYdfPDBqqmp0XnnnadFixbpkUce0U033aTx48fnF125Bd+wYcPyr75x5JFHarvttnO6gSV9+iqEY8eO1bx58/TII4/oiiuuKHiC1tyrEB5zzDFauHChbrnlFm277bbNvgphWzawpk+frrKyMp177rn5r7/99turZ8+esa9COHHiRC1evFjXX3+9+vbtq9ra2vxzEDX+98+ePTv/UOycpj845F6FcPvtt9ett96qhQsX5n/j2fg3qe3dwMp9/Iknnqjf//73Bb/FPOGEE1RWVqbTTjtNDz30kK699tr8K7O09JtJSTr22GNVUVGhyy67TI8++qh+/vOfq0+fPho4cGDB/S/3aljdu3fX9OnTtWTJEt133306/fTTi16FsC0bWNKm+0qXLl104okn6p577tHjjz+uO++8U2eccUazT/o7cuRIDRo0SFEU6brrriv6/7fccos6deqkI444QnPnztWyZct0991369xzz018npIbb7xRURTp5JNP1qOPPqqbbrpJQ4YMyX8f5TQ0NGjvvfdWRUWFZsyYEfsqhI2NGzdOffv2VdeuXZt9kv3HHntMFRUVOuCAA3T77bfnX1VoxowZGjt2bP794q4lq1ev1vDhw3XRRRdpwYIFevzxx3XRRRepsrIy/8IJn3zyiYYMGaK6ujrdfvvtWrx4sb7//e9r++23b9cGVmuuP23dwGrtNS7uVQgPPvjggq9zwgknqFu3bjrzzDO1YMECPfbYY7rtttt08sknF/ywyQYWXGjrWkByv4GVexXCXXfdVTfffLOWLl2qm2++ueCFVnKvQrjnnntq7ty5uu+++3TggQfGvgphazewcpvIY8eO1UMPPaTbb79du+66q+rq6lp8FcL58+fr7rvv1u67764uXboU/IlRS3Mz7lUIe/TooUsvvVQPP/yw6uvrVV5e3uyrELZ1A+vDDz9UVVWVvvSlL2np0qUFj8TJvQrh17/+dd1333266667tPvuu6d6FcK0M0v69FUITzjhBN1///166DdnHKQAACAASURBVKGHNHPmTF1xxRUF/5a2bmClnWE5Z599tioqKtSnT5+C+1zOiy++qN69e2uPPfbQr3/9ay1dulT333+/Lr300sRX2XzppZfUtWtXffWrX9XChQs1f/587b///vnj0rj7nHPOURRFBWvE5l6FMCe36Tlw4MBmn2T/rbfeUl1dnYYOHarZs2fr0Ucf1YMPPqhf/vKXGj16dP6pH1paO40ZM0ZnnXVW/hUG58yZo8GDB6uuri7/3JZp13Gt2cCSpL333ls1NTW6/vrr9fDDD+ucc85R//791atXL2d/Qpj2a7RmDZ927ccGFkqJDSx4rT2L1vXr1+viiy/WsGHDVFlZqe7du2vo0KE68cQT9corr+Tf7/e//71Gjhypbt26qU+fPpo0aZKeeeYZ5xtYkjRnzhztvvvu+Z7hw4cXbcbccMMN2mWXXdS1a1f17NlT3/jGN/K/OUpqkVrewPr44481efJkDRo0SFVVVRo1apSee+652OfAWrJkiY455hj16tUr/wqJjY+dtOk3cWPHjlWvXr3yTxCd09ymxIoVK3TIIYeoZ8+e6tq1q4YNG1Z0DNq7gSVtWuQNGDAg/4TbuUVAQ0ODZs2ape23317l5eXacsstdfTRRzf7vFhNvffee5o4caL69u2rbt266ctf/rKeeOKJZp+P5L333tOpp56qrbbaSuXl5erbt69Gjx6d/61jezewJOnee+/VPvvso8985jOqqKhQXV2dxo4dW/DSxznXXXedoihSVVVVs09sKm16eenRo0erpqZG5eXlqq2t1ejRo5tdwDU1c+ZMDR48WBUVFdpxxx11/fXXN9u9evVqHXfccerVq5e6deum/fffP//IuOY2sJYsWaIo2vRcDI03cRv785//nH8p8fLycvXr10/77rtvwYsAxF1L1q1bp5NOOkm77LKLPvOZz6iqqko77LCD6uvrC/4E5S9/+Yv2339/9ejRQ71799bhhx+u119/vV0bWFL6609bN7Ba8zVy15Xnn39eX/3qV1VVVaWamhqdfPLJzT6J/4033qg999xT1dXVqqqq0pAhQ3TsscfqT3/6U8HnZAML7WVpA0va9EqcBx98sHr27KmKigoNGTKk6Emln3jiCe277775748RI0bkX/k1zb+rpWuJJN18883acccdVVlZqc997nO68847Y58Da9asWTrvvPM0cOBAde3aVcOHDy94YY+cuLnZ3Ix75513dNJJJ6l///7q0qWL6urqdPbZZxc9Mq09G1jSpleVHjp0aP4Jtxufy3vvvVd77rmnKisrVV1drf32209PPvlk4ueU0s+shoYGXXbZZdppp53y67KRI0cWnMv2bGBJ6WZYzt/+9rf8TIx7peOVK1fquOOOU21trcrLy9WnTx/ttddezT4XWlMLFizIr5tra2t15pln5h893bh748aNuvDCCzVo0CB17dpVu+yyixYsWBD7/Gxr1qxRVVWVoijS9ddf3+zXfvvtt/XDH/5QW2+9tcrLy1VTU6PddttNU6dOzc+gltZOl1xyifbaay9tueWW+V/GTJw4seBPItOu41q7gfXGG2/o29/+tnr37q0ePXrooIMO0gsvvFB0P2/PBlbar9GaNbyUbu3HBhZKiQ0sAK3W2j+3AgAAtrT2z60AANjc2MAC0GpsYAEA4Dc2sAAAvmEDC0CrsYEFAIDf2MACAPiGDSwAAAAAAACYxgYWAAAAAAAATGMDCwAAAAAAAKaxgQUAAAAAAADT2MCCcw0NDVq1apVWr16tNWvWcOPGjRs3bpv9tnr1aq1atUoNDQ2be0wGgVnPjRs3btys3Zj14WMDC86tWrVKURRx48aNGzdu5m6rVq3a3GMyCMx6bty4ceNm9casDxcbWHBu9erV+QvH5t6F58aNGzdu3NasWZPfcFm9evXmHpNBYNZz48aNGzdrN2Z9+NjAgnNr1qxRFEVas2bN5k4BAEASs8k1jicAwBpmU/jYwIJzXDgAANYwm9zieAIArGE2hY8NLDjHhQMAYA2zyS2OJwDAGmZT+NjAgnNcOAAA1jCb3OJ4AgCsYTaFjw0sOMeFAwBgDbPJLY4nAMAaZlP42MCCc1w4AADWMJvc4ngCAKxhNoWPDSw4x4UDAGANs8ktjicAwBpmU/jYwIJzXDgAANYwm9zieAIArGE2hY8NLDjHhQMAYA2zyS2OJwDAGmZT+NjAgnNcOAAA1jCb3OJ4AgCsYTaFjw0sOMeFAwBgDbPJLY4nAMAaZlP42MCCc1w4AADWMJvc4ngCAKxhNoWPDSw4x4UDAGANs8ktjicAwBpmU/jYwIJzXDgAANYwm9zieAIArGE2hY8NLDjHhQMAYA2zyS2OJwDAGmZT+NjAyphly5ZpzJgx6t+/v6Io0j333FPw/zdu3Kj6+nr1799flZWVGjVqlF544YVWfQ0uHAAAa5hNbnE8AQDWMJvCxwZWxixcuFBTp07VvHnzmt3Amjlzpnr06KF58+ZpxYoVOuKII9S/f3+tXbs29dfgwgGgzeo/07YbkIDZ5BbHEx2OeQCglZhN4WMDK8OabmBt3LhR/fr108yZM/NvW7dunXr27Klrrrkm9eflwgGgzfiBBR2E2eQWxxMdjnkAoJWYTeFjAyvDmm5gvfrqq4qiSM8880zB+x166KE69thjYz/PunXrtGbNmvxt1apVXDgAtA0/sKCDsKh1i+OJDsc8ANBKzKbwsYGVYU03sJ588klFUaQ333yz4P2OP/54HXDAAbGfp76+XlEUFd24cABoNX5gQQdhUesWxxMdjnkAoJWYTeFjAyvD4jaw3nrrrYL3mzRpkg488MDYz8MjsFByLGrDxblFB2FR6xbHEx2OeQCglZhN4WMDK8Nc/QlhU1w40OFY1IaLc4sOwmxyi+OJDsc8ANBKzKbwsYGVYXFP4j5r1qz82z7++GOexB32sKgNF+cWHYTZ5BbHEx2OeQCglZhN4WMDK2Pef/99Pfvss3r22WcVRZEuvfRSPfvss3rttdckSTNnzlTPnj01f/58rVixQuPGjVP//v21du3a1F+DCwc6HIvacHFu0UGYTW5xPJFW3ZQH2nRjHgBoLWZT+NjAypilS5c2+4Tr48ePl7TpUVj19fXq16+fKioqtPfee2vFihWt+hpcONDhWNSGi3OLDsJscovjibTYwAJQKsym8LGBBee4cKDDsagNF+cWHYTZ5BbHE2mxgQWgVJhN4WMDC85x4UCHY1EbLs4tOgizyS2OJ9JiAwtFOLfoIMym8LGBBee4cKDDsfAJF+cWHYTZ5BbHE2mxgYUinFt0EGZT+NjAgnNcONDhWPiEi3Pbdhy7FmVpNi1btkxjxoxR//79i15xWPr0+S779++vyspKjRo1Si+88EKrvkaWjifahw0sFOHcooMwm8LHBhac48KBDsfCJ1yc27bj2LUoS7Np4cKFmjp1qubNm9fsBtbMmTPVo0cPzZs3TytWrNARRxzBKw6jw7CBhSKcW3QQZlP42MCCc1w4kBaLWhTh3LYdx65FWZ1NTTewNm7cqH79+mnmzJn5t61bt049e/bUNddck/rzZvV4ovWY9SjCuUUHYTaFjw0sOMeFA2mxqEURzm3bcexalNXZ1HQD69VXX1UURXrmmWcK3u/QQw/VscceG/t51q1bpzVr1uRvq1atyuTxROsx61GEc4sOktVZnyVsYME5LhxIi0UtinBu245j16KszqamG1hPPvmkoijSm2++WfB+xx9/vA444IDYz1NfX68oiopuWTueaD1mPYpwbtFBsjrrs4QNLDjHhQNpsahFEc5t23HsWpTV2RS3gfXWW28VvN+kSZN04IEHxn4eHoGFtmLWowjnFh0kq7M+S9jAgnNcOJAWi1oU4dy2HceuRVmdTa7+hLCprB5PtB6zHkU4t+ggzKbwsYEF57hwIC0WtSjCuW07jl2Lsjqb4p7EfdasWfm3ffzxxzyJOzoMsx5FOLfoIMym8LGBBee4cCAtFrUoYvncWm7zoW8zy9Jsev/99/Xss8/q2WefVRRFuvTSS/Xss8/qtddekyTNnDlTPXv21Pz587VixQqNGzdO/fv319q1a1N/jSwdT7QPsx5FOLfoIMym8LGBBee4cCAtFrUoYvncWm7zoW8zy9JsWrp0abNPuD5+/HhJmx6FVV9fr379+qmiokJ77723VqxY0aqvkaXjifZh1qMI5xYdhNkUPjaw4BwXDqTFohZFLJ9by20+9G1mzCa3OJ5Ii1mPIpxbdBBmU/jYwIJzXDiQFotaFLF8bi23+dC3mTGb3OJ4Ii1mPYpwbtFBmE3hYwMLznHhQFosasMV5Lm13OZD32bGbHKL44m0gpwHaB/OLToIsyl8bGDBOS4cSItFbbiCPLeW23zo28yYTW5xPJFWkPMA7cO5RQdhNoWPDSw4x4UDabGoDVeQ59Zymw99mxmzyS2OJ9IKch6gfTi36CDMpvCxgQXnuHAgLRa14Qry3JaoLchjZwCzyS2OJ9LimoYinFt0EGZT+NjAgnNcOJAWi9pwBXlu2cDyGrPJLY4n0uKahiKcW3QQZlP42MCCc1w4kBaL2nAFeW7ZwPIas8ktjifS4pqGIpxbdBBmU/jYwIJzXDiQFovacAV5btnA8hqzyS2OJ9LimoYinFt0EGZT+NjAgnNcOJAWi9pwBXlu2cDyGrPJLY4n0uKahiKcW3QQZlP42MCCc1w4kBaL2nAFeW7ZwPIas8ktjifS4poWLs4trGE2hY8NLDhn5sLBcDSPhU+4gjy3bGB5zcxsCgTHE2lxTQsX5xbWMJvCxwYWnDNz4WA4msfCJ1xBnls2sLxmZjYFguOJtLimhYtzC2uYTeFjAwvOmblwMBzNY+ETriDPLRtYXjMzmwLB8URaXNPCxbmFNcym8LGBBefMXDgYjuYFu/Cx3FYiQZ5bNrC8ZmY2BYLjibS4poWLcwtrmE3hYwMLzpm5cDAczQt24WO5rUSCPLdsYHnNzGwKBMcTaXFNC1ew57YEfcEeu82M2RQ+NrDgnJkLBxd484Id3pbbSiTIc1uitiCPnQFmZlMgOJ5Ii2tauII9tyXoC/bYbWbMpvCxgQXnzFw4uMCbF+zwttxWIkGe2xK1BXnsDDAzmwLB8URaXNPCFey5LUFfsMduM2M2hY8NLDhn5sLBBd68YIe35bYSCfLclqgtyGNngJnZFAiOJ9LimhauYM9tCfqCPXabGbMpfGxgwTkzFw4u8OYFO7wtt5VIkOe2RG1BHjsDzMymQHA8kRbXtHAFe25L0BfssdvMmE3hYwMLzpm5cHCBNy/Y4W25rUSCPLclagvy2BlgZjYFguOJtLimhSvYc1uCvmCP3WbGbAofG1hwzsyFgwu8ecEOb8ttJRLkuS1RW5DHzgAzsykQHE+kxTUtXMGe2xL0BXvsNjNmU/jYwIJzZi4cXODNC3Z4W24rkSDPbYnagjx2BpiZTYHgeCItrmnhCvbclqAv2GO3mTGbwscGFpwzc+HgAm9esMPbcluJBHluS9QW5LEzwMxsCoSZ48n93jyuaeEK9tyWoC/YY7eZmZlN6DBsYME5MxcOLvDmBTu8LbeViPVzG1qbF98Xm5mZ2RQIM8eT+715XNPCFey5LUFfsMduMzMzm9Bh2MCCc2YuHFzgzQt2eFtuKxHr5za0Ni++LzYzM7MpEGaOJ/d787imhSvYc1uCvmCP3WZmZjahw7CBBefMXDi4wJsX7PC23FYi1s9taG3Bfl847DMzmwJh5nhav98j3Gsawj23JegL9thtZmZmEzoMG1hwzsyFgwu8ecEOb8ttJWL93IbWFuz3hcM+M7MpEGaOp/X7PcK9piHcc1uCvmCP3WZmZjahw7CBBedcXzi4wIcr2HNrua1ErJ/b0NqC/b5w2Mei1i0zx9P6/R7hXtMQ7rktQV+wx24zMzOb0GHYwIJzbGAFgB/U28dyW4lYP7ehtQX7feGwj0WtW2aOp/X7PcK9piHcc1uCvmCP3WZmZjahw7CBBefYwAoAP6i3T2htAZ7b0NqC/b5w2Mei1i0zx9P6/R7hXtMQ7rktQV+wx24zMzOb0GHYwIJzbGAFgB/U2ye0tgDPbWhtwX5fOOxjUeuWmeNp/X6PcK9pMH9uLfdZbvOZmdmEDsMGFpxjAysly30sLNontLYAz21obcF+XzjsY1Hrlpnjaf1+j3CvaTB/bi33WW7zmZnZhA7DBhacYwMrJct9LCzaJ7S2AM9taG3Bfl847GNR65aZ42n9fo9wr2kwf24t91lu85mZ2YQOwwYWnGMDKyXLfSws2ie0tgDPbWhtwX5fOOxjUeuWmeNp/X6PcK9pMH9uLfdZbvOZmdmEDsMGFpxjAysly30sLErfVyohHrsS9Vlu45qXjEWtW2aOp/X7PcK9psH8ubXcZ7nNZ2ZmEzoMG1hwjg2slCz3sbAofV+phHjsStRnuY1rXjIWtW6ZOZ7W7/cI95oG8+fWcp/lNp+ZmU3oMGxgwTk2sFKy3MfCovR9pRLisStRn+U2rnnJWNS6ZeZ4Wr/fI9xrGsyfW8t9ltt8ZmY2ocOwgQXn2MBKyXIfC4vS95VKiMeuRH2W27jmJWNR6xazHmlxbsNl/dxa7rPc5jNmffjYwIJzLGpTstzHwqL0faUS4rErUZ/lNq55yVjUusWsR1qc23BZP7eW+yy3+YxZHz42sOAci9qULPexsCh9X6mEeOxK1Ge5jWteMha1bjHrkRbnNlzWz63lPsttPmPWh48NLDjHojYly30sLErfVyohHrsS9Vlu45qXjEWtW8x6pMW5DZf1c2u5z3Kbz5j14WMDC86xqE3Jch8Li9L3lUqIx65EfZbbuOYlY1HrFrMeaXFuw2X93Frus9zmM2Z9+NjAgnMsalOy3MfCovR9pRLisStRn+U2rnnJWNS6xaxHWpzbcFk/t5b7LLf5jFkfPjaw4ByL2pQs97GwKH1fqYR47ErUZ7mNa14yFrVuMeuRFuc2XNbPreU+y20+Y9aHjw0sOMeiNiXLfSwsSt9XKiEeuxL1WW7jmpeMRa1bzHqkxbkNl/Vza7nPcpvPmPXhYwMLzrGoTclyHwuL0veVSojHrkR9ltvoS8ai1i1mPdLi3IbL+rm13Ge5zWfM+vCxgQXnWNSmZLmPhUXp+0olxGNXoj7LbfQlY1HrFrMeaXFuw2X93Frus9zmM2Z9+NjAgnMsalOy3MfCovR9pRLisStRn+U2+pKxqHWLWY+0OLfhsn5uLfdZbvMZsz58bGDBORa1KVnuY2FR+r5SCfHYlajPcht9yVjUusWsR1qc23BZP7eW+yy3+YxZHz42sFBg/fr1mjp1qgYPHqzKykptvfXWOu+889TQ0JD6c7CoTclyHwuL0veVSojHrkR9ltvoS8ai1i1mPdLi3IbL+rm13Ge5zWfM+vCxgYUC06dP1xZbbKEHHnhAK1eu1Ny5c9W9e3ddfvnlqT8Hi9qULPexsCh9X6mEeOxK1Ge5jb5kLGrdYtYjLc5tuKyfW8t9ltt8xqwPHxtYKDB69Ggdd9xxBW877LDDdPTRR6f+HCxqU7Lcx8Ki9H2lEuKxK1Gf5Tb6krGodYtZj7Q4t+Gyfm4t91lu8xmzPnxsYKHAhRdeqLq6Or388suSpOeee059+/bV7bffHvsx69at05o1a/K3VatWsahNw3IfC4vS95VKiMeuRH2W2+hLxqLWLTawkBbnNlzWz63lPsttPmPWh48NLBTYuHGjzjrrLJWVlalLly4qKyvTjBkzWvyY+vp6RVFUdGNRm8ByHwuL0veVSojHrkR9ltvoS8ai1i02sJAW5zZc1s+t5T7LbT5j1oePDSwUuOOOOzRw4EDdcccdev755zVnzhzV1NTopptuiv0YHoHVRpb7WFiUvq9UQjx2Jeqz3EZfMha1brGBhbQ4t+Gyfm4t91lu8xmzPnxsYKHAwIEDddVVVxW8bdq0adphhx1Sfw4WtSlZ7mNhUfq+Ugnx2JWoz3IbfclY1LrFrEdanNtwWT+3lvsst/mMWR8+NrBQoKamRrNnzy5424wZM7Tddtul/hwsalOy3MfCovR9ltvoM99GXzIWtW4x65EW5zZc1s+t5T7LbT5j1oePDSwUGD9+vGpra/XAAw9o5cqVmj9/vrbccktNnjw59edgUZuS5T4WFqXvs9xGn/k2+pKxqHWLWY+0OLfhsn5uLfdZbvMZsz58bGChwNq1a3Xqqadqq622UmVlpbbZZhtNnTpVH3/8cerPwaI2Jct9LCxK32e5jT7zbfQlY1HrFrMeaXFuw2X93Frus9zmM2Z9+NjAgnMsalOy3MfCovR9ltvoM99GXzIWtYXWr1+vqVOnavDgwaqsrNTWW2+t8847Tw0NDak+nlmPtDi34bJ+bi33WW7zGbM+fGxgwTkWtSkxHOnzpY0+8230JWNRW2j69OnaYost8k8ZMHfuXHXv3l2XX355qo9n1iMtzm24rJ9by32W23zGrA8fG1hwjkVtSgxH+nxpo898G33JWNQWGj16tI477riCtx122GE6+uijU308sx5pcW7DZf3cWu6z3OYzZn342MCCcyxqU2I40udLG33m2+hLxqK20IUXXqi6ujq9/PLLkqTnnntOffv21e23357q45n1SItzGy7r59Zyn+U2nzHrw8cGFpxjUZsSw5E+X9roM99GXzIWtYU2btyos846S2VlZerSpYvKyso0Y8aM2Pdft26d1qxZk7+tWrWKWY9UOLfhsn5uLfdZbvMZsz58bGDBOTawUmI40udLG33m2+hLxqK20B133KGBAwfqjjvu0PPPP685c+aopqZGN910U7PvX19fryiKim7MeiTh3IbL+rm13Ge5zWfM+vCxgQXn2MBKieFIny9t9Jlvoy8Zi9pCAwcO1FVXXVXwtmnTpmmHHXZo9v15BBbainMbLuvn1nKf5TafMevDxwYWnGMDKyWGI32+tNFnvo2+ZCxqC9XU1Gj27NkFb5sxY4a22267VB/PrEdanNtwWT+3lvsst/mMWR8+NrDgHIvalBiO9PnSRp/5NvqSsagtNH78eNXW1uqBBx7QypUrNX/+fG255ZaaPHlyqo9n1iMtzm24rJ9by32W23zGrA8fG1hwjkVtSgxH+nxpo898G33JWNQWWrt2rU499VRttdVWqqys1DbbbKOpU6fq448/TvXxzHqkxbkNl/Vza7nPcpvPmPXhYwMLzrGoTYnhSJ8vbfSZb6MvGYtat5j1SItzGy7r59Zyn+U2nzHrw8cGFpxjUZsSw5E+X9roM99GXzIWtW4x65EW5zZc1s+t5T7LbT5j1oePDSw4x6I2JYYjfb600We+jb5kLGrdYtYjLc5tuKyfW8t9ltt8xqwPHxtYcI5FbUoMR/p8aaPPfBt9yVjUusWsR1qc23BZP7eW+yy3+YxZHz42sOAci9qUGI70+dJGn/k2+pKxqHWLWY+0OLfhsn5uLfdZbvMZsz58bGDBORa1KTEc6fOljT7zbfQlY1HrFrM+EFwz0A7Wz63lPsttPmPWh48NLDjHojYlhiN9vrTRZ76NvmQsat1i1geCawbawfq5tdxnuc1nzPrwsYEF51jUpsRwpM+XNvrMt9GXjEWtW8z6QHDNQDtYP7eW+yy3+YxZHz42sOAci9qUGI70+dJGn/k2+pKxqHWLWR8IrhloB+vn1nKf5TafMevDxwYWnGNRmxLDkT5f2ugz30ZfMha1bjHrA8E1A+1g/dxa7rPc5jNmffjYwIJzLGpTYjjS50sbfebb6EvGotYtZn0guGagHayfW8t9ltt8xqwPHxtYcI5FbUoMR/p8aaPPfBt9yVjUusWsDwTXDLSD9XNruc9ym8+Y9eFjAwvOsahNieFIny9t9Jlvoy8Zi1q3mPWB4JqBdrB+bi33WW7zGbM+fGxgwTkWtSkxHOnzpY0+8230JWNR6xazPhBcM9AO1s+t5T7LbT5j1oePDSw4x6I2JYYjfb600We+jb5kLGrdYtYHgmsG2sH6ubXcZ7nNZ8z68LGBBedY1KbEcKTPlzb6zLfRl4xFrVvM+kBwzWg7630lYP3cWu6z3NYuzHp0MDaw4ByL2pQYjvT50kaf+Tb6krGodYtZHwiuGW1nva8ErJ9by32W29qFWY8OxgYWnGNRmxLDkT5f2ugz30ZfMha1bjHrbWFebYZza72vBKyfW8t9ltvahVmPDsYGFpxjUZsSw5E+X9roM99GXzIWtW4x621hXm2Gc2u9rwSsn1vLfZbb2oVZjw7GBhacY1GbEsORPl/a6DPfRl8yFrVuMettYV5thnNrva8ErJ9by32W29qFWY8OxgYWnGNRmxLDkT5f2ugz30ZfMha1bjHrbWFebYZza72vBKyfW8t9ltvahVmPDsYGFpxjUZsSw5E+X9roM99GXzIWtW4x621hXm2Gc2u9rwSsn1vLfZbb2oVZjw7GBhacY1GbEsORPl/a6DPfRl8yFrVuMettYV6F22eZ9WNnuc9yW7sw69HB2MCCcyxqU2I40udLG33m2+hLxqLWLWa9LcyrcPsss37sLPdZbmsXZj06GBtYcI5FbUoMR/p8aaPPfBt9yVjUusWst4V5FW6fZdaPneU+y20+9MVh1oePDSw4x6I2JYYjfb600We+jb5kLGrdYtbbwrwKt88y68fOcp/lNh/64jDrw8cGFpxjUZsSw5E+X9roM99GXzIWtW4x621hXoXbZ5n1Y2e5z3KbD31xmPXhYwMLzrGoTYnhSJ8vbfSZb6MvGYtat5j1tjCvwu2zzPqxs9xnuc2HvjjM+vCxgQXnsraotdxnuY0+j9roM99GXzIWtW5lbdZbx7wKt88y68fOcp/lNh/64jDrw8cGFpzL2qLWcp/lNvo8aqPPfBt9yVjUupW1WW8d8yrcPsusHzvLfZbbfOiLw6wPHxtYcC5ri1rLfZbb6POojT7zHhlP/AAAIABJREFUbfQlY1HrVtZmvXXMq3D7LLN+7Cz3WW7zoS8Osz58bGDBuawtai33WW6jz6M2+sy30ZeMRa1bWZv11jGvwu2zzPqxs9xnuc2HvjjM+vCxgQXnsraotdxnuY0+j9roM99GXzIWtW5lbdZbx7wKt88y68fOcp/lNh/64jDrw8cGFpzL2qLWcp/lNvo8aqPPfBt9yVjUupW1WW8d8yrcPsusHzvLfZbbfOiLw6wPHxtYcC5ri1rLfZbb6POojT7zbfQlY1HrVtZmvXXMq3D7LLN+7Cz3WW7zoS8Osz58bGDBuawtai33WW6jz6M2+sy30ZeMRa1bWZv11jGvwu2zzPqxs9xnuc2HvjjM+vCxgQXnsraotdxnuY0+j9roM99GXzIWtW5lbdZbx7wKt88y68fOcp/lNh/64jDrw8cGFpzL2qLWcp/lNvo8aqPPfBt9yVjUupW1WW8d8yrcPsusHzvLfZbbfOiLw6wPHxtYcC5ri1rLfZbb6POojT7zbfQlY1HrVtZmvXXMq3D7LLN+7Cz3WW7zoS8Osz58bGDBuawtai33WW6jz6M2+sy30ZeMRa1bWZv11jGvwu2zzPqxs9xnuc2HvjjM+vCxgQXnsraotdxnuY0+j9roM99GXzIWtW5lbdZbx7wKt88y68fOcp/lNh/64jDrw8cGFpzL2qLWcp/lNvo8aqPPfBt9yVjUupW1WW8d8yrcPsusHzvLfZbbfOiLw6wPHxtYcC5ri1rLfZbb6POojT7zbfQlY1HrVtZmvXXMq3D7LLN+7Cz3WW7zoS8Osz58bGDBuawtai33WW6jz6M2+sy30ZeMRa1bWZv11jGvwu2zzPqxs9xnuc2HvjjM+vCxgQXnsraotdxnuY0+j9roM99GXzIWtW5lbdZbx7wKt88y68fOcp/lNh/64jDrw8cGFpzL2qLWcp/lNvo8aqPPfBt9yVjUupW1WW8d8yrcPsusHzvLfZbbfOiLw6wPHxtYcC5ri1rLfZbb6POojT7zbfQlY1HrVtZmvXXMq3D7LLN+7Cz3WW7zoS8Osz58bGDBuawtai33WW6jz6M2+sy30ZeMRa1bWZv1bRbi96XltgD72oRjZ77PcpsPfXGY9eFjAwvOZW1Ra7nPcht9HrXRZ76NvmQsat3K2qxvsxC/Ly23BdjXJhw7832W23zoi8OsDx8bWHAua4tay32W2+jzqI0+8230JWNR61bWZn2bhfh9abktwL424diZ77Pc5kNfHGZ9+NjAgnNZW9Ra7rPcRp9HbfSZb6MvGYtat7I269ssxO9Ly20B9rUJx858n+U2H/riMOvDxwYWnMvaotZyn+U2+jxqo898G33JWNS6lbVZ32Yhfl9abguwr004dub7LLf50BeHWR8+NrBQ5I033tBRRx2lmpoaVVVVadiwYfrTn/6U+uOztqi13Ge5jT6P2ugz30ZfMha1bmVt1rdZiN+XltsC7GsTjp35PsttPvTFYdaHjw0sFHj33XdVV1enCRMm6I9//KNWrlypRx55RH//+99Tf46sLWot91luo8+jNvrMt9GXjEWtW1mb9W0W4vel5bYA+9qEY2e+z3KbD31xmPXhYwMLBaZMmaIvf/nL7focWVvUWu6z3EafR230mW+jLxmLWreyNuvbLMTvS8tt9Jlvo89+mw99cZj14WMDCwV23HFHnXbaaRo7dqz69OmjXXfdVdddd12rPkfWFrWW+yy30edRG33m2+hLxqLWrazN+jYL8fvScht95tvos9/mQ18cZn342MBCgYqKClVUVOjss8/WM888o2uuuUaVlZW6+eabYz9m3bp1WrNmTf62atWqTC1qLfdZbqPPozb6zLfRl4xFrVtsYKUU4vel5Tb6zLfRZ7/Nh744zPrwsYGFAuXl5Ro5cmTB20455RSNGDEi9mPq6+sVRVHRLSuLWst9ltvo86iNPvNt9CVjUesWG1gphfh9abmNPvNt9Nlv86EvDrM+fGxgocBWW22liRMnFrxt9uzZGjBgQOzH8Agsu32W2+jzqI0+8230JWNR6xYbWCmF+H1puY0+82302W/zoS8Osz58bGChwLhx44qexP20004relRWS7K2qLXcZ7mNPo/a6DPfRl8yFrVuZW3Wt1mI35eW2+gz30af/TYf+uIw68PHBhYKPP300+rSpYsuuOACvfLKK7rtttvUrVs33Xrrrak/R9YWtZb7LLfR51Ebfebb6EvGorbYG2+8oaOOOko1NTWqqqrSsGHD9Kc//SnVx2Zt1rdZiN+XltvoM99Gn/02H/riMOvDxwYWiixYsEA77bSTKioqNHToUF6F0OM+y230edRGn/k2+pKxqC307rvvqq6uThMmTNAf//hHrVy5Uo888oj+/ve/p/r4rM36Ngvx+9JyG33m2+iz3+ZDXxxmffjYwIJzWVvUWu6z3EafR230mW+jLxmL2kJTpkwpesqA1sjarG+zEL8vLbfRZ76NPvttPvTFYdaHjw0sOJe1Ra3lPstt9HnURp/5NvqSsagttOOOO+q0007T2LFj1adPH+26666tesR11mZ9m4X4fWm5jT7zbfTZb/OhLw6zPnxsYMG5rC1qLfdZbqPPozb6zLfRl4xFbaGKigpVVFTo7LPP1jPPPKNrrrlGlZWVuvnmm5t9f15xmD4v2ugz30af/TYf+uIw68PHBhacYwPLTp/lNvo8aqPPfBt9yVjUFiovLy96heFTTjlFI0aMaPb96+vrFUVR0Y1Zn8E+y230mW+jz36bD31xmPXhYwMLzrGBZafPcht9HrXRZ76NvmQsagtttdVWmjhxYsHbZs+erQEDBjT7/jwCiz4v2ugz30af/TYf+uIw68PHBhacYwPLTp/lNvo8aqPPfBt9yVjUFho3blzRk7ifdtppRY/KisOsz3Cf5Tb6zLfRZ7/Nh744zPrwsYEF51jU2umz3EafR230mW+jLxmL2kJPP/20unTpogsuuECvvPKKbrvtNnXr1k233nprqo9n1me4z3Ibfebb6LPf5kNfHGZ9+NjAgnMsau30WW6jz6M2+sy30ZeMRW2xBQsWaKeddlJFRYWGDh3KqxDS538bfebb6LPf5kNfHGZ9+NjAgnMsau30WW6jz6M2+sy30ZeMRa1bzPoM91luo898G33223zoi8OsDx8bWHCORa2dPstt9HnURp/5NvqSsah1i1mf4T7LbfSZb6PPfpsPfXGY9eFjAwvOsai102e5jT6P2ugz30ZfMha1bjHrM9xnuY0+82302W/zoS8Osz58bGDBORa1dvost9HnURt95tvoS8ai1i1mfYb7LLfRZ76NPvttPvTFYdaHjw0sOMei1k6f5Tb6PGqjz3wbfclY1LrFrM9wn+U2+sy30We/zYe+OMz68LGBBedY1Nrps9xGn0dt9Jlvoy8Zi1q3mPUZ7rPcRp/5Nvrst/nQF4dZHz42sOAci1o7fZbb6POojT7zbfQlY1HrFrM+w32W2+gz30af/TYf+uIw68PHBhacY1Frp89yG30etdFnvo2+ZCxq3WLWZ7jPcht95tvos9/mQ18cZn342MCCcyxq7fRZbqPPozb6zLfRl4xFrVvM+gz3WW6jz3wbffbbfOiLw6wPHxtYcI5FrZ0+y230edRGn/k2+pKxqHWLWZ/hPstt9Jlvo89+mw99cZj14WMDC86xqLXTZ7mNPo/a6DPfRl8yFrVuMesz3Ge5jT7zbfTZb/OhLw6zPnxsYME5FrV2+iy30edRG33m2+hLxqLWLWZ9hvsst9Fnvo0++20+9MVh1oePDSw4x6LWTp/lNvo8aqPPfBt9yVjUusWsz3Cf5Tb6zLfRZ7/Nh744zPrwsYEF51jU2umz3EafR230mW+jLxmLWreY9Rnus9xGn/k2+uy3+dAXh1kfPjaw4ByLWjt9ltvo86iNPvNt9CVjUesWsz7DfZbb6DPfRp/9Nh/64jDrw8cGFpxjUWunz3IbfR610We+jb5kLGrdYtZnuM9yG33m2+iz3+ZDXxxmffjYwIJzLGrt9Fluo8+jNvrMt9GXjEWtW8z6DPdZbqPPfBt99tt86IvDrA8fG1hwjkWtnT7LbfR51Eaf+Tb6krGodYtZn+E+y230mW+jz36bD31xmPXhYwMLzrGotdNnuY0+j9roM99GXzIWtW4x6zPcZ7mNPvNt9Nlv86EvDrM+fGxgwTkWtXb6LLfR51Ebfebb6EvGotYtZn2G+yy30We+jT77bT70xWHWh48NLDjHotZOn+U2+jxqo898G33JWNS6xazPcJ/lNvrMt9Fnv82HvjjM+vCxgQXnWNTa6bPcRp9HbfSZb6MvGYtat5j1Ge6z3Eaf+Tb67Lf50BeHWR8+NrDgHItaO32W2+jzqI0+8230JWNR6xazPsN9ltvoM99Gn/02H/riMOvDxwYWnGNRa6fPcht9HrXRZ76NvmQsat1i1me4z3Ibfebb6LPf5kNfHGZ9+NjAgnMsau30WW6jz6M2+sy30ZeMRa1bzPoM91luo898G33223zoi8OsDx8bWHCORa2dPstt9HnURp/5NvqSsah1i1mf4T7LbfSZb6PPfpsPfXGY9eFjAwvOsai102e5jT6P2ugz30ZfMha1bjHrM9xnuY0+82302W/zoS8Osz58bGDBORa1dvost9HnURt95tvoS8ai1i1mfYb7LLfRZ76NPvttPvTFYdaHjw0sOMei1k6f5Tb6PGqjz3wbfclY1LrFrM9wn+U2+sy30We/zYe+OMz68LGBBedY1Nrps9xGn0dt9Jlvoy8Zi1q3mPUZ7rPcRp/5Nvrst/nQF4dZHz42sOAci1o7fZbb6POojT7zbfQlY1HrFrM+w32W2+gz30af/TYf+uIw68PHBhacY1Frp89yG30etdFnvo2+ZCxq3WLWZ7jPcht95tvos9/mQ18cZn342MCCcyxq7fRZbqPPozb6zLfRl4xFrVvM+gz3WW6jz3wbffbbfOiLw6wPHxtYcI5FrZ0+y230edRGn/k2+pKxqHWLWZ/hPstt9Jlvo89+mw99cZj14WMDC86xqLXTZ7mNPo/a6DPfRl8yFrVuMesz3Ge5jT7zbfTZb/OhLw6zPnxsYME5FrV2+iy30edRG33m2+hLxqLWLWZ9hvsst9Fnvo0++20+9MVh1oePDSw4x6LWTp/lNvo8aqPPfBt9yVjUusWsz3Cf5Tb6zLfRZ7/Nh744zPrwsYEF51jU2umz3EafR230mW+jLxmLWreY9Rnus9xGn/k2+uy3+dAXh1kfPjaw4ByLWjt9ltvo86iNPvNt9CVjUesWsz7DfZbb6DPfRp/9Nh/64jDrw8cGFpxjUWunz3IbfR610We+jb5kLGrdYtZnuM9yG33m2+iz3+ZDXxxmffjYwIJzLGrt9Fluo8+jNvrMt9GXjEWtW8z6DPdZbqPPfBt99tt86IvDrA8fG1hwjkWtnT7LbfR51Eaf+Tb6krGodYtZn+E+y230mW+jz36bD31xmPXhYwMLzrGotdNnuY0+j9roM99GXzIWtW4x6zPcZ7mNPvNt9Nlv86EvDrM+fGxgwTkWtXb6LLfR51Ebfebb6EvGotYtZn2G+yy30We+jT77bT70xWHWh48NLDjHotZOn+U2+jxqo898G33JWNS6xazPcJ/lNvrMt9Fnv82HvjjM+vCxgQXnWNTa6bPcRp9HbfSZb6MvGYtat5j1Ge6z3Eaf+Tb67Lf50BeHWR8+NrDgHItaO32W2+jzqI0+8230JWNR6xazPsN9ltvoM99Gn/02H/riMOvDxwYWnGNRa6fPcht9HrXRZ76NvmQsat1i1me4z3Ibfebb6LPf5kNfHGZ9+NjAgnMsau30WW6jz6M2+sy30ZeMRa1bzPoM91luo898G33223zoi8OsDx8bWHCORa2dPstt9HnURp/5NvqSsah1i1mf4T7LbfSZb6PPfpsPfXGY9eFjAwvOsai102e5jT6P2ugz30ZfMha1bjHrM9xnuY0+82302W/zoS8Osz58bGDBORa1dvost9HnURt95tvoS8ai1i1mfYb7LLfRZ76NPvttPvTFYdaHjw0sOMei1k6f5Tb6PGqjz3wbfclY1LrFrM9wn+U2+sy30We/zYe+OMz68LGBBedY1Nrps9xGn0dt9Jlvoy8Zi1q3mPUZ7rPcRp/5Nvrst/nQF4dZHz42sOAci1o7fZbb6POojT7zbfQlY1HrFrM+w32W2+gz30af/TYf+uIw68PHBhZaNGPGDEVRpFNPPTX1x7CotdNnuY0+j9roM99GXzIWtW4x6zPcZ7mNPvNt9Nlv86EvDrM+fGxgIdbTTz+twYMHa5dddmEDy9M+y230edRGn/k2+pKxqHWLWZ/hPstt9Jlvo89+mw99cZj14WMDC816//33td122+nhhx/WqFGj2MDytM9yG30etdFnvo2+ZCxq3WLWZ7jPcht95tvos9/mQ18cZn342MBCs4499liddtppksQGlsd9ltvo86iNPvNt9CVjUesWsz7DfZbb6DPfRp/9Nh/64jDrw8cGForccccd2mmnnfTRRx9JSt7AWrdundasWZO/rVq1ikWtkT7LbfR51Eaf+Tb6krGodYsNrAz3WW6jz3wbffbbfOiLw6wPHxtYKPD666+rb9++eu655/JvS9rAqq+vVxRFRTcWtZu/z3IbfR610We+jb5kLGrj8YIt9AXTRp/5Nvrst/nQF4dZHz42sFDgnnvuURRF6ty5c/4WRZHKysrUuXNnbdiwoehjeASW3T7LbfR51Eaf+Tb6krGobR4v2EJfUG30mW+jz36bD31xmPXhYwMLBdauXasVK1YU3L74xS/q6KOP1ooVK1J9Dha1dvost9HnURt95tvoS8aithgv2EJfcG30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sWPH9Oyzz+rll1+umyZJOnnyZMt/bs8884yKotBzzz1XN02StHHjRl155ZV68skndezYMf3yl7/U9OnT9e1vf7tumiTpc5/7nD784Q+rr69PR44cUW9vr97//vfr9ddfr5tGwWPrxxdbnya2fuw57z1bP7HYerqU8YBF2bV06VLdd999LV9bsGCB1q9fX5No5NyO2nd38uRJFUWhvr6+uimlfeADH9APfvCDuhlDvfXWW7r++uv1zDPPaOXKlVZH7aJFi+pmjNiDDz6om2++uW7GqOvu7taHPvQhDQ4O1k2RJK1atUr33ntvy9fuuOMO3X333TWJ/l/nzp1TW1ubnnzyyZavL1q0SBs2bKhJRbnE1qeJrR97bP34irT3bP3oY+vpUscDFmXV+fPn1dbWph07drR8/YEHHtCKFStqUo2c+1F75MgRFUWhAwcO1E0Z1oULF7R9+3ZNnjxZf//73+vmDPWFL3xBPT09kmR31F5xxRWaO3euurq6dOedd+qVV16pmyVJWrhwoXp6evTZz35Ws2fP1sc//nF9//vfr5s1YufPn9eVV16pTZs21U0Z6hvf+IY6Ozt1+PBhSdK+fft09dVX6+c//3nNsv/+KwVFUejZZ59t+fqyZcu0cuXKelCURWx9utj6scfWj68oe8/Wjy22ni51PGBRVp04cUJFUej5559v+fqmTZt0ww031KQaOeejdnBwULfddpvdr5Tt379f06ZNU1tbm2bOnKmnnnqqbtJQ27dv10033aR///vfkryO2p07d+pXv/qV9u/fP/QrxnPmzNE///nPummaMmWKpkyZooceekh/+9vf9N3vfldTp07Vj370o7ppw/rFL36htrY2nThxom7KUIODg1q/fr0mTZqkyy+/XJMmTdLmzZvrZg21fPlyrVy5UidOnNCFCxf0k5/8RJMmTbL75zHFiq1PE1s/9tj68Rdl79n6scfW06WMByzKqneO2hdeeKHl6xs3btSNN95Yk2rknI/atWvXqrOzU/39/XVTWjp//ryOHDmiv/zlL1q/fr2uuuoqi1+Vfe2113T11Vdr3759Q19zOmrf3dmzZzVnzhx985vfrJui9vZ2LV++vOVrX/nKV7Rs2bKaROV9+tOf1urVq+tmtLR9+3bNnz9f27dv1/79+/XjH/9Ys2bN0g9/+MO6aZKkl19+WStWrFBRFGpra9MnPvEJ3XXXXVq4cGHdNAocW58mtn5ssfUTK8res/Vjj62nSxkPWJRV/GsFE+/+++/X/PnzdfTo0bopld1yyy368pe/XDdDTzzxxNBov/MpikKTJk1SW1ubLly4UDdxWJ/61KeG/f4xddTR0aEvfelLLV/bunWr5s2bV5No5I4fP67LLrtMv/nNb+qmtDR//nx95zvfafna17/+dbv/En/27Fn94x//kPTf3+z1M5/5TM0iihxbP/HY+rHH1k+sCHvP1k8stp4uRTxgUXYtXbpUa9asafnawoUL+Y1dKxocHNS6des0b948vfTSS3VzRtUnP/lJ3XPPPXUzdObMGR04cKDls2TJEt19992Wv6/IwMCArr32Wj3yyCN1U/T5z39+2L++0tPTM+xXaeuut7dX11xzjd5+++26KS3NmjVLW7dubfna5s2bdf3119ckeu/efPNNzZw5U9/73vfqplDw2PrxxdaPP7Z+YkXYe7Y+TWw9/f+MByzKrnf+aO3HHntMhw4dUk9Pj6ZNm6bjx4/XTdNbb72lvXv3au/evSqKQt/61re0d+9eiz/2e82aNZo5c6Z27drV8kcJnzt3rm6aJOmhhx7S7t27dezYMe3fv18PP/ywLrvsMj399NN100bM6V8r+OpXv6pdu3bp6NGj+tOf/qTVq1drxowZFv8/sWfPHl1++eXatGmTjhw5op/97Ge64oor9NOf/rRu2lAXL15UR0eHHnzwwbopw7rnnnt07bXXDv3R2jt27NBVV12lr33ta3XTJEl/+MMf9Pvf/15Hjx7V008/rUWLFmnp0qX6z3/+UzeNgsfWjy+2Pm1s/ehz33u2fvyx9XQp4wGLsmzLli3q7OzU5MmTtXjxYps/Hvq5555TURTDPg6/sjiSqygKbdu2rW6aJOnee+8d+r/p7Nmzdcstt9getJLXUXvnnXdq7ty5am9v17x583THHXdY/H4i7/S73/1ON910k6ZMmaIFCxbY/alEf/zjH1UUxdCf/uPUmTNn1N3drY6ODk2dOlXXXXedNmzYoPPnz9dNk/Tf3wz3uuuu0+TJk3XNNddo3bp1OnXqVN0syiS2fuyx9Wlj68eW896z9eOPradLGQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERkHQ9YRERERERERERk3f8BLM3qvytJiSgAAAAASUVORK5CYII=\" width=\"1200\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Min corruption to achieve adversarial label')"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "local_mag = torch.norm(inputs.reshape(1, 10, -1) - local_adv_ex.detach(), dim=-1)\n",
    "gd_mag = torch.norm(inputs.reshape(1, 10, -1) - gd_adv_ex.detach(), dim=-1)\n",
    "\n",
    "width = 0.35\n",
    "fig, axes = plt.subplots(1, 2, figsize=(12, 5))\n",
    "axes[0].bar(np.arange(10) - width/2, local_mag.mean(dim=0), width=width, label='Local')\n",
    "axes[0].bar(np.arange(10) + width/2, gd_mag.mean(dim=0), width=width, label='GD')\n",
    "axes[0].set_xticks(np.arange(10))\n",
    "axes[0].set_title('Mean corruption to achieve adversarial label')\n",
    "\n",
    "axes[1].bar(np.arange(10) - width/2, (local_mag + torch.eye(10) * 100).min(dim=0)[0], width=width, label='Local')\n",
    "axes[1].bar(np.arange(10) + width/2, (gd_mag + torch.eye(10) * 100).min(dim=0)[0], width=width, label='GD')\n",
    "axes[1].set_xticks(np.arange(10))\n",
    "axes[1].set_title('Min corruption to achieve adversarial label')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/max/Projects/Learning Plasticity Rules/network.py:229: UserWarning: This overload of nonzero is deprecated:\n",
      "\tnonzero()\n",
      "Consider using one of the following signatures instead:\n",
      "\tnonzero(*, bool as_tuple) (Triggered internally at  /opt/conda/conda-bld/pytorch_1595629401553/work/torch/csrc/utils/python_arg_parser.cpp:766.)\n",
      "  self.edges = (self.graph > 0).nonzero()\n"
     ]
    }
   ],
   "source": [
    "meta_model = LocalNetOutputMultiRuleModel(784, 10, num_v = 500, p = .5, cap = 250, rounds = 0, step_sz=1e-5, options = options)\n",
    "optimizer = torch.optim.Adam(meta_model.output_rule_model.parameters(), lr=1e-3)\n",
    "losses = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0: 2.303\n",
      "0 100: 2.262\n",
      "0 200: 1.816\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-5-3e728af8adb5>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      8\u001b[0m             \u001b[0mcontinue_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmeta_model\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m         \u001b[0mloss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbackward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     11\u001b[0m         \u001b[0moptimizer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstep\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m         \u001b[0mlosses\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mloss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/tensor.py\u001b[0m in \u001b[0;36mbackward\u001b[0;34m(self, gradient, retain_graph, create_graph)\u001b[0m\n\u001b[1;32m    183\u001b[0m                 \u001b[0mproducts\u001b[0m\u001b[0;34m.\u001b[0m \u001b[0mDefaults\u001b[0m \u001b[0mto\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m`\u001b[0m\u001b[0;31m`\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;31m`\u001b[0m\u001b[0;31m`\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    184\u001b[0m         \"\"\"\n\u001b[0;32m--> 185\u001b[0;31m         \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mautograd\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbackward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgradient\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mretain_graph\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcreate_graph\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    186\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    187\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mregister_hook\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhook\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/autograd/__init__.py\u001b[0m in \u001b[0;36mbackward\u001b[0;34m(tensors, grad_tensors, retain_graph, create_graph, grad_variables)\u001b[0m\n\u001b[1;32m    125\u001b[0m     Variable._execution_engine.run_backward(\n\u001b[1;32m    126\u001b[0m         \u001b[0mtensors\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgrad_tensors\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mretain_graph\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcreate_graph\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 127\u001b[0;31m         allow_unreachable=True)  # allow_unreachable flag\n\u001b[0m\u001b[1;32m    128\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    129\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for i in range(5):\n",
    "    for j, data in enumerate(trainloader):\n",
    "        inputs, labels = data\n",
    "        optimizer.zero_grad()\n",
    "        if i == 0 and j == 0:\n",
    "            continue_ = False\n",
    "        else:\n",
    "            continue_ = True\n",
    "        loss = meta_model(inputs, labels, 1, 1)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        losses += [loss.item()]\n",
    "        if j % 100 == 0:\n",
    "            print('{:d} {:d}: {:.3f}'.format(i, j, loss.item()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f9eac090f50>]"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot(losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Local Net Test Accuracy: 67.050%\n"
     ]
    }
   ],
   "source": [
    "local_correct = 0\n",
    "\n",
    "with torch.no_grad():\n",
    "    for inputs, labels in testloader:\n",
    "        outputs = meta_model.forward_pass(inputs)\n",
    "        local_correct += np.count_nonzero((outputs.argmax(axis=1) == labels).numpy())\n",
    "print('Local Net Test Accuracy: {:.3f}%'.format(local_correct / len(testset) * 100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0: 0.646\n",
      "0 100: 1.968\n",
      "0 200: 9.661\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-69-85630eafcf12>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m15\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m     \u001b[0;32mfor\u001b[0m \u001b[0mj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrainloader\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m         \u001b[0minputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;31m#         if i == 0 and j == 0:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0;31m#             continue_ = False\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    361\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    362\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__next__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 363\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    364\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    365\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_kind\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0m_DatasetKind\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mIterable\u001b[0m \u001b[0;32mand\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    401\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    402\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_index\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 403\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_fetcher\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    404\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    405\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_utils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36mfetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/torchvision/datasets/mnist.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, index)\u001b[0m\n\u001b[1;32m     92\u001b[0m         \u001b[0;31m# doing this so that it is consistent with all other datasets\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     93\u001b[0m         \u001b[0;31m# to return a PIL Image\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 94\u001b[0;31m         \u001b[0mimg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mImage\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfromarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'L'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     95\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     96\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtransform\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/PIL/Image.py\u001b[0m in \u001b[0;36mfromarray\u001b[0;34m(obj, mode)\u001b[0m\n\u001b[1;32m   2664\u001b[0m             \u001b[0mobj\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mobj\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtostring\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2665\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2666\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mfrombuffer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msize\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"raw\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrawmode\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   2667\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2668\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/envs/ann/lib/python3.7/site-packages/PIL/Image.py\u001b[0m in \u001b[0;36mfrombuffer\u001b[0;34m(mode, size, data, decoder_name, *args)\u001b[0m\n\u001b[1;32m   2603\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32min\u001b[0m \u001b[0m_MAPMODES\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2604\u001b[0m             \u001b[0mim\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnew\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2605\u001b[0;31m             \u001b[0mim\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mim\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_new\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcore\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmap_buffer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msize\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdecoder_name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   2606\u001b[0m             \u001b[0mim\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreadonly\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2607\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mim\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "for i in range(15):\n",
    "    for j, data in enumerate(trainloader):\n",
    "        inputs, labels = data\n",
    "#         if i == 0 and j == 0:\n",
    "#             continue_ = False\n",
    "#         else:\n",
    "        continue_ = True\n",
    "        loss = meta_model(inputs, labels, 1, 1, continue_=False)\n",
    "        losses += [loss.item()]\n",
    "        if j % 100 == 0:\n",
    "            print('{:d} {:d}: {:.3f}'.format(i, j, loss.item()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 213,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez_compressed('models/localnet_mnist_rnn_outputrule.npz', \n",
    "                    input_weights=local_net.input_weights.numpy(), \n",
    "                    graph_weights=local_net.graph_weights.numpy(),\n",
    "                    output_weights=local_net.output_weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez_compressed('models/gdnet_mnist_rnn_outputrule.npz', \n",
    "                    input_weights=gd_net.input_weights.detach().numpy(), \n",
    "                    graph_weights=gd_net.graph_weights.detach().numpy(),\n",
    "                    output_weights=gd_net.output_weights.detach().numpy())"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
