{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Parallel AMS/AMSA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "def prune_threads(l):\n",
    "    '''\n",
    "    Description:\n",
    "        Removes adjacent threads that are within a threshold of 2 for amsa algorithm\n",
    "    Inputs:\n",
    "        l: number of heavy hitters\n",
    "    '''\n",
    "    i = 0 # index variable\n",
    "    while (i < len(threads_vec_amsa)):\n",
    "        # boundary check\n",
    "        if (i >= len(threads_vec_amsa) - 2):\n",
    "            return\n",
    "        t_i = threads_vec_amsa[i] # thread identity\n",
    "        \n",
    "        rest_est_ti = np.sqrt(np.median(hist_amsa[t_i][l:]**2))\n",
    "        temp_ti = np.concatenate((hist_amsa[t_i][:l], [rest_est_ti])) \n",
    "        ams_ti = np.linalg.norm(temp_ti, 2) # amsa estimate for thread\n",
    "        \n",
    "        t_i2 = threads_vec_amsa[i+2] # adjcaent thread\n",
    "        rest_est_ti2 = np.sqrt(np.median(hist_amsa[t_i2][l:]**2))\n",
    "        temp_ti2 = np.concatenate((hist_amsa[t_i2][:l], [rest_est_ti2])) \n",
    "        ams_ti2 = np.linalg.norm(temp_ti2, 2) # amsa estimate for adjacent thread\n",
    "        # check distance, prune hist, threads\n",
    "        denom = min(ams_ti, ams_ti2)\n",
    "        if (denom != 0 and (max(ams_ti, ams_ti2)/denom <= 2)):\n",
    "            # remove the thread in between\n",
    "            t_i1 = threads_vec_amsa[i+1]\n",
    "            threads_vec_amsa.pop(i+1)\n",
    "            hist_amsa.pop(t_i1)\n",
    "            hist_ams.pop(t_i1)\n",
    "            i -= 1\n",
    "        i += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "def spawn_threads(timestep, buckets, l, r):\n",
    "    '''\n",
    "    Description:\n",
    "        Helper function to spawn threads for AMSA\n",
    "    Inputs:\n",
    "        timestep: timestep identifier for new thread\n",
    "        buckets: number of buckets\n",
    "        l: number of heavy hitters\n",
    "        r: number of repetitions\n",
    "    '''\n",
    "    if (len(threads_vec_amsa) == num_threads_max):\n",
    "        prune_threads(l)\n",
    "    if (len(threads_vec_amsa) < num_threads_max):\n",
    "        # spawn a new thread\n",
    "        threads_vec_amsa.append(timestep)\n",
    "        hist_amsa[timestep] = np.zeros(buckets)\n",
    "        hist_ams[timestep] = np.zeros(r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "import ipaddress\n",
    "from utils import hash_func\n",
    "def parallel_ams_amsa_from_file(heavy, filepath, limit, r):\n",
    "    '''\n",
    "    Description:\n",
    "        Runs smooth histogram amsa algorithm on IP addresses\n",
    "    Inputs:\n",
    "        heavy: list of heavy hitter IP addresses\n",
    "        filepath: file to run algorithm on\n",
    "        limit: number of addresses to process\n",
    "        r: number of algorithm repetitions\n",
    "    Outputs:\n",
    "        histogram of estimated 2 norms of frequency vector\n",
    "    '''\n",
    "    \n",
    "    l = len(heavy)\n",
    "        \n",
    "    with open(filepath) as csvfile:\n",
    "        stream = csv.reader(csvfile, delimiter=',')\n",
    "        stream.__next__() # get rid of the header\n",
    "        time = 1\n",
    "        for row in stream:\n",
    "            if (stream.line_num == limit):\n",
    "                break\n",
    "            try:\n",
    "                s_i = int(ipaddress.ip_address(row[0]))\n",
    "            except:\n",
    "                # not an IPv4 or IPv6 address\n",
    "                continue\n",
    "            timestep = time\n",
    "            time += 1\n",
    "            # print(timestep)\n",
    "            vals.append(s_i)\n",
    "            try:\n",
    "                index = heavy.index(s_i)\n",
    "                # s_i is a heavy hitter\n",
    "                spawn_threads(timestep, l+r, l, r)\n",
    "                # update all existing threads\n",
    "                for t_i in threads_vec_amsa:\n",
    "                    hist_amsa[t_i][index] += 1\n",
    "                    # update the ams stack\n",
    "                    for i in range(r):\n",
    "                        v_i = 2*hash_func(i, s_i, 2) - 1\n",
    "                        hist_ams[t_i][i] += v_i\n",
    "            except ValueError:\n",
    "                # s_i is not a heavy hitter\n",
    "                spawn_threads(timestep, l+r, l, r)\n",
    "                # update all existing threads\n",
    "                for t_i in threads_vec_amsa:\n",
    "                    for i in range(r):\n",
    "                        v_i = 2*hash_func(i, s_i, 2) - 1\n",
    "                        hist_amsa[t_i][l+i] += v_i\n",
    "                        hist_ams[t_i][i] += v_i    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test Parallel AMS/AMSA on Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from CS\n",
    "hh = [2401796176,\n",
    " 3573875943,\n",
    " 879396542,\n",
    " 1572803056,\n",
    " 3451786411,\n",
    " 1298962670,\n",
    " 607033987,\n",
    " 2497912303,\n",
    " 3339135037,\n",
    " 887074222,\n",
    " 1115991985,\n",
    " 2613392396,\n",
    " 1604957565,\n",
    " 1072021340,\n",
    " 2987213905,\n",
    " 3124349474,\n",
    " 3124349526,\n",
    " 517524860,\n",
    " 595152676,\n",
    " 3568914218,\n",
    " 2839797836,\n",
    " 1039166085,\n",
    " 1115974613,\n",
    " 3174560376,\n",
    " 3124327772,\n",
    " 3016127925]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "hist_ams = {}\n",
    "hist_amsa = {}\n",
    "threads_vec_amsa = []\n",
    "num_threads_max = 20\n",
    "vals = []\n",
    "m=int(1e5)\n",
    "parallel_ams_amsa_from_file(heavy=hh, \n",
    "                            filepath=\"CAIDA_12mins_sender_IPs/125910_ip_timestamps.csv\",\n",
    "                            limit=m,\n",
    "                            r=11)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualize AMSA Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "def calculate_estimates(hist_ams, hist_amsa):\n",
    "    '''\n",
    "    Description:\n",
    "        Helper function to calcualte estimates for ams and amsa\n",
    "    Inputs:\n",
    "        hist_ams: ams histogram values\n",
    "        hist_amsa: amsa histogram values\n",
    "    Returns:\n",
    "        indices: unpruned amsa timesteps\n",
    "        est_amsa: corresponding amsa histogram estimates\n",
    "        est_amsa: corresponding ams histogram estimates\n",
    "        gts: ground truth norm values\n",
    "        err_amsa: amsa to ground truth ratios\n",
    "        err_ams: ams to ground truth ratios\n",
    "    '''\n",
    "    \n",
    "    # calculate amsa estimates\n",
    "    indices = []\n",
    "    est_amsa = []\n",
    "    l = len(hh)\n",
    "    \n",
    "    for time, norms in hist_amsa.items():\n",
    "        indices.append(time)\n",
    "        rest_est_ti = np.sqrt(np.median(norms[l:]**2))\n",
    "        temp_ti = np.concatenate((norms[:l], [rest_est_ti])) \n",
    "        ams_ti = np.linalg.norm(temp_ti, 2)\n",
    "        est_amsa.append(ams_ti)\n",
    "\n",
    "    # calculate ams estimates\n",
    "    est_ams = []\n",
    "\n",
    "    for _, norms in hist_ams.items():\n",
    "        est_ams.append(np.sqrt(np.median(norms**2)))\n",
    "        \n",
    "    # calculate the ground truth values\n",
    "    gts = []\n",
    "\n",
    "    for i in indices:\n",
    "        _, temp_freqs = np.unique(vals[i:], return_counts=True)\n",
    "        gt = np.linalg.norm(temp_freqs, 2)\n",
    "        gts.append(gt)\n",
    "\n",
    "    # calculate the errors\n",
    "    ratio = lambda x, y: max(x, y)/min(x, y)\n",
    "    err_amsa = np.array(list(map(ratio, est_amsa, gts)))\n",
    "    err_ams = np.array(list(map(ratio, est_ams, gts)))\n",
    "    \n",
    "    return indices, est_amsa, est_ams, gts, err_amsa, err_ams\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/vm/qg92d4j56_l5x0q4g9hbq4j80000gn/T/ipykernel_70168/2471018494.py:45: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  ratio = lambda x, y: max(x, y)/min(x, y)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkQAAAHHCAYAAABeLEexAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAXgdJREFUeJzt3QeYU9XWxvFF79WRJgxdBEWkiYCKilJFECuCIvYOUiyfUuyKFRvY5YqioGAXRIqiokhTVORaQIogRRg6wsz5nnfryU0ymQYzk0zy/z1PCDlnz8nOSVtZuxXyPM8zAACABFY42hUAAACINgIiAACQ8AiIAABAwiMgAgAACY+ACAAAJDwCIgAAkPAIiAAAQMIjIAIAAAmPgAgAACQ8AiIgAZ100knuEkvmzJljhQoVctco2Hbs2GFVqlSxV199NdpVwb/OP/98O/fcc6NdjZhGQIRMPf300+5Lqk2bNhmW0X5dLrvssoj7b7vttkCZTZs2hex77733rEOHDu7Ds3Tp0lavXj33pp02bVrEY6WmplqNGjXcsT766KNM675lyxYrWrSoTZo0KcfHGDVqlNtfuHBhW716dbr927Zts1KlSrky1113Xci+jRs32sCBA+2II45wZfTYjj32WLv55pvdF0VmXn755cC5inT56quvLLt+/PFH9zhWrlxpsfaa0uNMVHr9vfTSSy4grVy5spUoUcLq1KljAwYMsAULFhzU+zD4tajnPfi1U6xYMUtKSrJ27drZ//3f/9mqVasyredNN93k/u68887L8WMcM2aMlStXzn0J56exY8faOeecY8nJya7uF198cY7+Pi0tzUaPHm1169a1kiVL2tFHH20TJ060aFi7dq37LKxYsaKVL1/eevbsab/99lu6chl9Vtx///0h5fT589Zbb9m3336bj4+igNFaZkBG2rVr59WpU0fr3Xk///xzxDLaV7JkSa9ixYre3r170+2vW7eu269yGzduDGx/8MEH3bYOHTp4jzzyiDdu3Dhv6NCh3jHHHOP1798/4n19/PHH7m9Up759+2Za94kTJ3pFixb1tmzZkuNjjBw5MvC4HnjggXT7X3rppcBjuvbaawPbN2/e7CUnJ7tzMXjwYO/ZZ5/17rvvPq9Pnz5euXLlvBUrVmRaZx1Xx7zzzju9V155Jd0l+PxlZfLkye5Ys2fPTrdPz1Ok5yo/HHnkke45D5eamurt3r3bXcerXbt2eV26dHHPy4knnujeAy+88II3fPhwr1GjRl6hQoW81atXH/D7MPi1qNeatum1p9fO+PHjvccee8y95kuVKuWVLl3avUciSUtL82rWrOnuU2W3bduW7cf4999/e4ceeqh37733evmtdu3aXuXKld051ns/o8+RjNxyyy3unF1++eXuvdu9e3d3O6PzlFe2b9/uNWzY0KtSpYr7/NHnY61atdxzsmnTppCyqt9pp52W7rPi+++/T3fcY4891rvwwgvz8ZEULAREyNBvv/3m3mxTpkxxH3CjRo2KWE5levXq5RUuXNh7++23Q/Z98cUXbv9ZZ50VEhDt27fPK1++vHsjR/Lnn39G3H7RRRd5LVq08MaMGeOVKVPG27FjR4b11xs/0hdvdo7hB0S9e/d2AVo41dt/TMFfQqNHj3bb9LjDpaSkuC/87ARE33zzjXewMguIoimjgCgR6LWi5+TRRx9Nt2///v0uQAoPiHLyPowUEOmY4VauXOkdfvjhXvHixb0lS5ak2z9r1iz3t7ouVqyY9/LLL2f7Maqe+ttffvnFy296XArmRO/tnAREa9ascY81+BzqWCeccIILRPT85FbQps+XzCgI0jmcP39+YNuyZcu8IkWKeLfeemumz3tmHnroIXdeFHAhPZrMkCG1/1eqVMm6d+9uZ599dqb9AQ477DA78cQT7bXXXkt3jKZNm9pRRx0Vsl1NZ2p2at++fcTjqZkp3O7du23q1KmBtnDdfueddzJMfavZTXU/0GPIBRdcYEuWLLGffvopsG39+vU2a9Ysty/cr7/+akWKFLHjjjsu3T6lvZWGzy2vv/66tWzZ0jVN6Ng6z2qqEDVJqelATj755EAa3e+fE96HyO+/o+bFO+64wz2fOq6e95SUFNu7d68NGjTIPS9ly5Z1zTvaFkzNQKeccooro2agJk2auCaMYGoa+uGHH+zTTz8N1MmvR0Z9iCZPnuwep5of1eTTr18/15wQTE0jqpe29+rVy/3/0EMPtaFDh7omquxQs9SRRx7p6q4m1Wuvvda2bt0aUkZ11WtZzZE6r2rm1blSM0tW1qxZY88884yddtpp7lyG0+tG9a1Zs+YBvw+zq3bt2u418vfff0esu+5Dz58e46mnnpqj+3z77bfd81y/fv1cf46y87j0GjoQ+hzYt2+fXXPNNYFtOtbVV1/tnrt58+aFlFdz+wknnGBlypRx7xU9P3pt54Y333zTWrdu7S4+NcF37NgxXRcAnz7L9uzZk+lx9drbuXOnzZgxI1fqGW8IiJAhfQj27t3bihcvbn369LGff/7ZvvnmmwzLK0BQnyC/n8z+/fvdl1mkwEFfmvqCU/m//vorW/V599133bEVzFSrVs19OWX0Qa16qi9Pt27dDvgYoiBPX1DBgd4bb7zhPszDgy3/A1kf7q+88oodDAUhChqDL5s3bw7s1weanhN9UT7wwAOuv4AeyxdffBGo9w033OD+r/4iqo8ujRs3zvR+77vvPps+fbrdcsstdskll9iUKVPsqquucv//73//6/ok6TWhL1PdbzAFP3r8ur+HH37YatWq5b5cnnrqqUCZxx57zJ1Pfbj7dVIfs4zofhS4KlhQ3S6//HJXp+OPPz5dsKLz3rlzZzvkkEPsoYcecn3TVI9nn302y/Otx6UASIGQ/uass85ywUunTp3cl2R437QuXbpYs2bNXFk9FvXPyKpPm/brPXHhhRdaXr4Ps6tt27YuaAn/clSgq74mui/RtX4A6IdAdnz55ZfWokWLiPuy+xzpHIe//iNddu3aZbll8eLFLrgJf4+o/5+/36fXrd7/+hzQ+2D48OEuSNbr8mD77OnH3HfffWetWrVKt0910Y+u7du3p3ufqO76TFUgG/7D1Kd9KuN/TiBMhKwR4C1YsMClYmfMmBHSp2DgwIHpyvop27/++sul4NV+LR988IHrE6E0tt8EFdwHZsSIEW6bUrhdu3b17rnnHm/hwoUZ1un000/32rdvH7itNn71E9iwYUO6suqTodT0gR4juL7q19SgQYPAvtatW3sDBgwIeey+9evXu2YNbT/iiCO8q666ynvttde8rVu3etnhN5lFupQoUSJQTs+DmhwzS+Nn1mSmJqvgZiuVUdmjjjrK9QHxqf+JnkM9P8Hatm2b7vyqf0y4zp07e/Xq1ctWk5lfB7++qof6UKhOwU2N77//viun149PTSN+36tgzZs391q2bOllRs+9XredOnUK6b/05JNPumO++OKLgW2qt7b95z//CWxTX6xq1aq5JtTM3Hjjje5vFy9e7OXl+zA7TWa+nj17ujJqzvW9+eabIX2V1H9I/eUiNfOFU1O4Xi9DhgxJty8nz5FeWxm9D4IvmTU95bTJTP2Fwl+rsnPnTndf6l8kam5SH0H1Mwqm936FChXSbc9pk5k+cyKdJ3nqqafcvp9++imkf5n6hr3zzjve2LFj3ftFZZ5++umIx1dTafj7Gf8gQ4QMf5VWrVrVpczFH22iZpqM0tvKVuiXsz8qQ79SNKJFWYNI1DSjMs2bN3dZCWUK1DSiX5fLli0LKavsiMr4v1pFv+L9Zp5wH374YboMTk6P4VOG65dffnG/yv3rSFkv0TnTKA5lVfQrd9y4ca6sMmJ33XWXfoBYdiirol/uwZfgDIRGnuRF6vuiiy5yo5F8GtWkOitDFEzbNfpOGQ+ffnmGZ7iUAdDIGN3OKY242rBhg8syBTc16nlVVuaDDz5I9zc678HUpBFpZE6wTz75xDUdqRlLowp9ykapKTL8fpQVULOdT5kb/XLP6n7URCxqXsnL92FO6LFIcMZB96nsRIMGDQL11TnPTrOZsr16veizICPZeY50X+Gv/0gXvV5zi5qc1Fwazn/tab/ofpWd1OdIcLZKWUy9L2bPnh2SbQvPaikDpMxW+Pbgekh26iLK9mhU6xlnnOHO7cKFC12zrjK1weV8em7CR/viH0X/vQYC9EGrD1x9CK9YsSKwXW92pbdnzpzpmhIi0Ze/mgQ0pFd9CbLqW6EPFV30ZfH111+71K+CpB49etj3338f+ABQM5WaLhQ8KSgJrpM+PNXc4VNqf9GiRXbnnXeG3FdOjhFM5fUFrHopEFFTm/rKZKR69equ+Uh9UtS8oSBMafURI0a4fRlNTxBMX7CRUuY+BQkK4rp27er6sOj5UNOSAtKDoeHKwSpUqOCu1fwVvl0f7Ap01PzhfzCPHDnS9bUIb8pQOf9Y2fX777+760aNGqXbp+fj888/D9mm14r6pIR/+CswPZD7UaCjaSD8/T41+YX3U9H9qJkjMwquJLy5Iy/eh9nlN2/7QZq+6PVjQsP3g98j6uunZjQ1mx5++OFZHjejwD+7z1FGfQvzkgL68H5x4vfL8QN+vaclo88A/3kW/ThUf7twDz74oLtEOmf+/WSnLpHodavnzw+O1IwXfj8H2s8q3hEQIR31F1i3bp37MNYlnIKHjD6I9StFv2z69+/v3tDZnQhMHyLq8KeLMhTjx493AZIyDP59ZvZBqV+Y+vISZVL0wev/qg6ud3aPESnQU5CjLw79Qg/OJGREHzr68tBFv7AbNmzo6pCdgCgryjips7eCLT1eXdSpWb+Yde4OlH7l5mS7/yGufg3q8KlA5ZFHHnEBlD6Y9eX66KOPuuApr2VUx/y6n6yyfzo3snTpUjvmmGPy9H2YXfrRodeS/yWuPn963yrg0iXSfSqzmxHNq6TXfUZBaHafI/X/y04GTBkuP8t1sPRjRdmd8IBBz4Gof5n4r2X1I9KPo3Ca+8yn/lLhWVxlF/W8ZZTd8uem8u83WHhdMuL/gInUP1PPjT6LkB4BESJ+6OlDMrgzrE8dWjVKS01BkX6laJtGkEyYMMFlLzQqKKeUGdGXuv/m169jddTUrx4/QPLpw0kZKWVvbr/9drdNTRwKhoLrl9NjRAqIlOFRnQ6kw7QCLf0SjvQhd6AUcCiTposeg7JG6gisDp5q7sjPX4HqHK8vUnVaD84yBTcf+LJbL7+pdfny5el+jWtbRk2xORV8P8EBsZrR9LrRKKvcoPeDAgK9N7LTsfpg3ofZoUyeAtng5j/dp5pblOkLp9eW3iOZBUQKBtRROzijdSA0uio8MxeJ6qkO8blBQerzzz/vmuvV+dinH2b+fvFHz+m5yeq1oSBLl2D6sabXWUZ/qx9bGjEaaZJO1UV/m1Wzq98EGZ6NUxO3mrr1wxXpERAhhNqc9WGrIdsa4htOv0yUBtYXX0Yz2GoYrT409OsoI2pSUV8bjXQJ5/eV8Zsw/MyOZs4Nb7oRfYipjIIZNYnpF5lGJAXLyTEi0ePRCCmdH3/USST6wNIXikZ8BJs/f77rw5RbTQE6lt9U5X+Ialbd4FS7X4fw0Vh5wf/lH5wlUTOZslbhVK/s1EmBsb509KWvPkx+nwq9PvSlpQA1N+iLScHl448/7poc/YDthRdecI8h0mjCA6HXnfol6fE88cQTdv3114fsV1CrbJreV3puD/Z9mBkFGxoGr8c9bNgwt01flJ999pkLeCLdpwLEvn37utd4ZjNm6z19sMuv6L0Yqf9LuIwyulnR86ofJwpW/KZczQR94403uqbuJ598MvB61vOlZmn1hxR9rimjdu+997ofXsF97vzsVnggklM6/xrpqaDIbzpXwK6soT5fM7svNcnqs0o/RtUnM5hGwqnZzX8sCEVAhBD6gNUbKqNfEJpfR29AfWBl9EGs4ci6ZEYBkd6UOp6+hPRloS9J9TuaO3euyzKp747ovvTrLFIgI6qrvlzUb0gfdOqPFP4llpNjZDRkWB0Xs6Lske7rzDPPdB9G+sLRl/eLL77ofhmqo2N26Es/eO4jn86ZvgTU7KZ0uDIn6tOiLzh9yeox+sOG9X8FKuq/pPOigMKfJyi3qQnAz1hdeeWVrm/Kc8895+4rPCum86Lmx7vvvttlslQmUn8MfdGo7uqDoaye+pr9+eefbq4lzXOjL6/coNfzrbfe6gIBvRb1WtCXj74YlakIzqAcLDVDKSujKREU8Jx++ukuc6g+d2qu0nOuKSFy433o02taWSkFXHqPaVCA+gMp8NPr1Q+klf1RAJDRfWoKC2WAdJ+ZBUQKLHTc7PY3iuRAfzgoU+kvTaEfR+rXpdeZ6HH5j1XZNb2uFLD7y3vofaSO9erbo7/Vc+9/Hukx+0G/giG9fpXl02eFni89F3oOlZ1W3f2A6kAp26v3jz7HFADpvaCmaHWwHzJkSKCcsoeqo953yszqvabPGtVFz4Hek8H0Y1FzZ6lrAiL4d7QZ4PTo0cMNsdVQ04xcfPHFbkZXfwr57MyUGj7sXsNzn3vuOTfDtYahaki5lhLQEFwNE/aXldAwfP2dhtFnRMP6VUbDmjVEvkmTJiH7c3qMSPXNSPhj/+6777xhw4a5mbC1hICG9FevXt0755xzvEWLFnkHM+xeF+33h0ZrmLiGpWvIuJYLufLKK71169aFHE/nWEOJNcNt8JD2jIbda6h+dmbOjnR+3n33Xe/oo492rx8t+aDZdjVkXeWClyzR8GQNcdZSJv7SLcF1CJ8m4I033nCvC71GdE619IRmFQ6m4dUaZh3Or2d2aJi9pkrQa7tq1are1VdfnW7ZF9VV0waE0/1HmuYhEk2V8Pzzz7sZkDVMW/env9VUDv6Q/Nx4H/rD7v2LXos6f23atHGzHf/+++8hx2vatKl7HWXmpJNOcq85vX8zovduUlKSd9ddd+X6c5QVf2h/Zu+d4Nd18DbRtAtackTPh95Xeq4nTJgQ8b70OtW0EnoO9VzVr1/fPSeaKuFgZ6oWzVh+9tlnu+k1ypYt66YMCV+2RcsQadZ8Tfug14KmA9DnwsyZMyMeU899v379srzvRFVI/0QKlICCSG3/+tWdnZmDAeQNTTGh7ItGZOVXZ3dkToMwlNFSxjA7nfoTEfMQIW6oj4OaDyINcwWQf9ScqWbTSKPjEB2azV59kwiGMkaGCAAAJDwyRAAAIOEREAEAgIRHQAQAABIeAREAAEh4TMyYDZrQ7I8//nDTpbMoHgAABYPGjWmSU83untUalARE2aBgKKMZjgEAQGzT0jSajTwzBETZ4C+kpxPqrwoNAABim5ZyUkIjqwVxhYAoG/xmMgVDBEQAABQs2enuQqdqAACQ8AiIAABAwiMgAgAACY8+RACAbEtNTbV9+/ZFuxpAQPHixbMcUp8dBEQAgGzN57J+/XrbunVrtKsChFAwVLduXRcYHQwCIgBAlvxgqEqVKla6dGkmqUVMTZy8bt06S05OPqjXJQERACDLZjI/GDrkkEOiXR0gxKGHHuqCov3791uxYsXsQNGpGgCQKb/PkDJDQKzxm8oUuB8MAiIAQLbQTIZ4fl3SZBZFqWmpNnfVXFu3fZ1VL1fdTkg+wYoULhLtagEAkHDIEEXJlGVTrM6YOnby+JPtgikXuGvd1nYAAEaNGmXHHHOMxYKTTjrJBg0aZPGMgCgKFPScPelsW7NtTcj2tdvWuu0ERQDiOTM+Z+Ucm7h0orvW7fwYITdw4EBr0KCBlSxZ0qpWrWrt27e3sWPH2q5du6ygBktqKsrsciDmzJnj/jYRp1egySyf6c0/cNpA88xLt0/bClkhGzRtkPVs1JPmMwBxRT/29PkX/GOwZvmaNqbLGOvduHee3Odvv/3mgp+KFSvavffea02bNrUSJUrY0qVL7dlnn7XDDjvMzjjjjAw7kx/MqKW8NHToULvqqqsCt1u3bm1XXHGFXX755RHL//333wc9T0+8I0OUz9RnKDwzFB4Urd622pUDgHgRrcz4NddcY0WLFrUFCxbYueeea40bN7Z69epZz5497YMPPrAePXoEyiozoqyRAqQyZcrYPffc47ZrW/369V1A0ahRI3vllVcCf7Ny5Ur3d0uWLAlsU3ZF25RtCc66zJw501q1auVG67Vr186WL18eUtf777/fZa/KlStnl156qe3ZsyfDx1W2bFmrVq1a4FKkSBH3d/7t888/36677jrXzJWUlGSdO3fOsq4rV660k08+2W2vVKmS237xxReHzPlz0003WeXKld19KEsVTwiI8pk6UOdmOQAo6JlxUWY8t5vPNm/ebB9//LFde+21LsCJJLxpSV/yZ555pssgXXLJJTZ16lTX3DZkyBD7/vvv7corr7QBAwbY7Nmzc1yf2267zR5++GEXnClI0/F9kyZNcvetLJb2V69e3Z5++mk7GOPHj3dB3BdffGHjxo3LsnytWrXsrbfecv9XsKbJDseMGRNyPJ3Hr7/+2kaPHm133nmnzZgxw+IFTWb5TKPJcrMcAMRTZvykOifl2v3+8ssvbskRZXWCKWPiZ18ULD3wwAOBfRdccIELeHx9+vRxWRJlmmTw4MH21Vdf2UMPPRTIpmSXMk4dOnRw/7/llluse/furh7q1/TYY4+5rJAucvfdd9snn3ySaZYoKw0bNnSBi08ZoMwUKVLEZX9Ek3CqmTHY0UcfbSNHjgwc+8knn3RZr9NOO83iARmifKah9WozV1+hSLS9VvlarhwAxINYy4zPnz/fNRsdeeSRtnfv3pB9atIKtmzZMtcHKZhua3tOKaDwKQMkGzZsCNxPmzZtQsq3bdvWDkbLli0tNx0dVH//Mfj1jwcERPlMHaXVgVDCgyL/9mNdHqNDNYC4Ea3MuEaVqUksvK+O+hBpX6lSpdL9TUZNaxnxV1lXJip8Zu9wwR20/aY69cvJK+GPJSd1jSS8g7keQ17WP78REEWBRlO8ee6bdlj5w0K2K3Ok7Xk12gIAEikzrnXX1Jyjpp2dO3ce0DHUCVt9cILpdpMmTQLraIn62/iCOy3n5H7UNyeYmuZyU3bqWjyXlsEoiOhDFCUKejS0npmqASRKZlyjyRT8BHeuzuvMuDomq4lLTWHqtKxmH2VKvvnmG/vpp5+ybFYaNmyYG53WvHlzO/XUU+29996zKVOmuP49oizTcccd50aI1a1b1zUh3X777Tmupzpuq6+S6qn6vvrqq/bDDz+4bFZuyU5da9eu7TI/77//vnXr1s39jUa0JQIyRFGkN786EPZp2sddEwwBiFfRyoxruPzixYtdMHPrrbdas2bNXNDxxBNPuLl87rrrrkz/vlevXm6klTpRq8/RM888Yy+99JKbudn34osvupXWFVxpmLs6ROfUeeedZ8OHD3fD2nWc33//3a6++mrLbVnV9bDDDrM77rjDdfrWFAAaup8oCnnBjYmIaNu2bVahQgVLSUmx8uXLR7s6AJCvNNJpxYoVLqugEVEHgzUckZ+vz5x8f9NkBgDI98w4EGtoMgMAAAmPgAgAACQ8msyibNUqs02bNHOqWXJytGsDAEBiIiCKcjCkGeU1M7v6gWnuMIIiAADyH01mUaTMkL9Mja51GwAA5D8yRFFsJgtfCse/TfMZAAD5i4Aois1koqVltBSMrvv1+2cbzWcAAOQvmsyi2Ewm/rp4wevj0XwGAED+IiDKZ2oOC55I89/FhwPXov0qBwBAbtD6ZG+//XZU7nvUqFF2zDHHWKwjIMpnagZTc9jChWYTJoRmiHRb22kuAxCX/QUWLcr4ov15aN68eVakSBHr3r17un0rV650AYP2r127NmSfVoYvWrSo269yvqlTp7qFUrUsRLly5dw6Z1obLJLOnTu7Y2tB2azMmTPH3Veky/r16w84+NDj6Nq1q0Uj8Bo6dKjNnDnTYh19iKJAwU6kgKdxY7MWLaJRIwDIx86TkeRx58kXXnjBrr/+enf9xx9/WI0aNdKV0cKm//nPf9wisL7x48e77auCAjZ9uWsx1nvuucfOOOMMFwT8+OOPNmPGjHTH1N99+eWXbpFULazaunXrbNV3+fLl6dbeqlKlih2oatWqWbSULVvWXWIdGaIYaT6jmQxAwnSejCQPO0/u2LHD3njjDbd6vDJEL7/8csRy/fv3dyvZB9NtbQ/23nvvWfv27W3YsGHWqFEjO/zww61Xr1721FNPpTum/v7000939z1x4kTbvXt3tuqs4EdBTPCl8L99K5RFOvbYY61MmTJWsWJFV5fff//dPS6tVP/tt98Gskr+Yw3O3PgZsUmTJtkJJ5xgpUqVcoHaf//7X5fFatWqlQtglFHauHFjoE7ad9ppp1lSUpLLjHXo0MEWKbv3rzp16rjrM8880x3fvx2etUpLS7M777zTatasaSVKlHD7pk2bFtjv12/KlCl28sknW+nSpa1Zs2Yuy5eXCIhipPmMZjIAyBv64j/iiCNc8NKvXz+XqfE8L105ZXu2bNlin3/+ubuta93u0aNHSDkFJz/88IN9//33md6v7kMBke5T99+gQQN78803D+qx7N+/3wVfCka+++47FyRcccUVLoBQ1mrIkCGu+U5NZLpoW0ZGjhxpt99+uwtqihYtahdccIHddNNNNmbMGJs7d6798ssvNmLEiED57du3u+BQ5+Wrr76yhg0bWrdu3dx28ZsE9Zh13xk1Eer4Dz/8sD300EPuMahJUef+559/Dil32223uea2JUuWuKCzT58+7vHnGQ9ZSklJ0TvHXQNAotm9e7f3448/uusDsnChwo+sLyqXB9q1a+c99thj7v/79u3zkpKSvNmzZwf2r1ixwn3GL1682Bs0aJA3YMAAt13XN954o9uu/SonO3bs8Lp16+a21a5d2zvvvPO8F154wduzZ0/I/X788cfeoYce6u5THn30Ua9Dhw6Z1lX10nHLlCkTcmnSpInbv3nzZrd/zpw5Ef9+5MiRXrNmzdJt199MnTo15PE+//zzgf0TJ05022bOnBnYdt9993mNGjXKsK6pqaleuXLlvPfeey/i/WRUpxo1anj33HNPSJnWrVt711xzTYb1++GHH9y2ZcuW5ej1mZPvbzJEAIC4pb448+fPd9kFUSZEWRP1JYrkkksuscmTJ7sOzLrW7XBqqvrggw9cBkUZFjUvKTOjZqxdu3YFyikTpfvSfYrq8MUXX9ivv/6aZb2VoVFmxL98+OGHbnvlypXt4osvdlkVZa6UbVE25kAcffTRgf9XrVrVXTdt2jRk24YNGwK3//zzT7v88stdZkhNZurjpObI4P5VWdm2bZvrw6VmvmC6vSxstuLg+lWvXt1dB9cntxEQAQDilgIfNbOoE7UCE13Gjh1rb731lqWkpKQrr4BAzVsKXho3bmxHHXVUhseuX7++XXbZZfb888+7Zid1rFZfJfnrr7/cSLSnn346cL/qnK26KFDKSt26dV0Tm3+pXbt2YJ+apNRU1q5dO3d/ak5SE1ZOFStWLPD/QoUKRdym/j4+NZcpOFMQpo7i+v8hhxxif//9d47v+0DrF1yf3EZABACISwo+NGpM/VWCsy3qdKwASZ2cI1FWSB2XI2WHMqIOxOr8u3PnTnf71VdfdZ2GdV/B9626qKNzamrqQT225s2bu9FwCkwUtL322mtue/HixQ/62BlRduuGG25w/YbUT0kdojeFdYRXEJPZ/SurpHOvY4Ufu0mTJhZNDLsHAMSl999/33WKvvTSS10TT7CzzjrLZY+uuuqqdH+nZqFzzjnHjeCKRKOm1DSmwECZm61bt9rjjz9u+/btc6OwRMc+++yz02WYatWq5QIZjaqKNCeST01De8JG5ikbs2bNGnv22WddJ2QFFmoSVGfkiy66KBCYrVixwgVfCsg0R5ICl9zQsGFDe+WVV9woNDV9aZSdRqgF0/1rWgI1gel+K1WqlO44+jt16FaGTSPMlPFSfRVERhMZIgBA/k7RH0kezD2ioOTUU09NFwz5AdGCBQvcKKdwat7S0HK/7084jfD67bffXBCi5jUNT1efo48//tiNZFu4cKHLDOk+wqkuHTt2zLAPk0/HUb+Z4IuOqyzUTz/95I6tpjKNMLv22mvtyiuvDDyuLl26uOHqhx56aIZZsAPxwgsvuACzRYsWduGFF7psUfjcSMqAaT4mBX7KYkWivxs8eLDrd6UmSgWH7777rgu4oqnQv73CkQlFwnoRq705fKIsAIh3ylQo66B+LSWzCmwyoo63mc0zpGCIuUeQy6/PnHx/x0yG6P7773edpoKnPteDVOSrNKF68SvyVS/3YOrdrrSjomZFqkrFhc9ToLZgRbRK36lzWkaTcgEA8oiCHU3Fn9GFYAhRFhMBkSZveuaZZ0KG2MmNN97oZgTV0MdPP/3UDdXr3bt3YL86bikYUg93dSzTFOsKdoInklLUqDJKH6qNUgGXRgVMnz49Xx8jAACIXVEPiDSHQd++fe25554L6Xyl9JbaKx955BE75ZRTrGXLlq7jlQIff3ih2ms1zHHChAmuY5bace+66y43fbo/DHDcuHEujaZ2TQ2h1Hoy6uj26KOPRu0xAwCA2BL1gEhNYsrgqONbMHUeU4/94O3qvJacnBxYz0TX6pDlTyglmqxKbYaaVt0vE35slclsTZS9e/e6YwRfAABA/IrqsPvXX3/dTWYVab0T9djXfArhwx4V/GifXyY4GPL3+/syK6MgR4vshQ8ZlPvuu88tkJdn6FwIAEBMiVpAtHr1ahs4cKAbnnfAoxbyiOaI0JBAn4InDSHMtWCoUaPMV37W+WC1VwAA4r/JTE1imnhKo7/8ac3VcVqTW+n/yuKoH5AmvAqmUWZaaVh0HT7qzL+dVRkNv4uUHRKNRtP+4EuuUWYos2BItD+zDBIAAIiPgEgTUy1dujRkSnPNfqkO1v7/NQW4Zrz0aUZODbNv27atu61rHSN4sTdlnBTA+FOAq0zwMfwy/jEAAACi1mSm6cTDpzTXCsKac8jfrunW1XSl1X0V5Fx//fUukDnuuOPc/k6dOrnARzNmjh492vUX0srD6qjtT1WuadmffPJJu+mmm9y6NLNmzbJJkya5lYoBAABiYpRZZjQ0/vTTT3cTMp544omu+WvKlCmB/UWKFHFr1ehagVK/fv3cVOp33nlnoIyG3Cv4UVaoWbNmbvi9VibWSDMAAAqyk046KWRC4/w0Z84cN6FyeNeWAktLdyBzKSkpWt7EXR+0hQu1VkrWF5UDgBiwe/du78cff3TXueH33//5iNN1fvnyyy+9woULe926dUu3b8WKFe4zXvvXrFkTsu+PP/7wihQp4varnG/KlClemzZtvPLly3tly5b1mjRp4g0cODDTOugYkS4TJ07Msv6zZ892Zbds2RKyffPmzd62bdu8vNahQ4d0j2/v3r3eunXrvLS0NC9WX585+f6O6QwRACC++ANtW7b851q384Mm+lW3i88++8ytehDJYYcdZv/5z39CtmkFBG0Ppn6p5513nmu9mD9/vhskdM8997i587KiCYbXrVsXcunVq9cBPy51KVEXlGgoXry4a7lRligeEBABAPJN8EDb/BpQqxUR3njjDbv66qvdRMAZrWfZv39/F7AE021tD6Ylpdq3b+/WztSq9Fp1XkGNVknIiubWUxARfPGnnvn999+tR48ebtUG9ak98sgj7cMPP7SVK1e65adE+xSAXHzxxRGbzOrUqWN333236z6iNUBr167tVpLfuHGj9ezZ023TMlkLFiwI/M3mzZutT58+LvDTuqCa8HjixImB/bovjQIfM2aMu29dVKdITWZvvfWWq7f68aou6qYSTNvuvfde16dXgZwmW3722WctFhAQ5TdNupjVvEvar3IAECeUCVq0yGzZstDtuq3teZkp0kAarXSg4EV9TV988UV1F0lX7owzzrAtW7bY559/7m7rWrcVpARTEKPVEL7//vtcracGBGmlBGWxNIL6gQcecAGM5sFToOGPtlZWScFJZv1vFbAtXrzYBYAaeKQASY9dkyHXr1/f3fbPgRZSb9mypetvq8d0xRVXuL9R9kt0X+qne/nllweyWpHm5lOm7Nxzz7Xzzz/f1X/UqFE2fPjwdAGogiSNJFf9rrnmGheo6nFFXR416cWVXO1DFNyAntElPxvWASCP+xDpI61kyf91kSxcOPRaF+3Pq4++du3aeY899pj7/759+7ykpCTXJye8D9HixYu9QYMGeQMGDHDbdX3jjTe67cF9iHbs2OH6Imlb7dq1vfPOO8974YUXvD179mRaD5UvWbKkV6ZMmZDL7/8+8KZNm3qjRo3KUR+i8L49qk+/fv0Ct9XHR383fPjwwLZ58+a5bdqXke7du3tDhgzJ8H4i1emCCy7wTjvttJAyw4YN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W9ebMWOG+3/ZsmW9X3/91f1//PjxXuPGjb2DValSJe/555/3tm7d6hUrVsybPHlyYN+yZcs8VXnevHnu9ocffugVLlzYW79+faDM2LFjvfLly3t79+51t2+66SbvyCOPDLmP8847z+vcuXO265SSkuLuV9cAAKBgyMn3d44zRJdffrkNHDjQvv76aytUqJDL2rz66qs2dOhQu/rqqw84MFO25/XXX7edO3e6pjNljfbt22ennnpqoMwRRxxhycnJNm/ePHdb102bNrWqVasGyqh/07Zt2wJZJpUJPoZfxj9GJOoXpWMEXwAAQPwqmtM/uOWWWywtLc06duxou3btcs1n6pujgOj666/PcQWWLl3qAiD1F1I/oalTp1qTJk1c81bx4sWtYsWKIeUV/Kxfv979X9fBwZC/39+XWRkFObt373adw8Pdd999dscdd+T4sQAAgAQJiJQVuu2221zn5V9++cV27NjhAhgFMweiUaNGLvjRKLU333zT+vfv7/oLRdOtt95qgwcPDtxW8FSrVq2o1gkAAOSdHDeZXXLJJbZ9+3aXvVEgdOyxx7pgSE1d2pdTOo5GfrVs2dJlZpo1a2ZjxoyxatWquc7S4R21NcpM+0TX4aPO/NtZldGotkjZIVHGyx/55l8AAED8ynFApJFcamoKp23/+c9/DrpCao5THx4FSBrWP3PmzJARbhpmryY20bWa3DZs2BAoM2PGDBfAKFjzywQfwy/jHwMAACDbTWZqNvI8z12UISpZsmRIh+gPP/zQzQOU06aprl27uo7SOuZrr73m5gzSkHgN47/00ktd01XlypVdkKM+SgpkjjvuOPf3nTp1coHPhRdeaKNHj3b9hW6//XY3d5GyPHLVVVfZk08+aTfddJPLYM2aNcsmTZpkH3zwQY7qCgAA4le2AyJ1blb/IV0OP/zwdPu1PacdkZXZueiii2zdunUuANIkjQqGTjvtNLf/0UcftcKFC7sJGZU10uiwp59+OvD3RYoUsffff9+NblOgVKZMGdcH6c477wyUqVu3rgt+NKeRmuI099Hzzz/vjgUAACCFNPY+O6dCHZ1VVJMnavkOZW2C+wHVrl3batSoEZdnVdkxBWzq+E1/IuDgpaal2txVc23d9nVWvVx1OyH5BCtSuEi0qwUggb+/s50h6tChQ2DmZ424UuYGAHJqyrIpNnDaQFuzbU1gW83yNW1MlzHWu/H/ZqIHgJjMEIXTHETq4KyRYMHU7BVvyBABuRcMnT3pbPMs9GOnkBVy12+e+yZBEYDYzhD5Nm7caAMGDAhZhDWYOlgDQKRmMmWGwoMh0TYFRYOmDbKejXrSfAYg3+W43UuLo2puIC3doXl8pk2b5obiN2zY0N599928qSWAAk99hoKbySIFRau3rXblACC/5ThDpGHr77zzjrVq1cr1I1Jnao0KUypKEytqZXkACKcO1LlZDgCimiHSjNT+fEOVKlVyTWiiRVYXLVqUq5UDED80miw3ywFAVAMirT2mGaNFy2w888wztnbtWhs3bpxVr84HGYDINLReo8n8DtThtL1W+VquHADEfEA0cOBAN5GijBw50nWu1kzTjz/+uN177715UUcAcUAdpTW0XsKDIv/2Y10eo0M1gII17D54+P1PP/3kgqKkpCSLRwy7B/J2HiJlhhQMMeQeQLS+vw86IEoEBERA7mKmagAFfh4ixU9vvvmmzZ49261FptXpg02ZMiXnNQaQUBT8nFTnpGhXAwAOPCDSPETqSH3yySdb1apV3aKuAAAACRUQvfLKKy4L1K1bt7ypEQAAQKyPMlNbXL169fKmNgAAAAUhIBo1apTdcccdtnv37rypEQAAQKw3mZ177rk2ceJEN1t1nTp1rFixYiH7ma0aAADEfUDUv39/W7hwofXr149O1QAAIDEDog8++MCmT59uxx9/fN7UCAAAINb7ENWqVYvJCQEAQGIHRA8//LDddNNNtnLlyrypEQAAQKw3manvkNYvq1+/vpUuXTpdp+q//vorN+sHAAAQewHRY489ljc1AQAAKEijzAAAABIuINJqsX5Hav0/M3S4BgAAcRkQVapUydatW+cmY6xYsWLEuYc8z3PbU1NT86KeAOLBqlVmmzZlvD8pySw5OT9rBADZD4hmzZpllStXdv+fPXt2dv4EANIHQ40ame3Zk3GZkiXNli8nKAIQmwFRhw4dAv+vW7eum4soPEukDNHq1atzv4YA4oMyQ5kFQ6L9KkdABCDW5yFSQLRx48Z02zXcXvsAAADiPiDy+wqF27Fjh5VUuhsAACBeh90PHjzYXSsYGj58uJuU0aeO1F9//bUdc8wxeVNLAACAWAiIFi9eHMgQLV261IoXLx7Yp/83a9bMhg4dmje1BAAAiIWAyB9dNmDAABszZgzzDQEAgMTtQ/TSSy+FBEOaqPHtt9+2n376KbfrBgAAEJsB0bnnnmtPPvmk+//u3butVatWblvTpk3trbfeyos6AogHmnQxq4EX2q9yABDra5l99tlndtttt7n/T5061fUp2rp1q40fP97uvvtuO+uss/KingAKOs0tpEkXmakaQDwERCkpKYFZq6dNm+YCII046969uw0bNiwv6gggXijYIeABEA9NZpqlet68ebZz504XEHXq1Mlt37JlC/MQAQCAxMgQDRo0yPr27Wtly5a12rVr20knnRRoSlM/IgAAgLgPiK655hpr06aNrVq1yk477TQrXPifJFO9evVcHyIAAICCppCnXtHIlKYWqFChgus/xfxLAADE3/d3tvsQNWnSxC3gGpwp2hQ0WmTDhg0hy3kAAAAUFNkOiDTx4v79+wO3J0yY4CIvnxJNe/bsyf0aAgAAxNooM1+kljYt/AoAAJAwAREAAEDCBUTK/oRngMgIAQCAhBp2ryayjh07WtGiRQPrmPXo0cOKFy/ubgf3LwIAAIjLgGjkyJEht3v27JmuDOuYAQCAgoh5iLKBeYgAACh48mQeIgAAgHhFQAQAABIeAREAAEh4BEQAACDhERABAICEl+1h98G++eYbmz17tlvQNS0tLWTfI488klt1AwAAiM2A6N5777Xbb7/dGjVqZFWrVg2ZrZqZqwEAQEIERGPGjLEXX3zRLr744rypEQAAQKz3ISpcuLC1b98+b2oDAABQEAKiG2+80Z566qm8qQ0AAEBBaDIbOnSode/e3erXr29NmjSxYsWKheyfMmVKbtYPAAAg9gKiG264wY0wO/nkk+2QQw6hIzUAAEi8gGj8+PH21ltvuSwRAABAQvYhqly5smsuAwAASNiAaNSoUTZy5EjbtWtX3tQIAAAg1pvMHn/8cfv111/dpIx16tRJ16l60aJFuVk/AACA2AuIevXqlTc1AQAAKAgB0f79+92osksuucRq1qyZd7UCAACI1T5ERYsWtQcffNAFRgAAAAnbqfqUU06xTz/9NG9qAwAAUBD6EHXt2tVuueUWW7p0qbVs2dLKlCkTsv+MM87IzfoBAADEXobommuusT///NMeeeQR69u3r+tk7V/OPPPMHB3rvvvus9atW1u5cuWsSpUq7hjLly8PKbNnzx679tpr3azYZcuWtbPOOsvdf7BVq1a5iSJLly7tjjNs2LB0zXpz5syxFi1aWIkSJaxBgwb28ssv5/ShAwCAOJXjgCgtLS3DS2pqao6OpaY3BTtfffWVzZgxw/bt22edOnWynTt3hiwm+95779nkyZNd+T/++MN69+4d2K/7VDD0999/25dffulm0lawM2LEiECZFStWuDJabmTJkiU2aNAgu+yyy2z69Ok5ffgAACAOFfI8z7MYsXHjRpfhUeBz4oknWkpKih166KH22muv2dlnn+3K/PTTT9a4cWObN2+eHXfccfbRRx/Z6aef7gIlzY0k48aNs5tvvtkdr3jx4u7/H3zwgX3//feB+zr//PNt69atNm3atCzrtW3bNqtQoYKrT/ny5fPwDAAAgNySk+/vHGeIRAFLjx49XNOTLuo3NHfuXDtYqrC/PIgsXLjQZY1OPfXUQJkjjjjCkpOTXUAkum7atGkgGJLOnTu7k/DDDz8EygQfwy/jHyPc3r173d8HXwAAQPzKcUA0YcIEF1yov45WvtelVKlS1rFjR5fJOVBqclNTVvv27e2oo45y29avX+8yPBUrVgwpq+BH+/wywcGQv9/fl1kZBTq7d++O2LdJEaV/qVWr1gE/LgAAEIejzO655x4bPXq069vjU1CkTtZ33XWXXXDBBQdUEfUlUpPW559/btF266232uDBgwO3FTgRFAEAEL9ynCH67bffXHNZODWbqfPygbjuuuvs/ffft9mzZ4fMgF2tWjXXWVp9fYJplJn2+WXCR535t7Mqo/ZEZbfCaSSa9gVfAABA/MpxQKRMycyZM9Nt/+STT3KcRVF/bgVDU6dOtVmzZlndunVD9mueIy0eG3x/GpavYfZt27Z1t3WtOZE2bNgQKKMRawpimjRpEigTXmeV8Y8BAAASW46bzIYMGeKayDR8vV27dm7bF1984Ya6jxkzJsfNZOp39M4777i5iPw+P+q3o8yNri+99FLXfKWO1gpyrr/+ehfIaISZaJi+Ap8LL7zQNeXpGLfffrs7tjI9ctVVV9mTTz5pN910k1uHTcHXpEmT3MgzAAAAZWlybMqUKV779u29ypUru4v+//bbb+f4OLr7SJeXXnopUGb37t3eNddc41WqVMkrXbq0d+aZZ3rr1q0LOc7KlSu9rl27eqVKlfKSkpK8IUOGePv27QspM3v2bO+YY47xihcv7tWrVy/kPrKSkpLi6qVrAIDn7U/d781eMdt77bvX3LVuA7EmJ9/fMTUPUaxiHiIA+J8py6bYwGkDbc22NYFtNcvXtDFdxljvxv+bOBcoSN/fOW4yAwAkro9mPmP3TLrKDjVzF1+hP9bYPT+dZaXOHWddO14ZxRoCBybbGSJ1eC5UqFDmBytUyH799VeLN2SIAMAsdeUK29ewnpUMXSoyxJ6iZsV+/s2K1AkdJAPETYZIkyZmZOXKlfbMM8+4GZ4BAPFp8fczrFUmwZAoWFqgcnWuyK9qAbki2wHRwIED023766+/3GSMY8eOtTZt2tgDDzyQO7UCAMScTTs35Wo5IJYcUB8iLXehmakfeughq127tk2ZMsW6deuW+7UDAMSMpDJJuVoOKLABUWpqqj333HN2xx13WMmSJe3xxx+3fv36Zdm3CABQ8DWv1jxXywEFMiDSRIaa8FDLaNx222129dVXu4VXAQCJoUjhIrlaDiiQAdH555/vZo/u06eP/f7773bLLbdELKemNAAAgLgMiE488cQsh9XTdAYAAOI6IJozZ07e1gQAENuSksxKljTbsyfjMtqvckABw0zVAIDsSU42W77cbFMmw+oVDKkcUMAQEAEAsk/BDgEP4lDhaFcAAAAg2giIAABAwiMgAgAACS/HAVFaWlqG21etWpUbdQIAAIjNgGjbtm127rnnWpkyZaxq1ao2YsQIt5SHb+PGjVa3bt28qicAAED0R5kNHz7cvv32W3vllVfc8h133323LVq0yC3s6i/h4Xle3tUUAAAg2hmit99+25555hk7++yz7bLLLrMFCxa4rFCPHj1s7969rgwzVQMAgLgOiBT81K5dO3A7KSnJPvnkE9u+fbt169bNdu3alVd1BAAAiI2AKDk52ZYtWxayrVy5cvbxxx/b7t277cwzz8yL+gEAAMROQNSpUyd76aWX0m0vW7asTZ8+3Upq/RoAAIB47lR9xx132B9//BFxnzJFM2bMcJ2sAQAA4jZDVKlSJTvyyCMz3J+SkmKvvvpqbtULAACg4M1UvXnzZnvhhRdy63AAAAD5hqU7AABAwiMgAgAACY+ACAAAJLxsjzLr3bt3pvu1nAcAAEBcB0QVKlTIcv9FF12UG3UCAACIzYAo0qSMAAAA8YA+RAAAIOEREAEAgIRHQAQAABIeAREAAEh4BEQAACDhERABAICER0AEAAASHgERAABIeAREAAAg4REQAQCAhEdABAAAEh4BEQAASHgERAAAIOEREAEAgIRHQAQAABIeAREAAEh4BEQAACDhERABAICER0AEAAASHgERAABIeAREAAAg4REQAQCAhEdABAAAEl7RaFcAAIB4l5qWanNXzbV129dZ9XLV7YTkE6xI4SLRrhaCEBABAJCHpiybYgOnDbQ129YEttUsX9PGdBljvRv3jmrd8D80mQEAkIfB0NmTzg4JhmTttrVuu/YjNhAQAQCQR81kygx55qXb528bNG2QK4foIyACACAPqM9QeGYoPChavW21K4foow8RAOCArFpltmmTWVKSWXJytGsTe9SBOjfLIW8REAEADigYatTIbM8es5IlzZYvJygKp9FkuVkOeYuACACQY8oMKRgSXes2AVEoDa0/NrWa7f9zfYReRGaFzKxY1X+G4CP6CIgAADluJlu2LHS7f5vms/8psmatffnAZivyd8ZlUotvsiKXreWkxQACIgBAjpvJpHBhs7S0f6779ftnG81nQTZtsiJ/78u0iNtPei0mMMoMAJDjZjJRMBR8Hdx8BhQ0BEQAgGxRc5gyQD5lhoKvRftVDihoaDIDAGSLWnXUHOb3IfKbyZQhmjDBrHFj+hCh4CIgAgBkm4KdSAGPgqEWLaJRIyB30GQGADio5jOayRAPohoQffbZZ9ajRw+rUaOGFSpUyN5+++2Q/Z7n2YgRI6x69epWqlQpO/XUU+3nn38OKfPXX39Z3759rXz58laxYkW79NJLbceOHSFlvvvuOzvhhBOsZMmSVqtWLRs9enS+PD4AiPfms4ULGVWG+BDVgGjnzp3WrFkze+qppyLuV+Dy+OOP27hx4+zrr7+2MmXKWOfOnW1P0DAHBUM//PCDzZgxw95//30XZF1xxRWB/du2bbNOnTpZ7dq1beHChfbggw/aqFGj7Nlnn82XxwgA8UpBkJrJCIay2Qs9EtJrMaOQpzRMDFCGaOrUqdarVy93W9VS5mjIkCE2dOhQty0lJcWqVq1qL7/8sp1//vm2bNkya9KkiX3zzTfWqlUrV2batGnWrVs3W7Nmjfv7sWPH2m233Wbr16+34sWLuzK33HKLy0b99NNP2aqbgqoKFSq4+1cmCgCAHM1kmRF6oeepnHx/x2wfohUrVrggRs1kPj2oNm3a2Lx589xtXauZzA+GROUL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/l9H6WRbbcutkVsMVsGQbkcql9cIiAAAQFQpCAoOhKKBJjMAAJDwCIgAAEDCIyACAAAJj4AIAAAkPAIiAACQv7S2hxY8y4z2q1w+YZQZAACI3sJnGclqQbRcRkAEAADyn4KdfAx4skKTGQAASHgERAAAIOEREAEAgIRHQAQAABIeAREAAEh4BEQAACDhERABAICER0AEAAASHgERAABIeMxUnQ2e57nrbdu2RbsqAAAgm/zvbf97PDMERNmwfft2d12rVq1oVwUAABzA93iFChUyLVPIy07YlODS0tLsjz/+sHLlylmhQoVyPXpVoLV69WorX758rh4bmePcRwfnPXo499HDuY8OhTgKhmrUqGGFC2feS4gMUTboJNasWTNP70NvEN4k0cG5jw7Oe/Rw7qOHc5//ssoM+ehUDQAAEh4BEQAASHgERFFWokQJGzlypLtG/uLcRwfnPXo499HDuY99dKoGAAAJjwwRAABIeAREAAAg4REQAQCAhEdABAAAEh4BURQ99dRTVqdOHStZsqS1adPG5s+fH+0qxbT77rvPWrdu7WYMr1KlivXq1cuWL18eUmbPnj127bXX2iGHHGJly5a1s846y/7888+QMqtWrbLu3btb6dKl3XGGDRtm+/fvDykzZ84ca9GihRsR0qBBA3v55ZfT1SdRn7/777/fzdg+aNCgwDbOe95Zu3at9evXz53bUqVKWdOmTW3BggWB/RoXM2LECKtevbrbf+qpp9rPP/8ccoy//vrL+vbt6yYErFixol166aW2Y8eOkDLfffednXDCCe68akbl0aNHp6vL5MmT7YgjjnBlVI8PP/zQ4lVqaqoNHz7c6tat685r/fr17a677gpZE4tzH2c0ygz57/XXX/eKFy/uvfjii94PP/zgXX755V7FihW9P//8M9pVi1mdO3f2XnrpJe/777/3lixZ4nXr1s1LTk72duzYEShz1VVXebVq1fJmzpzpLViwwDvuuOO8du3aBfbv37/fO+qoo7xTTz3VW7x4sffhhx96SUlJ3q233hoo89tvv3mlS5f2Bg8e7P3444/eE0884RUpUsSbNm2al+jP3/z58706dep4Rx99tDdw4MDAds573vjrr7+82rVrexdffLH39ddfu3M0ffp075dffgmUuf/++70KFSp4b7/9tvftt996Z5xxhle3bl1v9+7dgTJdunTxmjVr5n311Vfe3LlzvQYNGnh9+vQJ7E9JSfGqVq3q9e3b172/Jk6c6JUqVcp75plnAmW++OIL93yMHj3aPT+33367V6xYMW/p0qVePLrnnnu8Qw45xHv//fe9FStWeJMnT/bKli3rjRkzJlCGcx9fCIii5Nhjj/WuvfbawO3U1FSvRo0a3n333RfVehUkGzZs0E8179NPP3W3t27d6j4k9MHlW7ZsmSszb948d1tfxIULF/bWr18fKDN27FivfPny3t69e93tm266yTvyyCND7uu8885zAVkiP3/bt2/3GjZs6M2YMcPr0KFDICDivOedm2++2Tv++OMz3J+WluZVq1bNe/DBBwPb9HyUKFHCfbGKvkD1XHzzzTeBMh999JFXqFAhb+3ate72008/7VWqVCnwXPj33ahRo8Dtc8891+vevXvI/bdp08a78sorvXikx3rJJZeEbOvdu7cLXIRzH39oMouCv//+2xYuXOjSq8Hrpen2vHnzolq3giQlJcVdV65c2V3rnO7bty/kvCrFnJycHDivula6uWrVqoEynTt3dgsv/vDDD4Eywcfwy/jHSNTnT01iavIKPzec97zz7rvvWqtWreycc85xzYzNmze35557LrB/xYoVtn79+pBzonWb1JQYfO7VVKPj+FRe5+7rr78OlDnxxBOtePHiIedeTdJbtmzJ1vMTb9q1a2czZ860//73v+72t99+a59//rl17drV3ebcxx8Wd42CTZs2ufbp4C8H0e2ffvopavUqSNLS0lwflvbt29tRRx3ltunDSR8q+gAKP6/a55eJdN79fZmV0Zf37t273YdUoj1/r7/+ui1atMi++eabdPs473nnt99+s7Fjx9rgwYPt//7v/9z5v+GGG9z57t+/f+DcRTonwedVwVSwokWLuh8SwWXUVyb8GP6+SpUqZfj8+MeIN7fccot77Sm4L1KkiHvt3XPPPa4/kHDu4w8BEQpstuL77793v9iQt1avXm0DBw60GTNmuA6dyN/AX9mFe++9191Whkiv+3HjxrmACHln0qRJ9uqrr9prr71mRx55pC1ZssT9CKtRowbnPk7RZBYFSUlJ7hdH+Cgc3a5WrVrU6lVQXHfddfb+++/b7NmzrWbNmoHtOndqVtm6dWuG51XXkc67vy+zMholopEkifb8qZlqw4YNbvSXft3q8umnn9rjjz/u/q9fqpz3vKHRS02aNAnZ1rhxYzdiT/zHndk50bWev2Aa3afRT7nx/MTrudcoSGWJzj//fNfce+GFF9qNN97oRrsK5z7+EBBFgdLdLVu2dO3Twb8Edbtt27ZRrVss0yAABUNTp061WbNmpUsz65wWK1Ys5LyqHV5fHv551fXSpUtDPqSU+dCXrv/FozLBx/DL+MdItOevY8eO7pzpF7J/UdZCTQf+/znveUNNwuFTS6hPS+3atd3/9R7Ql2LwOVEzj/qnBJ97BasKbH16/+jcqb+LX+azzz5zfcGCz32jRo1ck012np94s2vXLtfXJ5gCcp034dzHoWj36k5UGj6s0Qgvv/yyG4lwxRVXuOHDwaNwEOrqq692Q1znzJnjrVu3LnDZtWtXyPBvDcWfNWuWG/7dtm1bdwkf/t2pUyc3dF9Dug899NCIw7+HDRvmRks99dRTEYd/J/LzFzzKTDjveTfNQdGiRd0Q8J9//tl79dVX3TmaMGFCyNBvnYN33nnH++6777yePXtGHPrdvHlzN3T/888/d6MFg4d+a3SUhn5feOGFbui3zrPuJ3zot+ry0EMPuedn5MiRcT30u3///t5hhx0WGHY/ZcoUN1WERkP6OPfxhYAoijTPir5ENK+KhhNrngpkTPF7pIvmJvLpg+iaa65xw1j1oXLmmWe6oCnYypUrva5du7q5PvQBN2TIEG/fvn0hZWbPnu0dc8wx7rmpV69eyH34Evn5Cw+IOO9557333nPBpALBI444wnv22WdD9mv49/Dhw92Xqsp07NjRW758eUiZzZs3uy9hzaOjqQ4GDBjgplEIpnl0NMRfx1AgoC/7cJMmTfIOP/xwd+41RcIHH3zgxatt27a517heayVLlnSvx9tuuy1keDznPr4U0j/RzlIBAABEE32IAABAwiMgAgAACY+ACAAAJDwCIgAAkPAIiAAAQMIjIAIAAAmPgAgAACQ8AiIAMeniiy+2Xr16RbsaMVMPAHmLgAhAiI0bN9rVV19tycnJVqJECbdeU+fOne2LL74IlClUqJC9/fbbuXJ/K1eudMfTumjBxowZYy+//LLlJd1vZpdRo0blSz2yQlAG5L2i+XAfAAqQs846y61eP378eKtXr55bVVsLS27evDnX70v3k5EKFSpYXlu3bl3g/2+88YaNGDEiZDHVsmXLuguABBDttUMAxI4tW7a49eG0gG5GateuHbKWnG7LL7/84p1xxhlelSpVvDJlynitWrXyZsyYke5v77zzTreQZbly5dwCmuFr02mdNNE+LZbp0/brr7/eLf6qNdO0fpQWuQymhS/bt2/v1oRq3Lixu38dc+rUqVk+dq2bpsWDw0Wqx3XXXefWudLCnnq8Wl9sx44d3sUXX+zWrKpfv7734YcfhhxHC3FqoU+dG/1Nv379vI0bNwb2T5482a1ZpnWzKleu7NbF0jH1GMPPkdZ8k1WrVnnnnHOOq7fOic6/FiINr/uoUaPc+nE651deeWXIelwA/kGTGYB0GRE1h+3duzdimW+++cZdv/TSSy7D4t/esWOHdevWzWWTFi9ebF26dLEePXrYqlWrQv7+oYcesmbNmrkyw4cPt/nz57vtn3zyiTvelClTMqyfslZlypSxr7/+2kaPHm133nmnzZgxw+1LTU11zUqlS5d2+5999lm77bbbcu3chNcjKSnJ1f366693TYznnHOOtWvXzhYtWmSdOnWyCy+80Hbt2uXKb9261U455RRr3ry5LViwwKZNm+Yyb+eee67br8fdp08fu+SSS2zZsmU2Z84c6927t36w2tChQ105nU+V00X3s2/fPteUWa5cOZs7d65r0tRzp3LBmTc9H/4xJ06c6M7vHXfckSfnBSjQ/g2MAMB58803XbZBmYp27dp5t956q1uNO1h2sy5alVur0wdniHr16hVSRhkNHW/x4sVZZma0Iniw1q1bezfffLP7/0cffeQVLVrUW7duXWB/XmWIguuxf/9+l/VR1sunOuh+582b527fddddXqdOnUKOu3r1aldGq6MvXLjQ/X/lypUR6xZeB3nllVe8Ro0auRXXfcr8lCpVyps+fXrg75Rt2rlzZ6DM2LFjXRYrNTU1y3MCJBIyRADS9SH6448/7N1333XZBmUWWrRokWXHYmWIlM1o3LixVaxY0WUrlJkIzxC1atXqgOt29NFHh9yuXr26bdiwwf1ffX9q1arlOoH7jj322AO+r+zWo0iRInbIIYdY06ZNA9uqVq3qrv26ffvttzZ79uxABk6XI444wu379ddfXcasY8eO7hjKND333HO2ZcuWTOugY/7yyy8uQ+Qfs3LlyrZnzx53TJ+OrayZr23btu65Wr16dS6eEaDgo1M1gHRKlixpp512mruoWeuyyy6zkSNHutFOGVEwpOYrNYk1aNDASpUqZWeffXa6jtNq8jpQxYoVC7mtkWBpaWkHfLzcrEfwNt0Wv24KQNR8+MADD6Q7loI6BVU6d19++aV9/PHH9sQTT7jmPjX91a1bN2IddMyWLVvaq6++mm7foYceetCPEUg0BEQAstSkSZOQYfb68lefnWDqw6KA6cwzzwx8YWtIfVaKFy/ursOPl1ONGjVyWQ/1zfEzNH7/pmhThu2tt96yOnXqWNGikT92FUS1b9/eXTTarXbt2jZ16lQbPHiwO0fh50fH1Mi4KlWqWPny5TPNJO3evdsFqPLVV1+5bJKyaQD+hyYzAAEaWq/OvxMmTLDvvvvOVqxYYZMnT3YdmHv27Bkopy92ddZdv359oGmnYcOGrsOu5hPSl/AFF1yQreyNvtD1Ze13NE5JSTmguiubVb9+fevfv7+ruwK022+/PSRjEy3XXnut/fXXX67jtII0NWlNnz7dBgwY4AIdZYLuvfde1+FaTYw6j5oPSs2P/vnWY1Kz4KZNm1yH6r59+7qO3Xpe1Klaz5WaN2+44QZbs2ZN4L6Vobv00kvtxx9/tA8//NBl+q677jorXJiPfyAY7wgAAcoctGnTxh599FE78cQT7aijjnJNZpdffrk9+eSTgXIPP/ywa+JRlkEjp+SRRx6xSpUquRFQah7SCChlMbKijMnjjz9uzzzzjNWoUSMk8MoJNTspi6XMVOvWrV0znz/KTE2A0aTHpQBNwY9GoKmv0KBBg1xfKwUmyvB89tlnbpTe4Ycf7gI5neOuXbu6v9f5VwZM/a/UHKZjqV+Q/kYTaGpEmoInBT7qQxScMVLfJAWrej7PO+88O+OMM9yEkwBCFVLP6rBtABAXFDgcf/zxrvOxskeJRk2YGvKfW7OKA/GMPkQA4ob63CjLpYyIgqCBAwe6PjmJGAwByBkCIgBxY/v27XbzzTe7fjjqX3Pqqae6picAyApNZgAAIOHRqRoAACQ8AiIAAJDwCIgAAEDCIyACAAAJj4AIAAAkPAIiAACQ8AiIAABAwiMgAgAACY+ACAAAWKL7fyezCjgD+Yu2AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    " \n",
    "indices, est_amsa, est_ams, gts, err_amsa, err_ams = calculate_estimates(hist_ams, hist_amsa)\n",
    " \n",
    "# plot the ratio\n",
    "_, ax = plt.subplots()\n",
    "ax.plot(indices[:-13], err_amsa[:-13], 'r--', label=\"AMSA Estimation\")\n",
    "ax.plot(indices[:-13], err_ams[:-13], 'b-.', label=\"AMS Estimation\")\n",
    "ax.set_xlabel(\"Starting Timestep\")\n",
    "ax.set_ylabel(\"L2 Norm Estimate to Ground Truth Ratio\")\n",
    "ax.set_title(f\"AMSA/AMS Estimation Error on CAIDA (n={m:.1e})\")\n",
    "ax.legend()\n",
    "\n",
    "# plot the values\n",
    "_, ax2 = plt.subplots()\n",
    "ax2.plot(indices[:-13], gts[:-13], 'go', label=\"Ground Truth\")\n",
    "ax2.plot(indices[:-13], est_amsa[:-13], 'rs', label=\"AMSA Estimation\")\n",
    "ax2.plot(indices[:-13], est_ams[:-13], 'bP', label=\"AMS Estimation\")\n",
    "ax2.set_xlabel(\"Starting Timestep\")\n",
    "ax2.set_ylabel(\"L2 Norm Estimate\")\n",
    "ax2.set_title(f\"AMSA/AMS Estimation on CAIDA (n={m:.1e})\")\n",
    "ax2.legend()\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
