{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "d288536d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import h5py\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0684d0dd",
   "metadata": {},
   "source": [
    "# IBM Gestures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "id": "7f60d8b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "with h5py.File(\"../Results/attacks.h5\", \"r\") as F:\n",
    "    idx = F['attack_successful'][()]\n",
    "    gt_all = F['ground_truth'][()]\n",
    "    gt = gt_all[idx]\n",
    "    sinabs_out = F['sinabs_label'][()]\n",
    "    spk_orig = F['n_spikes_orig'][idx]\n",
    "    spk_attk = F['n_spikes_attk'][idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "id": "5bd20917",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fraction of cases where sinabs got the right label: 0.833\n",
      "Fraction of successful attacks: 0.777\n"
     ]
    }
   ],
   "source": [
    "print(\"Fraction of cases where sinabs got the right label:\", (sinabs_out == gt_all).mean())\n",
    "print(\"Fraction of successful attacks:\", idx.mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "id": "1cefddd0",
   "metadata": {},
   "outputs": [],
   "source": [
    "report = np.loadtxt(\"../Results/report_0.3.csv\", skiprows=1, delimiter=\",\")\n",
    "_, gt2, chip_out, chip_out_attacked = report.T\n",
    "\n",
    "assert np.all(gt == gt2)\n",
    "assert len(gt) == len(spk_orig) == len(spk_attk)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "2a0e01e6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fraction of correct output on original: 0.9691119691119691 753\n",
      "Fraction of successful attacks among attacks that had converged: 0.8532818532818532 663\n"
     ]
    }
   ],
   "source": [
    "print(\"Fraction of correct output on original:\", (chip_out == gt).mean(), (chip_out==gt).sum())\n",
    "successful_on_chip = chip_out != chip_out_attacked\n",
    "print(\"Fraction of successful attacks among attacks that had converged:\", successful_on_chip.mean(), successful_on_chip.sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "id": "e528dce0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median L1: 903.0\n",
      "Median increase: 0.0929294662776729\n"
     ]
    }
   ],
   "source": [
    "spk_orig_succ = spk_orig[successful_on_chip]\n",
    "spk_attk_succ = spk_attk[successful_on_chip]\n",
    "L1 = spk_attk_succ - spk_orig_succ\n",
    "incr = L1 / spk_orig_succ\n",
    "print(\"Median L1:\", np.median(L1))\n",
    "print(\"Median increase:\", np.median(incr))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "17c7a606",
   "metadata": {},
   "outputs": [],
   "source": [
    "att_matrix = np.zeros((11, 11), dtype=int)\n",
    "out_idx = chip_out[successful_on_chip].astype(int)\n",
    "out_idx_att = chip_out_attacked[successful_on_chip].astype(int)\n",
    "np.add.at(att_matrix, (out_idx, out_idx_att), 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "8944f803",
   "metadata": {},
   "outputs": [],
   "source": [
    "class_labels = [\n",
    "    \"Hand Clap\",\n",
    "    \"RH Wave\",\n",
    "    \"LH Wave\",\n",
    "    \"RH CW\",\n",
    "    \"RH CCW\",\n",
    "    \"LH CW\",\n",
    "    \"LH CCW\",\n",
    "    \"Arm Roll\",\n",
    "    \"Air Drums\",\n",
    "    \"Air Guitar\",\n",
    "    \"Other\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "cbb846fe",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.metrics import confusion_matrix, ConfusionMatrixDisplay\n",
    "\n",
    "ConfusionMatrixDisplay(confusion_matrix(out_idx, out_idx_att)).plot(cmap=plt.cm.magma_r)\n",
    "plt.xlabel(\"Label after attack\")\n",
    "plt.ylabel(\"Original label\")\n",
    "plt.yticks(range(11), [class_labels[i] + f\" {i}\" for i in range(11)])\n",
    "plt.title(\"Confusion matrix,  IBM Gestures (on chip)\")\n",
    "plt.savefig(\"chip_attack_matrix.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "675c65d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "777\n"
     ]
    }
   ],
   "source": [
    "dt = 2\n",
    "bins = np.arange(0, 201, dt)\n",
    "\n",
    "def get_histogram(spiketrain):\n",
    "    times = spiketrain['t'] - spiketrain['t'][0]\n",
    "    h, b = np.histogram(times / 1000, bins=bins)\n",
    "    return h\n",
    "\n",
    "\n",
    "F = h5py.File(\"../Results/attacks.h5\", \"r\")\n",
    "\n",
    "n = len(F['attacked_spiketrains'].keys())\n",
    "h_or, h_att = np.zeros((2, n, 100))\n",
    "print(n)\n",
    "tot = 0\n",
    "for i, k in enumerate(F['attacked_spiketrains'].keys()):\n",
    "    h_or[i] = get_histogram(F['original_spiketrains'][k])\n",
    "    tot += len(F['attacked_spiketrains'][k]) - len(F['original_spiketrains'][k])\n",
    "    h_att[i] = get_histogram(F['attacked_spiketrains'][k]) - h_or[i]\n",
    "    \n",
    "F.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "45cb2a04",
   "metadata": {},
   "source": [
    "## Video"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "07745288",
   "metadata": {},
   "outputs": [],
   "source": [
    "from aermanager.preprocess import create_raster_from_xytp\n",
    "\n",
    "fps = 25\n",
    "slowdown = 10\n",
    "T = 0.2 # 200 ms\n",
    "pause = 10\n",
    "dt = 1000000/fps/slowdown\n",
    "length = int(slowdown*fps*T)\n",
    "bins = np.arange(129)\n",
    "\n",
    "F = h5py.File(\"../Results/attacks.h5\", \"r\")\n",
    "N = 30\n",
    "orig, attk = np.zeros((2, N*(length+pause), 128, 128))\n",
    "orig_labels, attk_labels = [], []\n",
    "\n",
    "attacked_IDs = sorted([int(k) for k in F['attacked_spiketrains'].keys()])\n",
    "\n",
    "for i, k in enumerate(attacked_IDs):\n",
    "#     if not successful_on_chip[i]: continue\n",
    "    if i >= N: break\n",
    "\n",
    "    spk_orig = F['original_spiketrains'][str(k)][()]\n",
    "    spk_attk = F['attacked_spiketrains'][str(k)][()]\n",
    "    orig_labels.append(chip_out[i])\n",
    "    attk_labels.append(chip_out_attacked[i])\n",
    "    \n",
    "    start = i*(length+pause)\n",
    "\n",
    "    raster_orig = create_raster_from_xytp(spk_orig, dt=dt, bins_x=bins, bins_y=bins)\n",
    "    orig[start:start+length] = raster_orig[:, 1] - raster_orig[:, 0]\n",
    "    raster_attk = create_raster_from_xytp(spk_attk, dt=dt, bins_x=bins, bins_y=bins)\n",
    "    attk[start:start+length] = raster_attk[:, 1] - raster_attk[:, 0]\n",
    "\n",
    "F.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "b9818312",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x395.52 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import animation\n",
    "\n",
    "fig, ax = plt.subplots(1,2, figsize=(10, 5.5))\n",
    "\n",
    "MAX = 3 \n",
    "\n",
    "im = ax[0].imshow(\n",
    "    np.zeros((128, 128)),\n",
    "    interpolation='none',\n",
    "    vmin=-MAX, vmax=MAX,\n",
    "    cmap=plt.cm.twilight\n",
    ")\n",
    "ax[0].set_xticks([])\n",
    "ax[0].set_yticks([])\n",
    "im2 = ax[1].imshow(\n",
    "    np.zeros((128, 128)),\n",
    "    interpolation='none',\n",
    "    vmin=-MAX, vmax=MAX,\n",
    "    cmap=plt.cm.twilight\n",
    ")\n",
    "ax[1].set_xticks([])\n",
    "ax[1].set_yticks([])\n",
    "ax[0].set_title(\"Original data (correct prediction)\")\n",
    "ax[1].set_title(\"After attack\")\n",
    "\n",
    "t = ax[0].text(1, 5, \"Prediction:\", c='white', size=15)\n",
    "t2 = ax[1].text(1, 5, \"Prediction:\", c='white', size=15)\n",
    "\n",
    "# initialization function: plot the background of each frame\n",
    "def init():\n",
    "    im.set_data(np.zeros((128, 128)))\n",
    "    im2.set_data(np.zeros((128, 128)))\n",
    "    \n",
    "    return [im]\n",
    "\n",
    "# animation function.  This is called sequentially\n",
    "def animate(i):\n",
    "    im.set_array(orig[i])\n",
    "    im2.set_array(attk[i])\n",
    "    \n",
    "    orig_label = class_labels[int(orig_labels[i // (length + pause)])]\n",
    "    attk_label = class_labels[int(attk_labels[i // (length + pause)])]\n",
    "    t.set_text(orig_label)\n",
    "    t2.set_text(attk_label)\n",
    "    return [im]\n",
    "      \n",
    "fig.tight_layout()\n",
    "anim = animation.FuncAnimation(fig, animate, init_func=init,\n",
    "               frames=len(orig), blit=True)\n",
    "\n",
    "# save the animation as an mp4.  This requires ffmpeg or mencoder to be\n",
    "# installed.  The extra_args ensure that the x264 codec is used, so that\n",
    "# the video can be embedded in html5.  You may need to adjust this for\n",
    "# your system: for more information, see\n",
    "# http://matplotlib.sourceforge.net/api/animation_api.html\n",
    "anim.save('basic_animation.mp4', fps=fps, dpi=150, extra_args=['-vcodec', 'libx264'])\n",
    "\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4971508c",
   "metadata": {},
   "source": [
    "# NMNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b381544a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm.notebook import tqdm\n",
    "import torch\n",
    "from sklearn.metrics import confusion_matrix, ConfusionMatrixDisplay"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "50bda2af",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "871e279742ae43cb8bd71cc46e14b42f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "nsamples = 1000\n",
    "time_profile_orig = np.empty((nsamples, 60))\n",
    "time_profile_attk_pos = np.empty((nsamples, 60))\n",
    "time_profile_attk_neg = np.empty((nsamples, 60))\n",
    "out_idx = np.empty(nsamples, dtype=int)\n",
    "out_idx_attk = np.empty(nsamples, dtype=int)\n",
    "successful = np.empty(nsamples, dtype=bool)\n",
    "incr_nmnist = np.empty(nsamples)\n",
    "\n",
    "for k in tqdm(range(nsamples)):\n",
    "    \n",
    "    with np.load(f\"../Results/NMNIST_results/{k}.npz\", allow_pickle=True) as f:\n",
    "        x0 = f['arr_0'][()]['X0']\n",
    "        time_profile_orig[k] = x0.sum((1,2,3)).cpu()\n",
    "        \n",
    "        diff = f['arr_0'][()]['X_adv'] - x0\n",
    "        time_profile_attk_pos[k] = torch.clamp(diff, min=0).sum((1,2,3)).cpu()\n",
    "        time_profile_attk_neg[k] = -torch.clamp(diff, max=0).sum((1,2,3)).cpu()\n",
    "        \n",
    "        out_idx[k] = f['arr_0'][()]['predicted']\n",
    "        out_idx_attk[k] = f['arr_0'][()]['predicted_attacked']\n",
    "        successful[k] = f['arr_0'][()]['success']\n",
    "        \n",
    "        l0 = f['arr_0'][()]['L0']\n",
    "        assert time_profile_attk_pos[k].sum() + time_profile_attk_neg[k].sum() == l0\n",
    "        incr_nmnist[k] = l0/ x0.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "508641b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "out_idx = out_idx[successful]\n",
    "out_idx_attk = out_idx_attk[successful]\n",
    "time_profile_orig = time_profile_orig[successful]\n",
    "time_profile_attk_pos = time_profile_attk_pos[successful]\n",
    "time_profile_attk_neg = time_profile_attk_neg[successful]\n",
    "incr_nmnist = incr_nmnist[successful]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d90fd767",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "7.572144288577154"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "time_profile_attk_neg.sum(1).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6cedaf97",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "214.07615230460922"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "time_profile_attk_pos.sum(1).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "088c5098",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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mqtSV1fH888/T1hYGBdddFGr5R0OB9nZ2QwaNIilS5f6zdsrMDCQCRMmcMkllzB//nymTZvGOeecQ0REhDfVgycklT97WRdddBGDBg3i+eefb9bMGBMTw/bt27vU9ONPGpso9+7dS79+/c6YpO1wODAajT3O5O4rsbGxLFmyhH79+pGVldWi12hERAQXXXQRX331VYMoEp5IIr56B3aUVudBub3lHgX24nKqmKSUusetLJpEKbVOKfVzXErs37g8AdulQEQkWERCPZ9x9cxSgQ9xRazA/b/pSRttxBvuyDtoqnCUlqGU4vDhww3ent5++20SExOZPXt2u9urra0lLy+PWbNmkZyc3GvShYeFhREbG+udM6FpmnccClxvmt3lyVdUVMTXX39NREREhxwMamtr+f3vf09qaiq33357q+m+PS8aEydOZNq0aZ0yiTMkJITExETOOeccJkyYwNy5c1myZAlXXXUV5513HgMGDKC4uJicnBxKS0s73LMyGAz89Kc/JSsri48++qjJMmazGafTyb59+zrUVneRnZ3tvU+UUmfN+FNTBAYGMmfOHGbPnk1JSUmLY8Xf//73cTqdrF69usF6o9HYZT3m1sagngS2ARVAittpwqfRb7cX3/eAn+FK2/FKy3s0SzywUUT2AFuBT5RSa3Bl9b1ARI4C57u/d5gG8fgA0TQcJcUUFRVRXV3tfegcOHCA/fv3873vfa/d40RVVVWUlJSwcOHCXhkRe9SoUQ1cWJOTkzl16pT3jbQ7Bs9LSkpYu3YtISEhrSqUlqipqeH+++9n586d3HPPPVxwwQUtlvckd5sxYwZjxozp8oeYwWAgLi6OqVOncsUVV7BgwQLi4uK8JsHGeY7awowZM5g4cSKvvPJKs5NzY2JiOHLkSJsiGPQElFJkZWV5x5VPnjxJaWlpkwqqpqamR89/8hURYciQISxZsoSQkBBvkOnGJCQksGDBAj766KMG1z0iIoKjR492yXhoa6/rdwGJuDLqZotIuXupEJHy5nYSkbeAg8BC4J+45kX9sj0CKqXSlFLj3ctYpdRj7vVFSqnzlFLDlVLnN06e2F4kMBCMxtMKKjAIW04O6enpDSJHvPXWW4SEhPhk9mmKsrIyampqWLRoUa+96fv164fBYPDeqPXHoUJDQzl8+HCX2arBdU6//vprgoKCOhRhw6Oc9uzZ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NhgM9OvXj507d2I0GludRJ+VleUNNfb555+zZ88e7rrrrjPmOVVWVhIZGXnWhCVrLyaTiSlTprB+/XqvudNoNHL99dfzxBNPsHHjxk6zGOljUG5EhOq4OPJPpBMWFsa6vXvZc/w4yQsW4DSbCTh6FIxGNKsV46lT3v3sdruunOrhCX3k8ehavHgx/fv356WXXsLhcBAXF0dqamqbvX6ysrI4ceJEA3dfpRT/7//9P1atWsXll1/OXXfd1W7l5LGhFxQUMHnyZBYsWNCnlZMHo9HIrFmzGDJkCNnZ2W024wQEBJCSksLChQuZMGECAwcOJDg4uEVF54kV+Je//IWXXnqJ8847j88++4ybbrqJF198scmJup7QSlu3buXEiRPN1u10OsnJySEkJISysjKee+45xo4dy5IlS84oW15eftZOrm8rSUlJxMXFNXA7v+CCCxgwYAArV67sFPMe6ArKi8PhYHdmJhZzADaHnf/34YcM6dePJbNmYRs6lIATJ8BmwxERjjHtBFpZGU6nk9zcXKZOnaorp3okJSXhdDq94wk333wzJ06c4Ouvv/Ym1tu8eTO5ubk+1VdbW8uWLVuIjo72PtiUUjzzzDO88847fO973+NXv/pVu81wlZWVZGdnExcXx8UXX8yoUaN6TWbjrsBgMDBt2jRGjRpFdnZ2l+Z7GjJkCL/73e948803WbRoEa+//jq33XZbk8FqjUYjcXFxbNq0qdnJw+Xl5djtdgwGA//+97+prKzkN7/5zRnXu7q6mvDw8F4ba9HfaJrGpEmTGridGwwGbrjhBtLS0ti6dWvntNsptfZC0tLSKK2txZiYyHPvvUdWYSG3X345RoMB6/DhiN2OKT0dNA0VHIzpwEFyT50iOTm5T7mS+0JISAgxMTFej70FCxYwdOhQVq5cid1ux2QyERUVxbp163zKF7V7926cTqfX/u10Onn66ad57733uPrqq/nFL37RLuVktVrJyclBRDj//POZO3dupwQlPRvwPKDGjRvXbAbWziQqKop77rmHRx99lOLiYm677TZef/31M+QwmUzExcWxYcMGjh07RlpaGnv27GHDhg189tlnfPnllxiNRvbu3ctnn33G1Vdf3WQ267KysibDHvVloqOjGTZsWIMI+Oeeey6DBg1i9erVnXJP6Gcf16Dszp07iYqKYvmnn7Jq0yaunDOHGe4BV3tiAs7gYAKOHAVAWcyUFxUxzGYjJSWlzw2g+0JycjKlpaXY7XY0TeOWW24hOzubzz77DHBN7gsKCmLdunVUV1c3W09WVhbHjh3zmvacTid/+9vf+PDDD1m2bBm33XZbm8+/x3W8rKyMqVOnsnjxYv1N2QdEhJSUFKZOnUpOTk6np1FpitmzZ/Pyyy8zZ84cXnzxRW6//fYzco4FBAQQExPD9u3b2bp1K8ePH6e0tBRN04iOjiY8PJynnnqK+Ph4brjhhjPaqKmpISgo6Kye89ZePM87z3w3g8HATTfdRFZWlndelD/p8wpKKcXu3bsREZ566ineX7OGH86Zw2/qJyMUwTp8GKZTp5DaWsrLywlJSmJIQAD2LohD1htJSEhg6tSp5OXl4XQ6mTFjBmPGjOH555/nu+++A1w5aBwOBxs3bmzwsLPZbFRWVlJQUMDmzZu9pr3MzEzuuusuPv74Y374wx9y6623tlk5Wa1WsrOzSUhI4OKLL2bYsGFnZRK6zsIzxjh79myKiorIy8vrcFy8thIeHs5DDz3EAw88QHZ2Nrfccgt//OMfG4xrms1m+vXrR79+/YiKiiI0NBSz2Yymabz11ltkZGRwxx13NBnBvbS0lHHjxun3RRMEBQUxd+5ciouLvT2mefPm8cQTT3SKN590dlKwnsSUKVPU9u3bG6zLz8/n008/5aWXXmLDhg386Ec/4qaZMzHl5uEMO23uMRQUEPb2O5TMmE7dmDGMHz8Bo1I4ykoJu+giDGdBdlx/o5Ri586dHD58mMTERLKysnjwwQdJS0vjiiuu4Kc//Slms5m8vDzCw8MRESoqKrwPPBEhICCA0NBQ3n77bVauXInJZOK2225jyZIlbVZOxcXF2Gw2pk+f3iddx/1NdXU1x48f5+DBg958SS3NW2oKTyqL9lJSUsJbb73FBx98QE1NDTNmzOCHP/yhN+1LY7Kzs7n55puZMWMGjzzyyBnbPUlFL7300rM6uHNHOXjwIDt37iQxMRERIScnhzlz5jTpZSkiO5RSU9rTTp9XUIcPH+b73/8+e/fu5Re/+AVXXXUVUlGBZedOHPVitzkdDkLffBOD1UbUj39MqNv85ygtRQsJJnThQkS/oc/A4XCwadMmcnNziYuLw2q18vzzz/POO+8wZMgQHnjgAQYPHkxVVRUGg4GAgIAGb65HjhzhySef5NixY8ydO5df/epXbQ7c6XA4yMvLIy4ujunTp+vjTH6mrq6O9PR0UlNTsVqtzYYFstlsOJ1Ob+QBwBtg2LPO41gTGBhISEiIz8qroqKC999/n3feecfrfTdp0iSCgoIaLG+//TYHDx5k5cqVTYbKysnJYcqUKW3O99bXcDqdfPfdd2RlZREXF6crKH/QWEGVl5dzwQUXsG3bNu666y6WLl3q2qAU5u07QDlRZjOVlZXYbDYGBQUR8OFHOIqLCb/ySkLOPRcRwZabi3n4MCyjx2AIObujlrcHq9XK119/TU1NjTdg69atW/nzn/9MZWUlt912G0uXLqW0tNQbbaC0tJQjR47w4YcfEhERwR133MG8efPa3G5paSkOh8MbF1Ef9O487HY7mZmZzQaNDQ4OJjAwEIvFgtlsxmKxYDAYsNls1NXVUVtbS11dnderMi8vD03TiIyM9LlnVlNTwyeffMI777xDXl5ek2V++ctfcuWVV56x3mazUVZWxqWXXtrmnmBfpK6ujq+++gqHw0FVVZWuoDpKYwW1ceNGLrzwQn784x9zRf0xJ0DKy2HLViqVk5jEJIYMGUJgYCDO6mqKX32V2r17CZw8mcgf/hAJCMBeVAROJ+ah52AZMQJDH4t+3BpVVVV88cUXmEwm7/yikpISnnjiCbZs2dLkPiLCkiVL+NnPfubznCS73U5JSQl2u53AwECGDh3KoEGDWswZpdMzqays5NSpUxw+fJjq6mpvNl5fx4YcDgc1NTVUV1d7F4PBwIgRI5rsmeXm5jJ+/HifolHouCgtLWXNmjXU1dWxcOFCXUF1hKZMfLt37+bQoUPeOFNOp5OKigqqq6uJBEaXVxAxYABavdA5yumk4quvKP/gA4zx8UT/5CeYEhJQTieO0hKU1UbAgP5YRo/GUG/uTl+npKTE6+YbERHhNet89dVX5ObmEhkZecbSWsgip9NJdXU1VVVVOJ1OAgICOOeccxg4cCCRkZE9useknE5UbS3OujqU1YayWXFarajqGlRtDc5mAq5qAQGIJRAtKAgJCEBMJiTAhGgaGAyn/4uA0ej63otxOp0UFhaSlpbGyZMncTgcmM1mwsLC/DZO5Mnddumll/oUJks151KtaX3u937y5Em+/PJLFi1apCuo+ojIYuDvgAF4QSn155bKN6Wgjqal89WGzQQHB1NVVeWNkjxw4EAS+8URUFKEfeN6AqKj0RrZ1msPH6b4xRdRNhtBU6cSMHgwAYMHY4iPR1VU4KypQYxGtJBgtJBQDGGhaKGhaJZAxNDEQ0MEMZvRzGbEYun1D5amKCsr4+DBg5w4cQKj0UhUVJRPb8RKKWw2G1ar1WsSAtf8nLi4OBITE4mKiiIyMrLTva+UzeZSKrW13gj4jYQFpVxJMJ1OlMOJstlc+1VV4qyowFlVhdOdbRnRTu8HiMHgGs/UNGj8sFPKVafdfvoh6S4jKBQCnr/KtUkLDEQLCUULCcEQHoYWHIwYDGfWDS5lZ7G47sEemOLcZrNRVFTEqVOnOHnyJFarFaPRiNlsJiAgoNko901R/54qLS1l/PjxpKSkoByO0y8OtbU4amtxllfgrCjHUVmJs7IS7M0rqDb93o3G0y8ZJlOvHcdOTU0lLi6uycC6fVJBiYgBOAJcAGQC24BrlVIHmtunsYI6VVzNYx/s4tCpAoIsAQQFBWExmzEYNDQRggOMBAUYCKspp9/JQ0REhhEbaiEhxEhooImgACOqrIySVauoO3IE5Z4bIGYzAQMHYho4EC0kxHUDms3um9GEBJhdDyGDBlq9/5qGcr+BiSanHyyh7ps9ONilwCwWxGIBhwNnbS3K/UOye348TYQdEYMBLTgEQ2jI6QeQxeKfH4Sm+axMPQ/tiooKjh8/zuHDRxBxxfBzOBxeBWRv4gEQFBRIaGgooaGhRMfEEBEeTmhoqN8VkrJaTyugujrs5eU4KypwlFfgqKiAulqcdjvY7C5l4XSAw+k+NodLITnsKLsD7DbXf4fjdNbm+grMUW+bez3uKBxwOoAqIqcX93epr8A0zaV0DIYz/zdSREpAMxhAM5y+dpqGaOKaiC7ue9Ac4FJqIaFgMIAmrjo9+zTXU3Bv60hPQoymJu/5+veZw+GgpKSE/Px8SkpKqKyspKKiAofD6RWtqcebppxgtaLZHQSbTIQYDYQC/cPC0CpcvyGnzQY2G8puQ9ntQL0KPZq/ScHFe497rrF4rpUmrpcRTRBxn3Oj0XutxGCAABOGoCBw/z41kwkxBSBGI4bICIwxMRjCwxtYdHo6HVFQvVNdu5gGHFNKpQGIyJvAZUCzCqoxRVVW1p+owO4IAKugyqpRqhoFOJyN7+xEcGV/R0MRpFkJ0uoINRqJGH8dQZMhvqKIAUUnSSw4SXz+SaK+WYfB0f45Ik7RUJqgxKW4lGgNPrtwP8ga/WiU5wdV73ekRABx/Rdx7SkaSuqt83zG1W7DdaeRxr98z8PT/SMUEfeP2QlOz3+P4hQQl4z9AYfTid3pxAhYRMPVrOYSXaThf6AWyAIy3fW4+g6empVLNlXvv2ercp8Zr+yeMvU/KzTlRJxONKcDcXo+29Ecdgx+ni2vEJyea6sJCkFpGqcv3Gl5Xf8V0kheccvcE1Gea+25p8B7r3juKVeZ04rXfbTee8RV1r3OU6/3fnT9DxIhEIj11umuuYl7QZRyXVP3dRblRHM66Zqk9W3HYTDi1Ayu/wYjDqMRpzEAFRCAM8AMRtd6ZTShjEaUwYAyGFGaAWXQ3J81lPuFRGma63fv/Sze54DnOnh++14a/PybVs6Tf3od/Yb09+ux92YFlQScqvc9E5jeuJCI3ArcCjBw4MAG2yYMiODTX83l60P5mI0NewAOp6LW5qDa6qDKaqfa6sCan48jO5tqZaBaaVQpjUqrkG/VcKBxhHAcESk4IsbhGCY4FJgcNoJs1QTX1RBkqyXYVo3FXofB6cSonBicDoxOBwblwKCcaO6HTf3Pnu8Gp2e9679HCSnPyx2nTT2A+0Hm+e56sAkKrf4P1fPd0xbuBzSuB6Lm9JQ5/QA8rZoa36j1Hvwo9ze3AmxQXnnr97TfoAqfnrWnj+G0NMql1BHvf1fb0uAcKQFEcHrPn/uz+79DM2AXDYem4RADds2AQwzUGUxYDUZsmhGb+79DM+AQDadmwOnexykaNoPJVU4zYDWYsGkGbJoRu8GIXfMsrn2aehtv/HqkGn326FXvPVDvvjE4HRiV+75yLyanHaPTidFpx+S0u8q57ynPfkanw32/1bvvOP1ZUwqD03H6Hmlwf52mwX1V7z7z3H/edcp9H9RXutRTxOC+NxreI83d31o9RS6A03vtpcFnh2jexal5PhuoM5qwGgKwa0asRhM2QwAOgwGbwYRdM7gX17VzNmUedR+H5zfqOk8O13G713mUoyjlPv92TE6H67o4XP8NyoHRYcfofjYYnQ5MDhtGp50Ap2t9gMNGgNOOqcqOQdVgdDpd+7nLe69pvXvCc829v3XPPXPG3dY+Do4ZpSuotqKUWgGsAJeJr/H2xIhALp3ga0iTETjLylxmmRZwKoXV7qTO7myiJ3aGfDQuohptbwv+Mti2ZJzpSBvNHY4v1qD2GIxUC/s1Z4JqvrxrW28eBFdKNbq/Winfjvo7Wk9LMvl66lu0wuG6hvU3uzr/TSgdAbNRw2w0YNDadt2dTkWd3Umd3XHGb7yjeK7jGefKZgNrHVhtbrXtKd+MjIDDU8BTqP7nM3Zu/kCmTO5Y9uqm6M0KKguo7zLS372uTQQYNWJCmp5Y2CQhfTe7po6Ojk5X0pudJIy4nCTOw6WYtgE/UErtb2GfAiCjiU0xQGET688m9GM8O+gLxwh94zj7yjEGK6XODNvhA722B6WUsovI7cDnuNzMX2pJObn3afIkicj29nqZ9Bb0Yzw76AvHCH3jOPvQMQ5u7/69VkEBKKU+BT7tbjl0dHR0dPzP2TcTVEdHR0fnrEBXUC5WdLcAXYB+jGcHfeEYoW8cp36MrdBrnSR0dHR0dM5u9B6Ujo6Ojk6PRFdQOjo6Ojo9El1B6ejo6Oj0SHQFpaOjo6PTI9EVlI6Ojo5Oj0RXUDo6Ojo6PRJdQeno6Ojo9Eh0BaWjo6Oj0yPp1bH42kpMTIwaPHhwd4uho6Oj02fYsWNHYZ+LZt4eBg8ezPbt27tbDB0dHZ0+g4g0leLIJ3QTn46Ojo5Oj0RXUDo6Ojo6PZI+r6CUUugBc3V0dHR6Hn1qDKop6o4eRVmtBCYnd7coOjo6HcBms5GZmUltbW13i9InsVgs9O/fH5PJ5Lc6+7yCwuHAUVLa3VLo6Oh0kMzMTEJDQxk8eDAi0t3i9CmUUhQVFZGZmcmQIUP8Vm+fN/EBOKsqu1sEHR2dDlJbW0t0dLSunLoBESE6OtrvvVddQQGOyqruFkFHR8cP6Mqp++iMc68rKMBZpSsoHR0dnZ6GrqAAVV3d3SLo6Oj0EZYsWUJpaWmLZR588EG++uqrdtX/zTffcPHFF7dr356G7iQBOGtrUQ4HYjB0tyg6OjpnKZ4pLZ9++mmrZf/v//6vCyTq+eg9KEDZ7ai6uu4WQ0dHp5fz1FNPkZycTHJyMk8//TTp6emMHDmSG264geTkZE6dOsXgwYMpLCwE4I9//CMjR45kzpw5XHvttSxfvhyAm266iXfeeQdwhWh76KGHmDRpEikpKRw6dAiArVu3MnPmTCZOnMisWbM4fPhw9xx0J6L3oABsNpx1dWhBQd0tiY6Ojh/49a9/ze7du/1a54QJE3j66aeb3b5jxw5efvlltmzZglKK6dOnM3/+fI4ePcorr7zCjBkzGpTftm0bq1evZs+ePdhsNiZNmsTkyZObrDsmJoadO3fy//7f/2P58uW88MILjBo1ig0bNmA0Gvnqq6+4//77Wb16tT8PudvRFRTg1HtQOjo6HWTjxo1cccUVBAcHA3DllVeyYcMGBg0adIZyAti0aROXXXYZFosFi8XCJZdc0mzdV155JQCTJ0/m3XffBaCsrIwbb7yRo0ePIiLYbLZOOKruRVdQALqC0tE5q2ipp9PVeBRWRzCbzQAYDAbsdjsADzzwAOeeey7vvfce6enpLFiwoMPt9DT0MShA2W04a3UFpaOj037mzp3L+++/T3V1NVVVVbz33nvMnTu32fKzZ8/mo48+ora2lsrKSj7++OM2tVdWVkZSUhIAK1eu7IjoPZYeo6BE5CURyReR1HrrHhaRLBHZ7V6W1Nt2n4gcE5HDInJhhxp3OHDW1nSoCh0dnb7NpEmTuOmmm5g2bRrTp0/nxz/+MZGRkc2Wnzp1Kpdeeinjxo3joosuIiUlhfDwcJ/bu/vuu7nvvvuYOHGit1d1tiE9JZK3iMwDKoFXlVLJ7nUPA5VKqeWNyo4B3gCmAYnAV8AIpZSjpTamTJmiGicsrD14kKJXXyN86RJC5szx1+Ho6Oh0MQcPHmT06NHdLUabqKysJCQkhOrqaubNm8eKFSuYNGlSd4vVbpq6BiKyQyk1pT319ZgxKKXUehEZ7GPxy4A3lVJ1wAkROYZLWX3XnrbFZNSjSejo6HQ5t956KwcOHKC2tpYbb7yxVyunzqBVBSUis4HdSqkqEbkOmAT8XSnV7jS+beR2EbkB2A7cpZQqAZKAzfXKZLrXnYGI3ArcCjBw4MAmGxCjrqB0dHS6nv/+97/dLUKPxpcxqGeBahEZD9wFHAde7VSpGrY9FJgA5AB/bWsFSqkVSqkpSqkpsbGxTZYRkwlnpR7RXEdHR6cn4YuCsivXQNVlwD+VUv8CQjtXLBdKqTyllEMp5QSex2XGA8gCBtQr2t+9rl2I0YijSo/Hp6Ojo9OT8EVBVYjIfcD1wCciogH+S5nYAiKSUO/rFYDHw+9DYJmImEVkCDAc2NruhgwGVG0tyulsdxU6Ojo6Ov7FFyeJa4AfAD9SSuWKyEDgSX8LIiJvAAuAGBHJBB4CFojIBEAB6cBPAZRS+0XkLeAAYAd+0ZoHXyuNg4Cqq0MCAztyGDo6Ojo6fqJVBeVWSqtx9VIACoH3/C2IUuraJla/2EL5x4DH/CeBuKJJ6ApKR0dHp0W++eYbli9f3ubJxW2lVROfiPwEeAf4t3tVEvB+J8rUbTjrrN0tgo6Ojo6Xs3UCrq/4Mgb1C2A2UA6glDoKxHWmUN2FqqvtbhF0dHR6Ma+//jrTpk1jwoQJ/PSnP8XhcPDcc8/xu9/9zltm5cqV3H777c3W8fDDD3P99dcze/Zsrr/+egoKCvje977H1KlTmTp1Kps2bfKWu/HGG5k7dy6DBg3i3Xff5e677yYlJYXFixd7g8euXbuWiRMnkpKSwo9+9CPq6upYs2YNV199tbfN+kkOv/jiC2bOnMmkSZO4+uqrqXR7OK9Zs4ZRo0YxadIkb8DazsaXMag6pZTVk29eRIy4xoSaRUSGAplKqToRWQCMwxUhorRD0nYqSg8Yq6NzlvDIR/s5kF3u1zrHJIbx0CVjm91+8OBBVq1axaZNmzCZTPz85z/nP//5D9/73veYOXMmTz7pGrpftWoVv//971ts68CBA2zcuJHAwEB+8IMfcOeddzJnzhxOnjzJhRdeyMGDBwE4fvw4//vf/zhw4AAzZ85k9erV/OUvf+GKK67gk08+YfHixdx0002sXbuWESNGcMMNN/Dss89y++23c+utt1JVVUVwcDCrVq1i2bJlFBYW8uijj/LVV18RHBzME088wVNPPcXdd9/NT37yE77++muGDRvGNddc478T2wK+9KDWicj9QKCIXAC8DXzUyj6rAYeIDANW4HIJ79kz0pTCUav3oHR0dNrH2rVr2bFjB1OnTmXChAmsXbuWtLQ0YmNjOeecc9i8eTNFRUUcOnSI2bNnt1jXpZdeSqB7PPyrr77i9ttvZ8KECVx66aWUl5d7ezUXXXQRJpOJlJQUHA4HixcvBiAlJYX09HQOHz7MkCFDGDFiBAA33ngj69evx2g0snjxYj766CPsdjuffPIJl112GZs3b+bAgQPMnj2bCRMm8Morr5CRkcGhQ4cYMmQIw4cPR0S47rrrOvFMnsaXHtQ9wI+Bfbi86D4FXmhlH6dSyi4iVwDPKKWeEZFdHRO1kzEYcVbq0SR0dM4GWurpdBZKKW688UYef/zxM7YtW7aMt956i1GjRnHFFVfgsUg1R/0UHU6nk82bN2OxWM4o50nDoWkaJpPJW6+maa2OXy1btox//vOfREVFMWXKFEJDQ1FKccEFF/DGG280KOvv5I++0mIPSkQMwEGl1PNKqauVUle5P7cWYdYmItcCNwIeN48umTvVXlzRJCq6WwwdHZ1eynnnncc777xDfn4+AMXFxWRkuCLCXXHFFXzwwQe88cYbLFu2rE31Llq0iGeeecb7vS3KYuTIkaSnp3Ps2DEAXnvtNebPnw/A/Pnz2blzJ88//7xXphkzZrBp0yZv+aqqKo4cOcKoUaNIT0/n+PHjAGcosM6iRQXlnlt02D33qS3cDMwEHlNKnXBPpn2tnTJ2CWI06uGOdHR02s2YMWN49NFHWbRoEePGjeOCCy4gJycHgMjISEaPHk1GRgbTprkC4jz44IN8+OGHrdb7j3/8g+3btzNu3DjGjBnDc88957NMFouFl19+mauvvpqUlBQ0TeNnP/sZ4Ep+ePHFF/PZZ595HSRiY2NZuXIl1157LePGjWPmzJkcOnQIi8XCihUrWLp0KZMmTSIurmv85FpNtyEi64GJuCI1eG1gSqlLO1c0/9Ncuo2yNWswRkYhmhB1ww3dJJ2Ojk5H6I3pNs42uiPdxgNtrVRELgb+CAxytyGAUkqFtbWurkLMZux5eSiHAzEYulscHR0dnT6PL5Ek1rWj3qeBK4F9PoxX9QhEc1k7HeXlGFvIgqmjo6Oj0zX4kg+qgtPzngJwOTtUtdIbOgWk9nTlVFRUxK/uvZdzIyNZFBmFBYWzrAxaUVClpaWUlpaSlJSEyXSm74dSiiNHjrBjxw4MBgNBQUHExMTQr18/TCYTJSUlVFZW4nQ6ERGioqKIj48nIiKiRe8eT3lPmezsbLZu3crGjRvZtGkT/fv35+6772bq1KmAa4Bz79697N27l2HDhrFgwQIMBgMHDhxg27ZtDB06lOTkZCIiIhrIbrPZCAgIaMcZPU1RUREHDhygsLCQ0tJSxo4dy9SpU1v1XmoKm82GiGA0Nn+7FhYWUlFRQf/+/RtcE7vdztGjR3E4HAwePJiQkJAG24qLi1FKYbFYqKqq4vDhwxw5coQjR454B4SDg4OJiIggLi6OQYMGceGFF5KQkMCxY8f473//S1ZWFkopTCYT4eHhhIaGorlfeEJCQoiMjMRms5GZmUlBQQFOpxOlFIGBgQQFBREZGUlMTAy1tbVs2bKF/fv3YzQavfdNUlISQ4YMYdKkSQQHB7Ny5UreeecdBgwYwLx58xgwYABWq5Wqqiry8/MpLi7GYDBgNpuxWCwEBgYSFxfHhAkTSEpKYvPmzXz77bdeV+W4uDgmTZrEmDFjCA8PJzAwkLKyMgoLC8nKyiIjIwOj0cj555/P2LFjEREcDgcGt6XBarWyadMmjh49yvDhwxkzZgxxcXENrrXVaiUnJ4fCwkJCQkKIiIigvLyc7OxsEhMTGT58ODo6jfGlB+VNrSGuO+4yYEYru90NfCoi6wDv7Fel1FPtlLNTOHToEGvWreO/ZWUE/Oc/hFosWP/wB9A0wsLCiIqKYvjw4QwbNoz8/HwOHjzI0aNHKS4uBlyDjAMGDCAiIoLg4GAMBgNOp5P09HQyMzPbLE9iYiILFy5k0KBB7Nu3j0OHDnnnPNTW1mK32zEYDERFRaFpGnl5eYDL1XTKlCl89dVXvPPOOwwfPpySkhIKCwsb1O9RgocPH26w3jNPw2q1cuTIEWpqahg9ejQTJkwgMTGRqKgoiouLOXLkCGVlZYSFhREYGEhJSQnFxcVERUUxcOBAlFKkpaVx5MgRsrLOzH6SkpLCkiVLcDgclJaWcvDgQQ4dOoSIEBkZSWBgIHa7HaPRyPDhwxk8eDC7d+/2zpxPSUkhOTmZIUOGEBcXR1paGvv372f37t3e9gwGA/369SM4OBij0UhaWhq19ea3hYSEeBVYaWkpzb1DBQYGcs4552AwGKiqqvIeq4dzzjmHtLQ0RMT7MLbZbJSVlbXo3hsaGupVtLW1tdTU1DTYHhkZyfjx4wGX0j148CDZ2dneqACeY1y0aBEFBQX86U9/wlkvCn9gYCAxMTE4HA7q6uq8bTgbRer33N9KKXJycrBafQvzFR4ejs1mo7q6mqCgIPr160deXh5VjRJ+xsbGMm7cOBwOB0ePHm3yfvAgIixbtoyHH37YO19HRwd8cJJocieRXUqpiS1s/wKoxDV3yvvLUEo90h4h/UVTThKV+/bx1b//zf9OnqKstJSgqCgCBg+ioqKCgoIC75t0TEwMo0ePZsSIEQwdOpSIiAgyMjJIT0+nvLycqqoqnE4nBoOBmJgYFi5cyKxZsxARqqurKSwsJCcnB5vNRlRUlPct2+l0UlRURG5uLtu2bePrr7+mqKiIkSNHMnbsWKKioggODiYwMBCz2YzVaqWoqIi6ujrGjx/PlClTmDx5MhaLhfLycv7973/z7bff0q9fP5KSkhg3bhwpKSns3LmTN998k/Lyci677DLmz59Peno6qamppKWlkZaWhtFoZOTIkYSEhLBnzx727t1LXl4edXV1mM1mhg4dSlRUFBUVFdTU1BAZGUlkZGQDd9pzzjmHoUOHetvt168fISEhrF27lueff56dO3disVgICQlh5MiRjBkzBk3TKCkpoba2FpPJRG1tLYcPH+bEiROMGTOGc889F6PRyO7du9m/fz+5ubkAmEwmRo4cyfjx45k4cSIRERGkp6eTlZVFdXU1VquVIUOGMH78eMxmM+np6eTm5uJwOHA6nURHRxMbG4umadTU1GCxWBg5ciQjRoygf//+3l6QB7vdzsGDB/n444/59ttvmTNnDtdddx1JSaeTOSulvApRKUVFRQXFxcUYjUb69+/vnXzpweFweHsrmqYxdOjQM3qZTqeTjIwMdu7cSX5+PpdffjkJCa5MNJWVlZSVlREQEEBQUFCD+TP1ycnJYdeuXZw6dYpp06Yxbtw4bw/IZrNx4MABjh49SkVFBdXV1URERBAdHU1iYiKDBg2ivLycL774gh07dhAUFERoaCjl5eXk5uYSGRnJokWLSElJ4fjx4+zfv9/bcw8ICGD48OEMGTKEpKQkYmNjqayspLS0lLCwMBITE/nqq6/4xz/+QV1dHQcOHGi3ktKdJLoffztJ+OLFd2W9rxowBZivlJrZwj6pSqnk9gjUmbTkxReQmISzthYcdqJ/9KMGZZRS7TJNtQelFFar1TsBr7tRSlFTU4PZbPY+0Dpan6/nsrmytbW15Ofnk5iY2KLZT6f3kJeXx+rVq/n5z3/e7jp0BdX9+FtB+RLq6JJ6y4VABS4zX0t8KiKL2iNQdyJmM47yclQ9cwrQZcrJ01ZPUU7gkicoKMgvyslTX0fLWiwWBg4cqCuns4j4+PgOKae+yIIFC2j8wg2tB6NtisGDB58xJNAT8OUX/oJSalP9FSIyG8hvYZ/bgN+KSB1goxe4mcPpB6KjvBxjdHQ3S6Ojo6PTt/GlB/WMj+sQERO4HCuUUppSKlApFeb+3qOV02kER1lZdwuho6PTC/FHuo2tW7cyc+ZMJk6cyKxZs7xOTTU1NSxbtozRo0dzxRVXNHCwefnllxkxYgTTpk3zOhUBzabqKCoqYtGiRYwdO5Yf//jHzToLdTfN9qBEZCYwC4gVkd/U2xQGNGfv+c6drn0NsEYple6rICLyEnAxkO8ZvxKRKGAVMBhXyvfvK6VK3N6EfweWANXATUqpnb621YogOIqK4Zxz/FKdjo5O15P7pz9Rd/CQX+s0jx5Fv/vvb3a7v9JtjBo1ig0bNmA0Gvnqq6+4//77Wb16Nc8++yxBQUEcPHiQvXv3MmnSJMDlAPPQQw+xY8cOwsPDOffcc5k40eXDdscddzSZquORRx5hzpw5PPjgg3zyySe8+GKzycu7lZZMfAFAiLtMaL315cBVTe2glJoiIoOBxcDTIpIEbAQ+A9YppVpKuLQS+Cfwar119wJrlVJ/FpF73d/vAS7ClYJ+ODAdeNb9v8NogYHYcrL9UZWOjk4fon66DXD1eOLi4hqk2xg+fHir6TbKysq48cYbOXr0qHf6AsD69ev51a9+BcC4ceMYN24cAFu2bGHBggXExsYCcM0113DkyBHAlarjwIED3ro901bWr1/vTTq4dOlSIntocIJmFZQ7gsQ6EVmplMoAEBENCFFKNZsJzN1reg54zm3ym4tLYT0qIgVKqaXN7LferdzqcxmwwP35FeAbXArqMlwJEBWwWUQiRCRBKZXTyvG2ilgs2PJbGl7T0dHp6bTU0+ks/JVu44EHHuDcc8/lvffeIz09nQULFrRbppZSdfQGfBmDelxEwkQkGEgFDojI71rbCUApZQN2Aa8rpaYBt7ZRvvh6SicXiHd/TsIVrcJDpnvdGYjIrSKyXUS2FxQUtNqgZjbjLK/AoUc219HRaQP+SrdRVlbmnVu3cuVK7/p58+bx3/+68r6mpqayd+9eAKZPn866desoKirCZrPx9ttve/dpLlVH/bo+++wzSkpKOnDknYcvCmqMu8d0OS5T3RDg+pZ2EJFv3EotCtgJPC8iTymlmp9O3gru3lKbR/KUUiuUUlOUUlM8XeDWEJORiq+/RjWafa+jo6PTHP5Kt3H33Xdz3333MXHixAZRSW677TYqKysZPXo0Dz74IJMnTwYgISGBhx9+mJkzZzJ79uwG85CaS9Xx0EMPsX79esaOHcu7777LwIFtzajUNfgyUXc/MAFXyvZ/KqXWicgepdT4FvbZpZSaKCI/BgYopR4Skb1KqXGttDUY+Liek8RhYIFSKkdEEoBvlFIjReTf7s9vNC7XUv2tTdT1oJTCnplJ6AXnEzi+2cPU0dHpQegTdbuf7pio+29cHnTBwHoRGYTLUaIljG6F8n1OZ9RtDx/iysqL+/8H9dbfIC5mAGXtGX+y5edTvmYNzqrqButFBGN8PBX/+x/2Hjh5TUdHR6cv0KqCUkr9QymVpJRaolxkAOe2stsjwOfAMaXUNhE5Bzja0g4i8gbwHTBSRDJF5Bbgz8AFInIUON/9HeBTIA04BjwPtGsKuj03l6J/r8BecKZThAQEIEYT1Tt2tKdqHR0dHZ0O4ku6jXjgT0CiUuoiERmDK517S47zOfXNeUqpNBFpMZK5UuraZjad10RZBfyiNdlbI2DQIIBmJ+YaoqOpPXiQ4JkzMYT1knnGOjp9mK6Mm6nTkM6Y7OuLiW8lrt5Qovv7EeDXrezjc/SJ7sQQHo4WFoaztGkFJZoGolFTbx6Bjo5Oz8RisVBUVNRjoyKczSilKCoq8rs7uy+x+GKUUm+JyH1uQewi4miqYDujT3QrpsTEFkMbGaOiqNmxk6BJk9A6mMRPR0en8+jfv783KaRO12OxWOjfv79f6/RFQVWJSDRuF2+PU0IzZdscfaK7MSUmYj15stntEhCAstZRd/QogWPHdqFkOjo6bcFkMjFkyJDuFkPHj/iioH6Dy2tuqIhsAmJpPtTRGdEnejqmxERUdTXOujq0ZtJcGCKjqPjyK7TAIMzn6D8AHR0dna7Al5TvO0VkPjASV9qMw+4IES1hFpEVuIK8ettQSi3sgKydginRNbTmKCpCS0xssozmzoJa+t57hF20mMAxY7pMPh0dHZ2+SkvRzMNwhRo66h53GgMEApNE5HOlVF4L9b6NKx7fC0CT41U9BVOiK3W2vajIq6yaQgsMxBgXR8UXXxCQlIQhPLyrRNTR0dHpk7TUg1oOfMvp+UuP45p/FITLEeJnLexrV0o96xcJOxljv36AqwfVGlpAAE4RavbvJ2TWrM4WTUdHR6dP05Kb+VRcEcQ9VCilfqWU+jGQ3Eq9H4nIz0UkQUSiPEuHpe0ENLMZLSQEuw8KCsAQHUP1jp0461rKHKKjo6Oj01Fa6kEZVcMJBfUDxEa0Uq8nPFH9qOcK6JFZALWIcJ96UABiMoHdRt2RIwSmpHSyZDo6Ojp9l5YUlFNE+imlcgGUUqkA7iSELYb5Vkr1Klc3Q3g41uNpPs9CN0REUrVlK5YxYxBDj5zepaOjo9PracnE9yQuU908EQl1L/OB993bmkVEgkTkD25PPkRkuIhc7Dep/YwhPAJVW4uqrm69MKAFBeEsL6cuLa2TJdPR0dHpu7SUUfd1ESkEHgXG4jLR7QceVEp91kq9LwM7cDlTAGTh8uzrSGTzTkMLd8XZsxcVERAc7NM+hshIKr9Zh3nQIESPMKGjo6Pjd1qMxaeUWqOUmqeUilZKxSil5vugnACGKqX+Atjc9VTjmkPVIzGERwD47CgB7l5UZQU1qamdJJWOjo5O38aXSBLtwSoigZwOjzQU6LFub1poCBgM2PPPTLvREsaYWKo2fYsxJobaw4dxlJYS8b3vuYLM6ujo6Oh0iM56kj4MrAEGiMh/gLXA3Z3UVocRTSNg8GDqDh5sU5p3j2mvdPVq6g4fwXryJLZTpzpLTB0dHZ0+RacoKKXUF8CVwE3AG8AUpdQ3ndGWvwicMAFHSQm2FgLHNoUxLg5TYhLG2FgMIaFUN0opr6Ojo6PTPloKdfSb5rYBKKWaTUAoIh8B/wU+VEpVtV+8rsMyahTlZjM1u3cTMHhwu+rQwsOxZpzEXlCAMTbWvwLq6Ojo9DFa6kEtB64DonGl0AhttLTEcmAucEBE3hGRq0Sk3ZmsRCRdRPaJyG4R2e5eFyUiX4rIUff/yPbWDy5znWXMGGr378dptbZXTggwUb1nb0dE0dHR0dGhZSeJicC1wFJcLuNvAGsbRZdoknppNwzAQuAnwEu4Ehe2l3OVUoX1vt/rlufPInKv+/s9HaifwAkTqNm1i7qDBwkcP75ddRijoqnZvQt7bi4IWEaMJHDiBMRoxJaXT83uXYTMm+eNkK6jo6Oj0zQtzYPaA+wB7hWRWbiU1TMico9S6sPWKnZ78V0CXANMomFcP39wGbDA/fkV4Bs6qKBMAwdiiIykZteudisoMRgw9UtA2VwZSSo3bKD22FECBg2mevNmlN2GstsJW7LEp6gVOjo6On2VVp0kRCQWV28qBcgEWvXFFpG3gIO4ek//xDUv6pcdkFMBX4jIDhG51b0uXimV4/6cC8Q3I8utIrJdRLa3lgpaNI3AyZOxnjiBNTOz3cKKyYQWFIQWFIQpKQlHaRnVW7dijI/HNHAQtYcOUbtvX7vr19HR0ekLtOQk8SPg+4AFeAf4vlLK14lCLwLXKqX8lQtqjlIqS0TigC9F5FD9jUopJSJNmh6VUiuAFQBTpkxp1TwZNG0aVd9+S+X//kfU9de3VtwnjFENA7mb4uKp+Got1gxX0mHzsGFYRo/2S1s6Ojo6Zwst9aBeABKBCuBC4AUR+dCzNLWDiNwNoJT6HJebef1tf2qvkEqpLPf/fOA9YBqQJyIJ7roT8KFn5wua2UzwrFlYjx3D2klzmiQgAENMDLacXGzZOZR/tgZbdnantKWjo6PTW2lJQZ0L/BKXR95y4K+NlqZYVu/zfY22LW6PgCISLCKhns/AIiAV+JDTaT1uBD5oT/1NETRtGhIUROU33/iryjPQzGYM4eEYIiLQwsIo+/hjnFW9wiNfR0dHp0toyUliXTvqk2Y+N/XdV+KB99wOBUbgv0qpNSKyDXhLRG4BMnCZI/2CZjYTMns2FV9+SeU33xA8f36nOjQYQkOx5+dR/uWXhF96qR4qSUdHR4eWx6CGA/cDJcBTwPO45jYdB25RSjUVMkE187mp7z6hlEoDznCpU0oVAee1p05fCJo5E1t+PpX/+x+OigrCli7tVMVhjIvHevw4NXv2EjRxQqe1o6Ojo9NbaGke1MvAq7jmLm0Bfg1cgUtJ/QuY3sQ+40WkHFdvKdD9Gff3dk/U7Q7EYCD8iiswhIZStXEjjrIyIq66Cs3SeYdhjO9H5Tf/w5SUiCkurtPa0dHR0ekNtNQlCFFKrVBKLQdqlFJvK6VqlVJfAuamdlBKGZRSYUqpUKWU0f3Z893UKUfQiYgIoRdcQNjFF2M9fpyiF15oU0qONrdnMqEFBVP+2Wc4a2s7rR0dHR2d3kBLCqp+WO/yFrad9QRNnUrkDTfgrKqiaMUK6o4c6bS2DBEROMvKKV29GkdlZae1o6Ojo9PTaUlBjRKRvSKyr95nz/eRXSRfj8E8ZAjRt96KITKSkv/+l8pvvsGHqE/twhgfj6O0lNJVb1F7+DC1R45gzchA2e2d0p6Ojo5OT6SlMSh95mgjjJGRRN9yC2UffUTl//6Hs6aG0MWLO8XDzxgTi6O0lPJPTycwFouF4CmTCZw0CTEY/N6mjo6OTk+iJTfzjK4UpLcgJhPhV1yBFhjoiq3ncBAyfz5aSIjfFZUhIgJDRIT3u7Oujopv1uG02QiZNcuvbeno6Oj0NFpyM6+gaddwwRVdqCORyXs1IuLqORkMVG3aRM22bUhAAEFTpxJy/vmd5o6umc2YkpKo+vY7jDExWEaM6JR2dHR0dHoCLfWgWsv51KcREUIuuADziBHY8vKwZWRQtWkTzpoawi65pNOUlBgMGGNjKf/0MxxlZRijojDGxGAID++U9nR0dHS6i5bGoHRaQUQIGDyYgMGDUdOmYYiOpmr9ehwlJZiHD8fUvz+mAQP8rqw0iwXCw6n69jtwOkEpzKNGEjRpEqZ+/fzalo6Ojk53oSsoPyEihJ53HlpQEFXffYf1iy8AMERHEzR9OuYRIzBERPhtnMqTzgNAOZ1YT6RTd+gQpsQkgqZPwxDmssBqISFo5ianreno6Oj0aKSzXKV7IlOmTFHbtzeM0GTLzqZk9btgt2GIjPJbpltHZSXWtDSqN2/GlpUFgJjNrpxQCQmYkpIwDxuGFhzsl/a87ZaVuYLOam5FqBkImjKZwNGjGzhc6Ojo6HQFIrJDKTWlXfv2dQUFLu+4uiNHqFy3HjGZ/PogV0phz83FlpmJPS8PW14e9txclNUKIpgGDMAQFYUWFIRl9GgCBg70W9sAymZzRb9wODBERmAeNhxTQj8M4eGIO2yTmM1oAQF+bVdHR0cHdAXlM80pKA/24mJK330XVVeHMSa20+RQTif23FxqDx3CeuwYjspKV6/H6ST0wgsJmj69U+ZWOWtqcFRUgMM94Vca9bLGjvWaBnV0dHT8ga6gfKQ1BQXgqKig5I03kACz38x9vuCsq6Ps3XepO3QI86hRWMaOJWDgQLTQ0E6flKtsNhxFhYglkKibb9J7Uzo6On6jIwpKd5JohCE0lMAJE6j67rsuVVCa2UzENddQtX49Vd99R90hd1Z7ESQwEGN0NKZ+/TDGx7uW6GgwGEDTOqxQxGTC2C8Ba1YWtsxMzOec44cj0tHR0ekYuoJqgoBBg6na9G2XtyuaRsiCBQTPm+carzp1ymX+q6zEXlhIzd69qLq6M/YzxsYSMHw45mHDCBgwAGmnwtKCgqhJTdUVlI6OTo9AV1BNYIyNQQsKwllX1y0u2qJpLk+/hIQG65VSOMvKsOXl4SguBqVQNhvW9HSqt2yh+ttvwWDAlJCAMTYWQ1QUYjYjAQEYo6IwJSYipuaznhjCw7GmncBZXe11YdfR0dHpLnq1ghKRxcDfAQPwglLqz36pV9OwjBlN9a7daPHx/qjSL4jIGfH5AJg/H2ddHbaTJ7GeOIE1K4u6o0dxNk7XoWkYoqPRgoMbmC8N4eEYY2MxxsWhHA7qTp4kcNSozj8gHR0dnRbotQpKRAy4MvteAGQC20TkQ6XUAX/Ubz7nHKpbcajoSWhmM+bhwzEPH+5dp6xWnFYrymrFnp+P7dQp7EVFOKurcXgSLyqF9dgxlM3m3a/svfcIHDsW06CBGMLC0QItaGFhGCMjMURFY4qPwxATixZo0aOq6+jodBq9VkEB04BjSqk0ABF5E7gM8IuCMsbHIwFmlM3WolmsJyMBARjc41HGqCgszfSKlNOJo6wMe34+9rw8rBkZ2PLzqUlNdbm/OxzNN2I0IiYTYjSCpiEAmgYGg0t5GTRENJc50ul0OX14yivlCtXkFdi1DZMRMZpc+2uaKzwxgHL1IsViQcxmsNtPK1aDwVXO4UQ5HfWq1MBoQDR3XZqcduEXzbXO6QTlRDmcKLsNHPVk8ni5GgwNjhMB0QyI0eAupsBux1lT6xonNBgQo9G1XTPUa1dc2zQNUCinatiWZ/Fs87TvdKKU03UOjMbT51tz1+k+f6eX5i+Z51w2bK8RIq7jbAqHw3UtffEA1uT0ua8vUzNhqOPvuw9DSEjr9er0CXqzgkoCTtX7nglMb1xIRG4FbgUY2IZJsGI0Yhkzhppdu5r/oZ5lGMLCMISFeR0tDJERaEHBKLsdZ20tzupqnJWVOMvLcVZWotwKQjmdLiXmfmApj+Jx//dMZRCtnqJyOE7Pw/L8dzpd2+wOnFbbacWolLeMUgpsNlfyRu+D3lVGKeX67nlIux++3odp/YexR1an06U4PPtp2pmxE0VcsjkcroezZ3+n87SC9exbT/kq9zlp8DCvd06k8fHXb8+9rkEZzzmof749x1HvmHxSHPXabTznzltXvfN+eqNyHWc9eVqk8fE30X59mSOXLSMwJcU3+XXOenqzgvIJpdQKYAW45kG1Zd+QeXMJmtou9/2zA7di0tHpEkTDFB/X3VLo9CB6s4LKAgbU+97fvc5viMHQ580N+giTjo5Od9GbbVfbgOEiMkREAoBlwIfdLJOOjo6Ojp/otT0opZRdRG4HPsf1ov+SUmp/N4ulo6Ojo+Mn+lQsPhEpADKa2BQDFHaxOF2NfoxnB33hGKFvHGdfOcZgpVS7om/3KQXVHCKyvb3BDHsL+jGeHfSFY4S+cZz6MbZObx6D0tHR0dE5i9EVlI6Ojo5Oj0RXUC5WdLcAXYB+jGcHfeEYoW8cp36MraCPQeno6Ojo9Ej0HpSOjo6OTo9EV1A6Ojo6Oj2SPq2gRGSxiBwWkWMicm93y+MvRCRdRPaJyG4R2e5eFyUiX4rIUff/yO6Ws62IyEsiki8iqfXWNXlc4uIf7mu7V0QmdZ/kvtPMMT4sIlnu67lbRJbU23af+xgPi8iF3SN12xCRASLyPxE5ICL7ReQO9/qz5lq2cIxn27W0iMhWEdnjPs5H3OuHiMgW9/Gsckf7QUTM7u/H3NsHt9iAckeB7msLrugTx4FzgABgDzCmu+Xy07GlAzGN1v0FuNf9+V7gie6Wsx3HNQ+YBKS2dlzAEuAzXEkeZgBbulv+Dhzjw8Bvmyg7xn3fmoEh7vvZ0N3H4MMxJgCT3J9DgSPuYzlrrmULx3i2XUsBQtyfTcAW9zV6C1jmXv8ccJv788+B59yflwGrWqq/L/egvPmklFJWwJNP6mzlMuAV9+dXgMu7T5T2oZRaDxQ3Wt3ccV0GvKpcbAYiRCShSwTtAM0cY3NcBryplKpTSp0AjuG6r3s0SqkcpdRO9+cK4CCu9DlnzbVs4Ribo7deS6WU8qTuNrkXBSwE3nGvb3wtPdf4HeA8aZzvpR59WUE1lU+qpRuoN6GAL0RkhzsfFkC8UirH/TkX6Dm57DtGc8d1tl3f293mrZfqmWd7/TG6TTwTcb15n5XXstExwll2LUXEICK7gXzgS1y9v1KllN1dpP6xeI/Tvb0MiG6u7r6soM5m5iilJgEXAb8QkXn/v73zj5GquuL456sYbYFIpaQBY1JA2oYfZRORqC0JaRRtTYgaGlubKKkxbdOmgT9qNCrYxKaplmL8xR+oQMSoMUCgULFKEbdpjEVrXSgRKU3T+gMMkVKUroQ9/eOccR/DDLsLAzP75nySyQz33nfeOe+y77x75873FivNx9el+31BWeMClgDjgQ7gPWBRU71pEJKGAauAeWZ2oFhXlr6sEWPp+tLMjphZB77l0XSg9tbdJ0A7J6hTvp9UszCzd+J9L7AG/0+zpzItEu97m+dhQ6kXV2n618z2xE2gB1hK79TPoI1R0ln4jftJM1sdxaXqy1oxlrEvK5jZfmAzcCk+DVvZLaMYy6dxRv25wL56Nts5QZVyPylJQyUNr3wGZgHb8NhuimY3AWub42HDqRfXOuDGWAF2CfCfwvTRoKLq+5Zr8f4Ej/E7sTJqLDABePV0+zdQ4juHx4AdZvabQlVp+rJejCXsy1GSRsTnzwBX4N+3bQbmRLPqvqz08RzgDzFark2zV4E084WvDtqJz5ne0Wx/GhTTOHw10F+B7ZW48HneTcDbwIvAec329QRiewqfFjmMz2vfXC8ufHXRw9G3XcC0Zvt/EjE+ETG8GX/gowvt74gY3wK+2Wz/+xnj1/HpuzeBN+L1rTL15XFiLFtffhX4S8SzDVgQ5ePwBLsLeBY4O8rPiX/vivpxx7OfUkdJkiRJS9LOU3xJkiRJC5MJKkmSJGlJMkElSZIkLUkmqCRJkqQlyQSVJEmStCSZoJJBhaSRBSXo9wvK0AclPdIEf2YrlPAlXSNpYqHuJUnTahwzTdIDp9PPgSBpuaQ5fbc86ph5km5swLmfljThZO0k5WBI302SpHUws324TAyS7gYOmtmvm+jPOnp/4H0NsB74Wx/HbAW2nlrPTh+hCPB9XIX9ZFkC3Arc0gBbySAnR1BJKZA0U9L6+Hy3pBWSOiX9U9J1ku6V75G1MSRokHSRpC0hqvt8tUJ2iGD+IxQMRkg6UtE1lPSypAmS5kp6SNJlwGzgvhjRjQ8z35bvl7NT0ow6vj4eo63dkn5aI7YzY1SzLWKYH+W3SPqzfC+eVZI+G+XLJS2R9ErYnBnn2CFpecHuQUmL5fv4bJI0qsa5j3uNgm8Ar1uIg0YsiyVtjXNeLGm1fJ+ne6LNUEkbwvdtkq4PW53A5eqVyUnamExQSVkZj984ZwMrgc1mNgU4BFwdSepBYI6ZXQQ8DvyiaMDMjuC/6p+IKwO8DsyQdDZwgZm9XWj7J3wk9TMz6zCzv0fVEDObDswDFtbx9SvAlbgu28JKAi3QAZxvZpMjhmVRvtrMLjazqbi8zM2FYz6Ha6LND78WA5OAKZI6os1QYKuZTQK2VPvXn2sUfA14rarsEzObhu8FtBb4MTAZmCtpJHAV8K6ZTTWzycBGAHONul3A1DrXKmkj8iklKSvPmdlhSV345pQbo7wL+CLwZfyG+YLLpnEmLjFUTSe+ieBY4Jf41NMWXMuxP1SEUF+L89Zig5l1A92S9uLbTPy7UL8bGCfpQWAD8PsonxwjkhHAMOD5wjG/NTOL+PeYWReApO3hxxtAD/BMtF9Z8LVCf6/RaDxBFqlMe3YB2y208yTtxsVCu4BFkn4FrDezzsKxe4ExHJv0kjYjR1BJWemGT5/ID1uvplcP/mAm/MbZEa8pZjarhp2XgRn46OZ3eDKYiSeufvsBHKH+A2F34fMx7czsQ3xE8RLwQ+DRqFoO/CRGVT/Hdc6qbfZU2a/EX4tq3bP+XqNDVefu8/xmthP/zqoLuEfSgkKbc8Jm0uZkgkralbeAUZIuBZ/OkjSpRrtXgcuAHjP7Hz7y+AGeuKr5L769d0OR9HngDDNbBdxJ72KE4cB7MRX3vRMwfQa9itM3AH+squ/vNdoBXDiQE0saA3xsZiuB+zh6gcWX6FX5TtqYnOJL2hIz+ySWUj8g6Vz8b+F+XAG+2K5b0r+AV6KoE/gu/uRfzdPA0ljoMKBl2n1wPrBMUuWB8vZ4vwvfpfWDeB9ocvwImC7pTnxa7fpiZX+vEfAcrtI9EKbgC0p6cOX2HwFI+gJwyMzeH6C9pISkmnmStCmSDprZsAbZWgPcWlw4coJ25gMHzOyxRviVDG5yii9JkkZwG75Y4mTZD6xogJ2kBOQIKkmSJGlJcgSVJEmStCSZoJIkSZKWJBNUkiRJ0pJkgkqSJElakkxQSZIkSUvyfxib+fUIDMiwAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(2, 1, sharex=True)\n",
    "\n",
    "# NMNIST\n",
    "t = np.arange(0, 300, 5)\n",
    "a, b = 10, 90\n",
    "\n",
    "plt.sca(ax[0])\n",
    "plt.plot(t, time_profile_orig.mean(0), c='k', label='original')\n",
    "plt.fill_between(t, *np.percentile(time_profile_orig, (a, b), axis=0), color=\"k\", alpha=0.25)\n",
    "\n",
    "plt.plot(t, time_profile_attk_neg.mean(0), c=\"C0\", label='ev. removed')\n",
    "plt.fill_between(t, *np.percentile(time_profile_attk_neg, (a, b), axis=0), color=\"C0\", alpha=0.3)\n",
    "\n",
    "plt.plot(t, time_profile_attk_pos.mean(0), c=\"C3\", label='ev. added')\n",
    "plt.fill_between(t, *np.percentile(time_profile_attk_pos, (a, b), axis=0), color=\"C3\", alpha=0.3)\n",
    "\n",
    "plt.ylim([-4, 150])\n",
    "plt.ylabel(\"NMNIST\\nEvents/ms\")\n",
    "plt.title(\"Profile of perturbation in time\")\n",
    "# plt.xticks([])\n",
    "\n",
    "# Gestures\n",
    "plt.sca(ax[1])\n",
    "plt.plot(bins[:-1], np.mean(h_or, axis=0), c='k', label='original')\n",
    "\n",
    "plt.plot(bins[:-1], np.mean(h_att / dt, axis=0), c=\"C3\", label='added')\n",
    "qa, qb = np.percentile(h_att / dt, (a, b), axis=0)\n",
    "plt.fill_between(bins[:-1], qa, qb, alpha=0.4, color=\"C3\")\n",
    "\n",
    "plt.ylabel(\"IBM Gestures\\nEvents/ms\")\n",
    "plt.xlabel(\"Time within sample (ms)\")\n",
    "# plt.title(\"Profile of perturbation in time, IBM Gestures (chip)\")\n",
    "plt.legend(*ax[0].get_legend_handles_labels())\n",
    "plt.xlim((-5, 301))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"added_in_time_both.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "ac0485e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ConfusionMatrixDisplay(confusion_matrix(out_idx, out_idx_attk)).plot(cmap=plt.cm.magma_r)\n",
    "\n",
    "plt.xlabel(\"Label after attack\")\n",
    "plt.ylabel(\"Original label\")\n",
    "plt.title(\"Confusion matrix,  NMNIST\")\n",
    "plt.savefig(\"nmnist_attack_matrix.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f318cc66",
   "metadata": {},
   "source": [
    "## Distribution of distances (both datasets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "id": "c620dfcf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8847j9dff51vfetbAPzmN7/hxBNP5Pnnn6dv37707NmTLbbYgrvvvhuAoUOH8sADD3DTTTdx0003MXLkSAYPHsxrr73Gz3/+c6ZOncpXX33Ftttuy89+9jNOO+00ACZMmED37t1Zdtll2WSTTbjllluqui9qycl4MdU/8Cs5cM1amg4dOnDPPfdwxhlnsMoqCz4yceONN2bIkCGcfXZ6CtNdd93FhhtuON88o0aN4uWXX6Z3794Nbue4447jxBNPpH///gCMHTuWjTfemF12SQ9j2X777bn88svp27dvtd7aEuOOgsxssbVt25aBAwdy5ZVXlp0+YMAAhg0bBsAbb7xBly5dFkjaJ598Mhdc0Hgr5eTJk+nRY95zATbeeOPFjLw4nIzNrCqOPvpobrvtNqZNm7bAtM6dO7Pmmmsybtw4hgwZwj777LPAPHvvvTejR49mwoQJDW7jxBNPZMcdd6Rfv35ceeWVTJ06tZpvoVk5GZtZVXTu3JmDDjqIq64q9xg+2HfffRkyZAj33nsvP/nJTxaY3qZNG0499VQuuuiiBrdx6KGH8sorr7DXXnsxYsQItt56a7766quqvYfm5GRsZlVzwgkncMMNN/DZZ58tMO3HP/4xt956K2uttRadO3cuu/yBBx7Ik08+yTvvvFN2OsAaa6zBYYcdxrBhw2jbti3jxo1rcN6liZOxmVXNSiutxN57780NN9ywwLTllluOSy65hLPOOqvB5du1a8eJJ57YYNvz8OHDmTlzJgDvv/8+H3/8Md27N9b/2NLDV1OYtTDNfUXPySefzODBg8tO23fffRe6/OGHH86vfvWrstMeffRRjj/+eDp27AjAZZddxmqrrbbowRbIUv0MvL59+0Zzdy7vS9usub3yyitssMEGzR2GlVHus5E0KiIWuPbOzRRmZgXgZGxmVgBOxmZmBeBkbGZWAE7GZmYF4GRsZlYAvs7YrKUZ1KXK61uwr4n6OnXqxIwZM5g4cSIbbLABvXr1IiJYfvnl+b//+z969erFiBEj2GGHHbjuuus44ogjABgzZgybbbYZl112GaeccsoC6/3jH//IpZdeyuzZs2nbti1bbrkll19+OV27dm3SWxgxYgTt27fnu9/9bpOWW5JcMzazqlp33XUZM2YML774IgcffDAXXnjh3GkbbbQRd95559zx22+/nU033bTseoYPH86VV17Jww8/zPjx4xk9ejTf/e53+eCDD8rO35gRI0bwj3/8o0nLzJo1q8nbWRxOxmZWM59++ikrrrji3PG1116bL7/8kg8++ICIYPjw4fTr16/sshdccAGXX3753Nud27Rpw2GHHUavXr2A1P/x97//fbbYYgt22WUXJk+eDMBVV11F79692WSTTdh3332ZOHEiv//977nyyivp06cPTz31FIcccghDhw6du61OnToBKWlvu+227LHHHvTu3ZvZs2dz6qmnsuWWW7LJJpvwhz/8AUhdeW633Xb06dOHjTbaiKeeemqx95WbKcysqt544w369OnD9OnT+fzzz3n22Wfnm77nnnty1113sdlmm7H55pvToUOHsusZP348m2++edlpM2fO5Nhjj2XYsGF069aNO+64g7POOosbb7yRiy++mLfeeosOHTowdepUunbtylFHHUWnTp3mNoWU6zujzujRoxk3bhzrrLMO1157LV26dOH555/nq6++4nvf+x4777wz99xzD7vssgtnnXUWs2fP5vPPP1/EvTWPk7GZVVVdMwXAHXfcwcCBAxk+fPjc6XvvvTf77LMPr776Kvvtt19FzQdjx47lwAMPZPr06Vx44YVsuOGGjBs3jh/+8IcAzJ49m9VXTw+e32STTdh///0ZMGAAAwYMaHL8W221Feussw6Q+sJ46aWX5taip02bxuuvv86WW27JYYcdxsyZMxkwYAB9+vRp8nbqczOFmdXMHnvswZNPPjlf2WqrrUa7du147LHH2GmnnRpcdsMNN2T06NFAeqLHmDFj6NevH1988QURwYYbbsiYMWMYM2YMY8eO5dFHHwXgwQcf5Oijj2b06NFsueWWZdt+27Zty5w5cwCYM2cOX3/99dxpyy+//NzhiODqq6+eu5233nqLnXfeme22244nn3yS7t27c8ghh1TlWXtOxmZWM08//TTrrrvuAuW//OUvueSSS2jTpk2Dy55xxhmccsopTJo0aW7ZF198AUCvXr2YMmUK//znP4HUbDF+/HjmzJnDO++8ww477MAll1zCtGnTmDFjBiussALTp0+fu56ePXsyatQoAO6777653XLWt8suu3DNNdfMnf6vf/2Lzz77jLfffptVV12VI488kiOOOGLul8bicDOFWUtTwaVotVTXZhwRtG/fnuuvv36BeSq5xGy33XZjypQp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\n",
      "text/plain": [
       "<Figure size 388.8x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5.4, 4))\n",
    "\n",
    "distbins = np.arange(0, 0.75, 0.025)\n",
    "plt.hist((incr_nmnist, incr), bins=distbins, label=(\"NMNIST\", \"IBM Gestures\"));\n",
    "plt.legend()\n",
    "\n",
    "plt.xlabel(\"Events added/removed relative to original number\")\n",
    "plt.xticks(distbins[::4], [f\"{b*100:.0f}%\" for b in distbins[::4]])\n",
    "plt.ylabel(\"Number of samples\")\n",
    "plt.title(\"Distribution of perturbation sizes\")\n",
    "\n",
    "plt.savefig(\"sparsefool_increases_dist_both.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "762963c5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
