{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "06ea7ab5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import networkx as nx\n",
    "import experiments\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import copy\n",
    "matplotlib.rcParams['figure.figsize'] = (4.0,4.0)\n",
    "matplotlib.rcParams['font.family'] = ['serif']\n",
    "matplotlib.rcParams['text.usetex'] = True\n",
    "matplotlib.rcParams['font.size'] = 18.0\n",
    "path = 'plots/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7e3a4364",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 4039\n",
    "g = experiments.AdjacencyListGraph(n, 'graphs/facebook_combined.txt')\n",
    "M = g.get_adj_matrix()\n",
    "G = nx.Graph(M)\n",
    "graph_test = experiments.GNPGraph(30, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "08e24994",
   "metadata": {},
   "outputs": [],
   "source": [
    "CB_color_cycle = ['#377eb8', '#ff7f00', '#4daf4a',\n",
    "                  '#f781bf', '#a65628', '#984ea3',\n",
    "                  '#999999', '#e41a1c', '#dede00']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "de30e007",
   "metadata": {},
   "outputs": [],
   "source": [
    "comms = nx.community.greedy_modularity_communities(G)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "141c1027",
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_names = ['Inf 1 Rand', 'Def 1 Rand', 'Inf 1 Friend', 'Def 1 Friend', \n",
    "               'Inf 5 Rand', 'Inf 20 Rand', 'Def 5 Comm', 'Def 20 Comm', \n",
    "               'Inf+Def 5 Comm', 'Inf+Def 20 Comm', '2 Inf 5 Comm', '2 Def 5 Comm',\n",
    "                'Inf 5 Def 5 Comm', '2 Inf 20 Comm', '2 Def 20 Comm', 'Inf 20 Def 20 Comm',\n",
    "                'Def Big Comm']\n",
    "attack_names_short = {attack_names[d]: 'A%d' % d for d in range(0, len(attack_names))}\n",
    "def gen_attacks(n, n_mal, t1, t2, comm):\n",
    "    attacks = []\n",
    "    attacks.append( [[1, 0, n_mal-1, 'Random']])\n",
    "    attacks.append( [[0, 1, n_mal, 'Random']])\n",
    "    #an attack where no one is his friend\n",
    "    attacks.append( [[1, 0, n_mal-1, 'Friends']])\n",
    "    attacks.append( [[0, 1, n_mal, 'Friends']])\n",
    "    \n",
    "    #Try m = 1%, 5%, 10%, 15%, ..., 35%\n",
    "    attacks.append( [[t1, 0, n_mal-t1, 'Random']] )\n",
    "    attacks.append( [[t2, 0, n_mal-t2, 'Random']] )\n",
    "    attacks.append( [[0, t1, n_mal-t1, comm]] )\n",
    "    attacks.append( [[0, t2, n_mal-t2, comm]] )\n",
    "    \n",
    "    attacks.append( [[t1, t1, n_mal-t1, comm]] )\n",
    "    attacks.append( [[t2, t2, n_mal-t2, comm]] )\n",
    "    \n",
    "    attacks.append( [[t1, 0, n_mal//2-t1, comm], [t1, 0, n_mal//2-t1, comm]] )\n",
    "    attacks.append( [[0, t1, n_mal//2, comm], [0, t1, n_mal//2, comm]] )\n",
    "    attacks.append( [[t1, 0, n_mal//2-t1, comm], [0, t1, n_mal//2, comm]] )\n",
    "    attacks.append( [[t2, 0, n_mal//2-t2, comm], [t2, 0, n_mal//2-t2, comm]] )\n",
    "    attacks.append( [[0, t2, n_mal//2, comm], [0, t2, n_mal//2, comm]] )\n",
    "    attacks.append( [[t2, 0, n_mal//2-t2, comm], [0, t2, n_mal//2, comm]] )\n",
    "    \n",
    "    attacks.append( [[0, int((len(comm)-t1)*0.25), t1, comm]] )\n",
    "    \n",
    "    return attacks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "18b24da7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def collect_data(attacks, attack_names, g, g_name, max_adv, epsilon, thresh_values, attack_values, reps):\n",
    "    #labels = ['RR+Laplace, Response', 'RR+Laplace, Input', 'RR, Response', 'RR, Input', 'Naive, Response', 'Naive, Input']\n",
    "    labels = ['RR+Laplace, Response', 'RR, Response', 'Naive, Response']\n",
    "    E = [experiments.ResponseLaplaceManipulation(g, max_adv, epsilon, 1e-6, 0.1, [0.7, 0.5], [0.8, 0.5, 0.3]), \n",
    "         #experiments.InputLaplaceManipulation(g, max_adv, epsilon, 1e-6, 0.1, [0.7, 0.5], [0.8, 0.5, 0.3]),\n",
    "         experiments.ResponseRRManipulation(g, max_adv, epsilon, 1e-6, [0.7], [0.8, 0.5]),\n",
    "         #experiments.InputRRManipulation(g, max_adv, epsilon, 1e-6, [0.7], [0.8, 0.5]),\n",
    "         experiments.ResponseRRNaiveManipulation(g, max_adv, epsilon, 1e-6, [0.7], [0.8, 0.5])\n",
    "         #experiments.InputRRNaiveManipulation(g, max_adv, epsilon, 1e-6, [0.7], [0.8, 0.5])\n",
    "        ]\n",
    "    \n",
    "    data = []\n",
    "    for x in range(0, reps):\n",
    "        for av in attack_values.keys():\n",
    "            for a_i in range(0, len(attacks)):\n",
    "                A = copy.deepcopy(attacks[a_i])\n",
    "                if av == 'strong':\n",
    "                    for a in A:\n",
    "                        a[1] *= 3\n",
    "                for i in range(0, len(E)):\n",
    "                    E[i].reset_attacks()\n",
    "                E[0].add_attacks(A)\n",
    "                for i in range(1, len(E)):\n",
    "                    E[i].set_attacks_like(E[0])\n",
    "                for tv in thresh_values.keys():\n",
    "                    for i in range(0, len(E)):\n",
    "                        E[i].threshold_reduction = thresh_values[tv]\n",
    "                        E[i].inflation_factors = attack_values[av]\n",
    "                        d = E[i].get_results(False)\n",
    "                        h = {'Protocol': labels[i], 'Attack': attack_names[a_i], 'Attack Strength': av, 'Threshold Strength': tv, 'Eps': epsilon, 'Graph': g_name,\n",
    "                            'Mal Max Error': d[0][0], 'Mal L2 Error': d[0][1], 'Mal Mean Error': d[0][2], 'Mal T Nan': d[1][0], 'Mal T Tot': d[1][1], 'Mal Nan': d[2],\n",
    "                            'Hon T Max Error': d[3][0], 'Hon T L2 Error': d[3][1], 'Hon T Mean Error': d[3][2], 'Hon T Nan': d[4][0], 'Hon T Tot': d[4][1],\n",
    "                            'Rest Max Error': d[5][0], 'Rest L2 Error': d[5][1], 'Rest Mean Error': d[5][2], 'Rest Nan': d[6][0], 'Rest Tot': d[6][1]\n",
    "                        }\n",
    "                        data.append(h)\n",
    "    return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "242af26f",
   "metadata": {},
   "outputs": [],
   "source": [
    "thresh_values = {'med': (0.9, 0.5, 0.5)}\n",
    "attack_values = {'med': (0.1, 0.1), 'strong': (0.4, 0.4)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "13dc5c9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "atx = gen_attacks(g, 120, 5, 20, list(comms[1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "3268d4e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Automatic pdb calling has been turned ON\n"
     ]
    }
   ],
   "source": [
    "%pdb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "98e030a6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = collect_data(atx, attack_names, g, 'FB', 120, 2.0, thresh_values, attack_values, 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "db359597",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "#pickle.dump(df, open('df1.pkl', 'wb'))\n",
    "df = pickle.load(open('df1.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "cd28b3b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "D = pd.DataFrame(df).drop('Graph', axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "149cb7c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "dat = D.groupby(['Protocol', 'Threshold Strength', 'Attack', 'Attack Strength']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "1c1eb49e",
   "metadata": {},
   "outputs": [],
   "source": [
    "#lab = dat.index.get_level_values('Protocol').unique()\n",
    "lab = ['Naive, Response', 'RR, Response', 'RR+Laplace, Response']\n",
    "attack = dat.index.get_level_values('Attack').unique()\n",
    "attack_strength = dat.index.get_level_values('Attack Strength').unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "84b5e324",
   "metadata": {},
   "outputs": [],
   "source": [
    "inf_attack = [a for a in attack if 'Inf' in a]\n",
    "def_attack = [a for a in attack if 'Def' in a]\n",
    "best_inf_attacks = []\n",
    "best_def_attacks = []\n",
    "best_attacks = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "fc3fdf1f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "plots/fb_inf_strong.pdf\n",
      "plots/fb_def_strong.pdf\n",
      "plots/fb_tot_strong.pdf\n",
      "plots/fb_inf_med.pdf\n",
      "plots/fb_def_med.pdf\n",
      "plots/fb_tot_med.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "def plot_data(dat, attacks, s, err, y_lab, name):\n",
    "    if isinstance(name, str):\n",
    "        fig, ax = plt.subplots()\n",
    "    else:\n",
    "        ax = name\n",
    "    graph_data = []\n",
    "    for a in attacks:\n",
    "        pts = []\n",
    "        for p in lab:\n",
    "            if err == 'rob':\n",
    "                pts.append(dat.loc[p, 'med', a, s]['Mal Max Error'])\n",
    "            elif err == 'acc':\n",
    "                pts.append(dat.loc[p, 'med', a, s]['Hon T Max Error'])\n",
    "            elif err == 'total':\n",
    "                pts.append(np.sqrt(dat.loc[p, 'med', a, s]['Hon T L2 Error'] ** 2 + dat.loc[p, 'med', a, s]['Mal L2 Error'] ** 2))\n",
    "        #ax.plot(pts, color=c, alpha=0.5)\n",
    "        graph_data.append([a] + pts)\n",
    "    PD = pd.DataFrame(graph_data).set_index(0)\n",
    "    bplot = ax.boxplot(PD, labels=['Naive', 'RR', 'RR+Laplace'], whis=(0,100))\n",
    "    for box, color in zip(bplot['boxes'], CB_color_cycle[0:3]):\n",
    "        box_x = []\n",
    "        box_y = []\n",
    "        for j in range(5):\n",
    "            box_x.append(box.get_xdata()[j])\n",
    "            box_y.append(box.get_ydata()[j])\n",
    "        box_coords = np.column_stack([box_x, box_y])\n",
    "        ax.add_patch(matplotlib.patches.Polygon(box_coords, facecolor=color))\n",
    "    for med in bplot['medians']:\n",
    "        med.set_color('k')\n",
    "    #pdb.set_trace()\n",
    "    PD['metric 1'] = (PD[2] + PD[3]) / 2\n",
    "    PD = PD.sort_values('metric 1')\n",
    "    worst_attacks = PD.iloc[-2:, :]\n",
    "    #ax.set_xticks([0,1,2], labels=['Naive', 'RR', 'RR+Laplace'])\n",
    "    #pdb.set_trace()\n",
    "    ax.set_ylabel(y_lab)\n",
    "    if isinstance(name, str):\n",
    "        print(name)\n",
    "        plt.savefig(name, bbox_inches = \"tight\")\n",
    "    return list(worst_attacks.index)\n",
    "\n",
    "best_inf_attacks += plot_data(dat, inf_attack, 'strong', 'rob', 'Malicious Target Error', path + 'fb_inf_strong.pdf')\n",
    "best_def_attacks += plot_data(dat, def_attack, 'strong', 'acc', 'Honest Target Error', path + 'fb_def_strong.pdf')\n",
    "best_attacks += plot_data(dat, attack, 'strong', 'total', 'L2 Error', path + 'fb_tot_strong.pdf')\n",
    "best_inf_attacks += plot_data(dat, inf_attack, 'med', 'rob', 'Malicious Target Error', path + 'fb_inf_med.pdf')\n",
    "best_def_attacks += plot_data(dat, def_attack, 'med', 'acc', 'Honest Target Error', path + 'fb_def_med.pdf')\n",
    "best_attacks += plot_data(dat, attack, 'med', 'total', 'L2 Error', path + 'fb_tot_med.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "611be352",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: [Eps, Mal Max Error, Mal L2 Error, Mal Mean Error, Mal T Nan, Mal T Tot, Mal Nan, Hon T Max Error, Hon T L2 Error, Hon T Mean Error, Hon T Nan, Hon T Tot, Rest Max Error, Rest L2 Error, Rest Mean Error, Rest Nan, Rest Tot]\n",
       "Index: []"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def get_honest_nans(dat):\n",
    "    return dat.iloc[ np.where(dat['Hon T Nan'] + dat['Rest Nan'] > 0)[0] ]\n",
    "get_honest_nans(dat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "c6607d45",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Protocol              Attack Strength\n",
       "Naive, Response       med                0.0000\n",
       "                      strong             0.0000\n",
       "RR+Laplace, Response  med                0.0000\n",
       "                      strong             0.8680\n",
       "RR, Response          med                0.0000\n",
       "                      strong             0.5035\n",
       "Name: PCT Disq, dtype: float64"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#How many malicious users are being caught in both strong and weak attacks?\n",
    "def get_pct_disq(D):\n",
    "    X = D.copy()\n",
    "    X['PCT Disq'] = X['Mal T Nan'] / X['Mal T Tot']\n",
    "    return X[['Protocol', 'Attack Strength', 'PCT Disq']].groupby(['Protocol', 'Attack Strength']).mean()['PCT Disq']\n",
    "get_pct_disq(D)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2c6f76a3",
   "metadata": {},
   "source": [
    "## EuGraph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "4475b605",
   "metadata": {},
   "outputs": [],
   "source": [
    "eu = experiments.AdjacencyListGraph(n, 'graphs/eucore/email-Eu-core.txt')\n",
    "comms_eu = {}\n",
    "with open('graphs/eucore/email-Eu-core-department-labels.txt') as f:\n",
    "    for line in f:\n",
    "        arr = line.split(' ')\n",
    "        idx, c = int(arr[0]), int(arr[1])\n",
    "        if c in comms_eu:\n",
    "            comms_eu[c].append(idx)\n",
    "        else:\n",
    "            comms_eu[c] = [idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "f14986d3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(1, 65),\n",
       " (21, 61),\n",
       " (25, 6),\n",
       " (14, 92),\n",
       " (9, 32),\n",
       " (26, 9),\n",
       " (4, 109),\n",
       " (17, 35),\n",
       " (34, 13),\n",
       " (11, 29),\n",
       " (5, 18),\n",
       " (10, 39),\n",
       " (36, 22),\n",
       " (37, 15),\n",
       " (7, 51),\n",
       " (22, 25),\n",
       " (8, 19),\n",
       " (15, 55),\n",
       " (3, 12),\n",
       " (29, 5),\n",
       " (20, 14),\n",
       " (16, 25),\n",
       " (38, 13),\n",
       " (27, 10),\n",
       " (13, 26),\n",
       " (6, 28),\n",
       " (0, 49),\n",
       " (28, 8),\n",
       " (2, 10),\n",
       " (40, 4),\n",
       " (35, 13),\n",
       " (23, 27),\n",
       " (19, 29),\n",
       " (24, 6),\n",
       " (32, 9),\n",
       " (31, 8),\n",
       " (39, 3),\n",
       " (12, 3),\n",
       " (30, 4),\n",
       " (41, 2),\n",
       " (18, 1),\n",
       " (33, 1)]"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[(c, len(comms_eu[c])) for c in comms_eu]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "94246d6a",
   "metadata": {},
   "outputs": [],
   "source": [
    "thresh_values = {'med': (1.0, 0.5, 0.5)}\n",
    "attack_values = {'med': (0.10, 0.10), 'strong': (0.30, 0.30)}\n",
    "atx_eu = gen_attacks(eu, 60, 5, 20, list(comms_eu[4]) + list(comms_eu[14]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "893e9b9d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df_eu = collect_data(atx_eu, attack_names, eu, 'EU', 60, 2.0, thresh_values, attack_values, 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "37be85a2",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'pickle' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[58], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m#pickle.dump(df_eu, open('df2.pkl', 'wb'))\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m df_eu \u001b[38;5;241m=\u001b[39m \u001b[43mpickle\u001b[49m\u001b[38;5;241m.\u001b[39mload(\u001b[38;5;28mopen\u001b[39m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdf2.pkl\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mrb\u001b[39m\u001b[38;5;124m'\u001b[39m))\n",
      "\u001b[0;31mNameError\u001b[0m: name 'pickle' is not defined"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "> \u001b[0;32m/var/folders/16/n_zry7nd6lq5yjz8b66f969m0000gn/T/ipykernel_96141/1432945881.py\u001b[0m(2)\u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m      1 \u001b[0;31m\u001b[0;31m#pickle.dump(df_eu, open('df2.pkl', 'wb'))\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m----> 2 \u001b[0;31m\u001b[0mdf_eu\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpickle\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'df2.pkl'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'rb'\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\n",
      "ipdb> q\n"
     ]
    }
   ],
   "source": [
    "#pickle.dump(df_eu, open('df2.pkl', 'wb'))\n",
    "df_eu = pickle.load(open('df2.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "1e6ff581",
   "metadata": {},
   "outputs": [],
   "source": [
    "dat_eu = pd.DataFrame(df_eu).drop('Graph', axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "a9fece37",
   "metadata": {},
   "outputs": [],
   "source": [
    "dat_eu = dat_eu.groupby(['Protocol', 'Threshold Strength', 'Attack', 'Attack Strength']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "dc6ea8dc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "plots/eu_inf_strong.pdf\n",
      "plots/eu_def_strong.pdf\n",
      "plots/eu_tot_strong.pdf\n",
      "plots/eu_inf_med.pdf\n",
      "plots/eu_def_med.pdf\n",
      "plots/eu_tot_med.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "best_inf_attacks += plot_data(dat_eu, inf_attack, 'strong', 'rob', 'Malicious Target Error', path + 'eu_inf_strong.pdf')\n",
    "best_def_attacks += plot_data(dat_eu, def_attack, 'strong', 'acc', 'Honest Target Error', path + 'eu_def_strong.pdf')\n",
    "best_attacks += plot_data(dat_eu, attack, 'strong', 'total', 'L2 Error', path + 'eu_tot_strong.pdf')\n",
    "best_inf_attacks += plot_data(dat_eu, inf_attack, 'med', 'rob', 'Malicious Target Error', path + 'eu_inf_med.pdf')\n",
    "best_def_attacks += plot_data(dat_eu, def_attack, 'med', 'acc', 'Honest Target Error', path + 'eu_def_med.pdf')\n",
    "best_attacks += plot_data(dat_eu, attack, 'med', 'total', 'L2 Error', path + 'eu_tot_med.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "4fc45e95",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Protocol              Attack Strength\n",
       "Naive, Response       med                0.000\n",
       "                      strong             0.000\n",
       "RR+Laplace, Response  med                0.000\n",
       "                      strong             0.704\n",
       "RR, Response          med                0.000\n",
       "                      strong             0.402\n",
       "Name: PCT Disq, dtype: float64"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_pct_disq(pd.DataFrame(df_eu))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "4052279e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: [Eps, Mal Max Error, Mal L2 Error, Mal Mean Error, Mal T Nan, Mal T Tot, Mal Nan, Hon T Max Error, Hon T L2 Error, Hon T Mean Error, Hon T Nan, Hon T Tot, Rest Max Error, Rest L2 Error, Rest Mean Error, Rest Nan, Rest Tot]\n",
       "Index: []"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_honest_nans(dat_eu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "335c0375",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>RR+Laplace, Response</th>\n",
       "      <th>med</th>\n",
       "      <th>Inf 1 Friend</th>\n",
       "      <th>strong</th>\n",
       "      <td>2.0</td>\n",
       "      <td>228.603795</td>\n",
       "      <td>228.603795</td>\n",
       "      <td>228.603795</td>\n",
       "      <td>0.6</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.666823</td>\n",
       "      <td>326.199371</td>\n",
       "      <td>5.024784</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                      Eps  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength        \n",
       "RR+Laplace, Response med                Inf 1 Friend strong           2.0   \n",
       "\n",
       "                                                                      Mal Max Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                  \n",
       "RR+Laplace, Response med                Inf 1 Friend strong              228.603795   \n",
       "\n",
       "                                                                      Mal L2 Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                 \n",
       "RR+Laplace, Response med                Inf 1 Friend strong             228.603795   \n",
       "\n",
       "                                                                      Mal Mean Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                   \n",
       "RR+Laplace, Response med                Inf 1 Friend strong               228.603795   \n",
       "\n",
       "                                                                      Mal T Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                 0.6   \n",
       "\n",
       "                                                                      Mal T Tot  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                 1.0   \n",
       "\n",
       "                                                                      Mal Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength            \n",
       "RR+Laplace, Response med                Inf 1 Friend strong               0.0   \n",
       "\n",
       "                                                                      Hon T Max Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                    \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                       0.0   \n",
       "\n",
       "                                                                      Hon T L2 Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                   \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                      0.0   \n",
       "\n",
       "                                                                      Hon T Mean Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                     \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                        0.0   \n",
       "\n",
       "                                                                      Hon T Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                 0.0   \n",
       "\n",
       "                                                                      Hon T Tot  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                 0.0   \n",
       "\n",
       "                                                                      Rest Max Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                   \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                12.666823   \n",
       "\n",
       "                                                                      Rest L2 Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                  \n",
       "RR+Laplace, Response med                Inf 1 Friend strong              326.199371   \n",
       "\n",
       "                                                                      Rest Mean Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                    \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                  5.024784   \n",
       "\n",
       "                                                                      Rest Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength             \n",
       "RR+Laplace, Response med                Inf 1 Friend strong                0.0   \n",
       "\n",
       "                                                                      Rest Tot  \n",
       "Protocol             Threshold Strength Attack       Attack Strength            \n",
       "RR+Laplace, Response med                Inf 1 Friend strong             3919.0  "
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dat.iloc[ np.where(dat_eu['Mal Nan'] > 0)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "51fb2266",
   "metadata": {},
   "outputs": [],
   "source": [
    "gnp = experiments.GNPGraph(4000, 0.5)\n",
    "comms_gnp = np.random.choice(range(0, 4000), 800, replace=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "062cdd3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "thresh_values = {'med': (0.9, 0.5, 0.5)}\n",
    "attack_values = {'med': (0.10, 0.10), 'strong': (0.4, 0.4)}\n",
    "atx_gnp = gen_attacks(gnp, 120, 5, 20, list(comms_gnp))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "e63df90c",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df_gnp = collect_data(atx_gnp, attack_names, gnp, 'GNP', 120, 2.0, thresh_values, attack_values, 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "a93d0419",
   "metadata": {},
   "outputs": [],
   "source": [
    "#pickle.dump(df_gnp, open('df3.pkl', 'wb'))\n",
    "df_gnp = pickle.load(open('df3.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "8e691f0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "dat_gnp = pd.DataFrame(df_gnp).drop('Graph', axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "bf19854b",
   "metadata": {},
   "outputs": [],
   "source": [
    "dat_gnp = dat_gnp.groupby(['Protocol', 'Threshold Strength', 'Attack', 'Attack Strength']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "a02f3d0f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "plots/gnp_inf_strong.pdf\n",
      "plots/gnp_def_strong.pdf\n",
      "plots/gnp_tot_strong.pdf\n",
      "plots/gnp_inf_med.pdf\n",
      "plots/gnp_def_med.pdf\n",
      "plots/gnp_tot_med.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAakAAAFnCAYAAAAczrafAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAuVElEQVR4nO3dz28bZ5on8K+cwQj2xmaJysxiGjFaLMYN+TKJilRfcrOK6WunTUo5+GgVx7dBEIvioTEwBhiZGh9mL5uQUm65iKS9A+xeLNL6AyKRcncfbLTDIgdpZLCzVrFIZy140C3uQVvVovlDRVVRKrG+H0BIWPXW+760VHxY9T71vmOtVqsFIiIiF7pw1h0gIiLqhUGKiIhci0GKiIhci0GKiIhci0GKiIhci0GKiIhci0GKiIhc6y/OugNec3BwgB9++AGXL1/G2NjYWXeHiMi2VquFV69e4Sc/+QkuXHD22odB6pT98MMPuHr16ll3g4jIcd9//z3ef/99R+tkkDplly9fBnD4y7xy5coZ94aIyL5ms4mrV6+an29OYpA6ZcYtvitXrjBIEdFIGcYQBhMniIjItRikiIjItRikiIjItRikiIjItRikiIjItRikiIjItRikiIjItRikiIjItRikiIjItRikiIjItTgtEvX1+vVrPH/+vOf+/f191Go1TE1N4eLFiz3LTU9P49KlS8PoIhGNMAYp6uv58+cIhUK26ymVSpAkyYEeEZGXMEhRX9PT0yiVSj33P3v2DLdu3cI333yD69ev962HiGhQDFKEFy9e4NWrV0Nto9ctw8uXL+PatWtDbZuIzi8GKY/77W9/iw8//NB2Pbdu3Trxsb/5zW/wt3/7t7b7QESjh9l9Hve73/3urLvgij4QkTvxSsrjpqamAADBT5dw8b3TXdZ+/+X3qPyPVbMPRERvY5DyOCNt/OJ7V/Ff/uZsxob6pa4TkbcxSHnc69evAQD/99+/O9HxB3/8T7zR/zfGhf+KC3/xlwMdu//y+xO1SUTewSDlcUbWXfV//bcz68Ply5fPrG0icjcGKY/75S9/CeDkM0JYfU6qF6agE1E/DFIe99577+H27du267l+/TpnlCAixzEFnYiIXItBioiIXItBioiIXItBioiIXItBioiIXItBioiIXItBioiIXItBioiIXIsP81Jfr1+/7rlgIXA448TR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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZ4AAAFnCAYAAACW4S/eAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAseElEQVR4nO3dz2/bVro38K/bwTWS9zqi5V5c3KKeiajpIMYL3NaUPZvuYirdto1kd5FlRCG7F8XEtFYXsxlXRhbv6m0le3bZ2FIzi3fVSM4/YIvOzF04mFSUL3Ixg4tb07QybwIPptG7cMmxbP2gTIqyqe8HMFpRhzzHsanHh+c554w0Go0GiIiIfPLWoBtARETDhYGHiIh8xcBDRES+YuAhIiJfMfAQEZGvGHiIiMhXDDxEROSrnwy6AUHw5s0b/OlPf8LY2BhGRkYG3RwiItcajQZevnyJd999F2+95W0fhYHHA3/6058wOTk56GYQEXnuxYsXeO+99zy9JgOPB8bGxgAc/4CuXbs24NYQEblXr9cxOTlpf755iYHHA9bjtWvXrjHwEFGg9GP4gMkFRETkKwYeIiLyFQMPERH5ioGHiIh8xcBDRES+YuAhIiJfMfAQEZGvGHiIiMhXDDxEROQrBh4iIvIVl8wZQq9evcKzZ89avvf69Wvs7e3h+vXruHLlSttr3LhxA1evXu1XE4kowBh4htCzZ88Qi8VcXaNSqUCSJI9aRETDhIFnCN24cQOVSqXle7u7u7hz5w4ePnyIqampjtcgIjoPBp4hdPXq1a69lampKfZoiKgvmFxARES+YuAhIiJfMfAQEZGvGHiIiMhXDDxEROQrBh4iIvIVAw8REfmKgYeIiHzFwENERL668IHHNE2k02moqtqxXD6fh6qqiMfjiMVibcsnk0mk02lommZfv1wuI5lM2seIiKh/LuySOaqqQtd1zM7OolwuQ5bljmXT6TQURQFwHEySySTGx8dRq9UgCIJd1jRNFItF5PN5+5ggCCgUClwihojIBxc28GSzWfv/19fX25YrFotYWFiAKIr2MSuQjI+PI5lMolQq2e9JkgRVVe3ejSiKSCQSffgOiIiolQsbeJza2tpqGTgEQYCiKMjn8zBNs6nXI8tyxx4UERH1z4Uf4+kmn88jHo+3fM/ac2Z7e9vPJhERUQeXvsczMzPT9j3TNAEA4XDYp9YQudNpd1jA2Q6x3B2WLrpLH3hOjt+cVq1WAeBM0oCu6yiXy03lMplM0+O4To6OjnB0dGS/rtfrPbSYqD3uDkvD4NIHnk7y+byd6WbRdR2apjUd1zQNsVgMlUrFUfBZXl7Gr3/9a6+bS9Rxd1jA2Q6x3B2WLrrABh5VVSGKYlN2HAAUCoUzZSVJgiRJSKVSLd8/LZPJ4IsvvrBf1+t1TE5Oum80DT0nu8MC3CGWLrdABh5N05DP5x33YAAgHo8jnU47Kjs6OorR0VEXLSQiGl6XPqutlWQyic3Nzaa5Pd1YCQhcvYCIqL8CF3ji8ThyuVzLxxCdlt6xekaGYfSzeUREQy9QgccKLO0mh25sbEDX9ZbvWcc7pWcTEZF7gQk8KysrSCaTZ4LOydRpRVHaJg+USiWIouh4TIiIiM4nEIGnWCxCkqSWPR1N0+yxntnZ2ZZjONbCoacz4IiIyHuXIqvNNM22Yy+apiGXyyGZTDatOG2tWrC+vm7Pi0gkEkin00in001jQHNzc1AUhYuFEhH54MIGnpWVFWxtbUHXdfsrHo9DEAQsLCzYQWJubs7eU6eV05ltuVwOKysrWF9ftwNaJpNh0CEi8smFDTyLi4uOyh0cHPTt2kRE5L1AjPEQEdHlwcBDRES+YuAhIiJfMfAQEZGvGHiIiMhXDDxEROQrBh4iIvLVhZ3HQ+48f/4cL1++7Pm83d3dpv+ex9jYGN5///1zn09EwcbAE0DPnz/HL37xC1fXuHPnjqvz//jHPzL4EFFLDDwBZPV0op8u4so7vW3J/eZvf8WR+V8YFf4Zb/3kH3qu+/X3L1D93cq5eltENBwYeALsyjuT+B//0nuvY2zyf/ahNURExzxJLtjb2/PiMkRENARcB55bt24hGo2iXq970R4iIgo414EnHo/j8ePHuHbtmhftISKigPPkUdvc3FzXMplMxouqiIjoknMdeBRFwYMHD/D06dOO5XRdd1sVEREFgOustqWlJRiGgVwuB8MwIIoiwuFwUxnDMKBpmtuqiIgoAFwHnvX1dczMzOD27dttyxwcHLDHQ0READwIPKIo4vHjx13LnWeLaiIiCh7XYzyFQsFRuWw267YqIiIKANc9nkgkYv//kydPoGkatra2IIoifvnLX+LTTz89U46IiIaXJ0vm7O3tQVEUlMtlAIAgCDBNEwAQi8VQLBbxs5/9zIuqiIjokvMk8CQSCaTTaRQKBYRCIft4rVZDoVCALMuoVCqcZOqT169fH//3+xf+1/1jnVYbiIhOcx14Hjx4gEKh0PJRWiQSweLiImRZxvLyMpaXl91WRw5Ya+dVf7cy0DZ89NFHA6ufiC4u14Gn0Wh0Hb+RJAmbm5tuqyKHrl+/DuB82yK4ZW2LYLWBiOg014FnfHzcUbmRkRG3VZFDV65cOf7vObdF8LINRESnuU6ntpIIutnf33dbFRERBYDrwBOJRLC2ttaxTCaTQTQadVsVEREFgOtHbbdv38b8/DxyuRw+//xzTE9PAzjuCem6jlwuB0mSmFhAREQAPEqn3tjYQD6fx9LSEkzTxMjICBqNBoDjFQvu37/vRTVERBQAngQe4Hh7BEVRUKvVoOs6RFHkagVERHSGZysXWOmzkUiEAYeIiNpynVxw69YtRKNR1Ot1L9pDREQB57rHE4/Hoaoql8Mhcuj58+d4+fLluc7d3d1t+m+vxsbG8P77g5nbRWTx5FHb3Nxc1zKZTIaZbTT0nj9/jl/84heur3Pnzp1zn/vHP/6RwYcGynXgURQFDx48gCzL+PDDD9uW4w6kRLB7Og8/Bab+qffzX/8N2DOB6wJwpce7d/e/gTu/w7l7W0RecR14lpaWYBgGcrkcDMOAKIoIh8NNZQzDgKZp57q+aZpQVRWCIHTcTK5cLqNUKiEajdqrKSwuLrouS9QPU/8ESP9yvnM/8nf5PSLPuQ486+vrmJmZwe3bt9uWOTg46LnHo6oqdF3H7OwsyuUyZFluW7ZYLGJ9fb1pN9RyuYx4PI5SqXTuskRE5D3XgUcURTx+/LhruYODg56ue7J3s76+3racaZpIpVKo1WpNx2VZhqqqyOfzUBSl57JERNQfrtOpT/YcOun0mMyNjY0NiKIIQRDOvLewsIBcLneuskRE1B+eLBJqbTzWrVw/FAqFM2NKFlEUoWmaPY7TS1kiIuqPSz+BdHt7G6IotnzPOm6NL/VSloiI+sN14InH43j8+PHAJpCaptny0dlJVjDppSwREfWH68ADOJ9A6jcryBiG4WnZo6Mj1Ov1pi8iInLGdeCxJpA+ffq0Y7kg9SSWl5cRCoXsr8lJTqwgInLqwk8gdcNKFGiXUHDesplMBl988YX9ul6vM/gQETl0YSeQXmSjo6MYHR0ddDOIiC6lCzuBtJf62wU1a7zGyljrpSwREfXHpZ9AKklS27k3VpCRJKnnskRE1B+eTCD1slyv4vF4215MtVptWuOtl7JERNQfPT9qq9fr0HXdfjR18+bNpvcPDw+Rz+exv7+Pw8NDCIKAaDSKmZmZjtsmnNf8/Ly9oOjpx2TFYrGpp9VLWSIi6g/HPZ6f//znePvttzE3N4ft7W2Mj4+fCToAEAqFcP/+fXz55Zf46quvEIlEoCgKZmZmzt1I0zTbzq8RBAGrq6tQVbXpeLFYhCiKSCQS5ypLRET94bjHYxgGUqkUvv76654qsFZ7vnfvXk/nraysYGtrC7qu21/xeByCIGBhYaEpSCQSCQiCAFVVm/bYabXNQS9lL6tXr14BAP7fn7/r+dw3f/srjsz/wqjwz3jrJ//Q8/mvv3/R8zlENFxGGo1Gw0nBcDjsaFZ/v86/yOr1OkKhEA4PDwe2dNBJa2trSKVSA20Dt1duTdM0xGIxVJTzbwR37rr/DMTyQKVSYRINddXPzzXHPZ5Wj8rarVYgiuKZhrp51Ea9+eSTTwAAN27cwNWrV3s6d3d3F3fu3MHDhw8xNTV1rvrHxsYYdIioLceBZ3x8/MyxRqMBXdehqipqtRoURUEymWw5F6bV+dQf77zzDu7evevqGlNTU/yrmIj6wtUE0unpaUxPTyMSiWB+fh5fffWVV+0iIqKAcr1yAXA86ZIz/om6e/36NQBg93v/67bqtNpANCieBB4AXfe5ISLYu/XeeTTYNnz00UeDawANPceBp9uW0CMjI67OJxoG169fBwA8/AyYesffune/Pw54VhuIBsVx4Nna2sLExETb903T7Po+0bC7cuUKgOOg43c69ek2EA1KT4/aIpGIo/1qTtvf3++6URwREQ2HnubxONn+oJ1bt26d+1wiIgoOx2u1xeNxVxW5PZ+IiILBceC5f/++q4rcnk9ERMHgej8eIiKiXjDwEBGRrxh4iIjIVww8RETkKwYeIiLyFQMPERH5ioGHiIh8xcBDRES+YuAhIiJfud6PZ29vr+Uy69988w10XcfIyAgkScLNmzfdVkVERAHgOvCoqor19fUzx2/fvm3//87ODtbW1nD37l231RFdaq9evQIAaH8+3/mv/wbsmcB1AbjS4927+9/nq5PIa64DT6PR6FpmenoalUrFbVVEl96zZ88AAKn/O7g2jI2NDa5yIngQeLrtPAoA9XodlUqFPR4aep988gkA4MaNG7h69WrP5+/u7uLOnTt4+PAhpqamej5/bGwM77//fs/nEXmpp8Czs7ODXC5nj90AwPb2Nj7++OOW5Q3DgGma0HUdhULBfWuJLrl33nnHkz/ApqamIEmSBy0i8l9PgWd6ehpff/01AKBYLEJRFExMTCASibQsH4lEEI1GIcsypqen3beWiIguvXM/akskEpAkCUtLS3YwIiIi6sbVPB5RFLmzKBER9cT1BNJUKgXgeD7P2toaMpmM/d7h4SGePHnitgoiIgoQT1YuWFpagiiKWFxcRD6ft4+HQiGMj4/jwYMHXlRDREQB4DrwrK6uQtd1VKtVGIbRFHiA44SEVCqFtbU1t1UREVEAuJ7HU61WsbGxYb9uNa/H6vkQERG57vFEo9Gm1+1WMqjVam6rIiKiAHAdeJysXAAc94yIiIhcB56DgwM8evTIft0qEN27dw+xWMxtVUREFACux3ju37+PmZkZLC8vY2FhAdVqFYIgwDRNbG1tIZ/PQ5ZlrtNGREQAPAg8wPF6bSsrK1hcXAQA5PN5NBoNCIKAbDZrz/Whi+HVq1f2Ksmn7e7uNv23nfMucklEhIbHdF1vlMvlhq7rXl+6rUql0kgkEo1qteqofCKRaCiK0qhUKo1Go9E4ODholEqlRiKRsI/14vDwsAGgcXh42PO5g1CpVBoAXH2d59+J3LN+dvz3p37r5+ea6x7PrVu3MD8/bz9Ki0QibRcNffToEX7zm99gYmIC2WwWH374odvqAQC6rqNYLKJYLHYsV61WIYoiTNNEsVhsmnMkCAIKhcJQrPh748aNtvsjvX792t5V9sqVKx2vQUR0Hq4DTzKZdDR+s7Ozg7t372J1dRWhUAiqqqJQKODatWtum4CtrS0oinImtduyv78P4HhtOQCQJAmqqkLTNPt4IpFw3Y7L4urVqx0D7EcffeRja4ho2HgyxgMc92bW19chiiI+//xzfPDBB03vLy0tIZvN2ltiR6NR5PN5/OpXv/Kk/lwu1/Y9VVWRzWabjsmyDFmWPambiIic82SR0HA4jEQigWq1aj+u+u1vf9tUbnt7u2kl60gk4mjbbCdmZ2fbvpfP55FOpz2ph4iI3HMdeNbW1pDNZvHmzRtsb2/ju+++w/7+Pr799lvU63W7nGmauH79etO5giC4rR4A2j4m03UdwN8fsRER0eC5ftT23Xff4csvv2w6ZqVRl8tlfPbZZzg8PGx5rtNVD84rm822fQSn6zrK5bL9ulqtIpPJOAqGR0dHODo6sl+fDLBEbnRKdQecpbsz1Z0uOteBZ2JiouXxkZGRro/STNN0W31bnR6x6boOTdOgKIp9TNM0xGIxVCqVrsFneXkZv/71r71sLhEA4NmzZ45W+bhz507b9yqVylBkZ9LlNdJwOdCyurqKw8PDpiSBvb09pNNpO2ttZ2cHsVgMb968aTp3aWnpTG/JK/F4HKVSqadzkskkAKBQKHQs16rHMzk5icPDQ0+y9Gh4devxOEl3Z4+HvFCv1xEKhfryuea6x5NKpTA/P4+3334boijCMAyYpolUKoVyuYz9/X1ks1lks1msra3ZqdePHj3qmBTgRj6fP9dffPF43FEiwujoKEZHR8/TNKKOuqW6A0x3p8vPk3TqjY0NlMtllMtlRKNRyLKMSCSCw8NDbG9vo1KpIBQKYWlpCQsLCwiHw9B1Hd9++60X1Z+Ry+XOpE87EQ6HARw/duOjCiKi/vBsHk+reTGhUAhzc3P26y+//BLffPMNDMPAV1995VXVTazxm3aZbOl02k5+OM0a2zEMoy9tIyIijwKP9czZCWsCab9YmWrtAs/GxkbbiaNW+vXMzEx/GkdERO7n8dy6dQvRaPTCpBS3W4PMoihK2+SBUqkEURQ9m19ERERnuQ488Xgcjx8/vjDZXLqudwwcs7Oz9hptJ1kLh55nbIiIiJxzHXgANI3jtJPJZLyoqivrcVk7iUQCuVzuTPCZm5uDoihDtVgoEdEguB7jURQFDx48gCzLHbc56BYQvCJJUteJqblcDisrK1hfX4dpmjAMA5lMhkGHiMgHrieQ3rt3D4ZhQNM0GIYBURTttGSL9f4PP/zgqrEXVT8nWhERDcKFnkC6vr6OmZmZjtlqBwcHvvV4iIjoYnMdeERRxOPHj7uWOzg4cFsVEREFgOvA02lds83NTdRqNczMzDBbjIiIAHiQ1RaJRNq+Nzc3h7t376LRaGBzc9NtVUREFACepFN3I4pi1xWfiYhoOHgSeJ48eYLZ2VlMTEyc+Xr77bcRDoebtr0mIqLh5XqMZ2dnB4lEAoqiQFEUVCoVxGIxhMNhGIaBSqWCeDze9zXaiIjocnAdePL5PGq1GkKhEIDjBTbHx8ftRUNTqRRqtRqePHmCmzdvuq2OiIguOdeP2iRJsoMOcLy1gLVCtCUSiXAeDxERAfAg8IyMjDS9jkQiXVeIJiKi4eU68FgTQ/f29vDkyRMAxxvA/fa3v20qVyqV3FZFREQB4HqttsPDQywvL6NYLOLg4AD7+/swTROiKOLnP/855ubmUC6XMTMz07ddRweNa7URUdD083PNceBZW1tDtVqFaZoQBAETExOQJMlOGNjZ2YEgCPaEUl3XkUwmsbOzg3g8jm+//dbThl8kDDxEFDQXIvCEw2HMzs7i66+/7rhawTBi4CGioLkwq1MXCgV+sBIRkSuOkwtmZmYYdIiIyDXHgUcQBFcV3bt3z9X5REQUDI4Dz+n5Or0yDMPV+UREFAyOx3h0Xcd//Md/YHx8vOdKrK2viYiIHAeearUKURT72RYiIhoCPWW13b9//1yVHBwcoFgsnutcIiIKFseBR5ZlfPnll+euqFarnftcIiIKDt+SC9xmxRERUTA4DjymabqqKJPJuDqfiIiCwXHgcbufzvT0tKvziYgoGBwHnv39/TNbHRAREfXKceAZHx9HKpXCwsICHj16hKdPn6Jer/ezbUREFEA9zeMBjvffMQwDpmnCMAyu30ZERD3paR4PcLy7aCgU6kdbiIhoCLje+pqIiKgXDDxEROQrBh4iIvIVAw8REfmKgYeIiHzFwENERL5i4CEiIl/1PI/nokomkwiHw0in05AkCaZpYnt7G7lcDplMBpIkNZUvl8solUqIRqP2AqiLi4sDaDkR0XBxHXj29vZw/fr1M8e/+eYb6LqOkZERSJKEmzdvuq2qI9M0USwWkc/n7WOCIKBQKJwJOsViEevr6ygUCvaxcrmMeDyOUqnU13YSEQ27kUaj0XBzgYWFBayvr3css7Ozg0qlgrt377qpqiNVVRGPx6FpGgBAFEUkEokz5UzTRCQSQa1WO7NHUCwWQzqdhqIoPdVdr9cRCoVweHjIJYSIKBD6+bnmusfjJG5NT0+jUqm4raorWZYhy3LHMhsbGxBFseXGdAsLC8jlcj0HHiIics51coGTnUnr9bovgceJQqGAcDjc8j1RFKFpmutN74iIqL2eejw7OzvI5XL22A0AbG9v4+OPP25Z3lrFWtf1pvGUQdre3sb8/HzL90RRBHC86d3pcSEiIvJGT4FnenoaX3/9NYDjAXpFUTAxMYFIJNKyfCQSQTQahSzLvuxAqus6yuWy/bparSKTyTQ9VjNNs+VjttPXYeAhIuqPc4/xJBIJSJKEpaUlOxgNkq7r0DStaXxG0zTEYjFUKpWuwQaAXcYwjI7ljo6OcHR0ZL/mhnhERM65GuMRRRHxeNyrtrhSKBTOZLFJkgRJkpBKpTyta3l52d6XKBQKYXJy0tPrExEFmevkgk4f6nt7e9jb23NbhSvxeBzFYtFRWSupoF3ygSWTyeDw8ND+evHihdtmEhENDdfp1EtLS6jVagiHw0gmk7h58yZ2dnYgyzLC4TCmp6cxMjLSda5Pv1hBRNM0z8ZtRkdHMTo66sm1iIiGjevAMzs7i2g02tTzSSaTmJubw8bGBgDg8PAQDx48wK9+9Su31bWUTqchCAKy2eyZ906P24iiCF3XW17nZBkiIuoP14GnVqs1BZRvvvkGtVrNXkEAgD0W0i8bGxttJ45aQWZmZgYA7HXcOpVlRhsRUf+4HuM5HVBKpRJEUfR16RhFUdrOE7LaY/V84vF42x5PtVrtuvIBERG54zrwTExMNL0ul8stP7y7Ddi7MTs729TDslgLh558BDc/Pw/DMFoGn2KxiHQ63bd2EhGRB4GnWq3a/7+zswNd15FMJpvKPH361NHSOueVSCSQy+XOBJ+5uTkoitKUZi0IAlZXV6GqalPZYrHYdmFRIiLyjuvVqWu1GlRVxcTEBNbX1yHLsp1UsLm5iUKhgEKhgM3NTXz44YdetLmtlZUV7O/vwzRNGIaBhYWFtoHEy/14uDo1EQVNPz/XXAce4DhrrVwuQxRFe2mcWq3WtHzNxMQEPvvsM7dVXUgMPEQUNBc+8ADHk0XL5TJ0XcdvfvMbAMcBqVKp9H0TuEFj4CGioOnn55rrMR7geBKpKIpYXFxELpezj4dCIYyPj+PBgwdeVENERAHgOvCsrq5C13VUq1UYhtG09TRwvKJ1KpXC2tqa26qIiCgAXE8grVardjIB0HpjOKvnQ0RE5LrHE41Gm163GzKq1WpuqyIiogDwZetroHm+DxERDS/Xgefg4ACPHj2yX7cKRPfu3UMsFnNbFRERBYAn6dQzMzMYGRnBwsICqtUqkskkTNPE1tYW8vk8ZFke2LYIfmA6NREFzaWYx7OysoKlpaXji46MoNFo2FsVeL0D6EXDwENEQXMpAo+lVqtB13WIoohIJOLlpS8sBh4iCpp+fq65Tqc+LRKJDE3AISKi3nmycoETCwsLflVFREQXmGc9nqdPn9pbR59mmmbL/XKIiGj4eLL1dSwWa7udtKWf+/EQEdHl4fpRm6qqWF1dxcHBAd68edP2a25uzov2EhHRJee6xzM7O4vbt293LRePx91WRUREAeC6x+N08c/79++7rYqIiALAdeBpNBqo1+tdy51cVoeIiIaX68CTSqWwsbGBp0+fdiwX5CVziIjIOddjPB9//DGA4yQD0zQhiiIEQWgqY5omdF13WxUREQWA68CztbUFWZaRSqUwMTHRssz333/PHUiJiAiAB4FHFMWmHUjb4UZwREQEeDDGUygUHJVbXV11WxUREQWA6x7PyQVBnzx5Ak3TsLW1BVEU8ctf/hKffvopACAUCrmtioiIAsCTtdr29vagKArK5TIAQBAEewmdWCyGYrGIn/3sZ15URUREl5wnq1MnEgkkk0l72RzDMPDmzRt7N1JZlh3N9SEiouBzvRHcgwcPcPv27Y578GiahkKhgOXlZTdVXVjcCI6Igqafn2uerFzQbeM3SZIQDofdVkVERAHg21pt3BaBiIgADwJPt314LPv7+26rIiKiAHAdeCKRSNdVCTKZDKLRqNuqiIgoAFwnFwDA/Pw8arUaPv/8c0xPTwP4+/psuVwOkiQFepFQJhcQUdD083PNk3k8GxsbyOfzWFpagmmaGBkZgRXPstks9+IhIiKbJz2ek2q1GnRdhyiKXbPdgoI9HiIKmgvf4zkpEokMTcAhIqLeOU4uuHfvnquK3J5PRETB4DjwuN3IjRvBERER0MOjtlKphLfffvvM7qJOOJ3r41Y+n0e1WoWmaTAMA7IsI5vNnimXTCYRDoeRTqchSRJM08T29jZyuRwymQwkSfKlvUREw8hx4BEEAaIotl36Znt7GzMzMy3f29/fx9OnT8/VQKdUVUU6nYaiKACOg10ymcT4+DhqtVpTwDRNE8ViEfl83j4mCAIKhQKDDhFRnzkOPLIsd9xpdH5+vuv7/VIsFrGwsABRFO1jViAZHx9HMplEqVSy35MkCaqqQtM0AMe7qCYSib61j4iI/s5x4Jmdne34fre12Lqd78bW1lbLwCEIAhRFQT6fh2maTb0eWZYhy3Lf2kRERK05Ti5wOwm0n5NI8/k84vF4y/disRiA40eBREQ0eJ5sBDdo7caWgL8nNnBbBiKii8HzCaSDcHL85rRqtQoAZ5IGdF23t+q2ymUyGUdZe0dHRzg6OrJfc3dVIiLnPJtA2m3lnUwm47QqT+XzeTvTzaLrOjRNg6Io9tfCwgJisZij1O/l5WWEQiH7a3Jysk+tJyIKHs8mkHZLLrAyyPykqipEUTwzl6dQKJxJRpAkCZIkIZVKdb1uJpPB4eGh/fXixQtP201EFGQ9TSCdmJho+75pml3f95Omacjn86hUKo4nvcbjcaTT6a7lRkdHMTo66rKFRETDqacJpJFI5FyD9H5MID0tmUxic3OzaW5PN9b3pmkaJ5ISEfWJZxNIu+nnBNLT4vG4vQHdael0GoIgtFxKx+oZGYbR7yYSEQ0tx2M8bieA9nMC6UnpdBqqqradHLqxsdF2vMo63ik9m4iI3PF8I7hBWllZgSRJZ4KOruvQdR2yLENV1Za9HeD48ZymaXYKtlPcCI6Igqafn2uBmEAKHK/X1iroAMdjNtZYz+zsbMsMO2vh0HZBiYiIvBGIHo+maVBVFclksum4lUm3vr6OSqViH0+n0/aWCJZYLIaZmRnkcrme62ePh4iCpp+fa4EIPOPj4x3TtUVRPPP4bGVlBfv7+zBNE4ZhYGFh4dwrVDPwEFHQMPBccAw8RBQ0HOMhIqLAYOAhIiJfMfAQEZGvGHiIiMhXDDxEROQrBh4iIvIVAw8REfmKgYeIiHzFwENERL5i4CEiIl8x8BARka8YeIiIyFcMPERE5CsGHiIi8hUDDxER+YqBh4iIfMXAQ0REvmLgISIiXzHwEBGRr34y6AYQEV0Gr169wrNnz9q+//r1a+zt7eH69eu4cuVK23I3btzA1atX+9HES4OBh4jIgWfPniEWi7m+TqVSgSRJHrTo8mLgISJy4MaNG6hUKm3f393dxZ07d/Dw4UNMTU11vM6wY+AhIjrh+fPnePnyZd+u3+lx3djYGN5///2+1X1RMPAQEf3oD3/4Az744ANX17hz546r83//+9/jX//1X11d46JjVhsR0Y/+/d//fdBNuBBt6Df2eIiIfnT9+nUAwPT/+gD/+N4/+lr3X/7zL9j537+32xBk7PEQEf2o0WgAAH7465uez/3hrz/gL//5F/zw1x9ctaFTKnZQsMdDRPQja+D/D/9ncI+7xsbGBla3Xxh4iIh+9MknnwA43yRPp+nUnTCrjYhoyLzzzju4e/euq2tMTU0N/QTRbjjGQ0REvmKPh4jIgW5rte3u7jb9tx2u1cbAQ0TkiNO12rpNIOVabQw8RESOdFurrZfVqYfdSMNKXKdzq9frCIVCODw8xLVr1wbdHCIi1/r5ucbkAiIi8tXQP2orl8solUqIRqMwTRMAsLi4ONhGEREF2FAHnmKxiPX1dRQKBftYuVxGPB5HqVQaYMuIiIJraB+1maaJVCqF1dXVpuOyLMMwDOTz+QG1jIgo2IY28GxsbEAURQiCcOa9hYUF5HI5/xtFRDQEhjbwFAoFhMPhlu+JoghN0+wxHyIi8s7QBp7t7W2IotjyPeu4rut+NomIaCgMbeAxTbPlY7aTGHiIiLw31Flt7VgByTCMlu8fHR3h6OjIfl2v1/1oFhFRIAxtj8eN5eVlhEIh+2tycnLQTSIiujTY42nBSipol3yQyWTwxRdf2K8PDw/x05/+lD0fIgoM6/OsH6uqMfCcw+joKEZHR+3X1g+IPR8iCpqXL18iFAp5es2hDTyiKLZNHrDGdtplvZ327rvv4sWLFxgbG8PIyIhnbRyEer2OyclJvHjxggueXkD8+VxcQfvZNBoNvHz5Eu+++67n1x7awCNJUtt5OlZAcrpnxltvvYX33nvPq6ZdCNeuXQvEzRNU/PlcXEH62Xjd07EMbXJBPB5v2+OpVquQZdnnFhERDYehDTzz8/MwDKNl8CkWi0in0wNoFRFR8A1t4BEEAaurq1BVtel4sViEKIpIJBIDatlgjY6O4t/+7d+akifo4uDP5+Liz8a5od+BlPvxEBH5a+gDDxER+WtoH7UREdFgMPAQEZGvGHiIiMhXQzuB9DJZWVlBqVRCuVwGAFQqlZaTW/P5PLLZLHRdhyAIkGUZhULB7+ZSB6d/lrIsn9meQxRFZDKZttt2eHGNfgna97eysoKtrS2Uy2WYpglJkuy6nU4w95ppmkgmk/Z9XqlUBtIOVxp0aSiK0hAEoSFJUsdykiQ1qtWqq7pEUWwoiuLqGtSeJEkNQRBavlcqlRqCIDSy2Wzfr9EvQfv+JElqXLSPy0Qi0fWz4KLio7ZLJBqNYnV1FZqmIZ/Pty0ny7LjdeY68fuv5WESDofbrn5u9VRVVe34c/biGv0StO8vHA5fuPthdnZ20E04NwaeSyaRSECSJKiq2natuYmJCdf1VKtVZLNZ19eh87GWbHLzM/DiGv0yyO8vn8/bj/FoMBh4LqFCoQDTNJFKpQbdFOojQRBcb7/uxTX6ZVDfX7VabftHG/mDgecSEkURi4uLKBaL/MstoEzThGmarhar9eIa/RL07486Y1bbJZXNZpHP55FOp1GtVh2dY5om8vm8/ay6UqkgnU6fyc6xVu4+mTGjqiqKxSJ0XYcoishms03r2a2srEBVVQiCAEVRmh5/rKys2HVWq1VEo1EoiuLiuw8+698yl8sN9Br9EvTvD3B2v+m6bmeozczMoFAo2GNW+/v7ME0Tqqr2NGbr9D63FItFbG1tYWJiAvv7+23vT0/v40FnN5BzpzN4SqVSA8CZ4+0yfRYXF5teHxwcNARBaJRKpTNlFUU5kzFzcHDQsj6LLMuNSqXSdEySpEahUGg6lkgkzrRl2Miy3BBFsenYwcFBo1QqNRKJRENRlMbBwUHfr9EvF/n7W1xcPPM72Y0sy20z7DrVc1Kn+02W5YYkSY1cLtd0vFKpNARBaNnebDbbMqutl3oXFxcbiUTiTPnT1/D6PmbguURafeDLstwA0JQ+3apcpVJpiKJ4Js16cXGx5S9vu1/qVgHp5LWcXKNarZ5p87CxPshyuZz9Zf0snKYIe3GNfrnI358fgafX+21xcbHt9bPZbEMQhDNBttX91Uu91h+up697+hr9uI85xnPJWY8Zuu0fJAhCy/2HotFoT4Oz6XQamqZB07Sm4+VyGQsLC03HVFU9cww4HqMSBGHox6fC4TAURbG/stksKpWK/bjDyQC4F9fol6B/f52c535r9zhNURT78ZmX9aqqikQicSZN3DAMGIbRVM7r+5hjPJecNd6iqirK5XLbgVZRFHFwcGC/1nUdpmn2POtZkiRIkoRcLtf0bF3TtKbtJKxf8mq1imKx2PJaTsemho01fqeq6rnHL7y4Rr/48f2l0+m2H4iGYdjntpJOp8+9NYppmhAEwbP7DTgOJoIgYGtrq2vZXurVNK3l54Usy/Y1+nUfM/AEwOLiInK5HJLJZNMv3WmmaWJ5eRmmaSIWi0GWZcRiMWxsbPRUXzqdbrrhrZvtJOsXNplMtvzlHtaN9pyamZnBxsaGq6DhxTX6pd/fX6frqqqK2dlZz38HTdPExsaGPeDu1f0GHAcUp08mnNRrXavbnL9+3cd81BYQuVzOzoBpRdd1RCIRRKNR5HI5KIoCURTbzgzvxOr6W38BnbzZLNZjg4v6KOQysNKFB32Nfgna92dlfFr/79X9dvra3co5qde61v7+fsfr9es+ZuAJCFmWkUgk7EUNT0smkxBF8UyAOPksF4Dj57WKomB5eRlA619K6/lvp8cDF+UD4yKyepBuJlh6cY1+CeL3t76+bn9Qe3m/WcHVyRI5vdTbrRdlmmbf7mMGnkuk218nq6urAFr/Mrd7nlupVJp+cZzexFaSQT6fbzuuZD2Hb0XTNGxvbzuqaxid/MvZ0usgrhfX6JegfX/W4L/VszjP/dbuA3x5eRmCIDgad+ql3mw2i2Kx2LJeXdftf8t+3McMPJdIt6yWTpPpZFk+c1Pquo54PA7g+Jde0zTMzMzY73f6S8ZaHj6Xy7WdmKYoCmRZPpNxZ5pmx0SIoDNNE7qu21+tWP9mpVLJPnYyk9CLa/RLEL+/0z2Gk6yxlJNjnee53wCcGcC3/rjb3NxsW/dJvdSbSCSgKAqSyeSZ6xaLRXv8ph/38Uij0Wj0fBb56vSqAYlEouPCiPF4vOlmtKTTaRiGYf8SiqIIWZbt/U+SySTm5+eRSqXs/UdkWUY2m227/w+ArrOX8/k8KpUKotEoRFGEYRhDu3KB9W9xkiAILX+e5XIZ2WwW8Xjc3l9JFEVPrtEvl+H76yW5oNveQLqu28FOEISm5B4n95t1H1hZqZubm9jY2EA4HIau6/ZivSfrNH9cp9G6RxOJBNLptB0AeqkXOA4ypVKp6/3p5X3MwENEQ6VfWW1uWIHnUm7qdg5MpyaiobKwsNDXXh91x8BDRENlUFtW098xuYCIaMCGbWoBAw8R0YBY2yJsbGxA0zQkk8kLk/LeT0wuICIiX7HHQ0REvmLgISIiXzHwEBGRrxh4iIjIVww8RETkKwYeIiLyFQMPERH5ioGHiIh89f8BlRIiOmfEA68AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "best_inf_attacks += plot_data(dat_gnp, inf_attack, 'strong', 'rob', 'Malicious Target Error', path + 'gnp_inf_strong.pdf')\n",
    "best_def_attacks += plot_data(dat_gnp, def_attack, 'strong', 'acc', 'Honest Target Error', path + 'gnp_def_strong.pdf')\n",
    "best_attacks += plot_data(dat_gnp, attack, 'strong', 'total', 'L2 Error', path + 'gnp_tot_strong.pdf')\n",
    "best_inf_attacks += plot_data(dat_gnp, inf_attack, 'med', 'rob', 'Malicious Target Error', path + 'gnp_inf_med.pdf')\n",
    "best_def_attacks += plot_data(dat_gnp, def_attack, 'med', 'acc', 'Honest Target Error', path + 'gnp_def_med.pdf')\n",
    "best_attacks += plot_data(dat_gnp, attack, 'med', 'total', 'L2 Error', path + 'gnp_tot_med.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "72250e21",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Protocol              Attack Strength\n",
       "Naive, Response       med                0.000\n",
       "                      strong             0.000\n",
       "RR+Laplace, Response  med                0.000\n",
       "                      strong             0.893\n",
       "RR, Response          med                0.000\n",
       "                      strong             0.363\n",
       "Name: PCT Disq, dtype: float64"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_pct_disq(pd.DataFrame(df_gnp))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "58c5fb0b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: [Eps, Mal Max Error, Mal L2 Error, Mal Mean Error, Mal T Nan, Mal T Tot, Mal Nan, Hon T Max Error, Hon T L2 Error, Hon T Mean Error, Hon T Nan, Hon T Tot, Rest Max Error, Rest L2 Error, Rest Mean Error, Rest Nan, Rest Tot]\n",
       "Index: []"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_honest_nans(dat_gnp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "54820a75",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>RR+Laplace, Response</th>\n",
       "      <th>med</th>\n",
       "      <th>Def Big Comm</th>\n",
       "      <th>strong</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.8</td>\n",
       "      <td>11.023583</td>\n",
       "      <td>126.439999</td>\n",
       "      <td>5.005738</td>\n",
       "      <td>0.0</td>\n",
       "      <td>594.0</td>\n",
       "      <td>12.530342</td>\n",
       "      <td>302.824837</td>\n",
       "      <td>5.003485</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3401.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RR, Response</th>\n",
       "      <th>med</th>\n",
       "      <th>Def Big Comm</th>\n",
       "      <th>strong</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>86.280501</td>\n",
       "      <td>616.474047</td>\n",
       "      <td>20.152635</td>\n",
       "      <td>0.0</td>\n",
       "      <td>594.0</td>\n",
       "      <td>96.379949</td>\n",
       "      <td>1473.691744</td>\n",
       "      <td>20.118140</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3401.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                      Eps  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength        \n",
       "RR+Laplace, Response med                Def Big Comm strong           2.0   \n",
       "RR, Response         med                Def Big Comm strong           2.0   \n",
       "\n",
       "                                                                      Mal Max Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                  \n",
       "RR+Laplace, Response med                Def Big Comm strong                     0.0   \n",
       "RR, Response         med                Def Big Comm strong                     0.0   \n",
       "\n",
       "                                                                      Mal L2 Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                 \n",
       "RR+Laplace, Response med                Def Big Comm strong                    0.0   \n",
       "RR, Response         med                Def Big Comm strong                    0.0   \n",
       "\n",
       "                                                                      Mal Mean Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                   \n",
       "RR+Laplace, Response med                Def Big Comm strong                      0.0   \n",
       "RR, Response         med                Def Big Comm strong                      0.0   \n",
       "\n",
       "                                                                      Mal T Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Def Big Comm strong                 0.0   \n",
       "RR, Response         med                Def Big Comm strong                 0.0   \n",
       "\n",
       "                                                                      Mal T Tot  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Def Big Comm strong                 0.0   \n",
       "RR, Response         med                Def Big Comm strong                 0.0   \n",
       "\n",
       "                                                                      Mal Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength            \n",
       "RR+Laplace, Response med                Def Big Comm strong               4.8   \n",
       "RR, Response         med                Def Big Comm strong               5.0   \n",
       "\n",
       "                                                                      Hon T Max Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                    \n",
       "RR+Laplace, Response med                Def Big Comm strong                 11.023583   \n",
       "RR, Response         med                Def Big Comm strong                 86.280501   \n",
       "\n",
       "                                                                      Hon T L2 Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                   \n",
       "RR+Laplace, Response med                Def Big Comm strong               126.439999   \n",
       "RR, Response         med                Def Big Comm strong               616.474047   \n",
       "\n",
       "                                                                      Hon T Mean Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                     \n",
       "RR+Laplace, Response med                Def Big Comm strong                   5.005738   \n",
       "RR, Response         med                Def Big Comm strong                  20.152635   \n",
       "\n",
       "                                                                      Hon T Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Def Big Comm strong                 0.0   \n",
       "RR, Response         med                Def Big Comm strong                 0.0   \n",
       "\n",
       "                                                                      Hon T Tot  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength              \n",
       "RR+Laplace, Response med                Def Big Comm strong               594.0   \n",
       "RR, Response         med                Def Big Comm strong               594.0   \n",
       "\n",
       "                                                                      Rest Max Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                   \n",
       "RR+Laplace, Response med                Def Big Comm strong                12.530342   \n",
       "RR, Response         med                Def Big Comm strong                96.379949   \n",
       "\n",
       "                                                                      Rest L2 Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                  \n",
       "RR+Laplace, Response med                Def Big Comm strong              302.824837   \n",
       "RR, Response         med                Def Big Comm strong             1473.691744   \n",
       "\n",
       "                                                                      Rest Mean Error  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength                    \n",
       "RR+Laplace, Response med                Def Big Comm strong                  5.003485   \n",
       "RR, Response         med                Def Big Comm strong                 20.118140   \n",
       "\n",
       "                                                                      Rest Nan  \\\n",
       "Protocol             Threshold Strength Attack       Attack Strength             \n",
       "RR+Laplace, Response med                Def Big Comm strong                0.0   \n",
       "RR, Response         med                Def Big Comm strong                0.0   \n",
       "\n",
       "                                                                      Rest Tot  \n",
       "Protocol             Threshold Strength Attack       Attack Strength            \n",
       "RR+Laplace, Response med                Def Big Comm strong             3401.0  \n",
       "RR, Response         med                Def Big Comm strong             3401.0  "
      ]
     },
     "execution_count": 75,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dat_gnp.iloc[ np.where(dat_gnp['Mal Nan'] > 0)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "1e974f11",
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_hist = {d: [0, 0, 0] for d in attack}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47bac602",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "65641636",
   "metadata": {},
   "outputs": [],
   "source": [
    "best_attacks_df = pd.value_counts(best_attacks)\n",
    "best_inf_attacks_df = pd.value_counts(best_inf_attacks)\n",
    "best_def_attacks_df = pd.value_counts(best_def_attacks)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "9b48d3fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in best_attacks_df.index:\n",
    "    attack_hist[i][0] = best_attacks_df.loc[i]\n",
    "\n",
    "for i in best_inf_attacks_df.index:\n",
    "    attack_hist[i][1] = best_inf_attacks_df.loc[i]\n",
    "    \n",
    "for i in best_def_attacks_df.index:\n",
    "    attack_hist[i][2] = best_def_attacks_df.loc[i]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "ff8766a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "L = np.array([attack_hist[a] for a in attack_names])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "10ee98a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x11be3ceb0>"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "matplotlib.rcParams['figure.figsize'] = (12.0,4.0)\n",
    "x = np.arange(0, len(attack), 1)\n",
    "fig, ax = plt.subplots()\n",
    "ax.bar(x, L[:, 0], width = 0.25, label = 'L2 Error')\n",
    "ax.bar(x + .25, L[:, 1], width = 0.25, label = 'Malicious Target Error')\n",
    "ax.bar(x + 0.5, L[:, 2], width = 0.25, label = 'Honest Target Error')\n",
    "ax.set_xticks(x+0.25, [attack_names_short[a] for a in attack_names], rotation=90)\n",
    "fig.legend(loc='outside lower center')\n",
    "#ax.set_xticklabels(attack)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "c0697bcf",
   "metadata": {},
   "outputs": [],
   "source": [
    "#A3, A5, A13\n",
    "#Def 1 Friend, Inf 20 Rand, 2 Inf 20 Comm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "1bc40462",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'Inf 1 Rand': 'A0',\n",
       " 'Def 1 Rand': 'A1',\n",
       " 'Inf 1 Friend': 'A2',\n",
       " 'Def 1 Friend': 'A3',\n",
       " 'Inf 5 Rand': 'A4',\n",
       " 'Inf 20 Rand': 'A5',\n",
       " 'Def 5 Comm': 'A6',\n",
       " 'Def 20 Comm': 'A7',\n",
       " 'Inf+Def 5 Comm': 'A8',\n",
       " 'Inf+Def 20 Comm': 'A9',\n",
       " '2 Inf 5 Comm': 'A10',\n",
       " '2 Def 5 Comm': 'A11',\n",
       " 'Inf 5 Def 5 Comm': 'A12',\n",
       " '2 Inf 20 Comm': 'A13',\n",
       " '2 Def 20 Comm': 'A14',\n",
       " 'Inf 20 Def 20 Comm': 'A15',\n",
       " 'Def Big Comm': 'A16'}"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "attack_names_short"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "807ec6d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "D0 = pd.DataFrame(df)\n",
    "D1 = pd.DataFrame(df_eu)\n",
    "D2 = pd.DataFrame(df_gnp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "a17640a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "D1['Graph'] = 'EU'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "6fb2b508",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Protocol</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th>Eps</th>\n",
       "      <th>Graph</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>...</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>103</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def 50 Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>102.788586</td>\n",
       "      <td>528.666681</td>\n",
       "      <td>20.836537</td>\n",
       "      <td>0</td>\n",
       "      <td>397</td>\n",
       "      <td>88.292868</td>\n",
       "      <td>1525.079500</td>\n",
       "      <td>20.430882</td>\n",
       "      <td>0</td>\n",
       "      <td>3598</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>11.407530</td>\n",
       "      <td>147.615375</td>\n",
       "      <td>5.056111</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>12.203580</td>\n",
       "      <td>292.704451</td>\n",
       "      <td>4.991738</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>109</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>80.827978</td>\n",
       "      <td>705.286301</td>\n",
       "      <td>19.778669</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>105.309997</td>\n",
       "      <td>1429.924506</td>\n",
       "      <td>20.328696</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>111</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>11.867896</td>\n",
       "      <td>145.846710</td>\n",
       "      <td>4.988778</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>11.190530</td>\n",
       "      <td>293.701299</td>\n",
       "      <td>5.006035</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>112</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>78.553574</td>\n",
       "      <td>743.353696</td>\n",
       "      <td>20.914461</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>99.097249</td>\n",
       "      <td>1455.197670</td>\n",
       "      <td>20.472737</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>222</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>12.879345</td>\n",
       "      <td>147.337910</td>\n",
       "      <td>5.034436</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>12.085285</td>\n",
       "      <td>292.578005</td>\n",
       "      <td>4.979705</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>223</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>92.744821</td>\n",
       "      <td>758.170878</td>\n",
       "      <td>21.497077</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>101.118750</td>\n",
       "      <td>1447.819296</td>\n",
       "      <td>20.494569</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>225</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>11.971029</td>\n",
       "      <td>148.574481</td>\n",
       "      <td>5.059850</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>12.860085</td>\n",
       "      <td>295.743511</td>\n",
       "      <td>5.028161</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>226</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>95.658233</td>\n",
       "      <td>716.743809</td>\n",
       "      <td>20.672407</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>106.292868</td>\n",
       "      <td>1438.128764</td>\n",
       "      <td>20.318121</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>11.642042</td>\n",
       "      <td>147.071288</td>\n",
       "      <td>5.023491</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>12.109387</td>\n",
       "      <td>291.450356</td>\n",
       "      <td>4.969734</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>337</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>89.658233</td>\n",
       "      <td>696.724936</td>\n",
       "      <td>19.242272</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>92.532072</td>\n",
       "      <td>1451.893708</td>\n",
       "      <td>20.506048</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>339</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>15.131578</td>\n",
       "      <td>146.634084</td>\n",
       "      <td>4.992009</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>12.392306</td>\n",
       "      <td>293.268060</td>\n",
       "      <td>4.986459</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>340</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>81.414656</td>\n",
       "      <td>683.978880</td>\n",
       "      <td>19.434072</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>115.454049</td>\n",
       "      <td>1431.324845</td>\n",
       "      <td>20.301540</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>448</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def 50 Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>81.780021</td>\n",
       "      <td>513.767651</td>\n",
       "      <td>20.792561</td>\n",
       "      <td>0</td>\n",
       "      <td>397</td>\n",
       "      <td>90.866609</td>\n",
       "      <td>1524.080218</td>\n",
       "      <td>20.420672</td>\n",
       "      <td>0</td>\n",
       "      <td>3598</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>450</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>14.121595</td>\n",
       "      <td>146.469549</td>\n",
       "      <td>4.996999</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>13.064698</td>\n",
       "      <td>292.620489</td>\n",
       "      <td>4.989751</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>451</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>79.875173</td>\n",
       "      <td>698.010337</td>\n",
       "      <td>19.825198</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>90.623032</td>\n",
       "      <td>1455.157067</td>\n",
       "      <td>20.417176</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>453</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>12.142217</td>\n",
       "      <td>145.542533</td>\n",
       "      <td>4.968568</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>11.514983</td>\n",
       "      <td>294.877003</td>\n",
       "      <td>5.023939</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>454</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>76.049291</td>\n",
       "      <td>701.357095</td>\n",
       "      <td>19.866950</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>93.032162</td>\n",
       "      <td>1424.060313</td>\n",
       "      <td>20.092950</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>564</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>12.478020</td>\n",
       "      <td>146.736870</td>\n",
       "      <td>5.029710</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>11.819686</td>\n",
       "      <td>293.855420</td>\n",
       "      <td>5.006865</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>565</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>med</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>87.536444</td>\n",
       "      <td>704.882253</td>\n",
       "      <td>19.985598</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>95.845107</td>\n",
       "      <td>1436.039286</td>\n",
       "      <td>20.200534</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>567</th>\n",
       "      <td>RR+Laplace, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>13.106322</td>\n",
       "      <td>145.558689</td>\n",
       "      <td>4.952600</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>12.849948</td>\n",
       "      <td>292.167216</td>\n",
       "      <td>4.976985</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>568</th>\n",
       "      <td>RR, Response</td>\n",
       "      <td>Def Big Comm</td>\n",
       "      <td>strong</td>\n",
       "      <td>med</td>\n",
       "      <td>2.0</td>\n",
       "      <td>GNP</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>80.532072</td>\n",
       "      <td>718.872810</td>\n",
       "      <td>20.230222</td>\n",
       "      <td>0</td>\n",
       "      <td>795</td>\n",
       "      <td>93.996962</td>\n",
       "      <td>1423.417231</td>\n",
       "      <td>20.113554</td>\n",
       "      <td>0</td>\n",
       "      <td>3200</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>22 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                 Protocol        Attack Attack Strength Threshold Strength  \\\n",
       "103          RR, Response   Def 50 Comm             med                med   \n",
       "108  RR+Laplace, Response  Def Big Comm             med                med   \n",
       "109          RR, Response  Def Big Comm             med                med   \n",
       "111  RR+Laplace, Response  Def Big Comm          strong                med   \n",
       "112          RR, Response  Def Big Comm          strong                med   \n",
       "222  RR+Laplace, Response  Def Big Comm             med                med   \n",
       "223          RR, Response  Def Big Comm             med                med   \n",
       "225  RR+Laplace, Response  Def Big Comm          strong                med   \n",
       "226          RR, Response  Def Big Comm          strong                med   \n",
       "336  RR+Laplace, Response  Def Big Comm             med                med   \n",
       "337          RR, Response  Def Big Comm             med                med   \n",
       "339  RR+Laplace, Response  Def Big Comm          strong                med   \n",
       "340          RR, Response  Def Big Comm          strong                med   \n",
       "448          RR, Response   Def 50 Comm          strong                med   \n",
       "450  RR+Laplace, Response  Def Big Comm             med                med   \n",
       "451          RR, Response  Def Big Comm             med                med   \n",
       "453  RR+Laplace, Response  Def Big Comm          strong                med   \n",
       "454          RR, Response  Def Big Comm          strong                med   \n",
       "564  RR+Laplace, Response  Def Big Comm             med                med   \n",
       "565          RR, Response  Def Big Comm             med                med   \n",
       "567  RR+Laplace, Response  Def Big Comm          strong                med   \n",
       "568          RR, Response  Def Big Comm          strong                med   \n",
       "\n",
       "     Eps Graph  Mal Max Error  Mal L2 Error  Mal Mean Error  Mal T Nan  ...  \\\n",
       "103  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "108  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "109  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "111  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "112  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "222  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "223  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "225  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "226  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "336  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "337  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "339  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "340  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "448  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "450  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "451  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "453  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "454  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "564  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "565  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "567  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "568  2.0   GNP            0.0           0.0             0.0          0  ...   \n",
       "\n",
       "     Hon T Max Error  Hon T L2 Error  Hon T Mean Error  Hon T Nan  Hon T Tot  \\\n",
       "103       102.788586      528.666681         20.836537          0        397   \n",
       "108        11.407530      147.615375          5.056111          0        795   \n",
       "109        80.827978      705.286301         19.778669          0        795   \n",
       "111        11.867896      145.846710          4.988778          0        795   \n",
       "112        78.553574      743.353696         20.914461          0        795   \n",
       "222        12.879345      147.337910          5.034436          0        795   \n",
       "223        92.744821      758.170878         21.497077          0        795   \n",
       "225        11.971029      148.574481          5.059850          0        795   \n",
       "226        95.658233      716.743809         20.672407          0        795   \n",
       "336        11.642042      147.071288          5.023491          0        795   \n",
       "337        89.658233      696.724936         19.242272          0        795   \n",
       "339        15.131578      146.634084          4.992009          0        795   \n",
       "340        81.414656      683.978880         19.434072          0        795   \n",
       "448        81.780021      513.767651         20.792561          0        397   \n",
       "450        14.121595      146.469549          4.996999          0        795   \n",
       "451        79.875173      698.010337         19.825198          0        795   \n",
       "453        12.142217      145.542533          4.968568          0        795   \n",
       "454        76.049291      701.357095         19.866950          0        795   \n",
       "564        12.478020      146.736870          5.029710          0        795   \n",
       "565        87.536444      704.882253         19.985598          0        795   \n",
       "567        13.106322      145.558689          4.952600          0        795   \n",
       "568        80.532072      718.872810         20.230222          0        795   \n",
       "\n",
       "     Rest Max Error  Rest L2 Error  Rest Mean Error  Rest Nan  Rest Tot  \n",
       "103       88.292868    1525.079500        20.430882         0      3598  \n",
       "108       12.203580     292.704451         4.991738         0      3200  \n",
       "109      105.309997    1429.924506        20.328696         0      3200  \n",
       "111       11.190530     293.701299         5.006035         0      3200  \n",
       "112       99.097249    1455.197670        20.472737         0      3200  \n",
       "222       12.085285     292.578005         4.979705         0      3200  \n",
       "223      101.118750    1447.819296        20.494569         0      3200  \n",
       "225       12.860085     295.743511         5.028161         0      3200  \n",
       "226      106.292868    1438.128764        20.318121         0      3200  \n",
       "336       12.109387     291.450356         4.969734         0      3200  \n",
       "337       92.532072    1451.893708        20.506048         0      3200  \n",
       "339       12.392306     293.268060         4.986459         0      3200  \n",
       "340      115.454049    1431.324845        20.301540         0      3200  \n",
       "448       90.866609    1524.080218        20.420672         0      3598  \n",
       "450       13.064698     292.620489         4.989751         0      3200  \n",
       "451       90.623032    1455.157067        20.417176         0      3200  \n",
       "453       11.514983     294.877003         5.023939         0      3200  \n",
       "454       93.032162    1424.060313        20.092950         0      3200  \n",
       "564       11.819686     293.855420         5.006865         0      3200  \n",
       "565       95.845107    1436.039286        20.200534         0      3200  \n",
       "567       12.849948     292.167216         4.976985         0      3200  \n",
       "568       93.996962    1423.417231        20.113554         0      3200  \n",
       "\n",
       "[22 rows x 22 columns]"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "D2.loc[D2['Mal Nan'] > 0, :]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "190abebd",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_total = pd.concat((D0, D1, D2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "d64628d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_nan = df_total[['Protocol', 'Attack', 'Attack Strength', 'Mal T Nan', 'Mal Nan', 'Mal T Tot']]\n",
    "df_nan = df_nan.groupby(['Protocol', 'Attack', 'Attack Strength']).mean()\n",
    "#df_nan.columns = df_nan.columns.get_level_values(0)\n",
    "df_nan.loc[:, 'Mal Nan Pct'] = df_nan.loc[:, 'Mal T Nan'] / df_nan.loc[:, 'Mal T Tot']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "8235b28f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "inf_df_nan = df_nan.loc[df_nan.loc[:, 'Mal T Tot'] > 0, :]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "fa79acc5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"3\" halign=\"left\">Mal T Nan</th>\n",
       "      <th colspan=\"3\" halign=\"left\">Mal Nan</th>\n",
       "      <th colspan=\"3\" halign=\"left\">Mal T Tot</th>\n",
       "      <th colspan=\"3\" halign=\"left\">Mal Nan Pct</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>min</th>\n",
       "      <th>max</th>\n",
       "      <th>mean</th>\n",
       "      <th>min</th>\n",
       "      <th>max</th>\n",
       "      <th>mean</th>\n",
       "      <th>min</th>\n",
       "      <th>max</th>\n",
       "      <th>mean</th>\n",
       "      <th>min</th>\n",
       "      <th>max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">Naive, Response</th>\n",
       "      <th>med</th>\n",
       "      <td>0.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.7</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>strong</th>\n",
       "      <td>0.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.7</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">RR+Laplace, Response</th>\n",
       "      <th>med</th>\n",
       "      <td>0.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.7</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>strong</th>\n",
       "      <td>10.18</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>31.466667</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.7</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.817333</td>\n",
       "      <td>0.766667</td>\n",
       "      <td>0.906667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">RR, Response</th>\n",
       "      <th>med</th>\n",
       "      <td>0.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.7</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>strong</th>\n",
       "      <td>5.18</td>\n",
       "      <td>0.466667</td>\n",
       "      <td>12.866667</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.7</td>\n",
       "      <td>1.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.455500</td>\n",
       "      <td>0.321667</td>\n",
       "      <td>0.586667</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                     Mal T Nan                      Mal Nan  \\\n",
       "                                          mean       min        max    mean   \n",
       "Protocol             Attack Strength                                          \n",
       "Naive, Response      med                  0.00  0.000000   0.000000     0.0   \n",
       "                     strong               0.00  0.000000   0.000000     0.0   \n",
       "RR+Laplace, Response med                  0.00  0.000000   0.000000     0.0   \n",
       "                     strong              10.18  0.800000  31.466667     0.0   \n",
       "RR, Response         med                  0.00  0.000000   0.000000     0.0   \n",
       "                     strong               5.18  0.466667  12.866667     0.0   \n",
       "\n",
       "                                               Mal T Tot             \\\n",
       "                                      min  max      mean  min   max   \n",
       "Protocol             Attack Strength                                  \n",
       "Naive, Response      med              0.0  0.0      12.7  1.0  40.0   \n",
       "                     strong           0.0  0.0      12.7  1.0  40.0   \n",
       "RR+Laplace, Response med              0.0  0.0      12.7  1.0  40.0   \n",
       "                     strong           0.0  0.0      12.7  1.0  40.0   \n",
       "RR, Response         med              0.0  0.0      12.7  1.0  40.0   \n",
       "                     strong           0.0  0.0      12.7  1.0  40.0   \n",
       "\n",
       "                                     Mal Nan Pct                      \n",
       "                                            mean       min       max  \n",
       "Protocol             Attack Strength                                  \n",
       "Naive, Response      med                0.000000  0.000000  0.000000  \n",
       "                     strong             0.000000  0.000000  0.000000  \n",
       "RR+Laplace, Response med                0.000000  0.000000  0.000000  \n",
       "                     strong             0.817333  0.766667  0.906667  \n",
       "RR, Response         med                0.000000  0.000000  0.000000  \n",
       "                     strong             0.455500  0.321667  0.586667  "
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "inf_df_nan.groupby(['Protocol', 'Attack Strength']).agg([np.mean, min, max])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "d6ca96a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_nan2 = df_total[['Protocol', 'Attack', 'Attack Strength', 'Graph', 'Mal T Nan', 'Mal Nan', 'Mal T Tot']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "183de752",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_nan2 = df_nan2.groupby(['Protocol', 'Attack', 'Attack Strength', 'Graph']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "48ebebe3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Attack Strength</th>\n",
       "      <th>Graph</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">RR+Laplace, Response</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">Def Big Comm</th>\n",
       "      <th>med</th>\n",
       "      <th>GNP</th>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>strong</th>\n",
       "      <th>GNP</th>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">RR, Response</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">Def 50 Comm</th>\n",
       "      <th>med</th>\n",
       "      <th>GNP</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>strong</th>\n",
       "      <th>GNP</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">Def Big Comm</th>\n",
       "      <th>med</th>\n",
       "      <th>GNP</th>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>strong</th>\n",
       "      <th>GNP</th>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                         Mal T Nan  Mal Nan  \\\n",
       "Protocol             Attack       Attack Strength Graph                       \n",
       "RR+Laplace, Response Def Big Comm med             GNP          0.0      5.0   \n",
       "                                  strong          GNP          0.0      5.0   \n",
       "RR, Response         Def 50 Comm  med             GNP          0.0      0.2   \n",
       "                                  strong          GNP          0.0      0.2   \n",
       "                     Def Big Comm med             GNP          0.0      5.0   \n",
       "                                  strong          GNP          0.0      5.0   \n",
       "\n",
       "                                                         Mal T Tot  \n",
       "Protocol             Attack       Attack Strength Graph             \n",
       "RR+Laplace, Response Def Big Comm med             GNP          0.0  \n",
       "                                  strong          GNP          0.0  \n",
       "RR, Response         Def 50 Comm  med             GNP          0.0  \n",
       "                                  strong          GNP          0.0  \n",
       "                     Def Big Comm med             GNP          0.0  \n",
       "                                  strong          GNP          0.0  "
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_nan2[df_nan2['Mal Nan'] > 0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d01dcb00",
   "metadata": {},
   "source": [
    "# Effect of malicious users on graph size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "4f9bd880",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_mal = 120\n",
    "t2 = 20\n",
    "comm = comms\n",
    "selected_attacks = []\n",
    "selected_attacks.append( [(0, 1, n_mal, 'Friends')])\n",
    "\n",
    "#selected_attacks.append( [(t1, 0, n_mal-t1, 'Random')] )\n",
    "#selected_attacks.append( [(t2, 0, n_mal-t2, 'Random')] )\n",
    "\n",
    "selected_attacks.append( [(t2, t2, n_mal-t2, comm)] )\n",
    "\n",
    "selected_attacks.append( [(t2, 0, n_mal//2-t2, comm), (t2, 0, n_mal//2-t2, comm)] )\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "fd79ea36",
   "metadata": {},
   "outputs": [],
   "source": [
    "def collect_data_new(attack_names, g, g_name, max_adv, epsilons, thresh_values, attack_values, comm, reps):\n",
    "    #labels = ['RR+Laplace, Response', 'RR+Laplace, Input', 'RR, Response', 'RR, Input', 'Naive, Response', 'Naive, Input']\n",
    "    labels = ['RR+Laplace, Response', 'RR, Response', 'Naive, Response']\n",
    "    E = [experiments.ResponseLaplaceManipulation(g, 2000, 1.0, 1e-6, 0.1, [0.7, 0.5], [0.8, 0.5, 0.3]), \n",
    "         experiments.ResponseRRManipulation(g, 2000, 1.0, 1e-6, [0.7], [0.8, 0.5]),\n",
    "         experiments.ResponseRRNaiveManipulation(g, 2000, 1.0, 1e-6, [0.7], [0.8, 0.5])\n",
    "        ]\n",
    "    \n",
    "    data = []\n",
    "    max_adv = (g.get_dim() * np.array(max_adv)).astype(int)\n",
    "    for x in range(0, reps):\n",
    "        for n_mal in max_adv:\n",
    "            t2 = int(n_mal // 6)\n",
    "            attacks = [[(0, 1, n_mal, 'Friends')], [(t2, t2, n_mal-t2, list(comm))], [(t2, 0, n_mal//2-t2, list(comm)), (t2, 0, n_mal//2-t2, list(comm))]]\n",
    "            #pdb.set_trace()\n",
    "            for epsilon in epsilons:\n",
    "                for exp in E:\n",
    "                    exp.set_epsilon(epsilon)\n",
    "                    exp.max_num_mal = n_mal\n",
    "                for a_i in range(0, len(attacks)):\n",
    "                    for i in range(0, len(E)):\n",
    "                        E[i].reset_attacks()\n",
    "                    E[0].add_attacks(attacks[a_i])\n",
    "                    for i in range(1, len(E)):\n",
    "                        E[i].set_attacks_like(E[0])\n",
    "\n",
    "                    for av in attack_values.keys():\n",
    "                        for tv in thresh_values.keys():\n",
    "                            for i in range(0, len(E)):\n",
    "                                E[i].threshold_reduction = thresh_values[tv]\n",
    "                                E[i].inflation_factors = attack_values[av]\n",
    "                                d = E[i].get_results(False)\n",
    "                                h = {'Protocol': labels[i], 'Attack': attack_names[a_i], 'Attack Strength': av, 'Threshold Strength': tv, 'Eps': epsilon, 'Graph': g_name,\n",
    "                                    'Mal Max Error': d[0][0], 'Mal L2 Error': d[0][1], 'Mal Mean Error': d[0][2], 'Mal T Nan': d[1][0], 'Mal T Tot': d[1][1], 'Mal Nan': d[2],\n",
    "                                    'Num Mal': n_mal, 'Hon T Max Error': d[3][0], 'Hon T L2 Error': d[3][1], 'Hon T Mean Error': d[3][2], 'Hon T Nan': d[4][0], 'Hon T Tot': d[4][1],\n",
    "                                    'Rest Max Error': d[5][0], 'Rest L2 Error': d[5][1], 'Rest Mean Error': d[5][2], 'Rest Nan': d[6][0], 'Rest Tot': d[6][1]\n",
    "                                }\n",
    "                                data.append(h)\n",
    "    return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "865ae0c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO: Fix comms, and how do thresh values and attack values work?\n",
    "data_vary_n_mal = collect_data_new(['Def 1 Friend','Inf+Def Comm','2 Inf Comm'], g, 'FB', [0.01, 0.02, 0.03, 0.05, 0.10, 0.15, 0.20, 0.25, 0.30], [2.0], thresh_values, {'med': (0.1, 0.1)}, list(comms[1]) + list(comms[0]), 15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "7fe27ece",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_vary_n_mal = pd.DataFrame(data_vary_n_mal).drop(['Attack Strength', 'Threshold Strength', 'Eps'], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "f6a3b3d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "DF = data_vary_n_mal.groupby(['Protocol', 'Attack', 'Graph', 'Num Mal']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "4ab3ba6d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index([  40,   80,  121,  201,  403,  605,  807, 1009, 1211,   40,   80,  121,\n",
       "        201,  403,  605,  807, 1009, 1211,   40,   80,  121,  201,  403,  605,\n",
       "        807, 1009, 1211,   40,   80,  121,  201,  403,  605,  807, 1009, 1211,\n",
       "         40,   80,  121,  201,  403,  605,  807, 1009, 1211,   40,   80,  121,\n",
       "        201,  403,  605,  807, 1009, 1211,   40,   80,  121,  201,  403,  605,\n",
       "        807, 1009, 1211,   40,   80,  121,  201,  403,  605,  807, 1009, 1211,\n",
       "         40,   80,  121,  201,  403,  605,  807, 1009, 1211],\n",
       "      dtype='int64', name='Num Mal')"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "DF.index.get_level_values(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "e8c19647",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Graph</th>\n",
       "      <th>Num Mal</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">Naive, Response</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">2 Inf Comm</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">FB</th>\n",
       "      <th>40</th>\n",
       "      <td>517.101939</td>\n",
       "      <td>1646.048648</td>\n",
       "      <td>474.610696</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>102.605930</td>\n",
       "      <td>1706.435049</td>\n",
       "      <td>21.518771</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3999.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>80</th>\n",
       "      <td>540.757951</td>\n",
       "      <td>2508.347009</td>\n",
       "      <td>491.300811</td>\n",
       "      <td>0.0</td>\n",
       "      <td>26.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>104.517995</td>\n",
       "      <td>1692.732808</td>\n",
       "      <td>21.443005</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3959.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>121</th>\n",
       "      <td>553.248913</td>\n",
       "      <td>3171.880989</td>\n",
       "      <td>500.919127</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>103.414888</td>\n",
       "      <td>1685.991857</td>\n",
       "      <td>21.522304</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>201</th>\n",
       "      <td>590.921101</td>\n",
       "      <td>4317.578927</td>\n",
       "      <td>530.856500</td>\n",
       "      <td>0.0</td>\n",
       "      <td>66.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>99.729271</td>\n",
       "      <td>1672.684586</td>\n",
       "      <td>21.545622</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3839.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>403</th>\n",
       "      <td>660.210669</td>\n",
       "      <td>6924.093908</td>\n",
       "      <td>597.619681</td>\n",
       "      <td>0.0</td>\n",
       "      <td>134.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>103.487550</td>\n",
       "      <td>1631.868469</td>\n",
       "      <td>21.639607</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3637.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">RR, Response</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">Inf+Def Comm</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">FB</th>\n",
       "      <th>403</th>\n",
       "      <td>509.874620</td>\n",
       "      <td>3911.420950</td>\n",
       "      <td>477.545169</td>\n",
       "      <td>0.0</td>\n",
       "      <td>67.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>47.919254</td>\n",
       "      <td>156.676806</td>\n",
       "      <td>15.748798</td>\n",
       "      <td>0.0</td>\n",
       "      <td>67.0</td>\n",
       "      <td>45.190970</td>\n",
       "      <td>652.702882</td>\n",
       "      <td>8.672316</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3569.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>605</th>\n",
       "      <td>727.252432</td>\n",
       "      <td>6903.712370</td>\n",
       "      <td>690.164540</td>\n",
       "      <td>0.0</td>\n",
       "      <td>100.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>90.372343</td>\n",
       "      <td>274.469942</td>\n",
       "      <td>22.372330</td>\n",
       "      <td>0.0</td>\n",
       "      <td>100.0</td>\n",
       "      <td>46.347833</td>\n",
       "      <td>657.756055</td>\n",
       "      <td>8.987154</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3334.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>807</th>\n",
       "      <td>941.104458</td>\n",
       "      <td>10428.835728</td>\n",
       "      <td>900.639431</td>\n",
       "      <td>0.0</td>\n",
       "      <td>134.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>111.586360</td>\n",
       "      <td>399.073484</td>\n",
       "      <td>29.037574</td>\n",
       "      <td>0.0</td>\n",
       "      <td>134.0</td>\n",
       "      <td>52.113480</td>\n",
       "      <td>675.203434</td>\n",
       "      <td>9.483062</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3098.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1009</th>\n",
       "      <td>1154.821376</td>\n",
       "      <td>14399.224962</td>\n",
       "      <td>1110.554721</td>\n",
       "      <td>0.0</td>\n",
       "      <td>168.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>124.597020</td>\n",
       "      <td>536.869399</td>\n",
       "      <td>35.557637</td>\n",
       "      <td>0.0</td>\n",
       "      <td>168.0</td>\n",
       "      <td>57.230507</td>\n",
       "      <td>693.099031</td>\n",
       "      <td>9.916612</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2862.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1211</th>\n",
       "      <td>1372.389293</td>\n",
       "      <td>18766.911187</td>\n",
       "      <td>1323.345458</td>\n",
       "      <td>0.0</td>\n",
       "      <td>201.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>251.580205</td>\n",
       "      <td>769.382479</td>\n",
       "      <td>44.499679</td>\n",
       "      <td>0.0</td>\n",
       "      <td>201.0</td>\n",
       "      <td>62.086136</td>\n",
       "      <td>722.986591</td>\n",
       "      <td>10.571670</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2627.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>81 rows × 16 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                            Mal Max Error  Mal L2 Error  \\\n",
       "Protocol        Attack       Graph Num Mal                                \n",
       "Naive, Response 2 Inf Comm   FB    40          517.101939   1646.048648   \n",
       "                                   80          540.757951   2508.347009   \n",
       "                                   121         553.248913   3171.880989   \n",
       "                                   201         590.921101   4317.578927   \n",
       "                                   403         660.210669   6924.093908   \n",
       "...                                                   ...           ...   \n",
       "RR, Response    Inf+Def Comm FB    403         509.874620   3911.420950   \n",
       "                                   605         727.252432   6903.712370   \n",
       "                                   807         941.104458  10428.835728   \n",
       "                                   1009       1154.821376  14399.224962   \n",
       "                                   1211       1372.389293  18766.911187   \n",
       "\n",
       "                                            Mal Mean Error  Mal T Nan  \\\n",
       "Protocol        Attack       Graph Num Mal                              \n",
       "Naive, Response 2 Inf Comm   FB    40           474.610696        0.0   \n",
       "                                   80           491.300811        0.0   \n",
       "                                   121          500.919127        0.0   \n",
       "                                   201          530.856500        0.0   \n",
       "                                   403          597.619681        0.0   \n",
       "...                                                    ...        ...   \n",
       "RR, Response    Inf+Def Comm FB    403          477.545169        0.0   \n",
       "                                   605          690.164540        0.0   \n",
       "                                   807          900.639431        0.0   \n",
       "                                   1009        1110.554721        0.0   \n",
       "                                   1211        1323.345458        0.0   \n",
       "\n",
       "                                            Mal T Tot  Mal Nan  \\\n",
       "Protocol        Attack       Graph Num Mal                       \n",
       "Naive, Response 2 Inf Comm   FB    40            12.0      0.0   \n",
       "                                   80            26.0      0.0   \n",
       "                                   121           40.0      0.0   \n",
       "                                   201           66.0      0.0   \n",
       "                                   403          134.0      0.0   \n",
       "...                                               ...      ...   \n",
       "RR, Response    Inf+Def Comm FB    403           67.0      0.0   \n",
       "                                   605          100.0      0.0   \n",
       "                                   807          134.0      0.0   \n",
       "                                   1009         168.0      0.0   \n",
       "                                   1211         201.0      0.0   \n",
       "\n",
       "                                            Hon T Max Error  Hon T L2 Error  \\\n",
       "Protocol        Attack       Graph Num Mal                                    \n",
       "Naive, Response 2 Inf Comm   FB    40              0.000000        0.000000   \n",
       "                                   80              0.000000        0.000000   \n",
       "                                   121             0.000000        0.000000   \n",
       "                                   201             0.000000        0.000000   \n",
       "                                   403             0.000000        0.000000   \n",
       "...                                                     ...             ...   \n",
       "RR, Response    Inf+Def Comm FB    403            47.919254      156.676806   \n",
       "                                   605            90.372343      274.469942   \n",
       "                                   807           111.586360      399.073484   \n",
       "                                   1009          124.597020      536.869399   \n",
       "                                   1211          251.580205      769.382479   \n",
       "\n",
       "                                            Hon T Mean Error  Hon T Nan  \\\n",
       "Protocol        Attack       Graph Num Mal                                \n",
       "Naive, Response 2 Inf Comm   FB    40               0.000000        0.0   \n",
       "                                   80               0.000000        0.0   \n",
       "                                   121              0.000000        0.0   \n",
       "                                   201              0.000000        0.0   \n",
       "                                   403              0.000000        0.0   \n",
       "...                                                      ...        ...   \n",
       "RR, Response    Inf+Def Comm FB    403             15.748798        0.0   \n",
       "                                   605             22.372330        0.0   \n",
       "                                   807             29.037574        0.0   \n",
       "                                   1009            35.557637        0.0   \n",
       "                                   1211            44.499679        0.0   \n",
       "\n",
       "                                            Hon T Tot  Rest Max Error  \\\n",
       "Protocol        Attack       Graph Num Mal                              \n",
       "Naive, Response 2 Inf Comm   FB    40             0.0      102.605930   \n",
       "                                   80             0.0      104.517995   \n",
       "                                   121            0.0      103.414888   \n",
       "                                   201            0.0       99.729271   \n",
       "                                   403            0.0      103.487550   \n",
       "...                                               ...             ...   \n",
       "RR, Response    Inf+Def Comm FB    403           67.0       45.190970   \n",
       "                                   605          100.0       46.347833   \n",
       "                                   807          134.0       52.113480   \n",
       "                                   1009         168.0       57.230507   \n",
       "                                   1211         201.0       62.086136   \n",
       "\n",
       "                                            Rest L2 Error  Rest Mean Error  \\\n",
       "Protocol        Attack       Graph Num Mal                                   \n",
       "Naive, Response 2 Inf Comm   FB    40         1706.435049        21.518771   \n",
       "                                   80         1692.732808        21.443005   \n",
       "                                   121        1685.991857        21.522304   \n",
       "                                   201        1672.684586        21.545622   \n",
       "                                   403        1631.868469        21.639607   \n",
       "...                                                   ...              ...   \n",
       "RR, Response    Inf+Def Comm FB    403         652.702882         8.672316   \n",
       "                                   605         657.756055         8.987154   \n",
       "                                   807         675.203434         9.483062   \n",
       "                                   1009        693.099031         9.916612   \n",
       "                                   1211        722.986591        10.571670   \n",
       "\n",
       "                                            Rest Nan  Rest Tot  \n",
       "Protocol        Attack       Graph Num Mal                      \n",
       "Naive, Response 2 Inf Comm   FB    40            0.0    3999.0  \n",
       "                                   80            0.0    3959.0  \n",
       "                                   121           0.0    3919.0  \n",
       "                                   201           0.0    3839.0  \n",
       "                                   403           0.0    3637.0  \n",
       "...                                              ...       ...  \n",
       "RR, Response    Inf+Def Comm FB    403           0.0    3569.0  \n",
       "                                   605           0.0    3334.0  \n",
       "                                   807           0.0    3098.0  \n",
       "                                   1009          0.0    2862.0  \n",
       "                                   1211          0.0    2627.0  \n",
       "\n",
       "[81 rows x 16 columns]"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "DF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "efc4a5e6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "P1 = DF.loc['Naive, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P1.index), P1['Mal Max Error'])\n",
    "P2 = DF.loc['RR, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P2.index), P2['Mal Max Error'])\n",
    "P3 = DF.loc['RR+Laplace, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P3.index), P3['Mal Max Error'])\n",
    "ax.set_xlabel('\\# Malicious Users')\n",
    "ax.set_ylabel('Malicious Target Error')\n",
    "plt.savefig(path+'fb_inf_vary_nmal.pdf', bbox_inches = \"tight\")\n",
    "#Add asymptote for naive."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "f83d1719",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZEAAAGDCAYAAADqPy3HAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABMVUlEQVR4nO3de1yb9aE/8E+Alt4J0NZba8uT1tu8EUDrXdvE7uK24xpAN7e5YwnrvGxzSsrOzpxn56yG9fy2uTkNVD3b3BQS3dzcvCStznotkNZanVoT0GqtbUkebi1QyPP74yEpIQnkfv28Xy9eNk+e5PlC8PnwvSskSZJAREQUhbxUF4CIiDIXQ4SIiKLGECEioqgxRIiIKGoMESIiihpDhIiIosYQISKiqBWkugDZwOPxYP/+/Zg/fz4UCkWqi0NEFDNJktDf34+TTz4ZeXmh6xsMkTjYv38/li5dmupiEBHF3b59+7BkyZKQzzNE4mD+/PkA5B/2ggULUlwaIqLY9fX1YenSpb77WygMkTjwNmEtWLCAIUJEWWW6Jnp2rBMRUdQYIkREFDWGCBERRY0hQkREUWOIEBFR1BgiREQUNYYIERFFjSFCRERRY4gQEVHUGCJERFlMkqSEvj9DhIgoSx3sG8K6+1/Bmx/1JuwaDBEioix0sG8I17W8BvuHIhoe3w2PJzE1EoYIEVGWOdg/hOtbXoPz0CBOLpoF0w0VyMtLzF5HDBEioixysH8I1ze/Bsd4gDymvwinls5J2PUYIkREWeJg/xC+2vJ60gIEYIgQEWWFQ/3D+GrL63j/4ABOKpqFR/WrEh4gAEOEiCjjHeofxvUtr/kC5DH9KiwrnZuUazNEiIgymFwDkQPkxAWz8Ghd8gIEYIgQEWWswwNygOwdD5DH9KuwfGHyAgRgiBARZaTDA8O4vjm1AQIwRIiIMs7EGsgJCwrxaIoCBGCIEBFllJ6BYXyt5XW896kcII/pL0JZigIEYIgQEWWMngF5GO+7n/bLNZC6VSkNEIAhQkSUEXoGhvG1LXKALJ4vB4iwaF6qi8UQISJKd94AeeeAHCCP6dMjQACGCBFRWnMNjvgFyKNpFCAAQ4SIKG25Bkfw1ZbX8M6BfiwaDxBVGgUIwBAhIkpLE2sgi8absNItQACGCBFR2nGPB8i/PumTayB16RkgAEOEiCituAdH8NXxAFk4Tw6QFYvTM0AAhggRUdqYWANZOK8Qj+kvTOsAARgiRERpQTwyghsefB1v+2ogF2LF4vmpLta0GCJERCkmHpFrIG/t78PCeTPxaN2FWHlC+gcIwBAhIkqpwABZlTEBAjBEiIhSxtuE9db+PpTOnYk/ZViAAAwRIqKU6D1yDDc8+Dr2fCwHyKP6VTgtwwIEYIgQESVdtgQIwBAhIkoqb4C8+XGvrwkrUwMEYIgQESVN79Fj+PpDcoCUjAfI6SdmboAADBEioqToPXoMX3/wdez+yBsgF2Z8gAAMESKihOs9egzfmBQgZ5y4INXFiguGCBFRAnkD5I2PelE8Zwb+uD57AgRgiBARJUzf0DF846EdvgD5U90qnHlS9gQIABSkugDTaW5uhsPhgN1uh8vlgkajgdFoDHquzWaD1WqFSqWCKIoAgIaGhpjPJSKKVN/QMXz9wR14Y584XgPJvgAB0jxEDAYD6uvrodfrAQCiKKK6uhrFxcXo6uqCUqn0nWuxWNDa2gqz2ew7ZrPZoNVqYbVa/d43knOJiCLVN3QM35gUIGednH0BAgAKSZKkVBciGIvFAkEQoFar/Y6Looji4mJoNBrfDV8URZSVlQUECwBUVFQEBFG454arr68PRUVF6O3txYIF2fmLQkTh6Rs6hm8+tAM7PxShnDMDf8rQAAn3vpa2fSLt7e0BAQIASqUSer0eNpvN1wzV1tYGQRACQgEAamtrYTKZfI8jOZeIKBL9kwLkj+svzMgAiUTahkhzczO0Wm3Q5yoqKgAAHR0dAACz2YySkpKg5wqCALvd7gucSM4lIgpX/3gn+s4PRRTNnoFHbroQnzm5KNXFSri0DZHKysqQz3lv8t4w6OjogCAIQc/1Hnc6nRGfS0QUjok1kKLZcg3k7FOyP0CANA4Rq9UaspPb4XAAgK+5SxTFoM1TE3mDIZJziYim0z90DDc+3A57DgYIkOajs0Jpbm4Ou/PbGxgulytu5w4PD2N4eNj3uK+vL6yyEFF2GRgexY0Pt6PzA3dOBgiQxjWRUAwGAwRBCDlXJBk2bdqEoqIi39fSpUtTVhYiSo2B4VF886Ed6PzAjQWzCnIyQIA4hUh3d3c83mZadrsdzc3NsFqt0zZJeU3uP4nHuY2Njejt7fV97du3L6yyEFF2GBgexY1+AbIqJwMEiEOIXH311VCpVElp0qmursbWrVtDdownS2FhIRYsWOD3RUS5YWB4FN96eAc6JgTIOUtyM0CAOISIVqvFc889l/AbqVarhclkCjp3RBCEkJ3h3v4Nb/BEci4R0UTeAGnvlgPkkfUX5nSAAHFqzlqzZs205zQ2Nkb9/vX19TAYDNBoNEGfV6vVIed2eAPDGz6RnEtE5DU4IUDmjwfIuUuUqS5WysUcInq9Hps3b8auXbumPC/aYbNNTU2orq4OCBCn0wmbzQZArqWEen+Hw+H32kjOJSICvAHSfjxAbmKAeMW8dtaGDRvgcrl8q+wKghDQMe19fmxsLKL3tlgsUCqVQW/sFosFarUagiD41sPq7OwMaIpSqVQwGo3Q6XQAENG54eLaWUTZa3B4FN/6v3bs6HL5AuS8pcpUFyvhwr2vxRwiJSUlqKysnLIJyO12w2KxoKenJ+z3tdvtMBgMqK6u9jvubYpqbW1FZ2en73iwlXktFgtMJlNYq/iGOjccDBGi7HRkRJ4HsqPLhfmFBfjD+gtxfg4ECBD+fS3myYaCIOC5556b9jy32x3R+65ZswaiKPqarIJddyKdTgelUgmDweC3R0iwUIjkXCLKDcfGPPjQdQSOgwNwHBqE49AA7B+44Tw8mHMBEomYayJdXV0oKyuL23mZiDURoszRP3RMDomDA3Ac8n4N4oOeQRwbC7wdzi8swO9vugDlpxanoLSpk7SayMRg2LZtG+x2O9rb2yEIAi644AJce+21AecRESWSJEk40DeE9w8O+NUsHIcG8GnfcMjXzZ6RD9XiuVAtmgfVonlYsXgeqpaXYNH8wiSWPrPEZe2s7u5u3x4fgLwGlbeJqKKiAhaLBcuWLYvHpYiIfIZHx9B9+IgcEAeP1yochwZwZCT0QJ7F8wvloBgPjBWL5dA4ccEs5OUpkvgdZL64hIhOp0N9fT3MZjOKio5PvOnq6oLZbIZGo0FnZyebeogoKuKREblW4Q2J8X9/6DoCT4gG+YI8BZaVzhkPi3njtYu5UC2ehwWzZiT3G8hiMfeJbN68GevWrZuyucput8NsNmPTpk2xXCptsU+EKHZjHgn7xaMTwmIAjoNyraJncCTk6+YXFhwPiQlNUctK52BGfsatMZs2ktYnIknStP0darUaW7dujfVSRJQFjo6MwXl4YDwsBn1NUV2HBzE86gn5ulOUsyEsmjuhZjEXKxbNw6L5hVAo2ASVKjGHSHFxeCMW+CET5RZJktDe7cZ7n/b7NUN9LB4N+ZqZ+XkoWzh3vI9irq+GUbZwLuYWZuT2R1kv5k8l3P3II5loSESZ7/utu/CXXfuDPqecMwMrJnRoe5uhlhTPQT47tjNKXIb4btmyBevXrw95TmNjI1QqVayXIqIM8dTu/fjLrv3Iz1Pg8pULj4+AGg+NkrkzU11EipOYO9YBoKamBl1dXbjuuutQXl4OQK6hOJ1O3/Ltra2tMRc2XbFjnei4wwPDuPoXL8I1OILbVq/A7VefnuoiURSS1rEOAG1tbWhubsbGjRshiiIUCgW82WQ0GnHnnXfG4zJElAF+/OQeuAZHcMaJ83HL6pWpLg4lWFxqIhN1dXXB6XRCEIScmaXOmgiR7Knd+3HLn3YiP0+BJ2++JGe3jM0GSa2JdHd3Y/ny5QDkPpJcCQ8iOu7wwDB+/ORbAICbr1QxQHJERu2xTkTpi81YuSlj9lgnovT1992f4B9vHkB+ngKbq8/DzALOFM8VGbHHOhGlr8MDw/jPJ/cAYDNWLkr7PdaJKL2xGSu3xdyxvnHjRrhcLphMpmn3WCei7MJmLIo5RFpbW1FZWYl169aFPMftdrMmQpRl2IxFQBrvsU5E6e2uJ99iMxbF3idiNpvDOs9oNMZ6KSJKE3/f/Qn+/uYnbMai2EOkrKwM3d3dYZ1HRJmvZ0Iz1nfYjJXzONmQiCLy4wnNWLeyGSvncbIhEYWNzVg0GScbElFY2IxFwXCyIRGFhc1YFAwnGxLRtCY2Y/1cx2YsOo6TDYloSj0Dw/jxhGasc5awGYuO42RDIprSj598Cz1sxqIQONmQiEJiMxZNJy6TDeN5HhGlBzZjUTgibs7q6+uD0+mEy+UCAKxevdrv+d7eXjQ3N6Onpwe9vb1QKpVQqVSorKzE+eefH5dCE1Hi/fivcjPW6SfMxy2rV6S6OJSmwg6RFStWoKurC2q1GvX19aioqEB5eXnAeUVFRbjzzjt9j5ubm6HX65GXl4fR0dH4lJqIEuofb36Cv+8+PqmwsCA/1UWiNBV2iLhcLtTV1eGBBx6I6AJ6vR4AsGHDhshKRkQp0TMwjP/8i9yMteEKNmPR1CLqE4k0QLz0ej2KiviLSJQJJjZj3bqGzVg0tbBrIpWVlQHHQs1SFwQhYC2tYK8novTCZiyKVNg1keLi4oBjkiTB4XBAp9OhoqLCN2s93NcTUfpgMxZFI6bJhuXl5SgvL0dZWRlqampw//33x6tcRJRkbMaiaMRl5pBarYYgCPF4KyJKATZjUbTiNv1UqVTG662IKInYjEWxCDtERFGc8nmFQhHT64koNe5iMxbFIOw+kfb2dpSWloZ8XhTFaZ8novTy9Juf4Ck2Y1EMIupYLysrC9grJBw9PT3TblpFRMnVMzCMH7EZi2IU0TyRcJZ8D+Xqq6+O+rVEFH9sxqJ4CLtPRKvVxnShWF9PRPHDZiyKF4UkSVKqCzEVURRhMBigVCpD7klSXV2NkpIS1NfXQ61WQxRFdHR0wGQyobGxEWq12u98m80Gq9UKlUrl66tpaGiIuox9fX0oKipCb29vwEx9onTjGhyB9v/9Ez2DI7jlqhW4Y+3pqS4SpaFw72sx72yYKAaDAU6nE1VVVbDZbNBoNCHPFUURFosFzc3NvmNKpRJmszkgQCwWC1pbW/0207LZbNBqtbBarfH/RojSzI+f3MNmLIqbtA2RibWO1tbWKc9Vq9UwGAyw2+0A5LW7dDpdwHmiKKKurg5dXV1+xzUaDQwGg2/ZeqJsNbEZ6+fV57IZi2KWtiESKY1GM2VtBQDa2togCELQiZG1tbUwmUwMEcparsER/Of4ToXfvkLAuUuUqS0QZYWc2jDZbDaHHKIsCALsdjvns1DW+vGTe3B4YASnnTAPt61ZmeriUJbIqRDp6OgIucaX97jT6UxmkYiSgqOxKFGypjnL6XTCZrP5HjscDjQ2Nvo1XYmiOO0aX06nM6AzfrLh4WEMDw/7Hvf19UVVZqJkYDMWJVJWhIjT6YTdbvfrz7Db7aioqEBnZ2dYi0N6zwm1H8pEmzZtwt133x1tcYmS6q6/vsVmLEqYrGjOMpvNAaOx1Go11Go16urq4n69xsZG9Pb2+r727dsX92sQxcMzez7B397Yz2YsSpisqImEotVqUV9fH9a53g71cNYGKywsRGFhYSxFI0o41+CIb20sNmNRosQcIt3d3Vi+fHnA8ccffxxOpxMKhQJqtRqrV6+O9VIR8waC3W6ftp+DKNuwGYuSIebmLIPBEPT4unXrcOedd+KOO+5AcXExtmzZEuulgqqvrw9Zhsn9HIIghBx9NfEcokzHZixKlphDJJylt8rLy2O9TEhtbW0hg8F7vLKyEgB862pNdS5rLJTp2IxFyRRziEy3oyEgD4Ht7OyM9VJB6fV6v3WwJrJarX4z1LVabcjAcTgc0854J8oEbMaiZIqoT2Tnzp0wmUy+vg5AnsC3du3aoOe7XC6Iogin0xnyRh+rqqqqoH0e3kUZJ163pqbGt7Dj5GYri8UScpVgokzBZixKtohCpLy8HA888AAA+aar1+tRWlqKsrKyoOeXlZVBpVJBo9HE1KQlimLI+Rs6nQ719fW+ZeC91qxZA71e7zf0V6lUoqWlBQaDwS9cLBZLyEUbiTLFxGas+svZjEXJEdN+Ik6nExs3bkRbW1s8ywQAaGpqQnt7u28iISAvsqhUKlFbWxtww29qakJPT48vcIKd48X9RCgb3fboTvz1jf1YuXgenrrtUtZCKCbh3tdi3pSqpaUlIRP6MglDhFLtmT0H8O1HOpGfp8ATGy7GeUuVqS4SZbhw72sxd6x7A6S7uxtbtmxBY2Oj77ne3l5s27Yt1ksQ0RTkZqw3AcjNWAwQSqa4LHuyceNGCIKAhoYGv90Fi4qKUFxcjM2bN8fjMkQUxE/GR2OtXDwP39VwNBYlV8wh0tLSAqfTCYfDAZfL5RcigNwZX1dXl7DJhkS57Jk9B/BXjsaiFIp52ROHw+HXsR5s3oi3RkJE8eNmMxalgZhrIiqVyu9xqH76yfuaE1Fs7mIzFqWBpMxYB+QaCxHFB5uxKF3EHCJutxtPPPGE73GwUNmwYQMqKipivRQRgc1YlF5inicCyAscKhQK1NbWwuFwoLq6GqIoor29Hc3NzdBoNGhtbY1HedMS54lQMnFSISVDuPe1uGxK1dHRgaamJt+s7+bmZkiSBKVSCaPRmPOTEYnixduMlacAm7EoLcSlJjJRV1eXb4HDUGtqZRvWRCgZ3IMj0P7iRRweGMaGK1UwfPaMVBeJsljSZqxfffXVfnNAysrKsGbNmqAB8sQTT6CyshJr167Frl27Yr00UU75yd/ewuGBYaxcPA/f42gsShMxN2dVV1dj/fr10563c+dOrF+/Hi0tLSgqKvKtpMu/3Imm9+xbB/DkLrkZ6+dsxqI0Epc+EUCuZbS2tkIQBFx33XU477zz/J7fuHEjjEYj1q1bB0CeX9Lc3Iw77rgjXkUgykruwRH8x5/Hl3i/QoXzORqL0khcFmAsKSmBTqeDw+GA2WyGWq3Ggw8+6HdeR0cHtFqt73FZWVlYW+sS5To2Y1E6izlEtmzZAqPRCI/Hg46ODrz//vvo6enBs88+i76+Pt95oihi+fLlfq/1bltLRMGxGYvSXcwh8v777wcM4fUO7bXZbADkJeGDCXe2O1EuYjMWZYKYQ6S0tDTocYVCMW1zlXdXQSIKNLEZ67tr2IxF6SnmEFEqlQH7hXR3d6O+vt7XB+J0OoMGyuHDh2O9PFHWOToyhsYn3vRrxpo1g81YlJ7i0rG+Y8cO5OfnY+XKlSgtLYVKpUJZWRlsNhtaWlpQXV0No9HoN5/kiSeeQFVVVayXJ8oqb+/vwzW/3o5Hd3wIhQJo/NyZbMaitBa3Ges2mw02mw0qlQoajQZlZWXo7e1FR0cHKisrUVRUhI0bN6KrqwslJSVwOp149tln43HplOOMdYqVJEl4+OVu3PP0OxgZ82Dx/EL8ovZ8XLJiYaqLRjkq3Pta3Jc9mc7jjz8Ol8uVVetpMUQoFocHhnGH+Q288O4hAIDmzBPQpDsXJXNnprhklMuSugBjd3d3wPDdULyTDYkI+Od7h/CDtjdweGAYhQV5+NEXzsQNq5Zx5CJljJhD5Oqrr8bWrVvhdrv5VzhRmIZHx/DzZ97FlpfkHT9PP2E+7r2+HKefOD/FJSOKTMwhotVqYTAYGCBEYXIcGsB3H9uJPR/Lk3G/cdEy/PDzZ3IEFmWkmEdnAcCaNWumPaexsTEelyLKWJIkoa19H6659yXs+bgPxXNmoOUblfivL5/NAKGMFXOI6PV6bN68edql3Z1OZ6yXIspYvUeP4ZZHd6Lh8d04emwMF6tK8fR3L4f2rBNSXTSimMTcnLVx40a4XC6YTCa4XC4IgoCSkhK/c1wuF+x2e6yXIspI7d0ufO+xXfhYPIqCPAV+cPXpqL9cQF4eO88p88UcIq2traisrJxy1JXb7WZNhHLO6JgHv3n+fdy7dS88ErCsdA7uva4c53HyIGWRmENEEAQ899xz057ndrtjvRRRxvjIfQTfb92F9m759/4r6lPwX18+G/MK47aFD1FaiPk32mw2h3xu69at6OrqQmVlJYxGY6yXIsoIf9/9CTY+sRv9Q6OYX1iA/772bHz5/FNSXSyihIg5RILtpe7lHbW1c+dObN26NaxtdIky1ZGRUfzkr2+hreMjAED5qUrce105lpbMSXHJiBInLkN8pyMIwpQ1FqJMt+fjXlxz70to6/gICgVwy1Ur0FZ/EQOEsl5cGmi3bdsGg8EQtPPcu2cIm7MoG3k8Eh56uQvGZ97BsTEJJxXNwi9qz8cqIfg+O0TZJuYQ2blzJ3Q6HfR6PfR6PTo7O1FRUYGSkhK4XC50dnZCq9VyzSzKOgf7h3CHeTdefE9eOHHtZ06Acd25UM7hwomUO2IOkebmZnR1daGoqAgAUFlZieLiYt+CjHV1dejq6sK2bduwevXqWC9HlBaef/cg7jS/gcMDI5g1Iw8/vuYzuP6CpVw4kXJOzH0iarXaFyCAvNOhd291r7KyMs4ToawwPDqGu//2Fr71cDsOD4zgjBPn42+3XIqvXngqA4RyUswhMvl/nLKyMnR2dsb6tkRp5/2D/fi3+17Bwy93AwBuvHg5/nLzJVh5AlfepdwVc4h4JxF2d3dj27ZtAICioiI8+OCDfudZrdZYL0WUEpIk4dEdH+KaX7+Ef33Sh9K5M/HQjZX4yZc+w4UTKefFvLNhb28vNm3aBIvFArfbjZ6eHoiiCEEQsGLFCqxZswY2mw2VlZW4//7741XutMKdDbOXeGQEjU+8iaf3HAAAXLZyIf63+jwsXjArxSUjSqy4b4+7ZcsWOBwOiKIIpVKJ0tJSqNVqX2f5zp07oVQqfZMPnU4nqqursXPnTmi12qzZTz0Yhkh2et3Zg++17sInvUOYka9Aw9ozcNOlZVw4kXJC3EOkpKQEVVVVeOCBB6acpZ6LGCLZZXTMg19t3Yv7nn8fHgkoWzgX915XjnOWFE3/YqIskZA91s1mM2+SlNX2uY7gu4/thP1DEQBQU7kEd33xM5jLhROJggr7/4zKykoGCGW1J3d9jB/9eQ/6h0cxf1YBNn3lHFxz7smpLhZRWgs7RJRKZUwX2rBhQ1Qd66IowmAwQKlUTrl0is1mg9VqhUql8i210tDQEPO5lP0GhuWFEy2d8sKJFcuK8avrzseSYq57RTSdsEMk1olULpcrovO9a3FVVVXBZrNBo9GEPNdisaC1tdVvkUebzQatVhswtDiScyn77f5IxG2P7kR3zxHkKYBbV6/EratXoCA/KWuTEmW8sDvWq6qqYLFYUFxcHPFFXC4XtFot9u7dG/FrAaCiogKVlZUwmUwBz4miiLKyMnR1dQXUlioqKlBfXw+9Xh/xuZFgx3rm8XgkNG93YvOz72LUI+Hkoln45XXluKCsZPoXE+WAuHesOxwOCIIQl8LFU1tbGwRBCNrcVltbC5PJ5AuGSM6l7HWwbwi3t72Bl94/DAD4wjkn4WfXnoOiOTNSXDKizBPRkJM777wzqou43W5YLJaoXjsds9mMkpLgfz0KggC73e6b2xLJuZSdbG9/iobHd8M1OILZM/Lxky+dhZpKLpxIFK2wQ0Sj0eCee+6J+kJdXV1Rv3YqHR0dqKmpCfqct+bkdDqhVqsjOpeyy9CxMWz6x7/wu1c/AAB85uQFuPf6cqgWzUtxyYgyW9i9h7H+pZaov+7DqTl4VxCO5FzKHu992o9/u+9lX4Csv7QMT3znYgYIURyEXRPxDoWNVmNjY0yvj4Y3MMIZGRbJucPDwxgeHvY97uvri6p8lFiSJOGR1z/Efz/1NoZHPVg4byY2V5+HK09fnOqiEWWNsEMk1r/Qy8vLY3p9Otm0aRPuvvvuVBeDpnB4YBg/fOJNPPf2pwCAK09fhJ/rzsOi+YUpLhlRdgk7RHp6evDggw/ipptuSmR54spbewrVmR7tuY2Njbj99tt9j/v6+rB06dKoykjxMTrmwRsf9eLF9w5h+95D2LVPhEcCZubnwfC5M/Cti5dz4USiBAg7RIqLi1FXV4fnnnsOtbW1EAQBgiDk5LyIwsJCFBbyL9pU2+c6ghf3HsL29w7jZcdh9A+N+j1/zilFuGfdOfjMyVw4kShRIponAsj7h7hcLoiiCJfLlfIQEQQhZFObt3/DO/IqknMp/fQPHcOrjh5s33sY2/ceQnfPEb/nlXNm4JIVC3H5yoW4dOUinKKcnaKSEuWOiJcmLSoq8ttTPdXUanXITn9vYHiH7EZyLqXemEfC7o9EX2jYPxQx5jm+wEJBngLqZcW4fOVCXLZyEc4+pQj5bLIiSqqMX99aq9WGXJjR4XD4rbkVybmUGh+5j+ClvYfx4t5DePn9HvQePeb3vLBwLi4bD41VqlLM4xLtRCmV8f8H1tTU+BZrnNwUZbFY/EIjknMpOQaHR/GaU26ienHvITgPDfo9v2BWAS5ZIYfGZSsXYmkJV9YlSicZESLe/pdglEolWlpaYDAY/FbmtVgsEAQBOp0uqnMpMTweCXv298qh8d4h2D9049jY8Saq/DwFypcq5dA4bSHOPaWIK+oSpbG0DZGmpia0t7fD6XT6vrRaLZRKJWpra/1u+DqdDkqlEgaDwW+PkGBLu0dyLsXHJ71Hsf09bxPVYbiP+DdRLSud42uiukhVigWzuBAiUaYIeyl4Co1Lwfs7MjKK17tcvuB4/+CA3/PzCwtwkaoUl58mN1EtK52bopISUSgJ2WOdKBiPR8Lbn/T5RlF1dLsxMubxPZ+nAM4bb6K6fOVCnLdUiRlsoiLKCgwRisqnfUO+0Hhp72H0DI74PX+KcjYuP00OjYtVC7lXB1GWYohQWIaOjY03UR3C9r2H8e6n/X7Pz52ZP6GJahGWl87hHh1EOSDmEOnu7sby5csDjj/++ONwOp1QKBRQq9VYvXp1rJeiJJIkCe8c6Mf2vXJovN7lwsjo8SYqhQI495Qi39Db8lOLMbOATVREuSbmjvXa2lq0trZOec7OnTvR2dmJ9evXx3KptJVtHes7P3TjO3+045PeIb/jJxXNwuXjQ28vUS1E8dyZKSohESVa0jrWw8mg8vJydHZ2xnopSgKPR8IP/7wHn/QOYfaMfKwSSnxNVKpFc9lERUR+Yg6RcG4qfX19WV0TySbPvX0A//qkD/MKC/Biw1UoYW2DiKYQUYjs3LkTJpPJ19cByHucr127Nuj53tV+nU6n3wxxSk8ej4RfWPcCAL51yXIGCBFNK6IQKS8vxwMPPABAXipEr9ejtLQUZWVlQc8vKyuDSqWCRqPJqp0Ns9U/9nyCdz/tx/zCAqy/lEviE9H0om7O0ul0UKvV2Lhxoy9YKHONeST80ibXQm66rIzzOogoLDGNyRQEAVqtNl5loRR6avd+vH9wAAtmFeDfLw1esyQimizmgf11dXUhn+vu7kZ3d3esl6AEGx3z4FfjtRD95QIXQCSisMU8Omvjxo3o6upCSUkJqqursXr1auzcuRMajQYlJSUoLy+HQqGYdi4Jpc5f39gP5+FBKOfMwDcvXp7q4hBRBok5RKqqqqBSqfxqJNXV1VizZg3a2toAyPuyb968GXfccUesl6M4Gx3z4N6tx2sh81kLIaIIxBwiXV1dfuHw+OOPo6urC3a73Xcs3fZlp+P+vPNjdPccQcncmfjmRctTXRwiyjAx94lMDger1QpBELJi+Y9sd2zMg3u3ybWQb18hYC73KyeiCMUcIqWlpX6PbTYbNBpNwHklJSWxXori7PHOj7DPdRQL583EDauWpbo4lG2ODQEH9gDc9y6rxRwiDofD9++dO3fC6XSiurra75xdu3ZxzaU0MzLqwa+3vQ8A+PYVKsyZyVoIxZHzn8D9FwEPXAI0Xwm89yzDJEvFfOfQ6XSoqalBaWkpWltbodPpfMu+b926FWazGWazGVu3bo25sBQ/5s59+Fg8ikXzC1kLofg56gae+xGw85Hjxz7ZBfypBjilArjyh8CKNfJeApQV4rLHem9vL2w2GwRB8C1v0tXVBZvN5juntLQUX/nKV2K9VFrKtKXgh0fHcOXPX8AnvUP4yRfPwo2XcHIhxUiSgLf/AvyjARg8KB+rWg9cdAvQ+TCwowU4dkQ+vuQC4KofAsKVDJM0Fu59LS4hAsgTC202G5xOJ372s58BkMOls7Mz6zekyrQQ+f2r3fjxk2/hxAWz8MKdV2LWjPxUF4kyWe/HwD/uAN79h/x44enAl+4FTl11/JyBg8DLvwLatwCj4/vUnHqRHCZllye/zDStcO9rcdmKbuPGjRAEAQ0NDTCZTL7jRUVFKC4uxubNm+NxGYqDoWNjuO95uS/k5qtUDBCKnscj1zDuu1AOkLwZwBUbgW9v9w8QAJi3GFj7P8B33wAu3ADkFwIfvgr87ovA/10DdL+cmu+BYhZziLS0tMDpdMLhcMDlcqG5udnv+fLyctTV1WHLli2xXori4NEdH+LTvmGcXDQLNVVLU10cylQH3wEe/qxcAxnpl5uovr0duKoRKCgM/br5JwKfuwf47i7gAj2QPxPo3g783+eB330J+PC1pH0LFB8xd6w7HA7fzHQg+CZV3hoJpdbRkTH89gV5NN0tq1eisIC1EIrQ6DDw0i+A7f8LjI0AM+cBmp8AlTcBeRH8TbrgZODzPwcu+a78XvY/AF3/lL9Uq+UO+KVVCfs2KH5iromoVCq/x6G6WLq6umK9FMXoj69/gEP9w1hSPBu6iiWpLg5lmg9fB0yXAy9skgPktM8CN78OXFAXWYBMVLQEuOYXwG12QP1NIK8AcGwDHtQAj+iAj7mtdrqLOUTCnf8xcT4JJd+RkVHcP14LuXX1CswsiEt3GOWCoT7g73cAD60FDr0DzF0E6B4Crn9MDoF4UJ4qd8bf2gmU3wAo8oH3rUDLauBP1wH7d8XnOhR3Md9J3G43nnjiCd/jYKGyYcMGVFRUxHopisEfXv0APYMjOLVkDr6iZi2EwvTuM8BvVwHtLQAk4PwbgJt3AGevS8zw3OLlwJfvA25pB877KqDIA957Gmi+Anjsa8CBN+N/TYpJXIb4VlZWQqFQoLa2Fg6HA9XV1RBFEe3t7WhuboZGo8nqpeDTfYjvwPAoLjNug/vIMWyuPo9NWTS9gYPA0wbgrfE/EIuXA1/8lTy3I5kOvw+82ATsbgMwfqs680vAlY3ACWcltyw5JunzRJqamrBx40b5TRUKSJIEpVIJo9E45cZV2SDdQ+S+59/Hz599F2UL58L6/ctRkM+mLApBkoBdfwSe/Q9gSJSblS6+RR66O3NO6sp16F3gn0ZgzxOQw0QBfOZa4MqNwKLTU1euLJb0EPHq6uqC0+mEIAgoK8uNmdDpHCL9Q8dwqfF59B49hl/Unodry1kLoRBcTuBv3wW6XpQfn3gu8KVfAyefn9Ji+Tn4L+CFe+TZ8QAABXCODrjCACxcmcqSZZ2UhUguSucQ+fXWvfhf63sQFs2F9ftXID+Py0zQJGOjwKu/kUddjQ4BBbPl+R6rbgby03RhzgN7gH/eA/zrb/JjRR5wTg1wRQNQqpr6tRSWpM5YD0dtbW2yLkXjeo8eQ8t2JwDge5rTGCAUaP8uoOUqwHaXHCBlVwDfeUWev5GuAQIAJ54N1D4C1L8InP55QPIAux8DflMF/OU7gItTCpIlbr8lu3btgsvlCvqcKIp+Ox1Scjz0Uhf6hkZx2gnz8IVzTkp1cSidjBwBXvgZ8OpvAWkMmKUE1v4MOP+rmbUo4knnAdc/Cnxsl5u59j4r9+nsbgXOux64/E6gmKtUJ1JctsetqKiAKIpTnsf9RJKr98gxPPSS/NfYd9ewFkITOJ4Hnvoe4O6WH5+9DvjsPfL6VpnqFDXwtTbgo045HN+3ATv/ALzxKFD+deCyHwBKLvOTCDE3ZxkMBrS0tMDtdsPj8YT8WrNmTTzKS2Ha8pIT/cOjOOPE+fjc2SemujiUDo645KaeP/ybHCALTgGub5UnDmZygEy0pAK44XHgJisgXAV4RuWl6H+tBv7+A3nFYYqrmEOkqqoK69atC9hrfTKtVhvrpShM7sERXy3ke5rTkMdaSG6TJOBNi9xfsOuPABTABfXykiWnfzbVpUuMpRcA3/gL8K2ngeWXycu0tG8B7i2X9zzpP5DqEmaNmEMk3IUV77zzzlgvRWFq3u7E4MgYPnPyAqz9zAmpLg6lkrgP+FMt8PhNwJHDwKIzgJueAz7fBBTOT3XpEm/ZxcCNTwHffApYdgkwNgzsMAG/Og945ofypEqKScwhIkkS+vr6pj1v4tIolDg9A8P43SvdAIDva05jX1Su8owBr5vkJUv2PisvuX7lD4H67fJf6bmm7DLgxr8D33gSWHqhPBLttfuAX54rb+c7eDjVJcxYMYdIXV0d2trasGvXrinPy+ZlT9JJ84tOHBkZw7lLirDmzCxp56bIHPyXvFji0w3AyACwdBXw7ZeAKw1AwcxUly51FAp52ZZ/fxa44QnglEpg9Cjwyq/lMLHeBQz2pLqUGSfmyYZr164FAHR0dEAURQiCAKVS6XeOKIpwOp0YGxuL5VJpK10mGx7qH8ZlTdswdMyDh2+swlVnMERyyugw8OJmeb8PzzFg5nxA+xOg4t+jX6o9m0mSPIrr+f8B9u+Uj82cB1z4beCim4E5JaktX4olbcZ6SUkJNBoNBEFAaWlp0HMOHz6MLVu2oKcnO1M+XULkp0+9jQdf6sL5S5X483cuZlNWLvngVeBvtwGH35Mfn/554PObgaJTUluuTCBJwHvPAM//DDiwWz5WuABYtQFY9R1gtjKlxUuVcO9rMc8TEQTBb2fDULgpVWId7BvCI699AAC4Xcu+kJwx1AvY7gY6HpQfz10s7xh41pcza9JgKikUwOmfkzfZeufv8vIvn+6RF3x87QHgzC/KQTKrSA6XwvnArAUT/j3h+IxZqf5uki7mEDGbzWGd19LSEuulaAq/fcGB4VEPKpYV47KVC1NdHEqGd/4uz33o/0R+XP514OqfArO5FXVUFArgzGvkWtw7fwOe3wQc+hew65Hw3yN/ZpCgWTApdEIEkPf4zHkZ1fwYc4hMXKl327ZtsNvtaG9vhyAIuOCCC3DttdcCwLTzSCh6B/uG8KcdHwLgiKyc0H9A7jR/+0n5cYkg7/VRdnlqy5Ut8vLkmtwZX5Q3xPr0bWC4V97hcbgfGO4L/PdIv/zasRF5KPWRWEZ7KeRQCRo6EQRTkgZRxGXtrO7ubuj1ethsNgCAUqn0LYNSUVEBi8WCZcsSu35NdXU1SkpKUF9fD7VaDVEU0dHRAZPJhMbGRqjVar/zbTYbrFYrVCqVr6wNDQ0JLWOiNL/oxMioB+pTlbhkRfB+KcoCkgTYfw8895/yTU2RD1xym7wM+ozZqS5d9snLA874gvw1HY9HDpKhPjlYhif+uy/E8X65OXLicc8xANLx18Uiv/B4uJzxeeDq/47t/UKIS4jodDrU19fDbDb71Ti6urpgNpuh0WjQ2dmZ0E5nURRhsVjQ3NzsO6ZUKmE2mwMCxGKxoLW11a8pzmazQavVwmq1JqyMidAzMIw/vi7XQm5ds5K1kGzV45D3+ujeLj8+6Xx5r4+Tzk1psWhcXp5cA5gVQ4uLJMnzV3xBM1Xtpzd0rejYoPx+Y8PA4CH560jwxXHjIebRWZs3b8a6deum3IDKbrfDbDZj06ZNsVxqSgaDAVqt1rdasCAI0Ol0AeeJooiysjJ0dXUFDEWuqKhAfX099Hp9RNdO5egs4zPv4P4XHDh3SRGevPkShki2GTsGvHIv8IJRvinMmANc9R/yMNR0XqqdUmdsdEKtaDxcZhcDi8+M6G2SNjpLkqRpdzBUq9XYunVrrJealkajgUajmfKctra2oHNZAHnPE5PJFHGIpIp4ZAS/H5+dfstVK+IXIO4PAPvvgBVaYNlF8XlPitzHncBfb5NHCgGAajVwzS/k/c6JQskvkEMjSQMsYg6RcNfOSpe/kM1mM0pKgk8iEgQBdrsdoigGDZl089DL3RgcGcMZJ86H9qw4rZG1fxfwx2pg8CCw/X/lxeuuMMjLRlByfLIb2L4ZePuvACT5ZvDZe4Bzazlsl9JOzOPIpttHxCtdJhp2dHRAEISgz3mPO53OZBYpKn1Dx/Dwy/Lcm1tXx6kv5P2twP99QQ6QolOBvBlyG/zvrgEe/jzgfEFut6XE2LcD+GMNYLpsfOSVJG/5enM7cN51DBBKS3EZ4rtlyxasX78+5DmNjY1QqRK/77HT6fSNEAMAh8OBxsZGv1pFOLUMp9MZ0Bmfbn7/Sjf6h0axYvG8+OwX8kYr8OR35P0Xyq6Qtx4d7gNe+qXctPXBy8DvvywvXndFA6Baw5taPEiSHNQv/hzoelE+psiTN4q69HbghLNSWz6iacQcIuvWrUNNTQ1MJhOuu+46lJeXAzi+XpbJZIJarU5opzog3/jtdrtff4bdbkdFRQU6OzvDap7ynhNqm1+v4eFhDA8P+x6Hs4pxPA0Oj+LB8f1CbrlqRWz7hUgS8PKv5D22AeBsHfBv98tjzGctAL6wGbjsduDle+XNffa9DjyyDjhZLTdznbaWYRINSQL2WuVmq32vy8fyCuQax6W3A6WJ/6OLKB7iMryjra0Nzc3N2LhxI0RRhEKhgHfQl9FoTMpeIsFmzqvVaqjVatTV1YU9sz4cmzZtwt133x2394vUI699APeRY1heOgfXnBvD3umeMeDZHwKvPyA/vugWQPvTwNmyC04GPncPcOn35ZFCHQ8B++3Ao7XAiefKYXL65zNqlm3KeDzAO0/JNQ/vOk35hYD6G/KcD+WpqS0fUYTiNkZQr9dDr9ejq6sLTqcTgiBMO2orGbRaLerr68M619u/E6rj3auxsRG3336773FfXx+WLk3O/s1HR8bQsl3us/nOVStQkB/ljfvYEPBn/fFZz2t/Jq9cOpX5JwBr/we45HvAq78BdrTIN8LWrwEnnA1cfidw5pcYJsGMjQJvPSEPVjj0jnxsxlyg6t/l8J7PLYwpM8V9oHlZWVlahIeXNxDsdnvc+jkKCwtRWFgYl/eK1KM7PsThgREsKZ6Na8ujXKH1qAg89jXgg5fktX7+7X7gnMA5NSHNWwRo7wYuvg147bfy5kef7gHM3wQWnQlcfgfwmWuBvPzoypdNRkeANx6Vl2d3jy9CWlgEXKgHLtwAzOUKA5TZwv6TccOGDTFdKNbXT6W+vh4GgyHoc5P7OQRBCDn6auI56Wjo2BhMLzoAABuuVGFGNLWQ3o+Bhz8nB0jhAuCGxyMLkInmlgJr/hP4/pvAFRvlm+Ohf8lbsd53odxZPzYa3XtnumNHgdeb5T29/3abHCCzS4DV4z+v1T9igFBWCLsmEuuw10QOm21raws5ydB73crKSgDwras11bnpOjLL3PkRPu0bxklFs6CrWBL5Gxz8l9wp3vcxMO9E4AYLcOI5sRdsdjFwVSNw0XfkG+ervwF69srNZf+8B7jsDuDcGiB/RuzXSnfD/XKf0Su/kYdKA/LP+uJbgcpvATPnprZ8RHEWdohYrVbk5+dHNQkv3Lkk0dLr9TAajUGfs1qtfjPUtVptyHMdDse0M95TZWTUgwdekGsh9ZcLKCyIsKnog1fljvChXmDhaXINJN6duLOKgCvuBFZ9W+4vefU3gMspDx3+pxG47AfAeddn5xatR0VgR7PcvHfULR8rWgpc+j3g/Btycp8Jyg1hr51VUlICQRBCdjp3dHT4/tqfrKenB7t27UrY9rgWiwWCIATUIERRRHFxMcxms28dLe/aWZ2dnQHNViqVCkajMeiaW1NJxtpZre0fwvD4m1g4rxAvGa7CrBkRhMjbfwUeXy+vvbT0QuD6x5Kz9efwwPhf5ffKi8AB4zfW7wPlNwAFqelXiqvBw8Cr98mh6V0OvEQlB2au1L4oK4V9X5PCVF1dndDnY6XX66XOzk6/Y2q1WtLr9QHnms1mSafTBRzTaDRRXbu3t1cCIPX29kb1+ukcGx2TLjNuk5YZnpKa/+mI7MWvN0vSXUWSdNcCSfrT9ZI0ciQhZZzS8KAkvXKfJP18pVyOuxZI0uYzJOk1kySNHE1+eeKh92NJenqjJP30hOPf032rJGm3WZLGRlNdOqKYhXtfC7s5q6qqasrnp1t2Y7rXx8pkMqGpqQmtra0QRREulwuNjY1BaxU6nQ5KpRIGg8FvP5F0XQb+r2/sx4euIyiZOxNfWxVmE5QkAdt+Kg8pBYCKb8l7bqdi5deZc+T+kspvAfY/yCOV+vcDT98pl++S2+TyzZyT/LJFyv0B8PIvgZ2PyBsQAcDJ5fLw5tM+x+HNlHNiXgreq7a2Fq2trfF4q4yTyOasMY8E7S/+CeehQdy59nTcfNWKMF50TN57Ytcf5cdX/UgedpsuM8tHh+Wb8Eu/AHr3ycfmLhrvfL4JKJyX2vIFc3gvsP3/AbtbAWm8WfbUi+Wfq2p1+vxsieIkaUvBU+J85D6CR177EM5DgyiaPQPfuCiM3SGHBwDzjcD7Vnnnuy/+Up4NnU4KCoGqm+Q9wXc/Bry4GRA/AKw/ltfquvgWoKpOXnYl1Q7skZcmeesvAMb/3lKtlkecLb8klSUjSgsMkTTTdXgQT+/5BM/sOYDdH/X6jt90aRnmz5qmk3bgEPCnamD/Tnnzour/k9e2SlcFM+WAO+96YHebfLN2OYGt/yWv1XXRzcAFemC2Mvll+6hTLs+7/zh+7PQvAJf/ADilIvnlIUpTYYfIhg0bcP/994d8frpWscbGxoQvwpiJJEnCu5/245k9B/DMngN450C/7zmFAqhaXoIvnnsSvnrhNLUQlxP4w1fkSW1zSoGvmoElGXKzy58BlH9N3i9jz+PyulI9e4Hn/0eeb7Hq2/JOfskYUdb9snx95/PjBxTy7PvLfgCceHbir0+UYeI22XC6jnXvtrUk6zo8iLaOfXhmzwF0HR70HS/IU+AiVSk+e/aJuPqsE7FofhjDYId6jweIchlwwxPAwjD6TtJNfgFwXq08g/6tP8s380PvyHNMXv2tvFTIqpvjP9NbkgDHVrlZ7cNX5WOK/PEVdb8PLFwZ3+sRZZGwO9bz8vKm3MVwun06RFFM2DyRVIumY/2ZPQfw7Uc6AQAzC/Jw+cqF+OzZJ0Fz5mIo50QwGU+SgNYb5JVhi04F1tvkhRKzgccD/Ouvcph4t4idMRe4YD1w0a3yGl6xvv+7/5Df/5Nd8rH8mXJfzSXfBYrD6IMiylLh3tfiNtlwKomebJhq0YTI0ZExGB7fDe1ZJ+CqMxZjXmGU3VOv/hZ4tlHehfCmZ7Ozvd7jAd57Wq6RfPKGfKxgttw5f/Gtka+A6xmTazrb/xc4+LZ8bMYceZjxxbcCC2JYXp8oS8Q9RGpqatDW1hZ1gWJ9fTpLxoz1oPbtkBdT9IwCn/u53NyTzSQJ2Psc8MI98n4mAFAwC6i4Ua45LDh56tePHZOH6G7/f4BLXkIGhQuAC+qAVd8B5i5MaPGJMknch/jGOlkw0ZMNc85gjzyU1zMqd/xeUJfqEiWeQiGPNlt5tdyH8YIR+GiHvKlWx0PjGzt9D1BO2tvl2BCw8w/yDo7eeSmzi+X+lQvqUjP6iyhLxG2yYS5Lek3E4wH+VCPPBSlRAfoX0mNORbJJEtD1TzlMPnxFPpY3PtLr0u8DcxbKW/q+8mtg4FP5+bmLxyc1/nt6TmokShNxb86i0JIeIi9ulpc0KZgFrN/KoacA0P2S3GfS9aL8WJEPFM4HhkT58YIl8oq65TcAM2anqpREGYMz1rNV14vy/AlAXguLASJbfqn89cGrwItNgGObHCAlAnDp7fIclGxcgp4oxRgimaT/U8ByEyB5gPO/Bqi/nuoSpZ9lFwFf/zOwfxdw1AUsvzw1i04S5Qj+35UpxkblbWcHDwKLz5JrIRTayeenugREOYHrVmeKF34GdG8HZs4Dan6fGcumE1HWY4hkgr3W4/uCfPFXXIaDiNIGQyTdubqAJ8bngFStl9eVIiJKE+wTSVcDB+VNm9oflPdGP+l8YO3PUl0qIiI/DJF0M9gDvPIrYEcLcOyIfGzpKmDdFnkzJyKiNMIQSRdH3fLeGa8/AIwMyMdOVgOr/wNQreH2q0SUlhgiqTbUB7x2P/DqfcDw+E6GJ54DXPUfwGmfZXgQUVpjiKTK8ACwoxl45V65FgLI8z+ubATOuAbI45gHIkp/DJFUeeNRYOvd8r8XngZcuRE461qGBxFlFIZIqpR/HXj7SXlBwHOqgbz8VJeIiChiDJFUmTELuPGpVJeCiCgmbDshIqKoMUSIiChqDBEiIooaQ4SIiKLGECEioqgxRIiIKGoMESIiihpDhIiIosYQISKiqDFEiIgoagwRIiKKGkOEiIiixhAhIqKoMUSIiChqDBEiIooaQ4SIiKLGECEioqgxRIiIKGoMESIiilrO77Fus9lgtVqhUqkgiiIAoKGhIallGBodwsEjB/HpkU/x6ZFPcfDIQfnxoPzvvpE+lMwqwQlzT8AJc8a/xv+9eM5iLJy9EAV5oT/KUc8ohseGMTQ6JP93bAgjYyO+xxOf836NjI1AAQXy8/KRp8hDvkL+b0Fegd/j/Lz84/9W5Pu+8vKOP/adn5eHAsU0rw/yeOL5FF+SJMEjeTAmjWHUM4oxaQxjnjGMSqMY84wFfTzqGQ14HOo8j+SBQqGAAgrff/MUeUEfQwHkIQ8KhcL3WYc6d+J7TndO0Peapix+jxUKv5+ZAvJj73Hf40nHfedPc573ccjzQ7z++H+mOX9SeeItp0PEYrGgtbUVZrPZd8xms0Gr1cJqtSb02u0H2rFpxyYcPHIQvcO9057f3dcd8rk8RR4Wzl4IZaESI2MjAcEwJo3FseSp5QuhPP/gChU6vptNiJsHIP9P5r15Tb6ZTb5h+f130ntOviGGuumFem2wG2O4N3Xv8TEp+HOjntGQ70PZ7wvCF3DPZfck5L1zNkREUURdXR26urr8jms0GhgMBjQ3N0Ov1yfs+goosNe91/d4Vv4snDBXrlksnrPYV8s4Yc4JKCosQs/RHl9N5dPB4zWWQ0cOYVQa9dVeplOYX4jC/ELMyp+FmfkzMatglu9YYX4hCguOPydJknyzkcbkv1Y98n9HpVHfX6/e475/T7iZeSSPfL5n0vne9/Qc//fE86cyKo0CEoCpT6M4KFAUoCCvwFc7LMgr8KstTnxcoAj+nLcW4JE8kCBBkiRIkAIeS5IEDzyAdPxc7+9CwPnj50587cTz/V4vBXl9iOv7yjHhOc/4L5okSb6yZKLJtZ14ytkQaWtrgyAIUCqVAc/V1tbCZDIlNEROLzkd92vu9wXFgpkLoqp2jnnG4BpyyTWakV6/QJiVPwuFBYV+xxJdtY2VN7gmhk5ACE0XWt6Q84z5/qeffPOABL8bETB+8/HeTELc4CY+nnhj8b7W9z4T32PCe/pujFLoxxPLk6fIw4y8GVPfvCO8yU98Taj3CNaMQ4Emh0vAY2/o+P4zzfmSf0hN974B54c4b2bezCi/w+nlbIiYzWaUlJQEfU4QBNjtdoiiGDRk4mH+zPm49JRLY36f/Lx8LJqzCIvmLIpDqVJPoVCgQJGzv5aUYQL6NXIwd3O2p7KjowOCIAR9znvc6XQms0hERBknZ0MknFoGQ4SIaGpsNwjCGy4ulyvo88PDwxgeHvY97uvrS0axiIjSTs7WRGKxadMmFBUV+b6WLl2a6iIREaUEQyQI76TDUB3vjY2N6O3t9X3t27cviaUjIkofbM6KQmFhIQoLC1NdDCKilMvZmoggCCE7zr19IaFGbxERkSxnQ0StVvuarSbzhotarU5iiYiIMk/OhohWqw1ZE3E4HNBoNEkuERFR5snZEKmpqYHL5QoaJBaLBfX19SkoFRFRZsnZjnWlUomWlhYYDAa/VXwtFgsEQYBOpwv7vbzr1XC+CBFlC+/9bPL6XJPlbIgAgE6ng1KphMFg8NtPJNJl4Pv7+wGA80WIKOv09/ejqKgo5PMKabqYoWl5PB7s378f8+fPh0KhQF9fH5YuXYp9+/ZhwYIFqS4exRk/3+zHz1iugfT39+Pkk09GXl7ono+cronES15eHpYsWRJwfMGCBTn7C5gL+Plmv1z/jKeqgXjlbMc6ERHFjiFCRERRY4gkQGFhIe666y4ujZKl+PlmP37G4WPHOhERRY01ESIiihpDhIiIosYQISKiqDFEiIgoapxsGEc2mw1Wq9VvCZWGhobUFoqCqq6uRklJCerr633bAnR0dMBkMqGxsTFgG4BIPlv+HiSfKIowGAxQKpUwGo0hz0vU55jTn7lEcWE2myWdTud3zGq1ShqNJkUloqloNBoJgN+XUqmUrFZrwLmRfLb8PUiuhoYGSafTSUajURIEQdLr9SHPTdTnmOufOUMkDtxut6RUKiW32x3wnFqtlkwmU/ILRVNqaGiQrFarZDQaJaPRKJnN5qDnRfLZ8vcgtdRqdcgQSdTnyM9cktgnEgdtbW0QBAFKpTLgudraWphMpuQXiqal0WjQ0NCAhoaGkEv/R/LZ8vcgfSXqc+Rnzo71uDCbzSgpKQn6nCAIsNvtIbfipfQWyWfL34P0lajPkZ85QyQuOjo6IAhC0Oe8x0NtxUvpLZLPlr8H6StRnyM/c4ZIXIiiGLQ6O1G2/yJlIqfTiebmZt+XwWAI+Ksxks+WvwfpK1GfIz9zDvFNOO8vmMvlSm1ByI/T6YTdboder/cds9vtqKioQGdn57Q3BiCyz5a/B+krUZ9jrnzmrIlQTjKbzQGd6Wq1Gmq1GnV1dSkqFVHmYYgkmLd5JFTnG6UXrVYLi8US1rmRfLb8PUhfifocc+UzZ4gQTeD9H95ut6e4JESZgSESB4IghOw887aHhhrBQclXX18Pg8EQ9LnJ7diRfLb8PUhfifoc+ZkzROLCu/ZSMN5fsMlrMVHqtLW1hfwf33u8srISQGSfLX8P0leiPkd+5gyRuNBqtSFvSg6HAxqNJskloqno9XqYzeagz1mtVr8ZyJF8tvw9SF+J+hz5mYMLMMaDd/0ch8MR8JwgCCHXZaLUMJvNUmdnZ8Bxt9stAfD7vCL5bPl7kFrhrJ0V78+RnzkXYIybYCt5ms3mnFnJM9Po9fqAIAl1E4rks+XvQeoIghDws58oUZ9jrn/mCkmSpFTXhrJFTu8pkIGamprQ09MDURThcrlQW1sbciFG7i2RnpqamtDe3u6bPArIC2sqlcqgnyf3E4k/hggREUWNHetERBQ1hggREUWNIUJERFFjiBARUdQYIkREFDWGCBERRY0hQkREUWOIEBFR1BgiREQUNYYIERFFjSFCCafVagOONTU1wWazRfxeTU1N0Gq1UCgUUCgUYe9AKIoiiouLoVAooNVqQ25KNd17aLVaqFQqVFRURPz6bNXU1ITq6mq/n299fX3Aec3NzVCpVFAoFCguLkZ1dXUKSktxl9r1HynbORyOoKuZqtXqoMtnh6uhoUFSKpUhl/6ezGQySRqNRhIEIepreul0OkmtVgccFwQh7PIEE+vrU02tVktKpXLa8wRBiOmzp/TCmggllM1mC1oTEUUxpm1DS0tLodfr0dbWFtHrvJtNxaKqqiph7x+P8qWKd3/66eh0uqzfMjaXMEQoocxmc8DubjabLS47vtXX10MURVgslinPs9vtSdlhzuFwwGg0puz1RKnAEKGE6ujoCNhj2mw2B62dREoQBKjVarS2tk5bBv7lS5QYDBFKmFA1gHjVRACgtrYWFovFtxFQMOE2sxBR5ApSXQDKXsH6Q0RRhFKpjFvbv16vh8FgQFtbG/R6fdAyhBNYoiiiubnZV67Ozk7U19cH1KJC0Wq1cDqdUCqV6OzsDHjeYrGgvb0dpaWl6OnpgUql8itvOK/3Ph9s5zxRFLFmzRrfz3fiezQ1NcFkMsHlcgU0LzqdTlgsFgiCAJfL5euram9vT2rTWiTlaGpq8n1ODofD72fpdDpRXV0Np9OJmpoaGI1GNDc3AwCsViusVmtafd9ZIdU9+5S9NBpNwCgcs9ksNTQ0xPzeRqPR7zrBRktJkjwqK5zzJpfJ7XZLSqVSslqtQa8d7H30en3Q4w0NDQF7cLvd7oBrhnq9Tqfz+z4kSR71FmyEW6iRYw6HQwLg9/243e6ge5KbTKYp9yoPRaPRhDU6K9jPOtxyqNVqyWw2+x3T6XQB76nRaCSdTuf7PbFarRIAyeFwxP37znVszqKY1dfXQ6VSBXx5ayITj9XV1fnmC3i/Yu0fqa+vh91uh9Pp9Dse7ggwu93u+0vfS6lU+mo54VKpVAHHbDYbmpqa0NLS4nfc+5fwxGsGe31zczOcTmdALUsQBNTX1wfMxwg1cizYz8FmswVt6tPr9UltAgy3HE1NTQAQsG+60WhEU1OT389SrVb7NadqNBq43W4IgpA233e2YIhQzEwmExwOh9+XyWSCTqcLOF5SUgK32+13zNvEEC2dTgelUgmTyeR3PNymLKVSCZfLFRBCKpUq4FikDAaDr3wTuVwuuFyusF5fW1sb9LmamhrYbLaoJm0CcrC0tbUFnbCZzImA4ZYj1M9CEAQolcqAn4PL5fJrjvR+BunyfWcL9olQQtjt9qD9IYlSU1OD5uZmv/bscG7SgHxTcbvdvsdOpxOiKAbtm4hUqMEF3r+Mp+ItR6h+Ge9NMdohzGq1GhqNBhUVFRAEARqNBlqtFjqdLilDoiMphzfMHQ5HyCHdDofD73GoWmi6fN/ZgjURSoj29nZUVlb6Hevo6EjY/6TeOSPev0adTmfA9aciiiIMBgPq6+ths9mgVCpjXtrEe+MrLS2N6fVTUSqVaG9vj+r9AXm4tdVqhUajgc1mQ3V1NVQqVdjLyUwuS6LK4f1ZVFdXQ6fTBXy53e6ADvGpmqbi+X3nOoYIJYTdbg/4C9pqtSZszSm1Wg1BEGA2mwHITVnhjqxyOp0oKyuDSqWCyWSCXq+HIAgxt497/xLu6emJ6fVT1eBimfnvvTFrNBpfk6Tb7YZarcaaNWsifr+qqqqoapvhlCOcn0U8r0fhY4hQzCZ3rBcXF8PpdAZ0tDc1NcFgMAQcj8fEQ285vMM5I1FdXQ1BEAI6ryc3h0XT9yAIwpQ1iqluit4bZ6jXe49PtQzLVNcJ1p+iVCphNptRUlIScX+Qt5Y51c/J+3sRaTm8/R5T1brCDZh4f9+5jiFCMZvcsW40GmE0GgM61b19D5OPR9OxHuyve++onerq6oiazUL1KXR2dvrdmKK5uRiNxpCTIZ1O57TBZDQaAwYMeFksFqjVar/RShPnkUwU6jremttk4dbiJr9Gr9dPOc/CaDQGnc8TTjkmzvmYzG63o6OjI+yyxvP7znUMEYo7b1vzRPGcpQ7IQ18n3yy9y6CEauLxTiqbzNsuPpHT6fTVkERRhN1u9+tjCfVX7+TjOp0Oer0+6Kgfi8USMFx18usbGhqgVqsDhhrb7XaYTKaAm2FNTY2vQ37ie3prVZODMNgoJe9ro2km8wbe5O9XFMWgQ5IjKYder4dGowl4D29f2MTfr4nfc7TXo/AoJEmSUl0Iyi7FxcUBI48MBgOqqqoCbpqR8s6+9s7envyXr3fkzsTrNDU1ob293e+5qqoqvxnf9fX1cLlcvuDwjtppamqC1WpFdXU1ampqUFdXB5vNBlEUodPpUF9fj8rKSr/jGo0GRqPR769ai8UCq9UKlUrlmyXt/YtcFMVpX9/c3AyHw+HrpO/p6UFjY2PQzmybzQaTyYSqqirf83q9HgqFAkqlEhqNBmaz2Tdj2xss3puuKIp+P5toNDc3w2w2+2pGgiDAaDQGLW+k5WhubkZnZ2fQn6XT6YTBYPD7jLzXjvZ6NDWGCMWV3W6HwWAIaKKqqKjA1q1bM3qpcyIKxOYsiivvcMmJRFH0relERNmFIUJxlYz+ECJKHwwRiivvcMyJvH0KRJR9GCIUN06nM2iNw+VysSZClKXYsU5ERFFjTYSIiKLGECEioqgxRIiIKGoMESIiihpDhIiIosYQISKiqDFEiIgoagwRIiKK2v8H+17cHLaa7QMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "P1 = DF.loc['Naive, Response', 'Def 1 Friend', 'FB', :]\n",
    "ax.plot(list(P1.index), P1['Hon T Max Error'])\n",
    "P2 = DF.loc['RR, Response', 'Def 1 Friend', 'FB', :]\n",
    "ax.plot(list(P2.index), P2['Hon T Max Error'])\n",
    "P3 = DF.loc['RR+Laplace, Response', 'Def 1 Friend', 'FB', :]\n",
    "ax.plot(list(P3.index), P3['Hon T Max Error'])\n",
    "ax.set_xlabel('\\# Malicious Users')\n",
    "ax.set_ylabel('Honest Target Error')\n",
    "plt.savefig(path+'fb_def_vary_nmal.pdf', bbox_inches = \"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "f5fd4a3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Either L1 error or convert to scatter plot\n",
    "fig, ax = plt.subplots()\n",
    "P1 = DF.loc['Naive, Response', 'Inf+Def Comm', 'FB', :]\n",
    "ax.plot(list(P1.index), np.sqrt(P1['Hon T L2 Error']**2 + P1['Mal L2 Error']**2))\n",
    "P2 = DF.loc['RR, Response', 'Inf+Def Comm', 'FB', :]\n",
    "ax.plot(list(P2.index), np.sqrt(P2['Hon T L2 Error']**2 + P2['Mal L2 Error']**2))\n",
    "P3 = DF.loc['RR+Laplace, Response', 'Inf+Def Comm', 'FB', :]\n",
    "ax.plot(list(P3.index), np.sqrt(P3['Hon T L2 Error']**2 + P3['Mal L2 Error']**2))\n",
    "ax.set_xlabel('\\# Malicious Users')\n",
    "ax.set_ylabel('L2 Error')\n",
    "plt.savefig(path+'fb_l2_vary_nmal.pdf', bbox_inches = \"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0825a17d",
   "metadata": {},
   "source": [
    "### Varying Epsilon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "389f7b12",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[95], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m data_vary_eps \u001b[38;5;241m=\u001b[39m \u001b[43mcollect_data_new\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mDef 1 Friend\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mInf+Def Comm\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43m2 Inf Comm\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mg\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mFB\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0.03\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0.1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.2\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.3\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.5\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.75\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1.0\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1.5\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m2.0\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m2.5\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m3.0\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m4.0\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mthresh_values\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m{\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mmed\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m:\u001b[49m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m0.1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m}\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mlist\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mcomms\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;28;43mlist\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mcomms\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m10\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "Cell \u001b[0;32mIn[10], line 32\u001b[0m, in \u001b[0;36mcollect_data_new\u001b[0;34m(attack_names, g, g_name, max_adv, epsilons, thresh_values, attack_values, comm, reps)\u001b[0m\n\u001b[1;32m     30\u001b[0m E[i]\u001b[38;5;241m.\u001b[39mthreshold_reduction \u001b[38;5;241m=\u001b[39m thresh_values[tv]\n\u001b[1;32m     31\u001b[0m E[i]\u001b[38;5;241m.\u001b[39minflation_factors \u001b[38;5;241m=\u001b[39m attack_values[av]\n\u001b[0;32m---> 32\u001b[0m d \u001b[38;5;241m=\u001b[39m \u001b[43mE\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_results\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m     33\u001b[0m h \u001b[38;5;241m=\u001b[39m {\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mProtocol\u001b[39m\u001b[38;5;124m'\u001b[39m: labels[i], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mAttack\u001b[39m\u001b[38;5;124m'\u001b[39m: attack_names[a_i], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mAttack Strength\u001b[39m\u001b[38;5;124m'\u001b[39m: av, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mThreshold Strength\u001b[39m\u001b[38;5;124m'\u001b[39m: tv, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mEps\u001b[39m\u001b[38;5;124m'\u001b[39m: epsilon, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mGraph\u001b[39m\u001b[38;5;124m'\u001b[39m: g_name,\n\u001b[1;32m     34\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMal Max Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m0\u001b[39m][\u001b[38;5;241m0\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMal L2 Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m0\u001b[39m][\u001b[38;5;241m1\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMal Mean Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m0\u001b[39m][\u001b[38;5;241m2\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMal T Nan\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m1\u001b[39m][\u001b[38;5;241m0\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMal T Tot\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m1\u001b[39m][\u001b[38;5;241m1\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMal Nan\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m2\u001b[39m],\n\u001b[1;32m     35\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mNum Mal\u001b[39m\u001b[38;5;124m'\u001b[39m: n_mal, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHon T Max Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m3\u001b[39m][\u001b[38;5;241m0\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHon T L2 Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m3\u001b[39m][\u001b[38;5;241m1\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHon T Mean Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m3\u001b[39m][\u001b[38;5;241m2\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHon T Nan\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m4\u001b[39m][\u001b[38;5;241m0\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHon T Tot\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m4\u001b[39m][\u001b[38;5;241m1\u001b[39m],\n\u001b[1;32m     36\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mRest Max Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m5\u001b[39m][\u001b[38;5;241m0\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mRest L2 Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m5\u001b[39m][\u001b[38;5;241m1\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mRest Mean Error\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m5\u001b[39m][\u001b[38;5;241m2\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mRest Nan\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m6\u001b[39m][\u001b[38;5;241m0\u001b[39m], \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mRest Tot\u001b[39m\u001b[38;5;124m'\u001b[39m: d[\u001b[38;5;241m6\u001b[39m][\u001b[38;5;241m1\u001b[39m]\n\u001b[1;32m     37\u001b[0m }\n\u001b[1;32m     38\u001b[0m data\u001b[38;5;241m.\u001b[39mappend(h)\n",
      "File \u001b[0;32m~/Documents/GraphPoisoning/graphpoisoning/experiments.py:203\u001b[0m, in \u001b[0;36mManipulation.get_results\u001b[0;34m(self, verbose)\u001b[0m\n\u001b[1;32m    201\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mget_results\u001b[39m(\u001b[38;5;28mself\u001b[39m, verbose\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m):\n\u001b[1;32m    202\u001b[0m     D1 \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_degree_estimates()\n\u001b[0;32m--> 203\u001b[0m     D2 \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43minput_graph\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_degree_vec\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    204\u001b[0m     target_diffs \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m    205\u001b[0m     target_num_na \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n",
      "File \u001b[0;32m~/Documents/GraphPoisoning/graphpoisoning/experiments.py:22\u001b[0m, in \u001b[0;36mGraph.get_degree_vec\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m     21\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mget_degree_vec\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[0;32m---> 22\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmatrix_\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msum\u001b[49m\u001b[43m(\u001b[49m\u001b[43maxis\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39mastype(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mint\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "File \u001b[0;32m~/.python/environments/jupyter/lib/python3.8/site-packages/numpy/core/_methods.py:49\u001b[0m, in \u001b[0;36m_sum\u001b[0;34m(a, axis, dtype, out, keepdims, initial, where)\u001b[0m\n\u001b[1;32m     47\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_sum\u001b[39m(a, axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, dtype\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, out\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, keepdims\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m,\n\u001b[1;32m     48\u001b[0m          initial\u001b[38;5;241m=\u001b[39m_NoValue, where\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m):\n\u001b[0;32m---> 49\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mumr_sum\u001b[49m\u001b[43m(\u001b[49m\u001b[43ma\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43maxis\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdtype\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mout\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkeepdims\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minitial\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mwhere\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "data_vary_eps = collect_data_new(['Def 1 Friend','Inf+Def Comm','2 Inf Comm'], g, 'FB', [0.03], [0.1, 0.2, 0.3, 0.5, 0.75, 1.0, 1.5, 2.0, 2.5, 3.0, 4.0], thresh_values, {'med': (0.1, 0.1)}, list(comms[1]) + list(comms[0]), 10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "6af8ea41",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_vary_eps = pd.DataFrame(data_vary_eps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "2c02ea5b",
   "metadata": {},
   "outputs": [],
   "source": [
    "DF2 = data_vary_eps.drop(['Threshold Strength', 'Attack Strength'], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "e013341d",
   "metadata": {},
   "outputs": [],
   "source": [
    "DF2 = DF2.groupby(['Protocol', 'Attack', 'Graph', 'Eps']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "604bc8a4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA/0AAAGDCAYAAAB5iHD4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABAuUlEQVR4nO3dXWwb6Z3v+R8l2XJ32iJFJ5lMJ043i87Zwe5ZnDYlBXuxwAIt0gEWBwtMLFq5WGAPFi1q+mYv5kyL1s0OchOHhu/TpN33K5HtARaLA7RJ+2bvYon2nEVmcHCaJXWc9iSTFlmk+8VvUu2FTLYokhJLRfFN3w8gSKx66nkeqSSx/v96nqc8tm3bAgAAAAAAQ2ek1x0AAAAAAADHg6AfAAAAAIAhRdAPAAAAAMCQIugHAAAAAGBIEfQDAAAAADCkCPoBAAAAABhSBP0AAAAAAAypsV53YBjs7Ozo8ePHOnv2rDweT6+7AwAAAAAYcrZt68mTJ3rzzTc1MtL6fj5Bfwc8fvxY58+f73U3AAAAAAAnzKNHj/SjH/2o5X6C/g44e/aspN0f9sTERI97AwAAAAAYdpVKRefPn6/Fo60Q9HdAdUj/xMQEQT8AAAAAoGsOm2LOQn4AAAAAAAwpgn4AAAAAAIYUQT8AAAAAAEOKoB8AAAAAgCFF0A8AAAAAwJAi6AcAAAAAYEgR9AMAAAAAMKQI+gEAAAAAGFIE/QAAAAAADCmCfgAAAAAAhtRYrzuA7tjZsfV//F8P9JfeM/qh7zW96XtNP5x8TT/0vSbva6fk8Xh63UUAAAAAQIcR9J8Qf/7ymf6f//wvTfd95/So3tyXCKgmBt70ndEPJs5obJRBIQAAAAAwaAj6T4gzY6P6P//9f6vH1jf63Pqm9vmLL5/rq+fb+q//+qX+679+2fTYEY/0g4kz+uHkq8SA79vP1W1vjPOrBAAAAAD9hkjthPC+fkr/+/8YaNj+9MW2Hlvf6LH1VI+tb/SHakKg9I0el7/Rv1hP9Xx7R4/LT/W4/FRSqXn9r516lQionz7wpu81/cj3mr77xrhGRphCAAAAAADdRNB/wp05NSrje2/I+N4bTffv7Nj64stn+nzvCIHSN/r8VZLgc+sblb95Ufv453+pNK3n1KhHf+l9bd96AmfqRg6cOTV6nN8qAAAAAJw4BP040MiIR9+fOKPvT5zRxR9PNi3z5bOX9dMGSt/sef1Uf6w81YttW78vfq3fF79u2dZ33zhdlwSoTSF4lSSYfJ0FBwEAAADACYJ+uPbG+Jj+zV+c1b/5i7NN97/c3tGfnjzbM0rg2wRBddtXz7f1xZfP9cWXz/Wf/1BuWs+ZUyP1iYA9yYEfTb6mv5g4o9NjLDgIAAAAAFUE/Th2Y6MjtSB95u3G/bZtq/LNS/3B+lqPraf6vPS1Hpef7iYHXo0a+Ncnz/T0xY7MP38l889fNW3H45H+4uwZvek7ox9Ovr772Vc/pWDizKnj/WYBAAAAoI8Q9KPnPB6PvK+fkvd1r/67N71Nyzx7ua0/1iUCnurzapLg1ciB5y939MfK7nSC/O+tpvWcHR/bs8jgGf3Qtyc5MPmavn/2jEZZcBAAAADAkCDox0AYHxvVW+e+o7fOfafpftu2tfXV87r1BPY+mvCx9VTFr57rybOX+i9/eqL/8qcnTesZG/HoB94zddMI9i88+Ppp/mwAAAAADAaiFwwFj8ej774xru++Ma5/d97XtMzXz1/WRgY8rnsSwe7HH8tP9XLH1h9K3+gPpW9atjX5+qm6BQd/NPla3evvvnGaBQcBAAAA9AWCfpwYr58e04Xvv6EL32/+eMLtHVt/fvJMn1tf63Pr6b6nEOx+fvL0pUpfv1Dp6xf63ePmjyc8PTbyKgFwpn6xwVef/9J3RuNjPJ4QAAAAwPEj6AdeGX01tP8H3jOaeqt5mcrTF/seS/i07lGFf3ryVM9f7mjji6+08UXzBQcl6Xtnx/ckAs40PKbwtdOjGh3xaGzEw6gBAAAAAEdG0A84MHHmlCZ+cEp/9YOJpvtfbO/UFhysJQfKu9MFqqMFnr7Y0Z+fPNOfnzzTPz6yDm1zxCONjYzUkgCjox6Nejx1r/fuH/F4NDa6Z//It/tHR/Zv92h0ZGT3uP3bR+v3Ozp2pNqHkW/72rRPqqu/bt++73OEBRYBAAAAxwj6gQ46NTqi8/7Xdd7/etP9tm2r9PXuaIFqImD/FIIvvnxed8yOLT3f3pG2u/Ed9C+PR3VJgRHP7uMgGxMR1Y8myYTRV0mRvftH9xxXlzBprPvb5MbIvuSGZ19yY6TFcY31Nkt2HHTsiEeM/gAAAEDbCPqBLvJ4PPJ/57T83zmtf/vD5o8nfP5yR8+3d7S9bevlzo62d2xt27Zebtva3rH1cqf6+dW+nf3bbW3v7NTKb9uvtm/v23/QsTu2trf3HPvq9d79O4779Gp/y3p39+/YzX92ti292Lb1YtuWtHN8J2kA1Cc3WiQiPHv270tEjB4wGqT5yI2RxuRGk9EgTUd87Bll0mo0yNFGqDD1BQAAoB0E/UCfOT02otNjI73uRs/Y9gEJg2YJhe29CYNmiYhDkhzbe5IYDUmI3WO3d1RXR+P+1n3atlWfhGn4nprXvd0q+yHp5atyJ13rJMSrUREj0ojHo06mBjqdaOhobR3OgXQ6pdLJn13n+9bBujrcu37ObfXz30Onf24dr6+D323n+9bJyvr3d0Tq9N9+Z52ov69O9q6DVf2v/8Nb+l/+3Zudq7CHCPoB9BXPqzu+J/0BB7Zta8dWLdmxPyGxbdt1o0GaJSoOPHZPIqLtJMd2NTmy02T0yMFJjJc7tnaaJGEaR6Q0fj+tbO/Y2pZ94qe+AACAzpv9q+/3ugsdQ9APAH3I4/Fo1CONjpzs7Ec1+bFdl1g4OJmwd6SF3eEBEZ0eX9Hp/u3W2dlKB+J77nQv+7u63To73scO/94cy3nucH3H0MmO19jn51k6ht/Fgfj76+//s9Jx/A2evP8R/80Pzna4xt4h6AcA9K1vkx/V8XonOwkCAADg1MmdOAwAAAAAwJAj6AcAAAAAYEgR9AMAAAAAMKQI+gEAAAAAGFIE/QAAAAAADCmCfgAAAAAAhhRBPwAAAAAAQ4qgHwAAAACAIdWRoH9zc7MT1QAAAAAAgA5yHfRfunRJwWBQlUqlE/0BAAAAAAAd4jroj0QiunPnjiYmJjrRHwAAAAAA0CEdGd4/Ozt7aJnl5eVONAUAAAAAANrkOuiPxWK6ceOGHj58eGA50zTdNgUAAAAAABwYc1vB1atXVSwWlUwmVSwWZRiG/H5/XZlisah8Pu+2KQAAAAAA4IDroH9lZUXT09O6fPlyyzKlUok7/QAAAAAAdJnroN8wDN25c+fQcqVSyW1TNdevX1coFFI4HG7Yl8vllM1mFQwGZVmWJGlpaalpPU7KAgAAAAAwaFwH/el0uq1yiUTCbVOSJMuyFI/Hm7abyWS0srJSty+XyykSiSibzR65LAAAAAAAg8j1Qn6BQKD29b1793Tjxg3Nz89reXlZ//AP/9C0nBupVKrpdsuytLCwoJs3b9ZtD4fDKhaLdcc5KQsAAAAAwKByfadfkjY3NxWLxZTL5SRJPp+vNlx+ampKmUxGb731lut2crlc0yH9krS6uirDMOTz+Rr2zc/PK5lMKhaLOS4LAAAAAMCgcn2nX5Lm5uYUjUZVKpW0s7OjYrGonZ0dFQoFRaNRhcNhVSoV1+3k83mFQqGm+9LpdMNTA6oMw1A+n68lIpyUBQAAAABgULkO+m/cuKF0Oq2FhQV5vd66fYFAQEtLS1pZWdG1a9dctZNKpQ5cZG9tbU2GYTTdV91efYKAk7IAAAAAAAwq10G/bduHztcPhUIt76y3wzTNQ4+3LKvpcP399TgtCwAAAADAoHI9p39ycrKtch6P58htZDIZV4/Sqwb4xWKxI2WfPXumZ8+e1V53YuoCAAAAAACd5vpOf7tz37e2to5UfyaT0dzc3JGOPS7Xrl2T1+utfZw/f77XXQIAAAAAoEFHHtl369atA8ssLy8rGAw6rtuyLBWLxZbz753UI6mtKQbtlF1eXla5XK59PHr0yFX/AAAAAAA4Dq6H91++fFlXrlxRMpnUL37xC128eFHSbvBsmqaSyaRCodCRFvI7bPG+XhkfH9f4+HivuwEAAAAAwIFcB/3S7nPvU6mUrl69Ksuy5PF4ZNu2JCmRSOiDDz5wXOdBj+drxjCMlovvVefnV0cMOCkLAAAAAMCg6kjQL0mxWEyxWEwbGxsyTVOGYRy6qv9BTNPUysqKkslk3fbq8Ptr165pZWVFfr+/Npqg1foC1QC/mkRwUhYAAAAAgEHVkaB/c3NTb7/9tqTdOf5ugv2qubm5pgv4WZalyclJLS8v1+2PRCJKJBJN6yoUCgqHw0cqCwAAAADAoHK9kN+lS5cUDAZ7/ti6K1euqFgsNh22n8lktLi4eKSyAAAAAAAMKtdBfyQS0Z07dzQxMdGJ/hyqGqhX595X+Xw+3bx5U/F4vG57JpORYRh1owKclAUAAAAAYFB1ZHj/7OzsoWWWl5ePtIJ/VT6f17Vr12pBfzweVzabVSQSUSwWk7Q7JcDn8ykejysYDNbm7Wez2Yb6nJQFAAAAAGAQeezqMvtHVC6XdfPmTYXDYb3zzjsty83Pz2tlZcVNU32rUqnI6/WqXC53bcQDAAAAAODkajcOdX2n/+rVqyoWi0omkyoWizIMQ36/v65MsVhUPp932xQAAAAAAHDAddC/srKi6elpXb58uWWZUqnUdNE8AAAAAABwfFwH/YZh6M6dO4eWK5VKbpsCAAAAAAAOuF69P51Ot1UukUi4bQoAAAAAADjgOugPBALa3NxsqxwAAAAAAOge10H/pUuXFAwGValUOtEfAAAAAADQIa6D/kgkojt37vCoOgAAAAAA+ozroF+SZmdnDy2zvLzciaYAAAAAAECbXAf9sVhMN27c0MOHDw8sxyP7AAAAAADoLteP7Lt69aqKxaKSyaSKxaIMw5Df768rUywWlc/n3TYFAAAAAAAccB30r6ysaHp6WpcvX25ZplQqcacfAAAAAIAucx30G4ahO3fuHFquVCq5bQoAAAAAADjgek5/Op1uq1wikXDbFAAAAAAAcMB10B8IBDpaDgAAAAAAdIbj4f2VSkWmaapYLEqS3n333br95XJZqVRKW1tbKpfL8vl8CgaDmp6e1jvvvNORTgMAAAAAgMN5bNu22yl44cIFbWxsKBQKaXFxUVNTU7p48eKhx6VSKf3N3/yNRkZG9PLlS9cd7keVSkVer1flclkTExO97g4AAAAAYMi1G4e2fae/WCxqYWFBH374oaOOxGIxSdL777/v6DgAAAAAAOBO23f6/X5/bUj/Ubg9vp9xpx8AAAAA0E0dv9M/PT3dsO3hw4dNyxqG0dBos+MBAAAAAMDxaXv1/snJyYZttm2rUChobm5OU1NTSiaTLe/mNzseAAAAAAAcH8er9+918eJFXbx4UYFAQFeuXNFvfvObTvULAAAAAAC41Pad/oOEQiEZhtGJqgAAAAAAQId0JOiXJJ/P16mqAAAAAABAB7Qd9FuWdeB+j8fj6ngAAAAAANBZbc/pv3//vs6dO9dyv2VZh+4HAAAAAADd42ghv0AgIL/f77iRra2tlo/3AwAAAAAAx6PtoH96elp37tw5ckOXLl068rEAAAAAAMC5tuf0RyIRVw25PR4AAAAAADjjsW3b7nUnBl2lUpHX61W5XNbExESvuwMAAAAAGHLtxqEde2QfAAAAAADoLwT9AAAAAAAMKYJ+AAAAAACGFEE/AAAAAABDiqAfAAAAAIAhRdAPAAAAAMCQIugHAAAAAGBIEfQDAAAAADCkCPoBAAAAABhSBP0AAAAAAAypMbcVbG5u6u23327Y/vHHH8s0TXk8HoVCIb377rtumwIAAAAAAA54bNu23VQwPz+vlZWVA8s8ePBA6+vreu+999w01bcqlYq8Xq/K5bImJiZ63R0AAAAAwJBrNw51Pby/nZzBxYsX3TYDAAAAAAAcch30ezyeQ8tUKhWtr6+7bQoAAAAAADjgaE7/gwcPlEwma3P1JWltbU0/+9nPmpYvFouyLEumaSqdTrvvLQAAAAAAaNuR5/RnMhnFYjGdO3dOs7OzLcsFg0GFw+GhHuLPnH4AAAAAQDe1G4e6WsjPNE1dvXpVq6urR61iKBD0AwAAAAC6qSsL+RmGoUgk4qYKAAAAAABwTFwv5LewsCBJ2tzc1K1bt7S8vFzbVy6Xde/ePbdNAAAAAACAI3Ad9EvS1atXZRiGlpaWlEqlatu9Xq8mJyd148aNTjQDAAAAAAAccLR6fzM3b96UaZoqFAoKBAL6+OOP6/ZfvHhRhmHo1q1beu+99xzXb1mWUqmUtra2aq+LxaKWl5cVCoUayudyOWWzWQWDQVmWJUlaWlpqWreTsgAAAAAADBrXQX+hUKhbyK/6KL+9qnf8nbIsS9euXdPy8rJ8Pl9teyaT0dTUlLLZrMLhcN32lZWVuscD5nI5RSIRZbPZurqdlAUAAAAAYBC5Ht4fDAbrXrd6GMDGxobjuldXV5VKpVQsFuu2z83NyefzKR6P17ZZlqWFhQXdvHmzrmw4HFaxWKybduCkLAAAAAAAg8p10N/szn4zhULBcd2GYUhSbej9QVZXV2UYRt2IgKr5+Xklk8kjlQUAAAAAYFC5DvpLpZJu375de90sCfD+++9ramrKcd3hcFilUqnp3H3LsjQ9PV17nU6n5ff7m9ZjGIby+XwteeCkLAAAAAAAg8p10P/BBx/oV7/6lWZmZnTjxg1ls1ndu3dPt2/f1vLyss6dO6disXikRfxauX79uiTVDe9fW1urjQzYr7rdNE3HZQEAAAAAGFSuF/KTdoPo69ev11a+T6VSsm1bPp9PiURCCwsLnWhG0u4d/mQyqXQ6XRe4W5bVdLj+XqZpKhQKOSrbzLNnz/Ts2bPa60ql0nb/AQAAAADolo4E/dLuo+6Wlpa0sbEh0zRlGIYCgUBH6q4+tq9QKKhYLCqbzba8U99MNcDfvyDgUcteu3ZNv/zlL9tuHwAAAACAXnA9vP/SpUu6detW7XUgENDs7GzTgP/27duanp7Wz372Mz18+LDtNnw+n5aWlpRMJrW4uKjFxUVlMhm3XT+y5eVllcvl2sejR4961hcAAAAAAFpxfac/Go22NV//wYMHeu+993Tz5k15vV7F43Gl02lNTEw4ai8cDmt6elqTk5NKJpOKxWKHHlNdlK/V4n1Oy46Pj2t8fLyt/gIAAAAA0Cuu7/RX3b59W/Pz81peXtY//uM/Nuy/evWqEomELl++rHA4rA8//FCpVOpIbfl8Ps3NzWlxcZFV9gEAAAAAaMF10L+wsCC/36+5uTkVCgWl02mFQiF99NFHdeXW1tYUiURqrwOBgGzbPnK7MzMzkqRcLidpd9X9VivuV+fnV9cBcFIWAAAAAIBB5Trov3XrlhKJhHZ2drS2tqZPP/1UW1tb+uSTT+pWtbcsS2+//XbdsYetoD85OaloNNp0X/XYavBeXZW/mb1lnJYFAAAAAGBQuQ76P/3004ZH8lUf1Ve9C18ul5se6/F4WtZrWdaBQ/cLhYKkb+/IRyKRlnfvC4WCwuFw7bWTsgAAAAAADCrXQf+5c+eabvd4PIcO3z8oqPf5fIrFYkqn003353K52tx+Sbpy5YqKxWLTYD6TyWhxcbH22klZAAAAAAAGleug3+fz6caNG3XbNjc3tbi4WJvDb5pm0wTAF198cWDd8Xi86WJ9qVRK+Xxed+/erevHzZs3FY/H68pmMhkZhlFLDjgtCwAAAADAoPLYblbTe+XKlSv6+OOPZRiGisWiLMvSwsKCLl26pK2tLSUSCS0uLmpycrL2eL/bt2/Ltm1dvnz50PqrwbllWSoWi/L7/UokEk3XBMjlcspmswoGg7VkwdLSUtN6nZQ9SKVSkdfrVblcdvwIQgAAAAAAnGo3Du1I0C/tBtC5XE7BYFDhcFiBQEDlcllra2uanp6W1+vV1atXtbGxIb/fL9M09cknn3Si6Z4j6AcAAAAAdFPXg/52ffzxxyoWiw2L/w0ygn4AAAAAQDe1G4eOdaKxzc3NhsfxtdLOcH4AAAAAAOCe64X8Ll26pGAwqEql0on+AAAAAACADnEd9EciEd25c4dh7QAAAAAA9BnXQb8kzc7OHlpmeXm5E00BAAAAAIA2uQ76Y7GYbty4oYcPHx5YzjRNt00BAAAAAAAHXC/kd/XqVRWLRSWTSRWLRRmGIb/fX1emWCwqn8+7bQoAAAAAADjgOuhfWVnR9PT0gavyl0ol7vQDAAAAANBlroN+wzB0586dQ8uVSiW3TQEAAAAAAAdcB/3pdLrlvrt372pjY0PT09NKJBJumwIAAAAAAA64XsgvEAi03Dc7O6v33ntPtm3r7t27bpsCAAAAAAAOdOSRfYcxDOPAEQEAAAAAAKDzOhL037t3TzMzMzp37lzDx+joqPx+vyKRSCeaAgAAAAAAbXI9p//Bgweam5tTLBZTLBbT+vq6pqam5Pf7VSwWtb6+rkgkcuDq/gAAAAAAoPNcB/2pVEobGxvyer2SpOnpaU1OTurtt9+WJC0sLGhjY0P37t3Tu+++67Y5AAAAAADQJtfD+0OhUC3glySfz6dcLldXJhAIyDRNt00BAAAAAAAHXAf9Ho+n7nUgEND6+rrbagEAAAAAgEuug/5SqSRJ2tzc1L179yRJXq9XH330UV25bDbrtikAAAAAAOCAx7Zt200F5XJZ165dUyaTUalU0tbWlizLkmEYunDhgmZnZ5XL5TQ9Pa3f/OY3nep3X6lUKvJ6vSqXy5qYmOh1dwAAAAAAQ67dOLTtoP/WrVsqFAqyLEs+n0/nzp1TKBSqLc734MED+Xw+BQIBSZJpmopGo3rw4IEikYg++eSTDnxb/YmgHwAAAADQTR0P+v1+v2ZmZvThhx/WAnvsIugHAAAAAHRTu3Goo0f2pdNpgloAAAAAAAZE2wv5TU9PE/ADAAAAADBA2g76fT6fq4bef/99V8cDAAAAAABn2g76PR6Pq4aKxaKr4wEAAAAAgDNtz+k3TVOfffaZJicnHTdSLBaVz+cdHwcAAAAAAI6u7aC/UCjIMIzj7AsAAAAAAOggR6v3f/DBB0dqpFQqKZPJHOlYAAAAAABwNG0H/eFwWL/+9a+P3NDGxsaRjwUAAAAAAM51bSE/t6v/AwAAAAAAZ9oO+i3LctXQ8vKyq+MBAAAAAIAzbQf9pmm6aujixYuujgcAAAAAAM60HfRvbW3po48+Os6+AAAAAACADmo76J+cnNTCwoLm5+d1+/ZtPXz4UJVK5Tj7BgAAAAAAXGh79f5CoSBJKpfLKhaLsixLxWJRExMTx9Y5AAAAAABwdG0H/VVer1der/c4+gIAAAAAADqo7eH9AAAAAABgsBD0AwAAAAAwpAj6AQAAAAAYUgT9AAAAAAAMKYJ+AAAAAACGFEE/AAAAAABDiqAfAAAAAIAhdaxB/+bmpjY3N4+zCQAAAAAA0MKY2wquXr2qjY0N+f1+RaNRvfvuu3rw4IHC4bD8fr8uXrwoj8ejlZWVTvQXAAAAAAC0yXXQPzMzo2AwqIWFhdq2aDSq2dlZra6uSpLK5bJu3Lihv/u7v3PbHAAAAAAAaJProH9jY6MumP/444+1sbGhfD5f2+b1euX1et02BQAAAAAAHHA9p39/MJ/NZmUYhiYmJtxWDQAAAAAAXHB9p//cuXN1r3O5nCKRSEM5v99/pPpTqZQKhYLy+byKxaLC4bASiUTTsrlcTtlsVsFgUJZlSZKWlpZclwUAAAAAYBC5DvoLhULt6wcPHsg0TUWj0boyDx8+lMfjcVx3PB7X4uKiYrGYJMmyLEWjUU1OTmpjY0M+n69WNpPJaGVlRel0uratmoDIZrN19TopCwAAAADAoPLYtm27qWBjY0PxeFznzp3TysqKwuFwbQG/e/fuaXV1Vel0Wnfv3tU777zTdr2ZTEaGYSgUCtVttyxLk5OTCofDtQDdsiwFAoGGRIAkTU1NNSQO2i3brkqlIq/Xq3K5zLQGAAAAAMCxazcOdT2nPxAI6ObNmwqHw7p7924t4N/Y2FChUNDU1JR+/etfyzRNR/Xev3+/IeCXJJ/Pp1gsplwuVxuWv7q6KsMwGoJ4SZqfn1cymay9dlIWAAAAAIBB5np4v7S7mN/ly5frtgUCgbrH+DmVSqWUz+ebDrefmpqSJK2trSkcDiudTrdcM8AwDOXzeVmWJZ/P56gsAAAAAACDzPWd/nbNz887Kj89Pd1yX/UOfzV4X1tbk2EYTctWt1dHGjgpCwAAAADAIHN9p//evXuHljFNU7lczlG9By2oV108sDr8v50786ZpKhQKOSoLAAAAAMAgcx30z83N1e68N+PxeORyrcAGqVSq7cX2qgF+sVjsWNlnz57p2bNntdeVSqWtvgAAAAAA0E2uh/f7/X4VCgXt7Ow0fJRKJa2srCiZTGpnZ6cT/VU8HpdhGEokEh2p7yiuXbsmr9db+zh//nzP+gIAAAAAQCuug/7FxUUFAoGm+7xer+bm5nTlyhXdunXLbVPK5/NKpVLKZrNtL7S3f/5/J8ouLy+rXC7XPh49etRWXwAAAAAA6CbXw/s/+OCDQ8t4vd6ODPGPRqO6e/duy4X4umV8fFzj4+M97QMAAAAAAIfp2ur95XLZ1fGRSETJZLLpAnuGYbRccb86P7+aKHBSFgAAAACAQdaVoL9Sqei3v/3tkY9fXFxUPB5XOBxuur+6Kn8z1QC/mixwUhYAAAAAgEHmenj/zMzMgfsty5Jpmgc+gu8g169fVzQabQj4TdOUaZoKh8OKRCItF/YrFAp1xzopCwAAAADAIPPYLifbX7hwQaFQqGXw7/P5dOXKFXm9Xsd1ZzIZ+Xy+poF4JpNRKBSSYRiyLEuBQEDr6+sNQ/ODwaASiYTm5uYkyVHZdlUqFXm9XpXLZU1MTDj8LgEAAAAAcKbdONT1nX6fz6fV1VW31TTI5/NKJpOKRqNKpVK17dWh+SsrK1pfX6/14ebNm4rH40qn07WymUxGhmHUBfFOygIAAAAAMMhc3+kvl8tHuot/mMnJyZZz76XdxfYKhULdtlwup2w2q2AwWDt2aWmp6fFOyh6GO/0AAAAAgG5qNw51HfSDoB8AAAAA0F1dG96/171795TP53X//n0ZhqGf/vSn+uu//utONgEAAAAAANrUkaB/c3NTsVhMuVxO0u68+eqQ+ampKWUyGb311ludaAoAAAAAALRppBOVzM3NKRqNqlQqaWdnR8ViUTs7OyoUCrXH7VUqlU40BQAAAAAA2uR6Tv+NGzd0+fJlBQKBlmXy+bzS6bSuXbvmpqm+xZx+AAAAAEA3tRuHur7Tb9v2gQG/JIVCIfn9frdNAQAAAAAAB1wH/ZOTk22V83g8bpsCAAAAAAAOuA76qwv2HWZra8ttUwAAAAAAwAHXQX8gENCtW7cOLLO8vKxgMOi2KQAAAAAA4IDrhfwk6cqVK9rY2NAvfvELXbx4UdLuCADTNJVMJhUKhbSysuK6s/2KhfwAAAAAAN3Ubhw61onGVldXlUqldPXqVVmWJY/Ho2ouIZFI6IMPPuhEMwAAAAAAwIGO3Onfa2NjQ6ZpyjCMQ1f1Hxbc6QcAAAAAdFNX7/TvFQgEmgb7Dx8+1DvvvNPp5gAAAAAAQAuuF/JrVzwe71ZTAAAAAABADu/0v//++5qcnNSvfvWr2raZmZlDj6su6gcAAAAAALrHUdB/584djYyM1AX9pVJJ4XD4wEfy2batRCJx9F4CAAAAAADHHAX9hUKhYZthGPrwww8PPXZtbc1JUwAAAAAAwKWOr97fSrlcltfr7UZTXcfq/QAAAACAbmo3Du3YQn6bm5va3Nys21Yul3X79m1JGtqAHwAAAACAftWRoP/q1asKh8Oampqq2+71enXx4kXduHGjE80AAAAAAAAHXA/vv3XrlqLRqEzTVLFY1OzsbMty7733npum+hbD+wEAAAAA3dRuHOpoIb9mPv3009od/YNMTk66bQoAAAAAADjgenj/d7/73bbKbWxsuG0KAAAAAAA44Dro/+KLL9oq9+mnn7ptCgAAAAAAOOA66J+ZmdH8/LyePHnSdH+lUtHPfvYzXbp0yW1TAAAAAADAAddz+i9fvqzf/va38vl8mpubk2EYOnfunLa2tmSapjKZjGKxmH7+8593or8AAAAAAKBNrlfvr8rlcrp69ary+Xxtm2EYSiQSunz5ciea6Fus3g8AAAAA6KZ249COBf17bWxsKBAIdLravkXQDwAAAADopnbjUNdz+ptpFvA/fPjwOJoCAAAAAAAtHEvQ30w8Hu9WUwAAAAAAQA4X8nv//fc1OTmpX/3qV7VtMzMzhx5nWZZM03TeOwAAAAAAcGSOgv47d+5oZGSkLugvlUoKh8MKBoMtj7NtW4lE4ui9BAAAAAAAjjkK+guFQsM2wzD04YcfHnrs2tqak6YAAAAAAIBLx7J6fzPlcller7cbTXUdq/cDAAAAALqpp6v3N7O+vt6tpgAAAAAAgLoY9CeTyW41BQAAAAAA5GBOfzur9LfC6v0AAAAAAHRf20F/qVRSKBQ6UvDP6v0AAAAAAHRf20G/YRhaXV09ckOs3g8AAAAAQHe1HfSn02nHld+9e1cbGxuanp7WzZs3HR8PAAAAAACOru2F/I7yuL3Z2Vm99957sm37SEkDAAAAAABwdF1Zvd8wDIJ+AAAAAAC6rCNB/7179zQzM6Nz5841fIyOjsrv9ysSiXSiKQAAAAAA0Ka25/S38uDBA83NzSkWiykWi2l9fV1TU1Py+/0qFotaX19XJBLR5cuXO9FfAAAAAADQJtdBfyqV0sbGRm3O//T0tCYnJ/X2229LkhYWFrSxsaF79+7p3XffddscAAAAAABok+vh/aFQqG6RP5/Pp1wuV1cmEAjINE23TQEAAAAAAAdcB/0ej6fudSAQ0Pr6uttqAQAAAACAS66D/lKpJEna3NzUvXv3JO0+3u+jjz6qK5fNZt02BQAAAAAAHPDYtm27qaBcLuvatWvKZDIqlUra2tqSZVkyDEMXLlzQ7Oyscrmcpqen9Zvf/KZT/e4rlUpFXq9X5XJZExMTve4OAAAAAGDItRuHug76qx48eCCfz6dAICBJMk1T0WhUDx48UCQS0SeffHKkei3LUjwel8/nUyKRaFkul8spm80qGAzKsixJ0tLSkuuy7SDoBwAAAAB0U7txqOvV+6suXrxY99owDFdz++PxuEzT1MzMjHK5nMLhcMuymUxGKysrSqfTtW25XE6RSKRhWoGTsgAAAAAADLKO3ek/TlNTU5qenlYymWzYZ1mWAoGANjY25PP5Go5bXFxULBZzXNYJ7vQDAAAAALqp3Ti07YX8lpeXXXXoxo0bro5vZXV1VYZhNATxkjQ/P1+XKHBSFgAAAACAQdd20J/P5101dP/+fVfHt5JOp+X3+5vuMwxD+Xy+Nm/fSVkAAAAAAAZd23P6s9msfvKTnzS9S34Yy7Jkmqbj49qxtramK1euNN1nGIak3UUFQ6GQo7IAAAAAAAy6toN+r9dbW5nfqZ2dnSMd1w7Lsg5NRFQDeSdlAQAAAAAYdG0H/Zubm1pdXZUkhcNhxwmAVnfYj1M1wC8Wix0t++zZMz179qz2ulKpHKl/AAAAAAAcJ0d3+hcWFiRJDx480K1bt+T3+xUOh9tasX5mZubovewz165d0y9/+ctedwMAAAAAgAO1HfTvdfHiRV28eFGSdPfuXZmmqWAwqHfffbflMR988MHReuhCdVG+Vov3HbXs8vKy/vZv/7b2ulKp6Pz580fqYzf9J/M/6c033tRbE2/JN+6Tx+PpdZcAAAAAAMfoSEH/XrOzs5qdnVW5XNbHH3+sUqmk6elpvfPOOx3oXn8aHx/X+Ph4r7vhSOV5RfH/N157ffb0Wf347I/144kf68dnf6y3Jt7S+bPnSQgAAAAAwBBxHfRXeb1eXb58WZK0sbGhmzdvyuPxKBwO6+233+5UMw0Mw2j5ZIDq/PzqyvxOyg6br55/pZ/+4Kf6rPKZ/vT1n/Tk+RP9but3+t3W7xrKnj11tpYM+PEECQEAAAAAGFQdC/r3CgQCtfn/8/PzsixLi4uL+vnPf97xtqqr8jdTDfCrq/E7KTts/vKNv9RHP/tIkvT05VM9evJIv3/ye/2+8vva51pC4EX7CYG9IwVICAAAAABAfzmWoP/evXtKp9NKpVKybftYA+lIJKJEItF0X6FQUDgcPlLZYXZm7Ix+MvkT/WTyJw37WiUEfv/k9/rjV388UkLgxxM/1uT4JAkBAAAAAOgyj23bdicq2tzcVDKZVCqVUqlUkmEYWlxc1NzcnOPH++03NTWl6elpJZPJhn2WZSkQCGh9fb1haH4wGFQikdDc3Jzjsk5UKhV5vV6Vy+W2nmQwqJ6+fKo/PPmDPnvyWdOEwEHOnjqr8xPn9dbZt0gIAAAAAIBL7cahru70VyoVra6uKplMKp/Py+v16sqVK1pcXKyt7t8JlmXV5tzv5/P5dPPmTcXjcaXT6dr2TCYjwzDqgngnZdHozNgZXZi8oAuTFxr27U0IPKo8qvtcHSHwT1v/pH/a+qeGY/cmBM5P7K4dQEIAAAAAANw70p3+27dva2VlRZlMRrZtKxwOa3FxsbaQXydcv35d9+/fl2mayufzkqRwOCyfz6f5+fmGAD2XyymbzSoYDNbm7S8tLTWt20nZdpyUO/1HdVhC4CAkBAAAAACgUbtxaNtB/8OHD5VMJrW6uqpSqaRQKKT5+XnFYjF5vd5Dj19eXta1a9fa/w4GCEH/0VUTArXFBI+QENj7lAESAgAAAABOgo4H/SMjI5qcnFQsFlMsFnM0T79cLsswDG1tbbV9zCAh6D8e+xMCexMDhyUE3jj1Rv2igq+eMEBCAAAAAMAwOJagf2lpSefOnasLmKqHtwqivvjiC6VSKZXLZW1vbzv5HgYGQX/3tUoIVBcVtNX617pVQuD82fPyn/GTEAAAAADQ9zoe9F+6dEl37tw5cocuXLigTz/99MjH9zOC/v7y9OVTff7l5/qs8pkePXmkzyqfOUoInD97vjYqgIQAAAAAgH7U8dX7I5GIqw4tLi66Oh5o15mxMwr6ggr6gg37nm0/211UcG9C4NUogT9+9Ud9+eJL/XPxn/XPxX9uOHZvQqD6mYQAAAAAgH52pNX7UY87/cPhsIRAuyME9o8UICEAAAAAoNM6PrwfrRH0D79qQqA6TYCEAAAAAIBeIujvIoL+k21/QqD6hAEnCYH9Cwt+59R3dHr0tE6NnNr9GD2l0yOndWp09/WIZ6SL3yEAAACAfkPQ30UE/WilVULgUeWR/uWrfzkwIXCQMc+YTo2e0tjIWF0yYO/X1WRBs+37EwrNtrcqU0tANElGVLeNecYYwQAAAAAco44v5AfAufHR8QMXFfz8yed1UwU+e/KZPn/yuZ5uP9Xz7ed6sfNCL3Ze6OXOy7pjX9ov9fLly4Y6+4VHnpZJh7GRsbaSC51KQOxvv1oXoyUAAABwEhD0Az0yPjouw2fI8BmHlt2xd/Ry5+VuEmD7hZ7vPG/69d7Pz3eeN/26rsyexMLer+vKtij3cudl7evn28/rRi3YsvV857me7zw/zh+hK6Oe0SMlGppNuxgbGTswAVH9ev/IjIPaHBthtAQAAADcI+gHBsCIZ0SnR0/r9Ohp6VSve9NcLSnxKgnwcuflgQmKvV/vTSC0k2Q4KEnRqsz+0RLb9ra2t7f1dPtpj35ih2uVGBgbGWs90qHVaIhDpoAcJekxOjLa6x8RAAAADkHQD6AjxkbGNDYyptf0Wq+70pRt23VJgmMfLdFGMuKg0RKSauW/fvl1j35qB6uNlmhj2sXY6FjjVIsOJiBajcBgtAQAADjpCPoBnAgej2foRkvsTUYc12iJ/cfvVTda4kWPfmiHGPGMyKNvA/+9X9d/2bzM3qRBq+17tXVsO31ocWy/9MNNH9pto668m344PNZpH9quy8XvWzv9cHOeu/E9dPNvz3U/juH33s157pd+OP693Vdlv/3eu/l9O0o/OnWujqMPRzm+U+eqo33o8P+oC74LemviraZ9HTQE/QDQJxgt4XzqxmGjJXbsnQO+oWP+gQEAgIH1H6f+o/7Dv/0Pve5GRxD0AwDaMoijJfYG/XufUNvqcZmtytR93aqeui+dHdtOPUfpX92xHepHp/pwYF19fK7a7oebn3EfnKu26+rQ71vLeo5wrOPfmeP+fXPZh479zvTof0NH+3EM58ppH46rH8fxP+oo30O//Y9qpw8H1uXiXH/v9e81PXYQEfQDAIZGv4+WAAAA6DYeVA0AAAAAwJAi6AcAAAAAYEgxvP+k2NmW/r+M9JpPOuOr/zw23tOuAQAAAACOB0H/SfG0LP1DrPm+U683JgLO+KTXJpsnCfbuG+3T1bwAAAAAAAT9J8bOSynwP0lPLekba/fz0/Luvhdf7348eey83lPfOVqy4IyXhAEAAAAAHDOC/pPije9L/9v/Xb9tZ3s38N+bCKh9LjXZVv1clp5VEwZf7X5UPnfep9NvNCYGmiUJ9icSznilUX51AQAAAOAwRE4n2cio9Lp/98OpasLgm1JjYqDZtmqy4KklPavs1vH8y92Pyh+ct3/67CHJAl+TUQeTuwmDkVHn7QEAAADAACLox9G4SRhsv9w3wqB0wAiDcv3r509263j+ZPej/Mh5++MTDpMFvm9HGJAwAAAAADBACPrRfaNj0nfO7X44tf2iMRFw6HSEV5+ff7lbx7PK7kf59w4b9+wmDJwmC17zSeNeaYQnZAIAAADoLoJ+DJbRU9J3vrv74dTL50dcw8DaXbdA9u5aBs/KkvWZw8Y9uyMF2k0WjJ6WPKO7Iws8I9LI2KuvD9r26nOzbR6P858XAAAAgIFH0I+TY+y09Mb3dj+cevm8dUKg5RoGrz6/+FqS/eqJCZb77+MoPCP7EgFjuyMPurltZGxf0uKo20Z3621rW4skSNNtY9+2t38bSRMAAAAMKIJ+oB1jp3efgPDG950f+/LZAaMImowweFqWtp/vLpZob0s7O7uPXLS3D952EHtn92PnhfP+oz5pUkssjOxJbox2cZuT0R8OR4Q0bGuVuHGYzCFpAgAA0DME/cBxGxuXzv7F7sdxapoc2Pe1420vXyUL2tn2Khlhv3q9N0HRsG37VR2d3Oby+z0ISRN3PO2OzDiGbZ4+WkvDtnvdgz36qC991JVdfdQhfmda42fTHD+X1vjZNNdXPxepr342//0V6a/+5173oiMI+oFhMTIijZzudS8Gk203JjJaJgxe7klkHLZte1+9B207IGnS8WROh7e1kzTZft6dcwkAANAJb17sdQ86hqAfADyeb+8Qw7lmSZO2RoQctm1PguTQbS0SJPaOpD6aXtBXUx36qC999XOR+Nm00k99ET+bVvi5tMbPprm++rlIffOzOf/TXvegYwj6AQDukDQBAADoW3002REAAAAAAHQSQT8AAAAAAEOKoB8AAAAAgCFF0A8AAAAAwJAi6AcAAAAAYEgR9AMAAAAAMKQI+gEAAAAAGFIE/QAAAAAADCmCfgAAAAAAhhRBPwAAAAAAQ2qs1x0YBrZtS5IqlUqPewIAAAAAOAmq8Wc1Hm2FoL8Dnjx5Ikk6f/58j3sCAAAAADhJnjx5Iq/X23K/xz4sLYBD7ezs6PHjxzp79qw8Hk+vu9NSpVLR+fPn9ejRI01MTPS6O2iB89T/OEeDgfM0GDhP/Y9zNBg4T4OB89T/Bukc2batJ0+e6M0339TISOuZ+9zp74CRkRH96Ec/6nU32jYxMdH3v8DgPA0CztFg4DwNBs5T/+McDQbO02DgPPW/QTlHB93hr2IhPwAAAAAAhhRBPwAAAAAAQ4qg/wQZHx/X3//932t8fLzXXcEBOE/9j3M0GDhPg4Hz1P84R4OB8zQYOE/9bxjPEQv5AQAAAAAwpLjTDwAAAADAkCLoBwAAAABgSBH0AwAAAAAwpAj6AQAAAAAYUmO97gC67/r16wqFQgqHw73uCvYxTVPxeFyS5Pf75fP5lEgketwr7JXJZJTNZuu2JRIJ+Xy+3nToBLMsS/F4/NC/k1wup2w2q2AwKMuyJElLS0td6uXJ1u45SqVSKhQKyufzKhaLCofD/O/ronbP035cT3SXk/PE9URvtHuOuJboLSfvOUNzDWHjRCmVSrYkO51O97or2CedTtuhUMguFAq1baVSyV5aWuphr7DX0tKSnc1m67YVCgU7FArZpVKpN506gZaWluy5uTk7kUjYhmHYsVisZdl0Om3Pzc3Vbctms3Y4HD7ubp5oTs7R0tJSw/+9cDhs+3w+/q6OmZPztB/XE93j9DxxPdF9Tv/ncS3RO07ec4bpGoKg/4RJJBK8Sfeh9fX1pv9s5ubmbMMwetMp1FlfX295wbS+vt7wpoDuCIVCLS+uSqVSy8AxFArZyWTymHsH2z74HKXTaXt9fb1hezWgHMQLq0F10HlqhuuJ3jjsPHE90XsHnSOuJXrLyXvOsF1DMKf/BMnlcgzB61PxeFzLy8sNw7oikYgWFxd70ynUyeVympmZabovFAopn893uUc4zOrqqgzDaDpccn5+XslksvudQp379+8rFAo1bPf5fIrFYsrlcrXhlOgfXE/0L64n+hvXEr3l5D1n2K4hCPpPkHw+3/QXHb2Vz+eVy+UUi8Ua9sViscGcNzSkWv2DN01ThmF0uTc4TDqdlt/vb7rPMAzl83kCyh5LpVKKRCJN901NTUmS1tbWutkltIHrif7E9cRg4Fqid5y85wzbNQRB/wmRSqX4Z9+nkslky0wi+sfc3JxyuZyi0WjDP/lEIlFbMAn9Y21treUFVHW7aZrd7BL2mZ6ebrmv+nfW6qILvcH1RP/ieqL/cS3RW07ec4btGoLV+08A0zS5aOpjuVyu9s/j+vXrknaHGRUKhaZD9NAbhmHU3pBzuZzS6bTC4XAta8xQ1/5jWdahfz+maXLHsof2r169V6FQkCTOTx/heqK/cT3R/7iW6C0n7znDdg1B0H8CZDIZsvJ9rPoP4/r163XnyTRNTU1NaX19nTfqPrG0tCTDMBSNRhWJRGQYhrLZLMPxBlD1b6pYLPa2I2gplUo1HaaM3uF6or9xPTEYuJboT07ecwbxGoLh/UMuk8lobm6u193AIfL5fMN5MgxD4XBYCwsLPeoVmvH5fFpaWlI4HJZpmopEIiy8A3RYPB6v3RFDf+B6YjBwPTEYuJboLyfhPYegf4hZlqVisUjmcEA0O09TU1PKZDIDtVDIMIvH47IsS4lEQtlsVslksnYHJZfL9bp7cID54v0rn88rlUopm81yV7JPcD0xWLie6G9cS/SXo7znDOI1BEH/EGNo5OA4bKEQVq/uvVQqJUl1d1BisZgKhUJtmB4XU4B70WhUd+/eJcDsI1xPDA6uJ/ob1xL956S85xD0DykepzM42llpd5BWBx1WiUSi6bAvwzC0vr4uSWTo+4xhGC3/dqrz8Ib9TX7QRCIRJZNJ3r/6CNcTg4Prif7HtUR/Oeg9Z9iuIVjIb0iZpqmVlZWGZ4FWs4fXrl3TysqK/H5/y+eFojtCodChb8IHPWIEx++wFVx9Pp+Wl5e5mOozoVCo5R2T6rkimOkfi4uLisfjrF7dZ7ieGBxcT/Q3riX6y2HvOcN2DUHQP6Tm5uaaLrhjWZYmJye1vLzMgjx9Yn5+XtFotOm+6j+VQcokDiOfz9fWcDvOU3+JRCItF+UpFAoEl33k+vXrikajDefENE2Zpsm56iGuJwYH1xP9jWuJ/tHOe86wXUMwvB/osbm5Ofl8PmUymYZ96XRasViMxaz6gGEYBw65y2azA/cGMOyuXLmiYrHY9K5JJpPR4uJiD3qF/TKZjEKhUNO/n3w+zwUw0CauJ/of1xK91+57zrBdQ3Cn/4Sp/uIO0nMlT4J0Oq3FxUWFw+HaG3IqlZJpmkqn073tHCTtnqPZ2VklEom6NwrLshSPxxWPx7mY6oHqquLN+Hw+3bx5U/F4vO7vKJPJyDAM7k52yUHnKJ/PK5lMKhqN1ha4qh4jSSsrK7V5rjheB52nZrie6I3DzhPXE7130DniWqK3nLznDNs1hMe2bbvXncDxy+fzunbtmkzTVD6fl8/nqw1dYUXe/pDL5ZRMJuX3+2uPRhrm54UOquqjdvZKJBK8SXfR9evXdf/+/dr/M0m1C9z5+fmGN+JcLqdsNqtgMFg7d0tLS93u9onS7jmanJw8cLirYRgqFArd6PKJ5PRvSeJ6oheO8j+P64nucnqOuJbojaO85wzLNQRBPwAAAAAAQ4o5/QAAAAAADCmCfgAAAAAAhhRBPwAAAAAAQ4qgHwAAAACAIUXQDwAAAADAkCLoBwAAAABgSBH0AwAAAAAwpAj6AQAAAAAYUgT9AAAAAAAMKYJ+AAAAAACG1FivOwAAALrn+vXrymazWltbkyRNT0/L5/PVlbEsq7bf7/erUCh0u5u1fkSjUZmmKZ/Pp/X19Z70AwCAQeaxbdvudScAAEB3TU1NyTRNlUqllmUWFxeVSqXUrUuFYDCocDisZDJZt70a+BP0AwDgHMP7AQA4gfx+/6FlksmkQqGQLMs6/g69sn/UgSTNzMx0rX0AAIYNw/sBAEBLi4uLMk1ToVDo2Nvq1TQCAACGGXf6AQBAS9PT0yoWi73uBgAAOCKCfgAAUJPP55XP52uvu3GHHwAAHB+G9wMAgBrTNGUYRt22cDhc21ddVG96elrpdFqpVEqStLW1JcuyFI/HG443TVOZTEaGYahYLMqyLBmGofv37yuRSEiSIpHIkVbpz2QyteOqaw8sLS3Vtb23z9lsttZny7JqfdjfZwAAhgVBPwAAkLR7lz8ejyudTjfdbxiG1tfXFYlEVCwWtbq6Whdg5/N5TU1N6ebNm5qbm5OkWiJgf52pVEqmadZeZ7NZLS4u1h4V2I5oNKpIJNIQ5E9NTSmdTsswjFqfo9GoLMtSKpXSlStXagsGZjIZTU1NHfgUAwAABhnD+wEAOKEsy1I0Gq0Fz9U74ocJhUIyTVOxWKxh+/LyshYWFmp33XO5XNMnBcRisYbtwWCw7b5Xkwb7+2AYhhYXF7W4uNiwfW1tTdPT03VPCAiHw7Isq25KAwAAw4SgHwCAE8rn8ymdTiudTiubzapQKDQE0a20Gg4fi8Vqd9Sr5VZXV5sG1dFo9Mh9j8fjmp+fb7rvypUryuVyyuVytW3nzp2TZVkNaxRUEwAsVggAGFYE/QAAoKZZIF69a98On88nn8+n+/fvS9q9+x8OhzU1NaVgMKjFxUVlMhlJ364V4JRpmk0D+L19kNSQaGDePgDgJCLoBwAANdPT0w3BcfWufbsMw6ibJlAdSRAOh5XL5RSNRhUMBo88pL6dKQh7Ew97twEAcNIQ9AMAgJrqnfq9tra2HNWx9wkA1QA9HA4rmUyqUCioVCopFAppdnb2SH2s1n3QCITqEwIAADjpCPoBAMCBnAzvtyxLlmVpZmZGkhrm1kvfriXg9/vbumu/3/6Ewn7V7dU+AABwkhH0AwCAllKpVNNh8a0SAdeuXZPP56t7jF6rRwC2mpPfjkQioWQy2XRfJpNRKBSqPTYQAICTjKAfAIATqJ3V6lOplBYXF1s+Sq+6IF9VPp9XKpXS3bt367Y3W72/mjTYPwS/VTJh//alpSWFQiHF4/GGPiSTyYZEw9bW1qHTAQAAGEZjve4AAADonuvXryubzdaC8Egk0nAn37Isra2t1QLh6enphnp8Pp/C4bBSqVRtmH6hUNDGxkZdfX6/X3fv3pVpmjJNs5ZssCyrFphblqWFhQXlcjlZlqVIJKJEIiHDMOq2R6NRLS4u1lb9T6fTSqVSisfjOnfunKTd4H59fb3Wh/11R6NRzc/Pa25urvazkHYfAbiystJyVAIAAIPKY9u23etOAACAwRGPx5XL5bS+vt7rrgAAgEMwvB8AAAAAgCFF0A8AAAAAwJAi6AcAAI6w6B0AAIODoB8AALTFNE1Fo9HaavzRaFS5XK7X3QIAAAdgIT8AAAAAAIYUd/oBAAAAABhSBP0AAAAAAAwpgn4AAAAAAIYUQT8AAAAAAEOKoB8AAAAAgCFF0A8AAAAAwJAi6AcAAAAAYEgR9AMAAAAAMKT+f7ztIsTzXzjwAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1200x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Why is this not approaching 120?\n",
    "fig, ax = plt.subplots()\n",
    "P1 = DF2.loc['Naive, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P1.index), P1['Mal Max Error'])\n",
    "P2 = DF2.loc['RR, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P2.index), P2['Mal Max Error'])\n",
    "P3 = DF2.loc['RR+Laplace, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P3.index), P3['Mal Max Error'])\n",
    "ax.set_xlabel('Epsilon')\n",
    "ax.set_ylabel('Malicious Target Error')\n",
    "plt.savefig(path+'fb_inf_vary_eps.pdf', bbox_inches = \"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "f5c73ea5",
   "metadata": {},
   "outputs": [],
   "source": [
    "E = experiments.ResponseRRManipulation(g, 120, 20.0, 1e-6, [0.1], [0.8, 0.5])\n",
    "E.add_attacks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "5a28f80f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Malicious Target Error:\n",
      "\t0/0 Disqualified\n",
      "Honest Target Error:\n",
      "\t0/0 Disqualified\n",
      "Honest Error:\n",
      "\t0.00 (max), 0.00 (l_2), 0.00 (mean)\n",
      "\t0/4039 Disqualified\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "((0, 0, 0),\n",
       " (0, 0),\n",
       " 0,\n",
       " (0, 0, 0),\n",
       " (0, 0),\n",
       " (4.307811195758404e-06, 1.7876828994174457e-05, 1.8010776645615894e-07),\n",
       " (0, 4039))"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "E.get_results()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "fd983a91",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "P1 = DF2.loc['Naive, Response', 'Def 1 Friend', 'FB', :]\n",
    "ax.plot(list(P1.index), P1['Hon T Max Error'])\n",
    "P2 = DF2.loc['RR, Response', 'Def 1 Friend', 'FB', :]\n",
    "ax.plot(list(P2.index), P2['Hon T Max Error'])\n",
    "P3 = DF2.loc['RR+Laplace, Response', 'Def 1 Friend', 'FB', :]\n",
    "ax.plot(list(P3.index), P3['Hon T Max Error'])\n",
    "ax.set_xlabel('Epsilon')\n",
    "ax.set_ylabel('Honest Target Error')\n",
    "plt.savefig(path+'fb_def_vary_eps.pdf', bbox_inches = \"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "b2905e4f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Convert to scatter plot\n",
    "#Add inflation attacks\n",
    "fig, ax = plt.subplots()\n",
    "P1 = DF2.loc['Naive, Response', 'Inf+Def Comm', 'FB', :]\n",
    "ax.plot(list(P1.index), np.sqrt(P1['Hon T L2 Error']**2 + P1['Mal L2 Error']**2))\n",
    "P2 = DF2.loc['RR, Response', 'Inf+Def Comm', 'FB', :]\n",
    "ax.plot(list(P2.index), np.sqrt(P2['Hon T L2 Error']**2 + P2['Mal L2 Error']**2))\n",
    "P3 = DF2.loc['RR+Laplace, Response', 'Inf+Def Comm', 'FB', :]\n",
    "ax.plot(list(P3.index), np.sqrt(P3['Hon T L2 Error']**2 + P3['Mal L2 Error']**2))\n",
    "ax.set_xlabel('Epsilon')\n",
    "ax.set_ylabel('L2 Error')\n",
    "plt.savefig(path+'fb_l2_vary_eps.pdf', bbox_inches = \"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "940facea",
   "metadata": {},
   "source": [
    "### Varying Threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "6f218f22",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_vary_thresh = collect_data_new(['Def 1 Friend','Inf+Def Comm','2 Inf Comm'], g, 'FB', [0.03], [2.0], {0: (1.5, 1.0, 1.0), 1: (1.0, 0.5, 0.5), 2: (0.8,0.4,0.4), 3: (0.6,0.3,0.3), 4: (0.5,0.25,0.25), 5: (0.4,0.2,0.2), 6: (0.3,0.15,0.15)}, {'strong': (0.4, 0.4)}, list(comms[1]) + list(comms[0]), 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "3d333cfa",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_vary_thresh = pd.DataFrame(data_vary_thresh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "c1d5b991",
   "metadata": {},
   "outputs": [],
   "source": [
    "DF3 = data_vary_thresh.drop(['Attack Strength'], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "61bf4a65",
   "metadata": {},
   "outputs": [],
   "source": [
    "DF3 = DF3.groupby(['Protocol', 'Attack', 'Graph', 'Threshold Strength']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "9265a16e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Num Mal</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.0</td>\n",
       "      <td>335.646574</td>\n",
       "      <td>1828.838167</td>\n",
       "      <td>288.234240</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>44.088232</td>\n",
       "      <td>695.731933</td>\n",
       "      <td>8.845219</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.0</td>\n",
       "      <td>342.797858</td>\n",
       "      <td>1817.611541</td>\n",
       "      <td>289.212630</td>\n",
       "      <td>0.8</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>42.045097</td>\n",
       "      <td>696.305513</td>\n",
       "      <td>8.848048</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.0</td>\n",
       "      <td>320.338865</td>\n",
       "      <td>588.710842</td>\n",
       "      <td>302.810433</td>\n",
       "      <td>35.8</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>48.138660</td>\n",
       "      <td>696.313072</td>\n",
       "      <td>8.798222</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>40.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>45.740578</td>\n",
       "      <td>696.522754</td>\n",
       "      <td>8.837537</td>\n",
       "      <td>0.2</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>40.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>44.677060</td>\n",
       "      <td>698.709899</td>\n",
       "      <td>8.837259</td>\n",
       "      <td>11.2</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>40.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.6</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>46.376015</td>\n",
       "      <td>683.604205</td>\n",
       "      <td>8.810096</td>\n",
       "      <td>98.4</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>2.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>40.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>3.6</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>42.303148</td>\n",
       "      <td>652.921742</td>\n",
       "      <td>8.815462</td>\n",
       "      <td>449.6</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                    Eps  Mal Max Error  Mal L2 Error  Mal Mean Error  \\\n",
       "Threshold Strength                                                     \n",
       "0                   2.0     335.646574   1828.838167      288.234240   \n",
       "1                   2.0     342.797858   1817.611541      289.212630   \n",
       "2                   2.0     320.338865    588.710842      302.810433   \n",
       "3                   2.0       0.000000      0.000000        0.000000   \n",
       "4                   2.0       0.000000      0.000000        0.000000   \n",
       "5                   2.0       0.000000      0.000000        0.000000   \n",
       "6                   2.0       0.000000      0.000000        0.000000   \n",
       "\n",
       "                    Mal T Nan  Mal T Tot  Mal Nan  Num Mal  Hon T Max Error  \\\n",
       "Threshold Strength                                                            \n",
       "0                         0.0       40.0      0.0    121.0              0.0   \n",
       "1                         0.8       40.0      0.0    121.0              0.0   \n",
       "2                        35.8       40.0      0.0    121.0              0.0   \n",
       "3                        40.0       40.0      0.0    121.0              0.0   \n",
       "4                        40.0       40.0      0.0    121.0              0.0   \n",
       "5                        40.0       40.0      0.6    121.0              0.0   \n",
       "6                        40.0       40.0      3.6    121.0              0.0   \n",
       "\n",
       "                    Hon T L2 Error  Hon T Mean Error  Hon T Nan  Hon T Tot  \\\n",
       "Threshold Strength                                                           \n",
       "0                              0.0               0.0        0.0        0.0   \n",
       "1                              0.0               0.0        0.0        0.0   \n",
       "2                              0.0               0.0        0.0        0.0   \n",
       "3                              0.0               0.0        0.0        0.0   \n",
       "4                              0.0               0.0        0.0        0.0   \n",
       "5                              0.0               0.0        0.0        0.0   \n",
       "6                              0.0               0.0        0.0        0.0   \n",
       "\n",
       "                    Rest Max Error  Rest L2 Error  Rest Mean Error  Rest Nan  \\\n",
       "Threshold Strength                                                             \n",
       "0                        44.088232     695.731933         8.845219       0.0   \n",
       "1                        42.045097     696.305513         8.848048       0.0   \n",
       "2                        48.138660     696.313072         8.798222       0.0   \n",
       "3                        45.740578     696.522754         8.837537       0.2   \n",
       "4                        44.677060     698.709899         8.837259      11.2   \n",
       "5                        46.376015     683.604205         8.810096      98.4   \n",
       "6                        42.303148     652.921742         8.815462     449.6   \n",
       "\n",
       "                    Rest Tot  \n",
       "Threshold Strength            \n",
       "0                     3919.0  \n",
       "1                     3919.0  \n",
       "2                     3919.0  \n",
       "3                     3919.0  \n",
       "4                     3919.0  \n",
       "5                     3919.0  \n",
       "6                     3919.0  "
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Honest users flagged vs % malicious users flagged scatter plot.\n",
    "DF3.loc['RR, Response', '2 Inf Comm', 'FB', :]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "8c05e23d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Eps</th>\n",
       "      <th>Mal Max Error</th>\n",
       "      <th>Mal L2 Error</th>\n",
       "      <th>Mal Mean Error</th>\n",
       "      <th>Mal T Nan</th>\n",
       "      <th>Mal T Tot</th>\n",
       "      <th>Mal Nan</th>\n",
       "      <th>Num Mal</th>\n",
       "      <th>Hon T Max Error</th>\n",
       "      <th>Hon T L2 Error</th>\n",
       "      <th>Hon T Mean Error</th>\n",
       "      <th>Hon T Nan</th>\n",
       "      <th>Hon T Tot</th>\n",
       "      <th>Rest Max Error</th>\n",
       "      <th>Rest L2 Error</th>\n",
       "      <th>Rest Mean Error</th>\n",
       "      <th>Rest Nan</th>\n",
       "      <th>Rest Tot</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Protocol</th>\n",
       "      <th>Attack</th>\n",
       "      <th>Graph</th>\n",
       "      <th>Threshold Strength</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">Naive, Response</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">2 Inf Comm</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">FB</th>\n",
       "      <th>0</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1013.993757</td>\n",
       "      <td>6086.305290</td>\n",
       "      <td>962.083810</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>106.341324</td>\n",
       "      <td>1683.616254</td>\n",
       "      <td>21.442903</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1019.178341</td>\n",
       "      <td>6078.062026</td>\n",
       "      <td>960.731384</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>101.297319</td>\n",
       "      <td>1683.075994</td>\n",
       "      <td>21.457381</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1006.627056</td>\n",
       "      <td>6087.075140</td>\n",
       "      <td>962.182288</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>99.951362</td>\n",
       "      <td>1693.379033</td>\n",
       "      <td>21.615782</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1004.367686</td>\n",
       "      <td>6071.365676</td>\n",
       "      <td>959.740042</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>94.527004</td>\n",
       "      <td>1691.032203</td>\n",
       "      <td>21.592587</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1013.018303</td>\n",
       "      <td>6091.195564</td>\n",
       "      <td>962.819110</td>\n",
       "      <td>0.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>101.934044</td>\n",
       "      <td>1683.703997</td>\n",
       "      <td>21.437344</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">RR, Response</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">Inf+Def Comm</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">FB</th>\n",
       "      <th>2</th>\n",
       "      <td>2.0</td>\n",
       "      <td>272.534104</td>\n",
       "      <td>1062.210703</td>\n",
       "      <td>236.952257</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>26.457284</td>\n",
       "      <td>50.711696</td>\n",
       "      <td>8.978417</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>40.987629</td>\n",
       "      <td>659.852133</td>\n",
       "      <td>8.407077</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3898.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.0</td>\n",
       "      <td>264.521925</td>\n",
       "      <td>1071.020499</td>\n",
       "      <td>239.013722</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>24.563533</td>\n",
       "      <td>52.656758</td>\n",
       "      <td>9.783865</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>41.382819</td>\n",
       "      <td>659.052319</td>\n",
       "      <td>8.428225</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3898.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2.0</td>\n",
       "      <td>272.626207</td>\n",
       "      <td>1069.244851</td>\n",
       "      <td>238.659203</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>23.445170</td>\n",
       "      <td>55.351695</td>\n",
       "      <td>10.324327</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>40.550904</td>\n",
       "      <td>656.806291</td>\n",
       "      <td>8.345777</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3898.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>2.0</td>\n",
       "      <td>269.747807</td>\n",
       "      <td>1025.512510</td>\n",
       "      <td>237.494950</td>\n",
       "      <td>1.4</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>23.721669</td>\n",
       "      <td>46.603650</td>\n",
       "      <td>8.376324</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>40.164731</td>\n",
       "      <td>659.424816</td>\n",
       "      <td>8.410348</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3898.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>2.0</td>\n",
       "      <td>271.389671</td>\n",
       "      <td>968.116537</td>\n",
       "      <td>238.563105</td>\n",
       "      <td>3.6</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>121.0</td>\n",
       "      <td>24.547739</td>\n",
       "      <td>48.662198</td>\n",
       "      <td>8.812987</td>\n",
       "      <td>0.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>43.109483</td>\n",
       "      <td>661.322050</td>\n",
       "      <td>8.423510</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3898.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>63 rows × 18 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                       Eps  Mal Max Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                       \n",
       "Naive, Response 2 Inf Comm   FB    0                   2.0    1013.993757   \n",
       "                                   1                   2.0    1019.178341   \n",
       "                                   2                   2.0    1006.627056   \n",
       "                                   3                   2.0    1004.367686   \n",
       "                                   4                   2.0    1013.018303   \n",
       "...                                                    ...            ...   \n",
       "RR, Response    Inf+Def Comm FB    2                   2.0     272.534104   \n",
       "                                   3                   2.0     264.521925   \n",
       "                                   4                   2.0     272.626207   \n",
       "                                   5                   2.0     269.747807   \n",
       "                                   6                   2.0     271.389671   \n",
       "\n",
       "                                                       Mal L2 Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                 \n",
       "Naive, Response 2 Inf Comm   FB    0                    6086.305290   \n",
       "                                   1                    6078.062026   \n",
       "                                   2                    6087.075140   \n",
       "                                   3                    6071.365676   \n",
       "                                   4                    6091.195564   \n",
       "...                                                             ...   \n",
       "RR, Response    Inf+Def Comm FB    2                    1062.210703   \n",
       "                                   3                    1071.020499   \n",
       "                                   4                    1069.244851   \n",
       "                                   5                    1025.512510   \n",
       "                                   6                     968.116537   \n",
       "\n",
       "                                                       Mal Mean Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                   \n",
       "Naive, Response 2 Inf Comm   FB    0                       962.083810   \n",
       "                                   1                       960.731384   \n",
       "                                   2                       962.182288   \n",
       "                                   3                       959.740042   \n",
       "                                   4                       962.819110   \n",
       "...                                                               ...   \n",
       "RR, Response    Inf+Def Comm FB    2                       236.952257   \n",
       "                                   3                       239.013722   \n",
       "                                   4                       238.659203   \n",
       "                                   5                       237.494950   \n",
       "                                   6                       238.563105   \n",
       "\n",
       "                                                       Mal T Nan  Mal T Tot  \\\n",
       "Protocol        Attack       Graph Threshold Strength                         \n",
       "Naive, Response 2 Inf Comm   FB    0                         0.0       40.0   \n",
       "                                   1                         0.0       40.0   \n",
       "                                   2                         0.0       40.0   \n",
       "                                   3                         0.0       40.0   \n",
       "                                   4                         0.0       40.0   \n",
       "...                                                          ...        ...   \n",
       "RR, Response    Inf+Def Comm FB    2                         0.0       20.0   \n",
       "                                   3                         0.0       20.0   \n",
       "                                   4                         0.0       20.0   \n",
       "                                   5                         1.4       20.0   \n",
       "                                   6                         3.6       20.0   \n",
       "\n",
       "                                                       Mal Nan  Num Mal  \\\n",
       "Protocol        Attack       Graph Threshold Strength                     \n",
       "Naive, Response 2 Inf Comm   FB    0                       0.0    121.0   \n",
       "                                   1                       0.0    121.0   \n",
       "                                   2                       0.0    121.0   \n",
       "                                   3                       0.0    121.0   \n",
       "                                   4                       0.0    121.0   \n",
       "...                                                        ...      ...   \n",
       "RR, Response    Inf+Def Comm FB    2                       0.0    121.0   \n",
       "                                   3                       0.0    121.0   \n",
       "                                   4                       0.0    121.0   \n",
       "                                   5                       0.0    121.0   \n",
       "                                   6                       0.0    121.0   \n",
       "\n",
       "                                                       Hon T Max Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                    \n",
       "Naive, Response 2 Inf Comm   FB    0                          0.000000   \n",
       "                                   1                          0.000000   \n",
       "                                   2                          0.000000   \n",
       "                                   3                          0.000000   \n",
       "                                   4                          0.000000   \n",
       "...                                                                ...   \n",
       "RR, Response    Inf+Def Comm FB    2                         26.457284   \n",
       "                                   3                         24.563533   \n",
       "                                   4                         23.445170   \n",
       "                                   5                         23.721669   \n",
       "                                   6                         24.547739   \n",
       "\n",
       "                                                       Hon T L2 Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                   \n",
       "Naive, Response 2 Inf Comm   FB    0                         0.000000   \n",
       "                                   1                         0.000000   \n",
       "                                   2                         0.000000   \n",
       "                                   3                         0.000000   \n",
       "                                   4                         0.000000   \n",
       "...                                                               ...   \n",
       "RR, Response    Inf+Def Comm FB    2                        50.711696   \n",
       "                                   3                        52.656758   \n",
       "                                   4                        55.351695   \n",
       "                                   5                        46.603650   \n",
       "                                   6                        48.662198   \n",
       "\n",
       "                                                       Hon T Mean Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                     \n",
       "Naive, Response 2 Inf Comm   FB    0                           0.000000   \n",
       "                                   1                           0.000000   \n",
       "                                   2                           0.000000   \n",
       "                                   3                           0.000000   \n",
       "                                   4                           0.000000   \n",
       "...                                                                 ...   \n",
       "RR, Response    Inf+Def Comm FB    2                           8.978417   \n",
       "                                   3                           9.783865   \n",
       "                                   4                          10.324327   \n",
       "                                   5                           8.376324   \n",
       "                                   6                           8.812987   \n",
       "\n",
       "                                                       Hon T Nan  Hon T Tot  \\\n",
       "Protocol        Attack       Graph Threshold Strength                         \n",
       "Naive, Response 2 Inf Comm   FB    0                         0.0        0.0   \n",
       "                                   1                         0.0        0.0   \n",
       "                                   2                         0.0        0.0   \n",
       "                                   3                         0.0        0.0   \n",
       "                                   4                         0.0        0.0   \n",
       "...                                                          ...        ...   \n",
       "RR, Response    Inf+Def Comm FB    2                         0.0       20.0   \n",
       "                                   3                         0.0       20.0   \n",
       "                                   4                         0.0       20.0   \n",
       "                                   5                         0.0       20.0   \n",
       "                                   6                         0.0       20.0   \n",
       "\n",
       "                                                       Rest Max Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                   \n",
       "Naive, Response 2 Inf Comm   FB    0                       106.341324   \n",
       "                                   1                       101.297319   \n",
       "                                   2                        99.951362   \n",
       "                                   3                        94.527004   \n",
       "                                   4                       101.934044   \n",
       "...                                                               ...   \n",
       "RR, Response    Inf+Def Comm FB    2                        40.987629   \n",
       "                                   3                        41.382819   \n",
       "                                   4                        40.550904   \n",
       "                                   5                        40.164731   \n",
       "                                   6                        43.109483   \n",
       "\n",
       "                                                       Rest L2 Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                  \n",
       "Naive, Response 2 Inf Comm   FB    0                     1683.616254   \n",
       "                                   1                     1683.075994   \n",
       "                                   2                     1693.379033   \n",
       "                                   3                     1691.032203   \n",
       "                                   4                     1683.703997   \n",
       "...                                                              ...   \n",
       "RR, Response    Inf+Def Comm FB    2                      659.852133   \n",
       "                                   3                      659.052319   \n",
       "                                   4                      656.806291   \n",
       "                                   5                      659.424816   \n",
       "                                   6                      661.322050   \n",
       "\n",
       "                                                       Rest Mean Error  \\\n",
       "Protocol        Attack       Graph Threshold Strength                    \n",
       "Naive, Response 2 Inf Comm   FB    0                         21.442903   \n",
       "                                   1                         21.457381   \n",
       "                                   2                         21.615782   \n",
       "                                   3                         21.592587   \n",
       "                                   4                         21.437344   \n",
       "...                                                                ...   \n",
       "RR, Response    Inf+Def Comm FB    2                          8.407077   \n",
       "                                   3                          8.428225   \n",
       "                                   4                          8.345777   \n",
       "                                   5                          8.410348   \n",
       "                                   6                          8.423510   \n",
       "\n",
       "                                                       Rest Nan  Rest Tot  \n",
       "Protocol        Attack       Graph Threshold Strength                      \n",
       "Naive, Response 2 Inf Comm   FB    0                        0.0    3919.0  \n",
       "                                   1                        0.0    3919.0  \n",
       "                                   2                        0.0    3919.0  \n",
       "                                   3                        0.0    3919.0  \n",
       "                                   4                        0.0    3919.0  \n",
       "...                                                         ...       ...  \n",
       "RR, Response    Inf+Def Comm FB    2                        0.0    3898.0  \n",
       "                                   3                        0.0    3898.0  \n",
       "                                   4                        0.0    3898.0  \n",
       "                                   5                        0.0    3898.0  \n",
       "                                   6                        0.0    3898.0  \n",
       "\n",
       "[63 rows x 18 columns]"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "P1 = DF3.loc['Naive, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P1.index), P1['Mal Max Error'])\n",
    "P2 = DF3.loc['RR, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P2.index), P2['Mal Max Error'])\n",
    "P3 = DF3.loc['RR+Laplace, Response', '2 Inf Comm', 'FB', :]\n",
    "ax.plot(list(P3.index), P3['Mal Max Error'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "409f742d",
   "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.8.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
