{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2c0739f6-854d-4257-b5e4-f3c09ef1f32f",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f851b8a3-e5bf-4792-9506-4d9d960d689f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "from sklearn import datasets\n",
    "from sklearn.model_selection import train_test_split\n",
    "import numpy as np\n",
    "\n",
    "import veritas\n",
    "import xgboost as xgb\n",
    "import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import accuracy_score"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f045e3fb-30cf-45d5-85f3-e925479799a6",
   "metadata": {},
   "source": [
    "# Load MNIST from OpenML"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e16c9219-649f-429d-8f5e-f1d5e7f06aee",
   "metadata": {},
   "outputs": [],
   "source": [
    "X, y_mc = datasets.fetch_openml(data_id=554, return_X_y=True, as_frame=False, parser='auto')\n",
    "X = X.astype(veritas.FloatT)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3774ac64-5166-4a81-9823-ccc32a674cbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "y = y_mc.astype(int)\n",
    "xtrain, xtest, ytrain, ytest = train_test_split(X, y, test_size=0.2, shuffle=True, random_state=6)\n",
    "num_classes = 10"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a6192bd-375f-428d-b94f-37cd77a4b241",
   "metadata": {},
   "source": [
    "# Train an XGBoost model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0686c394-8a18-4c7f-91a6-7a768732d955",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "XGB trained in 9.493682384490967 seconds\n"
     ]
    }
   ],
   "source": [
    "# NOTE performances here are pretty bad, we used small trees to show practicalities of the new methods/structures\n",
    "params = {\n",
    "    \"n_estimators\": 10,\n",
    "    \"num_class\": num_classes,\n",
    "    \"objective\": \"multi:softmax\",\n",
    "    \"eval_metric\": \"merror\",\n",
    "    \"multi_strategy\": \"multi_output_tree\",\n",
    "    \n",
    "    \"tree_method\": \"hist\",\n",
    "    \"seed\": 135,\n",
    "    \"max_depth\": 3,#7,\n",
    "    \"learning_rate\": 0.5,\n",
    "    \"colsample_bynode\": 0.75,\n",
    "    \"subsample\": 0.5\n",
    "}\n",
    "model = xgb.XGBClassifier(**params)\n",
    "\n",
    "t = time.time()\n",
    "model.fit(X, y)\n",
    "print(f\"XGB trained in {time.time()-t} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "41e806a9-5015-40dd-9bf3-9ee5f56bd796",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train acc: 0.821, test acc: 0.822 wrt true labels\n"
     ]
    }
   ],
   "source": [
    "ytrain_pred = model.predict(xtrain)\n",
    "ytest_pred = model.predict(xtest)\n",
    "acc_train = accuracy_score(ytrain, ytrain_pred)\n",
    "acc_test = accuracy_score(ytest, ytest_pred)\n",
    "\n",
    "print(f\"Train acc: {acc_train:.3f}, test acc: {acc_test:.3f} wrt true labels\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d0c6fdb8-1972-4fb3-bbf3-539db0e0cda9",
   "metadata": {},
   "source": [
    "# Convert multiclass XGB to a multiclass AddTree"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "200d7862-0117-49b8-9d39-fc0e7d3cb167",
   "metadata": {},
   "outputs": [],
   "source": [
    "at = veritas.get_addtree(model, silent=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f9a3120a-9d35-41e1-ba4e-b88bcc95f261",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Node(id=0, split=[F409 < 1], sz=15, left=1, right=2)\n",
      "├─ Node(id=1, split=[F434 < 1], sz=7, left=3, right=4)\n",
      "│  ├─ Node(id=3, split=[F455 < 1], sz=3, left=5, right=6)\n",
      "│  │  ├─ Leaf(id=5, sz=1, value=[0.388856, -0.254628, -0.0554982, 0.171288, -0.25094, 0.418357, 0.0403791, 0.0108784, -0.22144, -0.247253])\n",
      "│  │  └─ Leaf(id=6, sz=1, value=[2.08205, -0.276259, -0.193254, -0.245987, -0.246963, -0.198137, -0.193254, -0.220597, -0.263564, -0.244033])\n",
      "│  ├─ Node(id=4, split=[F375 < 1], sz=3, left=7, right=8)\n",
      "│  │  ├─ Leaf(id=7, sz=1, value=[-0.267328, 1.647, 0.0594657, -0.191136, -0.242327, -0.208993, -0.181016, -0.195898, -0.157206, -0.262566])\n",
      "│  │  └─ Leaf(id=8, sz=1, value=[-0.241288, -0.0596621, -0.0881732, 0.0374868, -0.209609, 0.6151, 0.0058078, -0.267687, 0.422914, -0.214889])\n",
      "├─ Node(id=2, split=[F155 < 1], sz=7, left=9, right=10)\n",
      "│  ├─ Node(id=9, split=[F239 < 1], sz=3, left=11, right=12)\n",
      "│  │  ├─ Leaf(id=11, sz=1, value=[-0.271884, -0.162359, -0.211955, -0.242264, 1.37995, -0.224355, 0.163461, -0.094853, -0.231243, -0.104497])\n",
      "│  │  └─ Leaf(id=12, sz=1, value=[-0.24033, -0.230701, -0.171061, -0.117634, -0.136892, -0.0607892, -0.194358, 0.649299, -0.103034, 0.605501])\n",
      "│  ├─ Node(id=10, split=[F658 < 1], sz=3, left=13, right=14)\n",
      "│  │  ├─ Leaf(id=13, sz=1, value=[-0.202583, -0.243077, 0.708263, -0.025628, -0.14933, -0.188715, 0.758742, -0.26693, -0.167081, -0.223662])\n",
      "│  │  └─ Leaf(id=14, sz=1, value=[-0.115888, -0.215264, -0.110869, 0.644988, -0.208739, 0.153129, -0.240359, -0.268967, 0.571711, -0.209743])\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(at[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c9dee0a4-88af-4b2b-8329-e22662fb374a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Node(id=0, split=[F409 < 1], sz=15, left=1, right=2)\n",
      "├─ Node(id=1, split=[F434 < 1], sz=7, left=3, right=4)\n",
      "│  ├─ Node(id=3, split=[F455 < 1], sz=3, left=5, right=6)\n",
      "│  │  ├─ Leaf(id=5, sz=1, value=[-0.254628, 0.388856, -0.0554982, 0.171288, -0.25094, 0.418357, 0.0403791, 0.0108784, -0.22144, -0.247253])\n",
      "│  │  └─ Leaf(id=6, sz=1, value=[-0.276259, 2.08205, -0.193254, -0.245987, -0.246963, -0.198137, -0.193254, -0.220597, -0.263564, -0.244033])\n",
      "│  ├─ Node(id=4, split=[F375 < 1], sz=3, left=7, right=8)\n",
      "│  │  ├─ Leaf(id=7, sz=1, value=[1.647, -0.267328, 0.0594657, -0.191136, -0.242327, -0.208993, -0.181016, -0.195898, -0.157206, -0.262566])\n",
      "│  │  └─ Leaf(id=8, sz=1, value=[-0.0596621, -0.241288, -0.0881732, 0.0374868, -0.209609, 0.6151, 0.0058078, -0.267687, 0.422914, -0.214889])\n",
      "├─ Node(id=2, split=[F155 < 1], sz=7, left=9, right=10)\n",
      "│  ├─ Node(id=9, split=[F239 < 1], sz=3, left=11, right=12)\n",
      "│  │  ├─ Leaf(id=11, sz=1, value=[-0.162359, -0.271884, -0.211955, -0.242264, 1.37995, -0.224355, 0.163461, -0.094853, -0.231243, -0.104497])\n",
      "│  │  └─ Leaf(id=12, sz=1, value=[-0.230701, -0.24033, -0.171061, -0.117634, -0.136892, -0.0607892, -0.194358, 0.649299, -0.103034, 0.605501])\n",
      "│  ├─ Node(id=10, split=[F658 < 1], sz=3, left=13, right=14)\n",
      "│  │  ├─ Leaf(id=13, sz=1, value=[-0.243077, -0.202583, 0.708263, -0.025628, -0.14933, -0.188715, 0.758742, -0.26693, -0.167081, -0.223662])\n",
      "│  │  └─ Leaf(id=14, sz=1, value=[-0.215264, -0.115888, -0.110869, 0.644988, -0.208739, 0.153129, -0.240359, -0.268967, 0.571711, -0.209743])\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# By default, Veritas optimizes the 0th class. One can swap classes into the first position in order to optimize other classes\n",
    "at.swap_class(1)\n",
    "# the method simply swaps the order of the classes in the leaf value vectors: now in position 0 we have values related to class 1\n",
    "# check first tree as example:\n",
    "print(at[0])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "08e1e724-8137-49f3-9ab9-922648c60846",
   "metadata": {},
   "source": [
    "# Train a better model, extract one base example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "72ebc536-d995-48f4-9dd9-b362b965c457",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "XGB trained in 14.965305805206299 seconds\n",
      "Train acc: 0.902, test acc: 0.899 wrt true labels\n"
     ]
    }
   ],
   "source": [
    "# same as above, with deeper trees\n",
    "params[\"max_depth\"] = 5\n",
    "model = xgb.XGBClassifier(**params)\n",
    "\n",
    "t = time.time()\n",
    "model.fit(X, y)\n",
    "print(f\"XGB trained in {time.time()-t} seconds\")\n",
    "\n",
    "ytrain_pred = model.predict(xtrain)\n",
    "ytest_pred = model.predict(xtest)\n",
    "acc_train = accuracy_score(ytrain, ytrain_pred)\n",
    "acc_test = accuracy_score(ytest, ytest_pred)\n",
    "print(f\"Train acc: {acc_train:.3f}, test acc: {acc_test:.3f} wrt true labels\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3d050aca-67a0-4fe9-8394-b14b582cd6b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "at = veritas.get_addtree(model, silent=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c737fa46-0bd8-43bc-bf9f-666799599459",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7ed26d5e4910>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# select one example of class 1\n",
    "number_of_adv_examples = 1\n",
    "\n",
    "rng = np.random.default_rng(seed=6)\n",
    "xtest0 = xtest[ytest_pred==1, :]\n",
    "subset = xtest0[rng.choice(range(xtest0.shape[0]), number_of_adv_examples), :].astype(veritas.FloatT)\n",
    "\n",
    "plt.imshow((subset[0, :]).reshape((28,28)), cmap=\"binary\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "cab2dafa-553d-4e1d-a7de-45ab31b4c9e3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[0.002, 0.947, 0.003, 0.007, 0.005, 0.005, 0.004, 0.005, 0.01 ,\n",
       "         0.012]], dtype=float32),\n",
       " array([[0.002, 0.947, 0.003, 0.007, 0.005, 0.005, 0.004, 0.005, 0.01 ,\n",
       "         0.012]]))"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# test outputs for chosen base example\n",
    "base_example = subset[0, :]\n",
    "y_xgb = model.predict_proba(subset)\n",
    "y_ats = at.predict(subset)\n",
    "y_xgb.round(3), y_ats.round(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "423d5fea-8c14-4981-b6dd-69c48d67cdfe",
   "metadata": {},
   "source": [
    "# MAX_MAX example: targeted attack - one adv. ex. per class"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a3cde063-ec63-41b5-959e-74e39ea866d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# idea: we start with a base example of class 1\n",
    "# we try to generate an adversarial example classfied in each of the other classes (0, 2, 3, ..., 9)\n",
    "# a soltuion for class 0 is the solution to the maximization problem: \n",
    "# max_x [ T_0(x) - max_c (T_c(x)) ]\n",
    "# i.e., class0 is preferred over each other class"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "5c6ad94d-fc5f-47fa-a6e6-cae887c7c681",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "no adversarial examples found for 0\n",
      "2\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.   0.02 0.89 0.02 0.02 0.01 0.01 0.01 0.01 0.01]\n",
      "\n",
      "3\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.   0.   0.   0.99 0.   0.   0.   0.   0.   0.  ]\n",
      "\n",
      "4\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.01 0.01 0.01 0.02 0.88 0.01 0.02 0.01 0.02 0.02]\n",
      "\n",
      "5\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.   0.   0.   0.   0.   0.99 0.   0.   0.   0.  ]\n",
      "\n",
      "6\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.01 0.02 0.01 0.02 0.02 0.02 0.88 0.01 0.01 0.01]\n",
      "\n",
      "7\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.01 0.03 0.05 0.05 0.02 0.04 0.01 0.7  0.04 0.05]\n",
      "\n",
      "8\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.01 0.03 0.04 0.03 0.03 0.02 0.01 0.04 0.76 0.03]\n",
      "\n",
      "9\n",
      "[0.   0.95 0.   0.01 0.01 0.   0.   0.   0.01 0.01]\n",
      "[0.   0.01 0.01 0.02 0.03 0.03 0.01 0.02 0.03 0.84]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "### MAX_MAX multiclass\n",
    "\n",
    "adv_examples = []\n",
    "atc = at.copy()\n",
    "eps  = 5\n",
    "\n",
    "# once per class (class0 --> class1, class0 --> class2, ...)\n",
    "for c in range(0, num_classes):\n",
    "    if c==1:\n",
    "        continue\n",
    "        \n",
    "    print(c)\n",
    "    atc.swap_class(c)\n",
    "\n",
    "    config = veritas.Config(veritas.HeuristicType.MULTI_MAX_MAX_OUTPUT_DIFF)\n",
    "    config.ignore_state_when_worse_than = 0.0\n",
    "    config.max_memory = 16*1024*1024*1024\n",
    "    prune_box = [veritas.Interval(max(0.0, x-eps), min(255, x+eps)) for x in base_example]\n",
    "    s = config.get_search(atc, prune_box)\n",
    "\n",
    "    tstart = time.time()\n",
    "    while s.num_solutions() == 0:\n",
    "        stop_reason = s.steps(1000)\n",
    "        #print(s.stats.num_steps, stop_reason)\n",
    "        if stop_reason != veritas.StopReason.NONE:\n",
    "            break\n",
    "        \n",
    "    tstop = time.time()\n",
    "\n",
    "    atc.swap_class(c) #go back to original addtree for evaluation\n",
    "\n",
    "    if s.num_solutions() > 0:\n",
    "        sol = s.get_solution(0)\n",
    "        adv_example = veritas.get_closest_example(sol, base_example, 1e-5)\n",
    "\n",
    "        res = {\"c\": c, \"adv_example\": adv_example, \"base_example\": base_example}\n",
    "\n",
    "        print(at.predict(base_example)[0].round(2))\n",
    "        print(at.predict(adv_example)[0].round(2))\n",
    "        #print(sol.output)\n",
    "        print()\n",
    "\n",
    "        adv_examples.append(res)\n",
    "        \n",
    "    else:\n",
    "        print(\"no adversarial examples found for\", c)\n",
    "\n",
    "    #break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "300b4236-3c56-4794-a12e-cfcdcec35750",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApsAAAD4CAYAAACjbS25AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAtfklEQVR4nO3deXQUdb7+8adZ0hDIwpZtCBBBcEFAIyCyK1sCKggq4igwiohhH0HjURBEo+LMoBLQGTVcGRAEjcxFBNmREbiKcBFFBH9BwkCColkMkkDy/f3BTUuTTkgnXd2h836dU+fQ31r6k6Kf5NPVVdU2Y4wRAAAAYIEavi4AAAAA/otmEwAAAJah2QQAAIBlaDYBAABgGZpNAAAAWIZmEwAAAJah2QQAAIBlaDYBAABgGZpNAAAAWIZm04NatGihUaNGOR5v2bJFNptNW7Zs8VlNF7u4xqqyLaC8yBlwefNGZm02m5555pkKreuqvlGjRqlFixZOy/3666966KGHFBERIZvNpsmTJ0uSMjMzNWzYMDVq1Eg2m03z5s2rUB3+xG+azUWLFslmszmmOnXqqHXr1ho/frwyMzN9XZ5b1qxZU+GQwLOee+453X777QoPD6/ULy9/Qc7gad9++62mT5+uDh06KCgoSJGRkRo4cKC++OILX5dW5VyYv+3bt5eYb4xRdHS0bDabBg0a5IMKq5fnn39eixYt0rhx47R48WLdf//9kqQpU6Zo3bp1SkxM1OLFizVgwAAfVyplZWUpLCxMNptNK1eu9Prz1/L6M1ps9uzZiomJ0ZkzZ7R9+3YtXLhQa9as0f79+xUYGOjVWnr06KHffvtNAQEBbq23Zs0aJScn84ewCnjqqacUERGh66+/XuvWrfN1OVUGOYOnvPnmm3rrrbc0dOhQPfroo8rOztYbb7yhm266SWvXrlWfPn18XWKVU6dOHS1dulTdunVzGt+6dauOHTsmu93uo8rKp6KZ9aV//OMfKioqchrbtGmTbrrpJs2cObPE+B133KHHHnvMmyWWacaMGTp9+rTPnt9vjmwWi4uL0x//+Ec99NBDWrRokSZPnqy0tDStWrWq1HXy8vIsqaVGjRqqU6eOatTwu91cbaSlpenEiRP65z//6etSqhRyBk+59957lZ6erjfffFMPP/ywpk2bpl27dqlhw4a8EShFfHy8VqxYoXPnzjmNL126VLGxsYqIiPBRZeVzOWa2du3aJZr4kydPKjQ0tMSypY37yv79+7Vw4UI9/vjjPqvh8vmfrqBbbrlF0vmmQTp/3kX9+vX1/fffKz4+XkFBQbrvvvskSUVFRZo3b56uvfZa1alTR+Hh4Ro7dqx++eUXp20aYzRnzhw1bdpUgYGB6t27t77++usSz13aeSm7du1SfHy8GjRooHr16qldu3Z65ZVXHPUlJydLktPHlcU8XWNpioqK9Morr+i6665TnTp11KRJEw0YMKDMj7Z+/vlnPfbYY7ruuutUv359BQcHKy4uTv/7v/9bYtnXXntN1157rQIDA9WgQQPdeOONWrp0qWN+bm6uJk+erBYtWshutyssLEx9+/bVl19+We6fwRMuPkcHrpEzclZRsbGxql+/vtNYo0aN1L17dx04cMBrdVxO7r33Xp06dUrr1693jBUUFGjlypUaMWKEy3Vefvll3XzzzWrUqJHq1q2r2NjYEh+npqSkyGaz6e2333Yaf/7552Wz2bRmzZoy62rRooUGDRqkTz75RB06dFCdOnV0zTXX6IMPPnBa7uLMHjhwQHXr1tUDDzzgtNz27dtVs2ZNpyYpKytLkydPVnR0tOx2u1q1aqUXX3yxxFHH8jp27JgGDx6sevXqKSwsTFOmTFF+fn6J5S48Z7O4/rS0NH300UeO3x/FpzkYY5ScnFzi94qvTJo0SUOGDFH37t19VoPffYx+se+//17S+V9exc6dO6f+/furW7duevnllx0f+40dO1aLFi3S6NGjNXHiRKWlpWn+/Pnas2eP/v3vf6t27dqSzh+OnjNnjuLj4xUfH68vv/xS/fr1U0FBwSXrWb9+vQYNGqTIyEhNmjRJEREROnDggFavXq1JkyZp7NixOn78uNavX6/FixeXWN8bNUrSgw8+qEWLFikuLk4PPfSQzp07p08//VQ7d+7UjTfe6HKd//f//p8+/PBD3XXXXYqJiVFmZqbeeOMN9ezZU998842ioqIknf84YuLEiRo2bJgmTZqkM2fOaN++fdq1a5fjF+UjjzyilStXavz48brmmmt06tQpbd++XQcOHNANN9xQat1nz55VdnZ2uX7Ghg0bXlbvrKsyckbOSlPRnGVkZKhx48Zur1cdtGjRQl26dNG7776ruLg4SdLHH3+s7OxsDR8+XK+++mqJdV555RXdfvvtuu+++1RQUKBly5bprrvu0urVqzVw4EBJ0ujRo/XBBx9o6tSp6tu3r6Kjo/XVV19p1qxZevDBBxUfH3/J2g4dOqR77rlHjzzyiEaOHKmUlBTdddddWrt2rfr27etynauvvlrPPvuspk2bpmHDhun2229XXl6eRo0apauuukqzZ8+WJJ0+fVo9e/bUf/7zH40dO1bNmjXTZ599psTERJ04ccLtC3F+++033XrrrTp69KgmTpyoqKgoLV68WJs2bSpzvauvvlqLFy/WlClT1LRpU/35z3+WJF1//fWOczf79u1bonkuj19++UWFhYWXXC4wMLBcpyytWLFCn332mQ4cOKAjR464XY/HGD+RkpJiJJkNGzaYH3/80aSnp5tly5aZRo0ambp165pjx44ZY4wZOXKkkWSeeOIJp/U//fRTI8ksWbLEaXzt2rVO4ydPnjQBAQFm4MCBpqioyLHck08+aSSZkSNHOsY2b95sJJnNmzcbY4w5d+6ciYmJMc2bNze//PKL0/NcuK2EhATj6r/Gihpd2bRpk5FkJk6cWGLehdtr3ry507bOnDljCgsLnZZPS0szdrvdzJ492zF2xx13mGuvvbbMGkJCQkxCQkKZy7hSvM/LM6WlpZV7uz/++KORZGbOnOl2Tf6EnJEzY6zLWbFt27YZm81mnn76abfX9WfF+fv888/N/PnzTVBQkDl9+rQxxpi77rrL9O7d2xhz/jUzcOBAp3WLlytWUFBg2rZta2655Ran8RMnTpiGDRuavn37mvz8fHP99debZs2amezs7EvW17x5cyPJvP/++46x7OxsExkZaa6//nrH2MWZNcaYwsJC061bNxMeHm5++uknk5CQYGrVqmU+//xzxzLPPvusqVevnvnuu++cnveJJ54wNWvWNEePHnWMlef39bx584wk89577znG8vLyTKtWrUrUN3LkSNO8efMSP+/F+7n4uSuSq+JtlidX5flbdPr0adOsWTOTmJhojPl9v69YsaJCtVWG3x3ZvPhk8ubNm2vJkiX6wx/+4DQ+btw4p8crVqxQSEiI+vbtq59++skxXvwRz+bNmzVixAht2LBBBQUFmjBhgtPh8cmTJ+v5558vs7Y9e/YoLS1Nf/vb30qcz1GeQ+3eqFGS3n//fdlsthInPV+qzgvPZyksLFRWVpbq16+vNm3aOH0sFxoaqmPHjunzzz9Xx44dXW4rNDRUu3bt0vHjxx1Hasqjffv2Th8tlaWqn9dUlZEzcmZVzk6ePKkRI0YoJiZG06dPd2vd6uTuu+/W5MmTtXr1ag0YMECrV692eUSzWN26dR3/Lj561r17d7377rtOy0VERCg5OVn33nuvunfvrr1792r9+vUKDg4uV11RUVEaMmSI43FwcLAeeOABvfjii8rIyCj19VCjRg0tWrRI7du3V1xcnL744gs99dRTTkf4V6xYoe7du6tBgwZO2ezTp49eeOEFbdu2zXG6TnmsWbNGkZGRGjZsmGMsMDBQDz/8sM9ee0uWLNFvv/12yeWuuOKKSy7zwgsv6OzZs3ryySc9UVql+F2zmZycrNatW6tWrVoKDw9XmzZtSnyEU6tWLTVt2tRp7NChQ8rOzlZYWJjL7Z48eVKS9MMPP0iSrrzySqf5TZo0UYMGDcqsrfijxrZt25b/B/JyjcV1RkVFqWHDhm7VV3z+2YIFC5SWlub0UcCFH68+/vjj2rBhgzp16qRWrVqpX79+GjFihLp27epY5qWXXtLIkSMVHR2t2NhYxcfH64EHHrhkwBo0aMDVq15AzsiZFTnLy8vToEGDlJubq+3bt5c4lxO/a9Kkifr06aOlS5fq9OnTKiwsdGqaLrZ69WrNmTNHe/fudTon0dUbm+HDh+uf//ynPvroIz388MO69dZby11Xq1atSmyzdevWkqQjR46U+eajZcuWeuaZZzRt2jS1bdtWTz/9tNP8Q4cOad++fWrSpInL9YuzWV4//PCDy3rbtGnj1nY86cJ8VsaRI0c0d+5cJScnV4kc+V2z2alTp1LPdSpmt9tL/GEsKipSWFiYlixZ4nKd0l7c3lTVa3z++ef19NNP609/+pOeffZZx7lakydPdjp5++qrr9bBgwe1evVqrV27Vu+//74WLFigGTNmaNasWZLOv2vv3r27UlNT9cknn2ju3Ll68cUX9cEHHzjOUXKloKBAP//8c7nqbdKkiWrWrFm5H7qaIme+4685Kygo0J133ql9+/Zp3bp1FX6zUJ2MGDFCY8aMUUZGhuLi4kq9AvrTTz/V7bffrh49emjBggWKjIxU7dq1lZKS4nTBWLFTp045LlL75ptvVFRU5LXz2z/55BNJ0vHjx3Xq1Cmn5rSoqEh9+/Yt9ahjcVN7Ofvxxx/Ldc5m/fr1y2wiZ8yYoT/84Q/q1auX41zNjIwMx3McOXJEzZo189r/q981mxXVsmVLbdiwQV27dnX6uOFizZs3l3T+HdaF7/5//PHHElequnoO6fxtCMo6KlDaR2jeqLH4edatW6eff/7ZraMuK1euVO/evfXWW285jWdlZZU40b9evXq65557dM899zj+yDz33HNKTExUnTp1JEmRkZF69NFH9eijj+rkyZO64YYb9Nxzz5X5R/Czzz5T7969y1VvWloaV5t7GTlzfh5ydl5RUZEeeOABbdy4Ue+995569uxZrm1Xd0OGDNHYsWO1c+dOLV++vNTl3n//fdWpU0fr1q1zOg0jJSXF5fIJCQnKzc1VUlKSEhMTNW/ePE2dOrVcNR0+fFjGGKd8fffdd5IufXeP119/XevXr9dzzz2npKQkjR071ul2ai1bttSvv/7qsaPqzZs31/79+0vUe/DgQY9svyI6duzo+NSkLDNnzizz1mBHjx7V4cOHXX5K8eijj0o6fzqFt27RxKW4/+fuu+9WYWGhnn322RLzzp07p6ysLEnnzw2pXbu2XnvtNRljHMuU5yq4G264QTExMZo3b55je8Uu3Fa9evUkqcQy3qhRkoYOHSpjjOPoR2l1XqxmzZol5q9YsUL/+c9/nMZOnTrl9DggIEDXXHONjDE6e/asCgsLS1zpGhYWpqioKJe3pLhQ8blk5Zk4Z9P7yNnvyNnvJkyYoOXLl2vBggW68847L7k8zqtfv74WLlyoZ555Rrfddlupy9WsWVM2m83piNmRI0f04Ycfllh25cqVWr58uV544QU98cQTGj58uJ566ilHw3gpx48fV2pqquNxTk6O3nnnHXXo0KHM10JaWpqmTZumoUOH6sknn9TLL7+sf/3rX3rnnXccy9x9993asWOHyy/YyMrKKnHf0UuJj4/X8ePHnW4Bdfr0af397393azuXkp2drW+//bZcd3BYsmRJuXJ1qSvd58yZo9TUVKep+Hfa9OnTlZqa6vgd6A0c2fw/PXv21NixY5WUlKS9e/eqX79+ql27tg4dOqQVK1bolVde0bBhw9SkSRM99thjSkpK0qBBgxQfH689e/bo448/vuRtOmrUqKGFCxfqtttuU4cOHTR69GhFRkbq22+/1ddff+0IUGxsrCRp4sSJ6t+/v2rWrKnhw4d7pUZJ6t27t+6//369+uqrOnTokAYMGKCioiJ9+umn6t27t8aPH+9yvUGDBmn27NkaPXq0br75Zn311VdasmRJiXdW/fr1U0REhLp27arw8HAdOHBA8+fP18CBAxUUFKSsrCw1bdpUw4YNU/v27VW/fn1t2LBBn3/+uf7yl7+UWbunzyVbvHixfvjhB8c3L2zbtk1z5syRJN1///2Oo1soH3L2O3J23rx587RgwQJ16dJFgYGBJb5AYciQIV79o3i5GTly5CWXGThwoP76179qwIABGjFihE6ePKnk5GS1atVK+/btcyx38uRJjRs3zun1N3/+fG3evFmjRo3S9u3bL/mxa+vWrfXggw/q888/V3h4uN5++21lZmaWehRVOv/m6k9/+pPq1q2rhQsXSjp/+7H3339fkyZNUp8+fRQVFaVp06bpX//6lwYNGqRRo0YpNjZWeXl5+uqrr7Ry5UodOXLErdtljRkzRvPnz9cDDzyg3bt3KzIyUosXL/b4t6ClpqZq9OjRSklJ0ahRo8pc1lPnbF787VKSHEcxO3bsqMGDB3vkecrN69e/W+TCW0KUZeTIkaZevXqlzv/73/9uYmNjTd26dU1QUJC57rrrzPTp083x48cdyxQWFppZs2aZyMhIU7duXdOrVy+zf//+ErcocXV7B2OM2b59u+nbt68JCgoy9erVM+3atTOvvfaaY/65c+fMhAkTTJMmTYzNZitxexZP1liac+fOmblz55qrrrrKBAQEmCZNmpi4uDize/duxzKubsny5z//2fGcXbt2NTt27DA9e/Y0PXv2dCz3xhtvmB49ephGjRoZu91uWrZsaaZNm+a4tUZ+fr6ZNm2aad++vWMftW/f3ixYsOCSdXtaz549S731xMX/r9UBOSNnnlZ8m6zSporcOslflTd/rm7J89Zbb5krr7zS2O12c9VVV5mUlBQzc+ZMp9f9nXfeaYKCgsyRI0ec1l21apWRZF588cVyPe+6detMu3btHM918a12Ls7sK6+8UuKWScYYc/ToURMcHGzi4+MdY7m5uSYxMdG0atXKBAQEmMaNG5ubb77ZvPzyy6agoMCxnMp5e6AffvjB3H777SYwMNA0btzYTJo0yXGbM0/d+qj4/y0lJeWS9VjJl7c+shlTxuc1AAAA5dCiRQu1bdtWq1ev9nUpqGI4ZxMAAACWodkEAACAZWg2AQAAYBnO2QQAAIBlOLIJ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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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i9ILCgqUlZWl2rVrq2XLlk4fy4WEhOjw4cPatm2b2rZt63JfISEh2rp1q44cOeI4U1MSbdq0cfpo6XLCw8NLvF84I2fkzNs5GzJkiG677TYdP35caWlpyszM1NmzZ0tcU0Vz//33a/z48UpLS1Pfvn2Vlpbm8oxmkd+fIS46e9a5c2d9+OGHTtuFh4crOTlZQ4YMUefOnbVz506tWrVKderUKVFdkZGRGjBggONxnTp19PDDD+uVV15RRkaG29+HSpUqad68eWrTpo1iY2P1zTff6LnnnnM6w7948WJ17txZdevWdcpmz5499fLLL2vjxo2Oy3VKYvny5YqIiNCgQYMcYzVr1tRjjz2mp556qsT78aYFCxaU6Pf+mmuuueI2L7/8ss6fP69nn33WG6WVScA1m8nJyWrRooWqVKmisLAwtWzZsthHOFWqVFGjRo2cxvbt26fs7GyFhoa63O+xY8ckSb/88osk6dprr3Va37BhQ9WtW/eytRV91NiqVauS/0A+rrGozsjISNWrV8+j+oquP3vrrbeUnp7u9FHA7z9effrpp7V69Wq1a9dOzZs3V+/evTV06FB17NjRsc2rr76q+Ph4RUVFKSYmRnFxcXr44YevGLC6desWa4TgfeSMnHk7Z40bN1bjxo0lXWw8H3vsMfXs2VN79+7lo3QXGjZsqJ49e2rhwoU6c+aMCgoKnJqmS6WlpWnGjBnauXOn0zWJrt7YDB48WP/1X/+lzz77TI899ph69OhR4rqaN29ebJ8tWrSQJB04cOCybz6aNWumF154QZMmTVKrVq30/PPPO63ft2+fdu3a5fZmzaJsltQvv/zist6WLVt6tB9v+n0+y+LAgQOaOXOmkpOTVbt2ba/ssywCrtls166d22uditjt9mL/MBYWFio0NFQLFixw+ZzycCdyea/xpZde0vPPP68///nPmj59uuNarfHjxztdvH399ddr7969SktL04oVK7R06VK99dZbmjx5sqZOnSrp4rv2zp07KzU1VV988YVmzpypV155RZ988onjGiVX8vPz9euvv5ao3oYNG3KXaymRM/+pKDkbNGiQ3nnnHW3cuFF9+vTx+PkVwdChQzVixAhlZGQoNjbW7R3QX375pe6++2516dJFb731liIiIlS1alWlpKQ43TBW5OTJk46b1H744QcVFhb67Pr2L774QtLF+VdPnjzp1JwWFhaqV69ebs86FjW1V7Pjx4+X6JrN2rVrX7aJnDx5sv7whz+oW7dujms1MzIyHK9x4MABRUdH++z/a8A1m6XVrFkzrV69Wh07drzsu+iid9779u1zevd//PjxYnequnoN6eI0BJc7K+DuIzRf1Fj0OitXrtSvv/7q0VmXJUuWqHv37nr33XedxrOystSgQQOnsVq1aumBBx7QAw88oPz8fN1777168cUXlZiY6JgSIyIiQk888YSeeOIJHTt2TLfeeqtefPHFy/4j+PXXX6t79+4lqrdoWiP4Djlzfh1y5l7RR4klvRGpIhowYIBGjhypLVu26KOPPnK73dKlS1W9enWtXLnS6TKMlJQUl9snJCTo1KlTSkpKUmJiombNmqWJEyeWqKb9+/fLGOOUr59++knSlWf3ePvtt7Vq1Sq9+OKLSkpK0siRI7Vs2TLH+mbNmun06dNeO6veuHFj7d69u1i9e/fu9cr+S6Nt27aOT00uZ8qUKZedI/jgwYPav3+/y08pnnjiCUkXL6fw1RRN3Ir7f+6//34VFBRo+vTpxdZduHBBWVlZki5eG1K1alW9+eabTt9uUZK74G699VY1bdpUs2bNcuyvyO/3VTQX4aXb+KJGSRo4cKCMMY6zH+7qvFTlypWLrV+8eLH+/e9/O42dPHnS6XG1atV0ww03yBij8+fPq6CgoNg/MKGhoYqMjHQ5JcXvFV1LVpKFazZ9j5z9Bzm76Pjx4y7H3333XdlstsveFV/R1a5dW3PnztULL7ygu+66y+12lStXls1mczpjduDAAX366afFtl2yZIk++ugjvfzyy3rmmWc0ePBgPffcc46G8UqOHDmi1NRUx+OcnBx98MEHuvnmmy/7u5Cenq5JkyZp4MCBevbZZ/Xaa6/pX//6lz744APHNvfff782b97s8gs2srKydOHChRLVWCQuLk5HjhxxmgLqzJkz+sc//uHRfq4kOztbP/74Y4neOC1YsKBEubrSne4zZsxQamqq01L0N+2pp55SamqqJfMeu8OZzf/TtWtXjRw5UklJSdq5c6d69+6tqlWrat++fVq8eLHeeOMNDRo0SA0bNtSTTz6ppKQk9evXT3FxcdqxY4c+//zzYmcVLlWpUiXNnTtXd911l26++WYNHz5cERER+vHHH/X99987AhQTEyNJGjt2rPr06aPKlStr8ODBPqlRkrp3766HHnpIs2fP1r59+9S3b18VFhbqyy+/VPfu3TV69GiXz+vXr5+mTZum4cOH6/bbb9d3332nBQsWFHtn1bt3b4WHh6tjx44KCwvTnj17NGfOHN15550KCgpSVlaWGjVqpEGDBqlNmzaqXbu2Vq9erW3btumvf/3rZWv39rVk8+fP1y+//OL45oWNGzdqxowZkqSHHnrIcXYLJUPO/oOcXfTiiy/qq6++Ut++fRUdHa1ff/1VS5cu1bZt2zRmzBg1b97cK68TqOLj46+4zZ133qnXX39dffv21dChQ3Xs2DElJyerefPm2rVrl2O7Y8eOadSoUU6/f3PmzNG6des0bNgwbdq06Yofu7Zo0UKPPPKItm3bprCwML333nvKzMx0exZVuvjm6s9//rNq1KihuXPnSro4/djSpUs1btw49ezZU5GRkZo0aZL+9a9/qV+/fho2bJhiYmKUm5ur7777TkuWLNGBAwdKlL0iI0aM0Jw5c/Twww9r+/btioiI0Pz5873+LWipqakaPny4UlJSNGzYsMtu661rNi/9dilJjrOYbdu2Vf/+/b3yOiXm8/vfLfL7KSEuJz4+3tSqVcvt+n/84x8mJibG1KhRwwQFBZmbbrrJPPXUU+bIkSOObQoKCszUqVNNRESEqVGjhunWrZvZvXt3sSlKXE3vYIwxmzZtMr169TJBQUGmVq1apnXr1ubNN990rL9w4YIZM2aMadiwobHZbMWmZ/Fmje5cuHDBzJw501x33XWmWrVqpmHDhiY2NtZs377dsY2rKVn+8pe/OF6zY8eOZvPmzaZr166ma9euju3+/ve/my5dupj69esbu91umjVrZiZNmuSYWiMvL89MmjTJtGnTxnGM2rRpY956660r1u1tXbt2dTv1xKX/XysCckbOvO2LL74w/fr1M5GRkaZq1aomKCjIdOzY0aSkpDhNAYWS58/VlDzvvvuuufbaa43dbjfXXXedSUlJMVOmTHH6vb/33ntNUFCQOXDggNNzly1bZiSZV155pUSvu3LlStO6dWvHa1061c6lmX3jjTeKTZlkjDEHDx40derUMXFxcY6xU6dOmcTERNO8eXNTrVo106BBA3P77beb1157zeTn5zu2UwmnB/rll1/M3XffbWrWrGkaNGhgxo0b55jmzFtTHxX9f0tJSbliPVby59RH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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApsAAAD4CAYAAACjbS25AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAtWElEQVR4nO3deXQUdb7+8acDpNlCQiDrj7DIqiKgERBBFglLIi4IKuAoMAqIYQkojpmjKIjGbRxUIuqMhisDgoCARgTZkStwBeEiighM2ISERZNAkASS7+8PbnpskoZ00tUJnffrnDqH/tbSny76gU9XV1XbjDFGAAAAgAX8yrsAAAAA+C6aTQAAAFiGZhMAAACWodkEAACAZWg2AQAAYBmaTQAAAFiGZhMAAACWodkEAACAZWg2AQAAYBmaTQ9q3Lixhg0b5ni8bt062Ww2rVu3rtxqutSlNVaUbQHuIGvA1csbebXZbHr++edLtW5x9Q0bNkyNGzd2Wu7MmTN69NFHFR4eLpvNpoSEBElSRkaGBg4cqHr16slms2n69OmlqsOX+EyzOWvWLNlsNsdUvXp1tWjRQmPGjFFGRkZ5l+eWZcuWlTok8KwXX3xRd911l8LCwsr0j5cvIWvwtAMHDji9p/44zZs3r7zLqzD+mL2NGzcWmW+MUVRUlGw2m/r161cOFVYuL730kmbNmqXRo0dr9uzZeuihhyRJEyZM0IoVK5SYmKjZs2erb9++5VbfLbfcopCQEFWvXl3NmzdXQkKCTpw44fVaqnr9GS02depUNWnSROfOndPGjRs1c+ZMLVu2TLt27VLNmjW9WkvXrl31+++/y9/f3631li1bpuTkZP4TrACeeeYZhYeH68Ybb9SKFSvKu5wKhazB0wYPHqy4uDinsU6dOpVTNRVX9erVNXfuXHXp0sVpfP369Tpy5Ijsdns5VVYypc1refrHP/6hgoICp7E1a9bolltu0XPPPVdk/O6779aTTz7pzRKL2LZtm9q1a6dBgwYpICBAu3fv1j/+8Q998cUX2rFjh2rVquW1Wnyu2YyNjdXNN98sSXr00UdVr149vfHGG1q6dKkGDx5c7Do5OTmW7HQ/Pz9Vr17d49uF96Slpalx48Y6efKkQkJCyrucCoWswdNuuukm/elPfyrvMiq8uLg4LViwQG+99ZaqVv3Pf+Nz585VdHS0Tp48WY7VXdnVmNdq1aoVGTt+/Liuu+66YseDgoK8UNXlLVq0qMhYp06dNHDgQH3++ecaNGiQ12rxma/RXbn99tslXWwapIvnXdSuXVv79+9XXFycAgIC9OCDD0qSCgoKNH36dF1//fWqXr26wsLCNGrUKP32229O2zTGaNq0aWrQoIFq1qypHj166Icffijy3K7OS9myZYvi4uJUt25d1apVS23atNGbb77pqC85OVmSnL5KKuTpGl0pKCjQm2++qRtuuEHVq1dXSEiI+vbtq61bt7pc59dff9WTTz6pG264QbVr11adOnUUGxur//3f/y2y7Ntvv63rr79eNWvWVN26dXXzzTdr7ty5jvmnT59WQkKCGjduLLvdrtDQUPXq1UvfffddiV+DJ1x6jg5cI2tkzRNycnKUl5dXLs99tRg8eLBOnTqllStXOsby8vK0cOFCDRkypNh1Xn/9dd16662qV6+eatSooejoaC1cuNBpmZSUFNlsNn344YdO4y+99JJsNpuWLVt22boaN26sfv366auvvlK7du1UvXp1XXfddfr000+dlrs0r7t371aNGjX08MMPOy23ceNGValSRX/5y18cY5mZmUpISFBUVJTsdruaNWumV155pchRx5I6cuSI7rnnHtWqVUuhoaGaMGGCcnNziyz3x3M2C+tPS0vTF1984fi3o/A0B2OMkpOTi/ybUhEUvobMzEyvPq/PHdm81P79+yVJ9erVc4xduHBBffr0UZcuXfT66687vvIbNWqUZs2apeHDh2vcuHFKS0vTjBkztH37dv33f/+345PN5MmTNW3aNMXFxSkuLk7fffedevfuXaJ/IFeuXKl+/fopIiJC48ePV3h4uHbv3q3U1FSNHz9eo0aN0tGjR7Vy5UrNnj27yPreqFGSHnnkEc2aNUuxsbF69NFHdeHCBX399dfavHmz42jWpf79739ryZIluu+++9SkSRNlZGTovffeU7du3fTjjz8qMjJS0sWvI8aNG6eBAwdq/PjxOnfunHbu3KktW7Y4/qF87LHHtHDhQo0ZM0bXXXedTp06pY0bN2r37t266aabXNZ9/vx5ZWVlleg1BgcHy8/P5z9veQ1ZI2uulDRrU6ZM0aRJk2Sz2RQdHa0XX3xRvXv3LtFzVCaNGzdWp06d9PHHHys2NlaS9OWXXyorK0uDBg3SW2+9VWSdN998U3fddZcefPBB5eXlad68ebrvvvuUmpqqO+64Q5I0fPhwffrpp5o4caJ69eqlqKgoff/995oyZYoeeeSRIqc4FGfv3r164IEH9Nhjj2no0KFKSUnRfffdp+XLl6tXr17FrnPttdfqhRde0KRJkzRw4EDdddddysnJ0bBhw9SqVStNnTpVknT27Fl169ZNv/zyi0aNGqWGDRvqm2++UWJioo4dO+b2hTi///67evbsqUOHDmncuHGKjIzU7NmztWbNmsuud+2112r27NmaMGGCGjRooCeeeEKSdOONNzrO3ezVq1eR5rkkfvvtN+Xn519xuZo1a5bodCVjjE6dOqULFy5o7969evrpp1WlShV1797d7drKxPiIlJQUI8msWrXKnDhxwhw+fNjMmzfP1KtXz9SoUcMcOXLEGGPM0KFDjSTz9NNPO63/9ddfG0lmzpw5TuPLly93Gj9+/Ljx9/c3d9xxhykoKHAs99e//tVIMkOHDnWMrV271kgya9euNcYYc+HCBdOkSRPTqFEj89tvvzk9zx+3FR8fb4r7q7GixuKsWbPGSDLjxo0rMu+P22vUqJHTts6dO2fy8/Odlk9LSzN2u91MnTrVMXb33Xeb66+//rI1BAYGmvj4+MsuU5zCfV6SKS0trcTbPXHihJFknnvuObdr8jVkjawZ49msHTx40PTu3dvMnDnTfPbZZ2b69OmmYcOGxs/Pz6Smprpdm68qzN63335rZsyYYQICAszZs2eNMcbcd999pkePHsaYi++XO+64w2ndwuUK5eXlmdatW5vbb7/dafzYsWMmODjY9OrVy+Tm5pobb7zRNGzY0GRlZV2xvkaNGhlJZtGiRY6xrKwsExERYW688UbH2KV5NcaY/Px806VLFxMWFmZOnjxp4uPjTdWqVc23337rWOaFF14wtWrVMj///LPT8z799NOmSpUq5tChQ46xkvx7PX36dCPJfPLJJ46xnJwc06xZsyL1DR061DRq1KjI6710Pxc+d2kyVbjNkmSqpP8XHTt2zGm9Bg0amPnz55eqtrLwuSObMTExTo8bNWqkOXPm6P/9v//nND569GinxwsWLFBgYKB69erldL5LdHS0ateurbVr12rIkCFatWqV8vLyNHbsWKfD4wkJCXrppZcuW9v27duVlpamv//970XO5yjJoXZv1ChdPM/DZrMVOen5SnX+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1ltvae/everbt68KCgr09ddfq0ePHhozZkyx6/Xr109Tp07V8OHDdeutt+r777/XnDlzipz71bt3b4WHh6tz584KCwvT7t27NWPGDN1xxx0KCAhQZmamGjRooIEDB6pt27aqXbu2Vq1apW+//VZ/+9vfLlu7p88jmz17tg4ePOgI7YYNGzRt2jRJFy9gKDyyhZIja/9B1i566qmntH//fvXs2VORkZE6cOCA3nvvPeXk5Djui4riDR069IrL3HHHHXrjjTfUt29fDRkyRMePH1dycrKaNWumnTt3OpY7fvy4Ro8e7fTemzFjhtauXathw4Zp48aNV/w6vUWLFnrkkUf07bffKiwsTB9++KEyMjJcHkWVLn6w+vOf/6waNWpo5syZki7eemzRokUaP368YmJiFBkZqUmTJumzzz5Tv379NGzYMEVHRysnJ0fff/+9Fi5cqAMHDpQod4VGjBihGTNm6OGHH9a2bdsUERGh2bNne/wX0BYvXqzhw4crJSVFw4YNu+yynjpnc+/evYqJidEDDzygVq1ayc/PT1u3btW//vUvNW7cWOPHj/fI85SY169/t8gfbwlxOUOHDjW1atVyOf/999830dHRpkaNGiYgIMDccMMN5qmnnjJHjx51LJOfn2+mTJliIiIiTI0aNUz37t3Nrl27ityepLjbOxhjzMaNG02vXr1MQECAqVWrlmnTpo15++23HfMvXLhgxo4da0JCQozNZityaxZP1ujKhQsXzGuvvWZatWpl/P39TUhIiImNjTXbtm1zLFPc7VieeOIJx3N27tzZbNq0yXTr1s1069bNsdx7771nunbtaurVq2fsdrtp2rSpmTRpkuPWGrm5uWbSpEmmbdu2jn3Utm1b884771yxbk/r1q2by1tPXPr3WlmQNbLmaXPnzjVdu3Y1ISEhpmrVqqZ+/fqmf//+TvsAJc9ecbfk+eCDD0zz5s2N3W43rVq1MikpKea5555zes/fe++9JiAgwBw4cMBp3aVLlxpJ5pVXXinR865YscK0adPG8VwLFixwWu7SvL755ptFbplkjDGHDh0yderUMXFxcY6x06dPm8TERNOsWTPj7+9v6tevb2699Vbz+uuvm7y8PMdyKuHtgQ4ePGjuuusuU7NmTVO/fn0zfvx4xy3OPHXro8K/t5SUlCvW4yknTpwwI0eONK1atTK1atUy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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApsAAAD4CAYAAACjbS25AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAt5UlEQVR4nO3de5iN9f7/8dcazDKYA8OctsHkWAk1IZFDjiOJqNC3UCQNQqlmb4ccairtUgzt3WHsbFKU7C2Rs3zDr8SWDsKeHPaYUWpmGJnBfH5/+M7allmLWWPda8aa5+O67utqfe573es9d/Ma73Wv+/4smzHGCAAAALBAQGkXAAAAAP9FswkAAADL0GwCAADAMjSbAAAAsAzNJgAAACxDswkAAADL0GwCAADAMjSbAAAAsAzNJgAAACxDs+lF9erV05AhQxyPN27cKJvNpo0bN5ZaTRe7uMaysi/AE2QNuHr5Iq82m03PPvtsiZ7rqr4hQ4aoXr16TtudPHlSw4YNU1RUlGw2m8aOHStJyszMVP/+/RUeHi6bzaZZs2aVqA5/4jfN5vz582Wz2RxL5cqV1ahRI40aNUqZmZmlXZ5HVq5cWeKQwLuee+459e7dW5GRkVf0x8ufkDVY5cCBAxo0aJAiIiIUFBSkhg0b6k9/+lNpl1VmXJi9LVu2FFlvjFFsbKxsNpt69epVChWWL88//7zmz5+vkSNHasGCBXrggQckSePGjdPq1auVlJSkBQsWqEePHj6v7dSpU0pJSVG3bt0UHR2t4OBg3XjjjZo3b57OnTvn83oq+vwVLTZt2jTFxcXp9OnT2rJli+bNm6eVK1dqz549qlKlik9rad++vX7//XcFBgZ69LyVK1cqJSWFfwTLgIkTJyoqKko33nijVq9eXdrllClkDd60a9cudezYUX/4wx/0xBNPKDw8XIcOHdLhw4dLu7Qyp3Llylq0aJHatWvnNL5p0yYdOXJEdru9lCornpLmtTS9+eabKigocBpbv369brnlFk2ZMqXI+F133aUnn3zSlyU6+fe//63Ro0erc+fOGj9+vEJCQrR69Wo99thj2rZtm/72t7/5tB6/azYTEhJ08803S5KGDRum8PBwvfLKK1q+fLkGDhzo8jm5ubmqWrWq12sJCAhQ5cqVvb5f+E5aWprq1aunX375RbVq1SrtcsoUsgZvKSgo0AMPPKAmTZpow4YNCgoKKu2SyrSePXtqyZIlev3111Wx4n//GV+0aJHi4+P1yy+/lGJ1l3c15rVSpUpFxo4dO6brrrvO5XhYWJgPqnIvKipK33zzja6//nrH2IgRI/TQQw8pNTVVkyZNUoMGDXxWj998jO7O7bffLul80yCdv+6iWrVqOnDggHr27Kng4GDdf//9ks7/wZs1a5auv/56Va5cWZGRkRoxYoR+++03p30aYzRjxgzVrl1bVapUUadOnfTtt98WeW1316Vs375dPXv2VPXq1VW1alU1a9ZMr732mqO+lJQUSXL6qLKQt2t0p6CgQK+99ppuuOEGVa5cWbVq1VKPHj301VdfuX3Or7/+qieffFI33HCDqlWrppCQECUkJOhf//pXkW1nz56t66+/XlWqVFH16tV18803a9GiRY71J06c0NixY1WvXj3Z7XZFRESoa9eu+vrrr4v9M3jDxdfowD2yRtZK6rPPPtOePXs0ZcoUBQUF6dSpU6XyUd/VYuDAgTp+/LjWrFnjGMvPz9fSpUs1aNAgl895+eWXdeuttyo8PFxBQUGKj4/X0qVLnbZJTU2VzWbTO++84zT+/PPPy2azaeXKlZesq169eurVq5c+++wztWjRQpUrV9Z1112njz76yGm7i/P6/fffKygoSA8++KDTdlu2bFGFChX09NNPO8aysrI0duxYxcbGym63q0GDBnrxxReLnHUsriNHjqhPnz6qWrWqIiIiNG7cOOXl5RXZ7sJrNgvrT0tL0yeffOL421F4mYMxRikpKUX+pvhSzZo1nRrNQn379pV0/pj7kt+d2bzYgQMHJEnh4eGOsbNnz6p79+5q166dXn75ZcdHfiNGjND8+fM1dOhQjRkzRmlpaZozZ4527typ//3f/3W8s5k8ebJmzJihnj17qmfPnvr666/VrVs35efnX7aeNWvWqFevXoqOjtbjjz+uqKgoff/991qxYoUef/xxjRgxQunp6VqzZo0WLFhQ5Pm+qFGSHn74Yc2fP18JCQkaNmyYzp49q88//1zbtm1znM262L///W99/PHHuueeexQXF6fMzEz95S9/UYcOHfTdd98pJiZG0vmPI8aMGaP+/fvr8ccf1+nTp7V7925t377d8Yfy0Ucf1dKlSzVq1Chdd911On78uLZs2aLvv/9eN910k9u6z5w5o+zs7GL9jDVq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+HBlZGQoISHB7R3Qn3/+uXr37q327dtr7ty5io6OVqVKlZSamup0s1ih48ePO25Q++6771RQUOCz69s/++wzSVJ6erqOHz/u1JwWFBSoa9eubs86Fja1V7Off/65WNdsVqtWTdWqVSvWPufPn6+nn35ajz76qCZOnHilJZaI3zWbJVW/fn2tXbtWbdu2veS0G3Xr1pV0/h3Whe/8f/7558v+Qaxfv74kac+ePZd8l+7u4zNf1Fj4OqtXr9avv/7q0RmXpUuXqlOnTnr77bedxrOysopcjFy1alXdd999uu+++5Sfn6+7775bzz33nJKSkhxTYkRHR+uxxx7TY489pmPHjummm27Sc889d8l/AL/44gt16tSpWPUWTmsE3yJrzq9D1s5fnvDmm2/qP//5j9N4enq6pNJv7suqvn37asSIEdq2bZvef/99t9t9+OGHqly5slavXu10CUZqaqrL7RMTE3XixAklJycrKSlJs2bN0vjx44tV0/79+2WMccrWjz/+KOnys3u88cYbWrNmjZ577jklJydrxIgRWr58uWN9/fr1dfLkSa+d5a5bt6727NlTpN69e/d6Zf8l0bJlS8cnJpcyZcqUYs0PvHz5cg0bNkx33323Y/aN0sCtuP/n3nvv1blz5zR9+vQi686ePausrCxJ568NqVSpkmbPni1jjGOb4twFd9NNNykuLk6zZs1y7K/QhfsqnIfw4m18UaN0/lopY4zjzIe7Oi9WoUKFIuuXLFlS5B+Q48ePOz0ODAzUddddJ2OMzpw5o3PnzhW5yzUiIkIxMTEup6S4UOF1ZMVZuGazdJC1/yJr5911112y2+1KTU11OjP71ltvSZLbu5jLu2rVqmnevHl69tlndeedd7rdrkKFCrLZbE5nzH766Sd9/PHHRbZdunSp3n//fb3wwgt65plnNGDAAE2cONHRMF5Oenq6li1b5nick5Ojd999Vy1atLjk70FaWpomTJigfv366Y9//KNefvll/eMf/9C7777r2Obee+/V1q1bXX7BRlZWls6ePVusGgv17NlT6enpTlNAnTp1Sn/961892s/lZGdn64cffijW7A0LFy4sVqaKc6f75s2bNWDAALVv314LFy4s1dlXOLP5fzp06KARI0YoOTlZu3btUrdu3VSpUiXt27dPS5Ys0Wuvvab+/furVq1aevLJJ5WcnKxevXqpZ8+e2rlzpz799NPLTiUQEBCgefPm6c4771SLFi00dOhQRUdH64cfftC3337rCFB8fLwkacyYMerevbsqVKigAQMG+KRGSerUqZMeeOABvf7669q3b5969OihgoICff755+rUqZNGjRrl8nm9evXStGnTNHToUN1666365ptvtHDhwiLXfnXr1k1RUVFq27atIiMj9f3332vOnDm64447FBwcrKysLNWuXVv9+/dX8+bNVa1aNa1du1Zffvml/vznP1+ydm9fs7lgwQIdPHhQp06dknQ+vDNmzJAkPfDAA44zWyg+svZfZO28qKgo/elPf9LkyZPVo0cP9enTR//617/05ptvauDAgW5vboI0ePDgy25zxx136JVXXlGPHj00aNAgHTt2TCkpKWrQoIF2797t2O7YsWMaOXKk0+/enDlztGHDBg0ZMkRbtmy5bMPSqFEjPfzww/ryyy8VGRmpd955R5mZmW7Pokrn31g99NBDCgoK0rx58ySdn3rsww8/1OOPP64uXbooJiZGEyZM0D/+8Q/16tVLQ4YMUXx8vHJzc/XNN99o6dKl+umnnzya0mf48OGaM2eOHnzwQe3YsUPR0dFasGCB178BbdmyZRo6dKhSU1M1ZMiQS27rrWs2Dx48qN69e8tms6l///5asmSJ0/pmzZqpWbNmXnmtYvHpve8WunBKiEsZPHiwqVq1qtv1f/3rX018fLwJCgoywcHB5oYbbjBPPfWUSU9Pd2xz7tw5M3XqVBMdHW2CgoJMx44dzZ49e4pMT+JqegdjjNmyZYvp2rWrCQ4ONlWrVjXNmjUzs2fPdqw/e/asGT16tKlVq5ax2WxFpmbxZo3unD171sycOdM0adLEBAYGmlq1apmEhASzY8cOxzaupmN54oknHK/Ztm1bs3XrVtOhQwfToUMHx3Z/+ctfTPv27U14eLix2+2mfv36ZsKECY6pNfLy8syECRNM8+bNHceoefPmZu7cuZet29s6dOjgduqJi/+/lhdkjaxZoaCgwMyePds0atTIVKpUycTGxpqJEyea/Px8n9dSVhU3e66m5Hn77bdNw4YNjd1uN02aNDGpqalmypQpTr/zd999twkODjY//fST03OXL19uJJkXX3yxWK+7evVq06xZM8drLVmyxGm7i/P62muvFZkyyRhjDh06ZEJCQkzPnj0dYydOnDBJ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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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pfT0dN16662SpNGjR+vDDz/UtGnT1L9/f0VFRembb77R7Nmz9eCDDyouLu6ite3fv1/33HOPHn74YcXHxyslJUV33XWXVq1apf79+7vc58orr9Qzzzyj6dOna/jw4br99tuVn5+vUaNG6YorrtCcOXMkSadPn1bv3r3173//W+PGjVPLli31xRdfKDExUceOHfP4RpzffvtNt9xyiw4fPqxJkyYpMjJSixcv1vr168vc78orr9TixYs1depUtWjRQn/5y18kSdddd53j2s3+/fuXap7L49dff1VRUdFFt2vQoEG5LldKTU3VF198ob179+rgwYMe1+M1xk+kpKQYSWbt2rXmp59+MpmZmWbZsmWmadOmpn79+ubIkSPGGGPi4+ONJPP444877f/ZZ58ZSWbJkiVO46tWrXIaP378uAkICDC33nqrKS4udmz3xBNPGEkmPj7eMbZhwwYjyWzYsMEYY8y5c+dMdHS0adWqlfn111+dXuePz5WQkGBc/dVYUaMr69evN5LMpEmTSq374/O1atXK6bnOnDljioqKnLbPyMgwdrvdzJkzxzF2xx13mKuvvrrMGoKDg01CQkKZ27hScszLs2RkZJT7eX/66ScjycyaNcvjmvwNWSNrxliXNWOM2bNnj5FkZsyY4XFd/qwke19++aVZsGCBCQoKMqdPnzbGGHPXXXeZvn37GmPO/77ceuutTvuWbFeisLDQdOjQwdx8881O48eOHTNNmjQx/fv3NwUFBea6664zLVu2NLm5uRetr1WrVkaS+eCDDxxjubm5JiIiwlx33XWOsQvzaowxRUVFpkePHiYsLMz8/PPPJiEhwdSpU8d8+eWXjm2eeeYZ07BhQ/PDDz84ve7jjz9uateubQ4fPuwYK8+/1/PnzzeSzPvvv+8Yy8/PN23bti1VX3x8vGnVqlWpn/fC41zy2hXJVMlzlidT5fm/6PTp06Zly5YmMTHRGPP7cU9NTa1QbZXhd2c2+/Xr5/S4VatWWrJkif70pz85jY8fP97pcWpqqoKDg9W/f3+n611iYmIUGBioDRs2aOTIkVq7dq0KCws1ceJEp9PjU6ZM0XPPPVdmbTt37lRGRoZeeeWVUtdzlOdUuy9qlKQPPvhANput1EXPF6vzjxelFxUVKScnR4GBgWrfvr3TR3IhISE6cuSIvvzyS7cX/oeEhGj79u06evSo4yxNeXTq1Mnpo6WyhIeHl/t5URpZI2tWZW3JkiWSxEfoZbj77rs1ZcoUpaena9CgQUpPT3d5RrNE/fr1HX8uOXvWs2dPvfvuu07bhYeHKzk5Wffee6969uypXbt2ac2aNWrUqFG56oqMjNTQoUMdjxs1aqQHHnhAL7zwgrKystz+LtSqVUuLFi1Sp06dFBsbq6+++kpPPvmk09n91NRU9ezZU40bN3bKZb9+/fT8889r8+bNHv3OrFy5UhERERo+fLhjrEGDBnrooYc0Y8aMcj+PNy1ZskS//fbbRbe77LLLLrrN888/r7Nnz+qJJ57wRmmV4nfNZnJystq1a6c6deooLCxM7du3L/XxTZ06ddSiRQunsf379ys3N1ehoaEun/f48eOSpEOHDkmSLr/8cqf1zZs3V+PGjcusreRjxg4dOpT/B/JxjSV1RkZGqkmTJh7VV3Lt2RtvvKGMjAynjwL++NHqY489prVr16pLly5q27atBgwYoJEjR6p79+6ObV588UXFx8crKipKMTExiouL0wMPPHDRgDVu3LhUEwRrkDWyZkXWjDFaunSpOnToUOqmIfyuefPm6tevn5YuXarTp0+rqKjIqWm6UHp6uubOnatdu3Y5XZPo6k3NiBEj9F//9V/6+OOP9dBDD+mWW24pd11t27Yt9Zzt2rWTJB08eLDMNx5t2rTR008/renTp6tDhw566qmnnNbv379fu3fvdnuzZkkuy+vQoUMu623fvr1Hz+NNf8xmZRw8eFDz5s1TcnKyAgMDvfKcleF3zWaXLl3cXudUwm63l/pPsbi4WKGhoY531BeqDnciV/can3vuOT311FP685//rGeeecZxndaUKVOcLt6+8sortW/fPqWnp2vVqlX64IMP9MYbb2jmzJmaPXu2pPPv2nv27Km0tDR9+umnmjdvnl544QV9+OGHjmuUXCksLNQvv/xSrnqbN2+u2rVrV+6HrsHIWtXx56x9/vnnOnTokJKSksq1fU02cuRIjR07VllZWYqNjXV7B/Rnn32m22+/Xb169dIbb7yhiIgI1a1bVykpKU43i5U4ceKE4wa17777TsXFxT67vv3TTz+VJB09elQnTpxwak6Li4vVv39/t2cdS5raS9lPP/1Urms2AwMDy2wiZ86cqT/96U/q06eP41rNrKwsx2scPHhQLVu29Nnfq981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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApsAAAD4CAYAAACjbS25AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAuBUlEQVR4nO3de1hU9b7H8c94Gy/cvHFLVNLUytQidZv38gaZaVqZnUIrM8P7zoqe0jSLymqbSdbeFZ48mqVFdsw072app0wzy0w7eNsKlgUoJij8zh8eJkdmkIFZAw7v1/Os52l+a62ZLys++J01a/3GZowxAgAAACxQpbwLAAAAgP+i2QQAAIBlaDYBAABgGZpNAAAAWIZmEwAAAJah2QQAAIBlaDYBAABgGZpNAAAAWIZmEwAAAJah2fSipk2bavjw4Y7H69evl81m0/r168utpgtdWGNFeS7AE2QNuHT5Iq82m01PP/10qfZ1Vd/w4cPVtGlTp+1OnjypBx54QOHh4bLZbJowYYIkKSMjQ0OGDFH9+vVls9k0a9asUtXhT/ym2Zw3b55sNptjqVmzplq0aKExY8YoIyOjvMvzyPLly0sdEnjXs88+qwEDBigsLKxMf7z8CVmDFY4ePaoHH3xQ0dHRqlWrlpo1a6ZJkybp+PHj5V1ahXF+9jZt2lRkvTFGUVFRstls6t+/fzlUWLk899xzmjdvnkaPHq358+frnnvukSRNnDhRK1euVGJioubPn69+/fqVc6VSZmamQkNDZbPZtGTJEp+/fjWfv6LFpk+frujoaJ0+fVqbNm3S3LlztXz5cu3atUu1a9f2aS3dunXTn3/+qRo1ani03/Lly5WcnMw/ghXAk08+qfDwcF177bVauXJleZdToZA1eMvJkyfVqVMn5eTk6OGHH1ZUVJS+++47zZkzR+vWrdO2bdtUpYrfnBsps5o1a2rhwoXq0qWL0/iGDRt0+PBh2e32cqqsZEqb1/L0r3/9SwUFBU5ja9eu1d/+9jdNnTq1yPitt96qRx55xJclFmvKlCk6depUub2+3zWbsbGxuv766yVJDzzwgOrXr69XXnlFS5cu1V133eVyn5ycHNWpU8frtVSpUkU1a9b0+vPCd9LS0tS0aVP99ttvatiwYXmXU6GQNXjLJ598ogMHDmjZsmW6+eabHeP16tXT9OnT9d133+naa68txworlri4OC1evFizZ89WtWp//TO+cOFCxcTE6LfffivH6i7uUsxr9erVi4wdO3ZMV111lcvxkJAQH1RVMrt27dLcuXM1ZcoUTZkypVxq8Pu3ijfeeKOkc02DdO66i4CAAP3yyy+Ki4tTYGCg7r77bklSQUGBZs2apauvvlo1a9ZUWFiYRo0apT/++MPpOY0xmjFjhho1aqTatWurZ8+e+uGHH4q8trvrUrZu3aq4uDjVrVtXderUUZs2bfTqq6866ktOTpYkp48qC3m7RncKCgr06quv6pprrlHNmjXVsGFD9evXT998843bfX7//Xc98sgjuuaaaxQQEKCgoCDFxsbqu+++K7Lta6+9pquvvlq1a9dW3bp1df3112vhwoWO9SdOnNCECRPUtGlT2e12hYaGqnfv3vr2229L/DN4w4XX6MA9skbWSis7O1uSFBYW5jQeEREhSapVq5bParkU3HXXXTp+/LhWrVrlGMvLy9OSJUs0bNgwl/u89NJLuuGGG1S/fn3VqlVLMTExRT5OTUlJkc1m0zvvvOM0/txzz8lms2n58uXF1tW0aVP1799fn3/+udq1a6eaNWvqqquu0kcffeS03YV53b17t2rVqqV7773XabtNmzapatWqeuyxxxxjmZmZmjBhgqKiomS329W8eXO98MILRc46ltThw4c1cOBA1alTR6GhoZo4caJyc3OLbHf+NZuF9aelpenTTz91/O0ovMzBGKPk5OQif1PKy/jx4zVo0CB17dq13GrwuzObF/rll18kSfXr13eMnT17Vn379lWXLl300ksvOT7yGzVqlObNm6cRI0Zo3LhxSktL05w5c7R9+3Z9+eWXjnc2U6ZM0YwZMxQXF6e4uDh9++236tOnj/Ly8i5az6pVq9S/f39FRERo/PjxCg8P1+7du7Vs2TKNHz9eo0aN0pEjR7Rq1SrNnz+/yP6+qFGS7r//fs2bN0+xsbF64IEHdPbsWX3xxRfasmWL42zWhf73f/9XH3/8sW6//XZFR0crIyNDb775prp3764ff/xRkZGRks59HDFu3DgNGTJE48eP1+nTp7Vz505t3brV8YfyoYce0pIlSzRmzBhdddVVOn78uDZt2qTdu3fruuuuc1v3mTNnlJWVVaKfsV69enw050Vkjay5c7GsdevWTVWqVNH48eP18ssvq1GjRtq5c6eeffZZDRw4UK1atSrR61QWTZs2VadOnfTee+8pNjZWkvTZZ58pKytLQ4cO1ezZs4vs8+qrr2rAgAG6++67lZeXp0WLFun22293Ops8YsQIffTRR5o0aZJ69+6tqKgoff/995o2bZruv/9+xcXFXbS2vXv36s4779RDDz2k+Ph4paSk6Pbbb9eKFSvUu3dvl/tceeWVeuaZZzR58mQNGTJEAwYMUE5OjoYPH65WrVpp+vTpkqRTp06pe/fu+ve//61Ro0apcePG+uqrr5SYmKijR496fCPOn3/+qZtuukkHDx7UuHHjFBkZqfnz52vt2rXF7nfllVdq/vz5mjhxoho1aqS///3vkqRrr73Wce1m7969izTPJfHHH38oPz//otvVrl27RJcrLV68WF999ZV2796t/fv3e1yP1xg/kZKSYiSZ1atXm19//dUcOnTILFq0yNSvX9/UqlXLHD582BhjTHx8vJFkHn/8caf9v/jiCyPJLFiwwGl8xYoVTuPHjh0zNWrUMDfffLMpKChwbPfEE08YSSY+Pt4xtm7dOiPJrFu3zhhjzNmzZ010dLRp0qSJ+eOPP5xe5/znSkhIMK7+11hRoytr1641ksy4ceOKrDv/+Zo0aeL0XKdPnzb5+flO26elpRm73W6mT5/uGLv11lvN1VdfXWwNwcHBJiEhodhtXCk85iVZ0tLSSvy8v/76q5Fkpk6d6nFN/oaskTVjvJ+1t956y4SEhDjtFx8fb86cOeNxbf6qMHtff/21mTNnjgkMDDSnTp0yxhhz++23m549expjzv2+3HzzzU77Fm5XKC8vz7Ru3drceOONTuNHjx419erVM7179za5ubnm2muvNY0bNzZZWVkXra9JkyZGkvnwww8dY1lZWSYiIsJce+21jrEL82qMMfn5+aZLly4mLCzM/PbbbyYhIcFUq1bNfP31145tnnnmGVOnTh3z888/O73u448/bqpWrWoOHjzoGCvJ3+tZs2YZSeaDDz5wjOXk5JjmzZsXqS8+Pt40adKkyM974XEufO3SZKrwOUuSqZL8W3Tq1CnTuHFjk5iYaIz567gvXry4VLWVhd+d2ezVq5fT4yZNmmjBggW67LLLnMZHjx7t9Hjx4sUKDg5W7969na53iYmJUUBAgNatW6dhw4Zp9erVysvL09ixY51Oj0+YMEHPPfdcsbVt375daWlp+sc/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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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OVzvEh0drYCAAG3dulWjRo3Spk2bVFBQoEmTJjmcHp8yZYqeffbZS9a2d+9epaWl6eWXXy5xPUdpTrV7o0ZJev/99+Xn51fioufL1XnhRemFhYXKyspSQECAWrdu7fCRXEhIiI4dO6YvvvhCnTp1crqvkJAQ7dmzR8ePH7efpSmN9u3bO3y0dClhYWGl3i9KImtkzVNZmzBhgj766CPdfffdmjdvnurWravFixfbLyX4448/Sl1XVXHXXXdpypQpSklJ0cCBA5WSkuL0jGax2rVr2/+7+OzZLbfconfeecdhu7CwMCUlJemee+7RLbfcon379mnjxo0KCgoqVV0RERH2j2olKSgoSPfff7+ef/55ZWRkuPxdqFatmpYuXar27dsrJiZGX375pWbMmOFwdn/VqlW65ZZbVK9ePYdc9u3bV88995x27Nhhv1SnNNatW6fw8HCNGDHCPlanTh099NBDevzxx0u9H09avnx5qX7fr7rqKrf3PXHiRH377bf6+OOPHa719QafazaTkpLUqlUr1ahRQ6GhoWrdunWJj29q1KihJk2aOIwdOnRI2dnZaty4sdP9njx5UpJ05MgRSSrxkU6jRo2cfgx0oeKPGdu2bVv6H8jLNRbXGRERofr167tVX/G1Z4sXL1ZaWprDRwEXfrT6xBNPaNOmTercubNatmyp/v37a9SoUerWrZt9mxdeeEFxcXGKjIxUdHS0YmNjdf/99182YPXq1SvRBMEaZI2seSprMTExWrhwoZ588kn7R/ctW7bUvHnz9PjjjysgIMAjr+NLGjVqpL59+2rFihU6ffq0CgsLHZqmi6WkpGju3Lnat2+fwzWJzt7UjBw5Uv/1X/+ljz/+WA899JD69OlT6rpatmxZYp+tWrWSJP3000+XfOPRokULPfPMM5o+fbratm2rp556ymH9oUOHtH//fpc3axbnsrSOHDnitN4Lrx32tguz6Unz58/X66+/rjlz5pTqcghP87lms3Pnzi6vcypms9lK/FEsKipS48aNtXz5cqfPqQx3Ilf2Gp999lk99dRTeuCBBzRnzhz7dVpTpkxxuHj7mmuu0cGDB5WSkqL169fr/fff1+LFi/X0009r1qxZks6/a7/lllu0Zs0affrpp5o/f76ef/55ffDBB/ZrlJwpKCjQr7/+Wqp6GzVqpOrVq5fvh67CyFrF8cWs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",
      "text/plain": [
       "<Figure size 800x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i, res in enumerate(adv_examples):\n",
    "    fig, ax = plt.subplots(1, 3, figsize=(8, 3))\n",
    "    ax[0].imshow((res[\"base_example\"]).reshape((28,28)), cmap=\"binary\")\n",
    "    base_class = np.argmax(at.eval(res[\"base_example\"])[0])\n",
    "    ax[0].set_title(f\"Predicted class = {base_class}\")\n",
    "    adv_class = np.argmax(at.eval(res[\"adv_example\"])[0])\n",
    "    ax[1].imshow((res[\"adv_example\"]).reshape((28,28)), cmap=\"binary\")\n",
    "    ax[1].set_title(f\"Predicted class = {adv_class}\")\n",
    "    ax[2].imshow((res[\"adv_example\"]-res[\"base_example\"]).reshape((28,28)))\n",
    "    max_diff = np.max(np.abs(res[\"base_example\"]-res[\"adv_example\"]))\n",
    "    ax[2].set_title(f\"Max pixel diff. = {int(max_diff)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "84a1d216-7569-4e44-965b-5cf35564e61b",
   "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.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
