{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Process Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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>AnonID</th>\n",
       "      <th>Query</th>\n",
       "      <th>QueryTime</th>\n",
       "      <th>ItemRank</th>\n",
       "      <th>ClickURL</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>479</td>\n",
       "      <td>family guy</td>\n",
       "      <td>2006-03-01 16:01:20</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>479</td>\n",
       "      <td>also sprach zarathustra</td>\n",
       "      <td>2006-03-02 14:48:55</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>479</td>\n",
       "      <td>family guy movie references</td>\n",
       "      <td>2006-03-03 22:37:46</td>\n",
       "      <td>1.0</td>\n",
       "      <td>http://www.familyguyfiles.com</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>479</td>\n",
       "      <td>top grossing movies of all time</td>\n",
       "      <td>2006-03-03 22:42:42</td>\n",
       "      <td>1.0</td>\n",
       "      <td>http://movieweb.com</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>479</td>\n",
       "      <td>top grossing movies of all time</td>\n",
       "      <td>2006-03-03 22:42:42</td>\n",
       "      <td>2.0</td>\n",
       "      <td>http://www.imdb.com</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   AnonID                            Query            QueryTime  ItemRank  \\\n",
       "0     479                       family guy  2006-03-01 16:01:20       NaN   \n",
       "1     479          also sprach zarathustra  2006-03-02 14:48:55       NaN   \n",
       "2     479      family guy movie references  2006-03-03 22:37:46       1.0   \n",
       "3     479  top grossing movies of all time  2006-03-03 22:42:42       1.0   \n",
       "4     479  top grossing movies of all time  2006-03-03 22:42:42       2.0   \n",
       "\n",
       "                        ClickURL  \n",
       "0                            NaN  \n",
       "1                            NaN  \n",
       "2  http://www.familyguyfiles.com  \n",
       "3            http://movieweb.com  \n",
       "4            http://www.imdb.com  "
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "\n",
    "aol_df = pd.read_csv(\"user-ct-test-collection-02.txt\", delimiter=\"\\t\")\n",
    "aol_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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>AnonID</th>\n",
       "      <th>Query</th>\n",
       "      <th>QueryTime</th>\n",
       "      <th>ItemRank</th>\n",
       "      <th>ClickURL</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>328959</th>\n",
       "      <td>811283</td>\n",
       "      <td>new jersey inside water parks</td>\n",
       "      <td>2006-03-01 00:01:16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>http://themeparks.about.com</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432072</th>\n",
       "      <td>1082283</td>\n",
       "      <td>cancionero</td>\n",
       "      <td>2006-03-01 00:01:26</td>\n",
       "      <td>4.0</td>\n",
       "      <td>http://www.cancionerolatino.com.ar</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432073</th>\n",
       "      <td>1082283</td>\n",
       "      <td>cancionero</td>\n",
       "      <td>2006-03-01 00:01:26</td>\n",
       "      <td>4.0</td>\n",
       "      <td>http://www.cancionerolatino.com.ar</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432074</th>\n",
       "      <td>1082283</td>\n",
       "      <td>cancionero</td>\n",
       "      <td>2006-03-01 00:01:26</td>\n",
       "      <td>6.0</td>\n",
       "      <td>http://www.nuevosvalores.com</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432075</th>\n",
       "      <td>1082283</td>\n",
       "      <td>cancionero</td>\n",
       "      <td>2006-03-01 00:01:26</td>\n",
       "      <td>2.0</td>\n",
       "      <td>http://www.cancionero.com.ar</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         AnonID                          Query            QueryTime  ItemRank  \\\n",
       "328959   811283  new jersey inside water parks  2006-03-01 00:01:16       1.0   \n",
       "432072  1082283                     cancionero  2006-03-01 00:01:26       4.0   \n",
       "432073  1082283                     cancionero  2006-03-01 00:01:26       4.0   \n",
       "432074  1082283                     cancionero  2006-03-01 00:01:26       6.0   \n",
       "432075  1082283                     cancionero  2006-03-01 00:01:26       2.0   \n",
       "\n",
       "                                  ClickURL  \n",
       "328959         http://themeparks.about.com  \n",
       "432072  http://www.cancionerolatino.com.ar  \n",
       "432073  http://www.cancionerolatino.com.ar  \n",
       "432074        http://www.nuevosvalores.com  \n",
       "432075        http://www.cancionero.com.ar  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "aol_sorted = aol_df.sort_values(by=\"QueryTime\")\n",
    "aol_sorted.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>AnonID</th>\n",
       "      <th>Query</th>\n",
       "      <th>QueryTime</th>\n",
       "      <th>ItemRank</th>\n",
       "      <th>ClickURL</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2710854</th>\n",
       "      <td>10257280</td>\n",
       "      <td>syntace stem</td>\n",
       "      <td>2006-05-31 23:59:45</td>\n",
       "      <td>2.0</td>\n",
       "      <td>http://www.trisports.com</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>986729</th>\n",
       "      <td>2462060</td>\n",
       "      <td>patio doors</td>\n",
       "      <td>2006-05-31 23:59:49</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2864669</th>\n",
       "      <td>11533607</td>\n",
       "      <td>south africa's political structure</td>\n",
       "      <td>2006-05-31 23:59:51</td>\n",
       "      <td>1.0</td>\n",
       "      <td>http://en.wikipedia.org</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2864670</th>\n",
       "      <td>11533607</td>\n",
       "      <td>south africa's political structure</td>\n",
       "      <td>2006-05-31 23:59:51</td>\n",
       "      <td>4.0</td>\n",
       "      <td>http://www.bbc.co.uk</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>439305</th>\n",
       "      <td>1103248</td>\n",
       "      <td>-</td>\n",
       "      <td>2006-05-31 23:59:56</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           AnonID                               Query            QueryTime  \\\n",
       "2710854  10257280                        syntace stem  2006-05-31 23:59:45   \n",
       "986729    2462060                         patio doors  2006-05-31 23:59:49   \n",
       "2864669  11533607  south africa's political structure  2006-05-31 23:59:51   \n",
       "2864670  11533607  south africa's political structure  2006-05-31 23:59:51   \n",
       "439305    1103248                                   -  2006-05-31 23:59:56   \n",
       "\n",
       "         ItemRank                  ClickURL  \n",
       "2710854       2.0  http://www.trisports.com  \n",
       "986729        NaN                       NaN  \n",
       "2864669       1.0   http://en.wikipedia.org  \n",
       "2864670       4.0      http://www.bbc.co.uk  \n",
       "439305        NaN                       NaN  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "aol_sorted.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "aol_sorted.to_clipboard(columns=['AnonID'], index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Parallel SS/SSA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "def estimate_norm(timestep, order, r1, r2, q):\n",
    "    '''\n",
    "    Description:\n",
    "        Helper function to estimate norm at timestep based on its histogram\n",
    "    Input:\n",
    "        hist: histogram to use for norms\n",
    "        timestep: timestep for which to estimte order norm\n",
    "        order: order of norm\n",
    "        r1: number of values to take median of\n",
    "        r2: number of values to take mean of\n",
    "        q: threshold of ssa algorithm\n",
    "    Returns:\n",
    "        Order norm at timestep\n",
    "    '''\n",
    "    t = hist_ssa[timestep] # keeps track of samples\n",
    "    r1_norms = []\n",
    "    for i in range(r1):\n",
    "        r2_norms = []\n",
    "        t_i = t[i] # sample for current iteration\n",
    "        for j in range(r2):\n",
    "            curr_t = t_i[j]\n",
    "            moment = np.sum(np.power(list(curr_t.values()), order))\n",
    "            r2_norms.append(\n",
    "                    np.power((1/q * moment), 1/order)\n",
    "                )\n",
    "        r1_norms.append(np.mean(r2_norms))\n",
    "    rest_est = np.median(r1_norms)\n",
    "    temp_arr = np.concatenate((hist_hh_sums[timestep], [rest_est]))\n",
    "    return np.linalg.norm(temp_arr, order)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prune_threads_ssa(order, r1, r2, q):\n",
    "    '''\n",
    "    Description:\n",
    "        Removes adjacent threads that are within a threshold of 2\n",
    "    Inputs:\n",
    "        order: order of norm\n",
    "        r1: number of values to take median of\n",
    "        r2: number of values to take mean of\n",
    "        q: threshold for ssa algorithm\n",
    "    '''\n",
    "    i = 0 # index variable\n",
    "    while (i < len(threads_vec_ssa)):\n",
    "        # boundary check\n",
    "        if (i >= len(threads_vec_ssa) - 2):\n",
    "            return\n",
    "        t_i = threads_vec_ssa[i] # thread identity\n",
    "        ssa_ti = estimate_norm(t_i, order, r1, r2, q) # ssa estimate for thread\n",
    "\n",
    "        t_i2 = threads_vec_ssa[i+2] # adjcaent thread\n",
    "        ssa_ti2 = estimate_norm(t_i2, order, r1, r2, q) # ssa estimate for adjancent thread\n",
    "        \n",
    "        # check distance, prune hist, threads\n",
    "        denom = min(ssa_ti, ssa_ti2)\n",
    "        if (denom != 0 and (max(ssa_ti, ssa_ti2)/denom <= 2)):\n",
    "            # remove the thread in between\n",
    "            t_i1 = threads_vec_ssa[i+1]\n",
    "            threads_vec_ssa.pop(i+1)\n",
    "            hist_ssa.pop(t_i1)\n",
    "            hist_ss.pop(t_i1)\n",
    "            hist_hh_sums.pop(t_i1)\n",
    "            i -= 1\n",
    "        i += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "def spawn_threads_ssa(timestep, order, l, r1, r2, q):\n",
    "    '''\n",
    "    Description:\n",
    "        Helper function to spawn threads for ssa\n",
    "    Inputs:\n",
    "        timestep: timestep identifier to spawn threads for ssa\n",
    "        order: order of norm\n",
    "        l: number of heavy hitters\n",
    "        r1: number of values to take median of\n",
    "        r2: number of values to take mean of\n",
    "        q: threshold for ssa algorithm\n",
    "    '''\n",
    "    if (len(threads_vec_ssa) == num_threads_max):\n",
    "        prune_threads_ssa(order, r1, r2, q)\n",
    "    if (len(threads_vec_ssa) < num_threads_max):\n",
    "        threads_vec_ssa.append(timestep)\n",
    "        hist_ssa[timestep] = [[{} for _ in range(r2)] for _ in range(r1)]\n",
    "        hist_ss[timestep] = [[{} for _ in range(r2)] for _ in range(r1)]\n",
    "        hist_hh_sums[timestep] = np.zeros(l)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "def selective_subsampling(s_i, r1, r2, q):\n",
    "    '''\n",
    "    Description:\n",
    "        Helper method to run ss in parallel with ssa\n",
    "    Inputs:\n",
    "        s_i: the current stream value\n",
    "        r1: number of values to take median of\n",
    "        r2: number of values to take mean of\n",
    "        \n",
    "    '''\n",
    "    for thread in threads_vec_ssa:\n",
    "        t = hist_ss[thread]\n",
    "        for i in range(r1):\n",
    "            t_i = t[i]\n",
    "            for j in range(r2):\n",
    "                curr_t = t_i[j]\n",
    "                prob = seeded_input_random((i+1)*(j+1) + s_i, s_i)\n",
    "                if (prob < q):\n",
    "                    curr_t.setdefault(s_i, 0)\n",
    "                    curr_t[s_i] += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from utils import seeded_input_random\n",
    "import csv\n",
    "\n",
    "def selective_subsampling_augmented(heavy, filepath, order, limit, r1, r2, q, q_ss):\n",
    "    '''\n",
    "    Description:\n",
    "        Uses augmented selective subsampling algorithm to estimate order norm of frequencies\n",
    "    Inputs:\n",
    "        heavy: list of heavy hitters IP addresses\n",
    "        filepath: file to run algorithm on\n",
    "        order: order of norm\n",
    "        limit: number of addresses to process\n",
    "        r1: number of values to take median of\n",
    "        r2: number of values to take mean of\n",
    "        q: threshold for ssa algorithm\n",
    "        q_ss: threshold for ss algorithm\n",
    "    Outputs:\n",
    "        returns estimated order norm of frequency vector\n",
    "    '''\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(row[0])\n",
    "            except:\n",
    "                # ip address is not valid IPv4 or IPv6 address\n",
    "                continue\n",
    "            vals.append(s_i)\n",
    "            # run augmented algorithm\n",
    "            spawn_threads_ssa(time, order, len(heavy), r1, r2, q)\n",
    "            try:\n",
    "                index = heavy.index(s_i)\n",
    "                # s_i is a heavy hitter\n",
    "                for thread in threads_vec_ssa:\n",
    "                    t = hist_hh_sums[thread]\n",
    "                    t[index] += 1\n",
    "            except ValueError:\n",
    "                # s_i is not a heavy hitter\n",
    "                for thread in threads_vec_ssa:\n",
    "                    t = hist_ssa[thread]\n",
    "                    for i in range(r1):\n",
    "                        t_i = t[i]\n",
    "                        for j in range(r2):\n",
    "                            curr_t = t_i[j]\n",
    "                            prob = seeded_input_random((i+1)*(j+1) + s_i, s_i)\n",
    "                            if (prob < q):\n",
    "                                curr_t.setdefault(s_i, 0)\n",
    "                                curr_t[s_i] += 1\n",
    "            finally:\n",
    "                # run ss in parallel\n",
    "                selective_subsampling(s_i, r1, r2, q_ss)\n",
    "                time += 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## AOL Dataset Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from cs\n",
    "hh = [2708,\n",
    " 14530,\n",
    " 19913,\n",
    " 30063,\n",
    " 31910,\n",
    " 59766,\n",
    " 81902,\n",
    " 94748,\n",
    " 98594,\n",
    " 112549,\n",
    " 136429,\n",
    " 231764,\n",
    " 234490,\n",
    " 235802,\n",
    " 242755,\n",
    " 268550,\n",
    " 350228,\n",
    " 386598,\n",
    " 468720,\n",
    " 490033,\n",
    " 495960,\n",
    " 505568,\n",
    " 528269,\n",
    " 544822,\n",
    " 582943,\n",
    " 595064,\n",
    " 607249,\n",
    " 638885,\n",
    " 641882,\n",
    " 644634,\n",
    " 657233,\n",
    " 666760,\n",
    " 671587,\n",
    " 672897,\n",
    " 749116,\n",
    " 784926,\n",
    " 799336,\n",
    " 809164,\n",
    " 839825,\n",
    " 870559,\n",
    " 893990,\n",
    " 907640,\n",
    " 949884,\n",
    " 1041520,\n",
    " 1090292,\n",
    " 1105372,\n",
    " 1108764,\n",
    " 1145810,\n",
    " 1178078,\n",
    " 1199246,\n",
    " 1199906,\n",
    " 1235663,\n",
    " 1251005,\n",
    " 1258520,\n",
    " 1311602,\n",
    " 1314128,\n",
    " 1316538,\n",
    " 1342978,\n",
    " 1344179,\n",
    " 1360709,\n",
    " 1395579,\n",
    " 1436599,\n",
    " 1460885,\n",
    " 1484685,\n",
    " 1496895,\n",
    " 1536200,\n",
    " 1551168,\n",
    " 1565388,\n",
    " 1566364,\n",
    " 1664362,\n",
    " 1673928,\n",
    " 1700699,\n",
    " 1704474,\n",
    " 1717963,\n",
    " 1803937,\n",
    " 1826994,\n",
    " 1845373,\n",
    " 1884580,\n",
    " 1919698,\n",
    " 1944301,\n",
    " 1945467,\n",
    " 1955947,\n",
    " 1998576,\n",
    " 2008602,\n",
    " 2053307,\n",
    " 2061594,\n",
    " 2097493,\n",
    " 2120617,\n",
    " 2124018,\n",
    " 2162282,\n",
    " 2175385,\n",
    " 2186066,\n",
    " 2202596,\n",
    " 2228313,\n",
    " 2248354,\n",
    " 2256996,\n",
    " 2262369,\n",
    " 2265240,\n",
    " 2280767,\n",
    " 2332095,\n",
    " 2373521,\n",
    " 2382113,\n",
    " 2399416,\n",
    " 2426641,\n",
    " 2503321,\n",
    " 2523281,\n",
    " 2532935,\n",
    " 2541128,\n",
    " 2559430,\n",
    " 2590883,\n",
    " 2665695,\n",
    " 2682392,\n",
    " 2699054,\n",
    " 2700537,\n",
    " 2730599,\n",
    " 2747414,\n",
    " 2749521,\n",
    " 2755954,\n",
    " 2779372,\n",
    " 2875718,\n",
    " 2932694,\n",
    " 2933929,\n",
    " 2951243,\n",
    " 2963792,\n",
    " 2994485,\n",
    " 3019805,\n",
    " 3033935,\n",
    " 3034929,\n",
    " 3131451,\n",
    " 3177006,\n",
    " 3180271,\n",
    " 3241766,\n",
    " 3247870,\n",
    " 3318459,\n",
    " 3390279,\n",
    " 3394675,\n",
    " 3400024,\n",
    " 3414878,\n",
    " 3439662,\n",
    " 3501213,\n",
    " 3507274,\n",
    " 3510572,\n",
    " 3512782,\n",
    " 3525209,\n",
    " 3547648,\n",
    " 3552531,\n",
    " 3556698,\n",
    " 3568883,\n",
    " 3610110,\n",
    " 3634829,\n",
    " 3638979,\n",
    " 3657428,\n",
    " 3657840,\n",
    " 3751563,\n",
    " 3782464,\n",
    " 3811939,\n",
    " 3819506,\n",
    " 3855871,\n",
    " 3901843,\n",
    " 4051910,\n",
    " 4276751,\n",
    " 4309593,\n",
    " 4314807,\n",
    " 4360867,\n",
    " 4372087,\n",
    " 4374147,\n",
    " 4408990,\n",
    " 4533510,\n",
    " 4538306,\n",
    " 4555485,\n",
    " 4615477,\n",
    " 4620308,\n",
    " 4667729,\n",
    " 4668440,\n",
    " 4692726,\n",
    " 4724591,\n",
    " 4736350,\n",
    " 4754354,\n",
    " 4823649,\n",
    " 4827349,\n",
    " 4843753,\n",
    " 4903984,\n",
    " 4936979,\n",
    " 4998669,\n",
    " 5109143,\n",
    " 5141688,\n",
    " 5144903,\n",
    " 5153350,\n",
    " 5163449,\n",
    " 5166258,\n",
    " 5231549,\n",
    " 5242136,\n",
    " 5289919,\n",
    " 5291094,\n",
    " 5329922,\n",
    " 5339829,\n",
    " 5395927,\n",
    " 5488213,\n",
    " 5526272,\n",
    " 5528656,\n",
    " 5551497,\n",
    " 5688329,\n",
    " 5874984,\n",
    " 5913637,\n",
    " 6352620\n",
    " ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set up shared variables\n",
    "hist_ssa = {} # maps timestep to ssa value\n",
    "hist_ss = {} # maps timestep to ss value\n",
    "hist_hh_sums = {} # maps timestep to hh sum value\n",
    "threads_vec_ssa = [] # stores thread identities\n",
    "num_threads_max = 20 # hyperparam for max counters\n",
    "vals = []\n",
    "r1 = 3\n",
    "r2 = 5\n",
    "order = 3\n",
    "q = 1/75\n",
    "q_ss = 1/75\n",
    "filepath = \"aol-processed.csv\"\n",
    "m = int(2e6)\n",
    "\n",
    "selective_subsampling_augmented(heavy=hh, filepath=filepath, order=order, limit=m, r1=r1, r2=r2, q=q, q_ss=q_ss)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "def norm_helper(time, order, r1, r2, q):\n",
    "    '''\n",
    "        Description:\n",
    "            Helper function to calculate order norm for ss\n",
    "        Inputs:\n",
    "            time: timestep for calculation\n",
    "            order: order of norm\n",
    "            r1: number of values to take median of\n",
    "            r2: number of values to take mean of\n",
    "            q: threshold for ss algorithm\n",
    "        Outputs:\n",
    "            order norm\n",
    "    '''\n",
    "    t = hist_ss[time] # keeps track of samples\n",
    "    r1_norms = []\n",
    "    for i in range(r1):\n",
    "        r2_norms = []\n",
    "        t_i = t[i] # sample for current iteration\n",
    "        for j in range(r2):\n",
    "            curr_t = t_i[j]\n",
    "            moment = np.sum(np.power(list(curr_t.values()), order))\n",
    "            r2_norms.append(\n",
    "                    np.power((1/q * moment), 1/order)\n",
    "                )\n",
    "        r1_norms.append(np.mean(r2_norms))\n",
    "    \n",
    "    return np.median(r1_norms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_estimates():\n",
    "    '''\n",
    "    Description:\n",
    "        Calculates estimates for ssa/ss and computes ground truth\n",
    "    Inputs:\n",
    "        None\n",
    "    Outputs:\n",
    "        timesteps: unpruned timesteps\n",
    "        est_ssa: ssa estimates corresponding to timesteps\n",
    "        est_ss: ss estimates corresponding to timesteps\n",
    "        gt: ground truth vaues corresponding to timesteps\n",
    "    '''\n",
    "    timesteps = []\n",
    "    est_ssa = []\n",
    "    est_ss = []\n",
    "    gt = []\n",
    "    for time in hist_ssa.keys():\n",
    "        timesteps.append(time)\n",
    "        est_ssa.append(estimate_norm(time, order, r1, r2, q))\n",
    "        est_ss.append(norm_helper(time, order, r1, r2, q_ss))    \n",
    "        _, temp_freq = np.unique(vals[time:], return_counts=True)\n",
    "        gt.append(np.linalg.norm(temp_freq, order))\n",
    "    return timesteps, est_ssa, est_ss, gt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def plot_estimates(timesteps, est_ssa, est_ss, gt):\n",
    "    '''\n",
    "    Description:\n",
    "        Plots ground truth and estimates for ss/ssa\n",
    "    Inputs:\n",
    "        timesteps: unpruned timesteps\n",
    "        est_ssa: ssa estimates corresponding to timesteps\n",
    "        est_ss: ss estimates corresponding to timesteps\n",
    "        gt: ground truth values corresponding to timesteps\n",
    "    '''\n",
    "    _, ax = plt.subplots()\n",
    "    timesteps = np.subtract(m, timesteps)\n",
    "    ax.plot(timesteps, est_ssa, 'rx', label=\"SSA Estimation\", markersize=10)\n",
    "    ax.plot(timesteps, est_ss, 'bP', label=\"SS Estimation\")\n",
    "    ax.plot(timesteps, gt, 'go', label=\"Ground Truth\", fillstyle='none')\n",
    "    ax.set_title(f\"SSA/SS Estimation on AOL (n={m:.1e})\")\n",
    "    ax.set_xlabel(\"Window Size\")\n",
    "    ax.set_xscale('log')\n",
    "    ax.set_yscale('log')\n",
    "    ax.set_ylabel(\"Estimated 3 Norm\")\n",
    "    ax.legend()\n",
    "    plt.show()\n",
    "\n",
    "def plot_error_ratio(timesteps, est_ssa, est_ss, gt):\n",
    "    '''\n",
    "    Description:\n",
    "        Computes and plots ss/ssa to ground truth ratio\n",
    "    Inputs:\n",
    "        timesteps: unpruned timesteps\n",
    "        est_ssa: ssa estimates corresponding to timesteps\n",
    "        est_ss: ss estimates corresponding to timesteps\n",
    "        gt: ground truth values corresponding to timesteps\n",
    "    '''\n",
    "    # plot the ratio\n",
    "    ratio = lambda x, y: max(x, y)/min(x, y)\n",
    "    err_ss = np.array(list(map(ratio, est_ss, gt)))\n",
    "    err_ssa = np.array(list(map(ratio, est_ssa, gt)))\n",
    "\n",
    "    _, ax2 = plt.subplots()\n",
    "    timesteps = np.subtract(m, timesteps)\n",
    "    ax2.plot(timesteps, err_ssa, 'r--', label=\"SSA Estimation\")\n",
    "    ax2.plot(timesteps, err_ss, 'b-.',label=\"SS Estimation\")\n",
    "    ax2.set_xlabel(\"Window Size\")\n",
    "    ax2.set_ylabel(\"L3 Norm Estimate to Ground Truth Ratio\")\n",
    "    ax2.set_title(f\"SSA/SS Estimation Error on AOL (n={m:.1e})\")\n",
    "    ax2.legend()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/vm/qg92d4j56_l5x0q4g9hbq4j80000gn/T/ipykernel_23348/900554639.py:36: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  ratio = lambda x, y: max(x, y)/min(x, y)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAkJ5JREFUeJztnQd0FHUXxS8hCb333qVJE6SJICCCIIIFQUVBxQIWlKaoiIiggqKiUj6VomDBgooioNIsCNKL0pQm0kvoJJD5zv0Pk+yGJGRhk9lyf+dMdtrOvJ1MefNqJsuyLAghhBBChAgRbgsghBBCCOFPpNwIIYQQIqSQciOEEEKIkELKjRBCCCFCCik3QgghhAgppNwIIYQQIqSQciOEEEKIkELKjRBCCCFCCik3QgghhAgppNwI4Ufmz5+PTJkymc9A4pprrjGDEL6wY8cOZM2aFb/++qvboohzNGzYEAMGDHBbjIBHyk0YsWbNGtx6660oU6aMuWGVKFECrVq1wltvveW1XmxsLN58803UqVMHuXPnRt68eVG9enU88MADWL9+fbLb/uuvv8xDnds9fPhwqnLMmDEDERER2L17t5net28fevfujSpVqiBbtmwoXLgw6tevjyeffBLHjh0777vNmjUz62TPnh3ly5fHbbfdhlmzZl3w95ctW9bImNzQpk0b+MKYMWMwadIkBBJ//vknnn/+eWzduhWBpuylNHzyySduixgw8DzmMeF5nxpUNG666SYUKVIEWbJkMef1gw8+iO3bt5+3Ls8HbnP//v0XJdMLL7yABg0a4KqrrkJGMmzYMNx4443mN1J+/g5fOH36tDmOxYsXN/cU/oYffvgBbsB7I+8vOXPmRP78+XHXXXeZe15qTJ061fxuficp/F3vvPNOwv1TJE8m9ZYKD3777Tc0b94cpUuXRrdu3VC0aFHzVvb777/j77//xubNmxPWbd++Pb7//nvcfvvtaNSoEeLi4oxS8+2332Lo0KHo3r37edt/5plnMGHCBBw6dAhvv/02evTokaIsDz30EJYtW4Y//vgDBw8eNErUkSNHcO+99xoF58CBA1i9erXZHz958yavvvoq+vfvb5SbDh06GOWGcv/444+oVavWBZUNbidfvnzo27fvect4E2zRokWaj+fll1+OggULnmehiY+PN8phdHS0UeAyks8//xydOnXC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jbWZONEef/FFu5+SuHjYYJN1cB580D62VHZ4XMOrBrsQ4qKUm4MHD6L8uUITLKLDadKkSRMsZD6mECJNsJrCr78C77wD3Hef29KEBswyGzsWGDTInuZn795AfLzbkgkhAlq5oWKzZcsWM16lShVMmzYtwaKTV/mYQvhEtmxAr15K/fa30shOMKNH29NvvQV07Wq7q4QQ4YHPys0999xjqhGTp556Cu+88w6yZs2KJ554wsTjCCEuzMyZdnaPSD8efRT46CMgMhL4+GO7GemxY25LJYQISOWGSsxjjz1mxq+99lqsX78eH330EVasWIHetP/6AN1Y7du3N8HIrHj81VdfXfA7jOupVasWsmfPjmLFipmiguxrJUSwMGsW0K4dwJqXZ864LU1oc/vttCoD2bPb6fbXXss+eG5LJYRIby659FWZMmVw8803o2bNmvjcx/zL48ePG0WF1p+08Ouvv+Luu+/Gfffdh3Xr1uGzzz7DkiVLcP/99yMQYOl83jiZ3itESjBMjR7cq6+2rQoifWnTxq59w/YMixfbx33HDrelEkIEjHJz5swZrF27Fhs3bvSa//XXXxsl5c477/Rp59dffz1efPFF3MSyrGlg0aJFps0DLUeslMwg5gcffNAoOIFAkyZAwYLAzz+7LYkIZO64w+74/dxzbksSPjRoYF+XJUvais2ePW5LJIQICOWGSk3FihWNElO1alVjrdmzZ4+pWEzXEBWVv//+O12FZe+qHTt2YObMmabPFfdPa1Hbtm1T/M7p06czroryurXmI9PPyhoTqUMlWKnfGUu1anZ2GjuJ16vntjRCiIBQbp588kmj3NBK06VLFxMfc80115iYmX///Rcvv/wySvK1KB256qqrTMxN586dTbPOokWLmgaeqbm1XnrpJbOOM5QqVSrd5PsaHbAW1XHl8fnptg8RvLz2mh3/obor7lG6NFvIJE7/8YcdiyOECC0yWTSBpAG2W5gzZw5q166NmJgY02ph8uTJuOuuu/wjSKZMmD59Ojp27JjiOn/++acJYmZQc+vWrbFr1y6ToXXllVfi/fffT9Fyw8GBlhsqOPwNrNPjT2pmWo01qIkf75iAllPv9eu2RXBDT2716nYAMeM+6td3WyLBihZXXsl7gt3fq2VLtyUSQqQGn980UqTl+Z3mcMb9+/ebrCbCjbOvVMOGDZGR0ApD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CCGEECGFlBshhBBChBRSboQQQggRUki5EUIIIURIIeXGT7zzzjsoW7YssmbNigYNGmDJkiVuixTQvPTSS7jyyitNpejChQujY8eO2LBhg9c6p06dwsMPP4wCBQogZ86cuOWWW7Bnzx6vdbZv34527dohe/bsZjv9+/fHmTNnvNaZP38+rrjiChO5X7FiRUyaNAnhyMsvv2yqcj/++OMJ83SM/cfOnTvRtWtXcyyzZcuGGjVqYOnSpQnLmbvx3HPPoVixYmb5tddei02bNnlt4+DBg7jzzjtN4bO8efPivvvuw7Fjx7zWWb16Na6++mpzr2EV2BEjRiBcOHv2LAYNGoRy5cqZY1ihQgUMHTrUq9eQjvPFsXDhQrRv395U/+V94quvvvJanpHH9bPPPkOVKlXMOryOZs6c6fsPYraUuDQ++eQTKzo62powYYK1bt066/7777fy5s1r7dmzx23RApbWrVtbEydOtNauXWutXLnSatu2rVW6dGnr2LFjCes89NBDVqlSpayffvrJWrp0qdWwYUOrcePGCcvPnDljXX755da1115rrVixwpo5c6ZVsGBBa+DAgQnr/PPPP1b27NmtPn36WH/++af11ltvWZkzZ7ZmzZplhRNLliyxypYta9WsWdPq3bt3wnwdY/9w8OBBq0yZMlb37t2txYsXm2Mye/Zsa/PmzQnrvPzyy1aePHmsr776ylq1apV14403WuXKlbNOnjyZsE6bNm2sWrVqWb///rv1888/WxUrVrRuv/32hOUxMTFWkSJFrDvvvNNcOx9//LGVLVs2a/z48VY4MGzYMKtAgQLWt99+a23ZssX67LPPrJw5c1pvvvlmwjo6zhcHr+1nnnnG+vLLL6kpWtOnT/danlHH9ddffzX3jxEjRpj7ybPPPmtFRUVZa9as8en3SLnxA/Xr17cefvjhhOmzZ89axYsXt1566SVX5Qom9u7day6oBQsWmOnDhw+bE5o3L4e//vrLrLNo0aKEizEiIsLavXt3wjpjx461cufObZ0+fdpMDxgwwKpevbrXvjp37myUq3Dh6NGjVqVKlawffvjBatasWYJyo2PsP5588kmrSZMmKS6Pj4+3ihYtao0cOTJhHo9/lixZzA2e8EbOY//HH38krPP9999bmTJlsnbu3Gmmx4wZY+XLly/h2Dv7rly5shUOtGvXzrr33nu9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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "timesteps, est_ssa, est_ss, gt = calculate_estimates()\n",
    "plot_estimates(timesteps, est_ssa, est_ss, gt)\n",
    "plot_error_ratio(timesteps, est_ssa, est_ss, gt)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## AOL Dataset Test - Vary Selection Probability"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "q_range = [\n",
    "    1/10, 1/20, 1/40, 1/80, 1/160, 1/320, 1/640\n",
    "]\n",
    "\n",
    "est_ssa_2 = []\n",
    "est_ss_2 = []\n",
    "gt_2 = []\n",
    "\n",
    "for q in q_range:\n",
    "    hist_ssa = {} # maps timestep to ssa value\n",
    "    hist_ss = {} # maps timestep to ss value\n",
    "    hist_hh_sums = {} # maps timestep to hh sum value\n",
    "    threads_vec_ssa = [] # stores thread identities\n",
    "    num_threads_max = 20 # hyperparam for max counters\n",
    "    vals = []\n",
    "    r1 = 3\n",
    "    r2 = 5\n",
    "    order = 3\n",
    "    filepath= \"aol-processed.csv\"\n",
    "    m = int(2e5)\n",
    "    W = int(m/2) # window size\n",
    "    sel_idx = m - W\n",
    "    q_ss = q\n",
    "    selective_subsampling_augmented(heavy=hh, filepath=filepath, order=order, limit=m, r1=r1, r2=r2, q=q, q_ss=q_ss)\n",
    "    timesteps, est_ssa, est_ss, _ = calculate_estimates()\n",
    "    diffs = np.absolute(np.array(timesteps)-sel_idx)\n",
    "    est_idx = diffs.argmin()\n",
    "    est_ssa_2.append(est_ssa[est_idx])\n",
    "    est_ss_2.append(est_ss[est_idx])\n",
    "    _, temp_freq = np.unique(vals[:-W], return_counts=True)\n",
    "    gt_2.append(np.linalg.norm(temp_freq, order))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjsAAAHLCAYAAAAurFnfAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAYW5JREFUeJzt3QncVHP///FP+6p9054t7UR2pZSULbJFFN2JkkKlSGVpkX1ffqjuO6GQVERU1rJEKIlI5dYitGs//8f763/mnmuumeuaubaZ61yv5+MxXc2ZMzPfOXPmnM/5fLdCnud5BgAAEFCFk10AAACA3ESwAwAAAo1gBwAABBrBDgAACDSCHQAAEGgEOwAAINAIdgAAQKAR7AAAgEAj2AEAAIFGsIPAWrBggRUqVMj9TSWnnXaauyE5Dhw4YE2bNrXRo0cnuyhAIPzxxx9WpkwZe/PNNy1VEewkybfffmsXXnih1atXz0qWLGm1atWyDh062KOPPppmvT179tjDDz9sRx99tJUrV84qVKhgTZo0sWuuuca+//77qK+9fPlyd5LX627evDnDcsycOdMKFy5s69evd/d///13GzBggB155JFWqlQpq1atmh133HF2yy232Pbt29M9t02bNm6d0qVL2yGHHGIXX3yxzZkzJ9PPX79+fVfGaLczzzzTEvHEE0/YxIkTLZV89913NmrUKPvll1+sINN3o+/0+OOPz3C9NWvW2LXXXuv2ixIlSrh9qkuXLvbxxx/HDGJfeeWVLJXpxRdftLVr19r1119veenll1+27t272+GHH+7Kn5WA97nnnrNGjRq537ZeJ/J4kVd0XNExqGrVqu4k17ZtW/vyyy8zfM5PP/3kyq3P/sUXX2TpfRs3bmwtWrRIt3z69OnudXU8ivT888+7x9555x3LDh1jYh2z/ONnZnRs1vGtbNmyVqlSJbviiivcMTcZnotjX9J27dixo9WsWdP9LmvXru3OW0uXLk2zXuXKle1f//qX3X777Zaqiia7AAXRJ5984g4OdevWtd69e1uNGjXcwXfRokUusOnfv39o3a5du9pbb71l3bp1c+vu3bvXBTmzZs2yk046yQUlkSZPnuxe86+//nInBO2EscyePduOOeYYt/6ff/5pxx57rG3dutWuvvpq99qK2L/55ht78skn7brrrnM/Urnvvvts8ODB7uAy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ljVs2NA79dRTQ/f37dvn3vfFF1+MWdZ7773XO+aYY2K+T7QyPfPMM267bd++PfT47NmzvcKFC4e2jV8+lcF30UUXeZdccomX7MxOwr2xNFVDtKkjtMyfxgEAgFiqVPknc+NTRif8r+hxrZfTVDvx22+/uSyLsigapLZly5ZpshOjR492o/A/9dRT1qRJE/f3yCOPdFmRjGhiar+HsX8799xz3WM9e/Z09xs2bOhqQ955550slV/l0ZRIvurVq7tBd33KCulcHD4G3csvv2wnn3yyy1opszV8+HDX6zkRmotSE3eHT/it19RQLyuUggsrX3hmSlmeyPHw8sUIyppmQakr7SD+WDZKnSkF9n//93+5UUYAQICoakrnRzVGXr78f1VXqsqaPFnDivwT6ORWQ+WSJUu6ah7dbr/9dndOGzlypAtIfAoYLrroIncbM2aMHX300W6CaTVsjkXVPxoeJRoFVBpe5a233nLVRRdffLGby/GVV15JqOzFihVLc1/VbNGWKQgRTa90+eWXu3O3qqFUxpdeesnuv//+hN43O+Xzy5Kvgh3tDBrfRvWPr732mlum+5r1nIH8AADxUCATLZhRoNOyZd6WpXHjxhmOJ1O8eHE3VVFmvbEyo9H61YZFN7UHUmZJPZjVq1hBwv79+y2nqT1PvXr17LbbbgstW716dbrPl9l76zyv7Je2gZ/dUZshZZmUrQrk3FgKal544YWcLw0AoEBWaamxcm5VXfnUvVyZmquvvtrNtahGul988YWNHz/eDVors2bNcpkPDU57xBFHuOFRZs6caW+++aZrQJyRnTt3ppuEWo2gNXzLAw884Kp0lCFSgDBt2jRXraSu7VK/fn3XBV5VQ/5zcsLhhx/uqqz0mVq1amWzZ892ja/D6b39QX3VqFnbJbLxtrJDyn6pw5IGO1QX/f79+9sVV1zhqtICOYKyZiBXnd9ll10WqotTam7ZsmU5XT4AQAGo0tKsPznd+yqS2qvoYv3BBx90vZeaNm3qqrHUU0g9iv0sj8bGufnmm10vIvXaUg+qZ5991p3YM6KmHApowm/dunVzjymAUFB17LHHuqBDY/cogPLb36haae7cuW5SagVEOUVthm688UbXa0qfR5kefebIdkzKMrVt29aqVq1qL774YrrX0TbRuEPKRKn8ykxpPCJ/u6W6Qv+/xXXc3n//fevUqZOLPtX1TY2WNDDTuHHjXIScaP1jKtCs56rH3LJlC5OCAkAmdu3a5TIBDRo0cO1fgGTtb/GevxPO7AwdOtTuvvtuF4Gqns/Xrl07N48VAABAKkk42FHXu/PPPz/dcg2ItElN6wEAAPJzsKPGVOvWrUu3/KuvvrJatWrlVLkAAACSE+yohfott9ziWpz7/efV/WzQoEF25ZVX5kypAAAAkhXsaHAljSSpFuPbt293LdfVqv2kk05yPbQAAADy9Tg7apSs7nUjRoxw7XcU8KibnPryAwAA5PvMjmY818BJyux07tzZDXmtQOfvv/92jwEAAOTrYEfzayibE0kBkB4DAADI18GOxiBUw+RIX3/9tZvfAwAAIF+22dE8HQpydNN8IeEBjyYQU7bn2muvza1y5h9r1vwzlW8suTmVLwDkFxwrc8xpp53mpoJ46KGH8vy9FyxY4KaZ+Ouvv0LzfOXrYEcbUVkdTaCm6ioNzxzeaFkTiZ144olmBf3Hq9lfNaNdLBrqOrcngAGAVJbEY6UmsFQHG02IuWHDBnch36JFC7dM0yD5NRWaP0qzAmg6Ak3YqTm1Hn30UTeAbrixY8e6nsiaMmnw4MGZvn+0mhHRfFQa2iUrgcVrr73mZk1PRlB10kknubH3wmOCfB3saKZT0dwU+nB5sWHzHV2lZPTjFT2u9Qh2ABRUSTxWatLLPXv22KRJk9y8jgp4NNu4ZkT3gyFNcHn22We7iS8VVGjSzjfeeMN27NiR7vWef/55GzJkiPsbT7Ajmj1dE2+Gy05WJJlNSIoXL+6CwZTnZcPff//tbdmyJc0tP1K5tSmyXf7FizWrauY3rQcA+ZSO/d999537m5+OlX/99Zc71i9YsCDmOtOnT/eKFi3q7d27N9PX0+vUqlXL27Nnj1ezZk3v448/zvQ5en+9Ryy//PKLd/bZZ3sVKlTwSpcu7TVu3NibPXu2t2rVKvfc8FuPHj3cc9q0aeMNGDAg9Br16tXz7rrrLu+KK67wypQp49WtW9ebMWOGt3HjRu/cc891y5o1a+Z9/vnnoeds2rTJu/TSS93nKFWqlNe0aVNvypQpocf1XpHvrzLNnz/f/V/b1vfKK6+4chcvXtyV5b777kvzGbVs9OjR3lVXXeWVLVvWq1Onjvf0009naX+L9/ydcANl9brSVPFK5ZUpU8alAMNvAACkorJly7rb66+/brt37466jrIU+/bts+nTp7umGxl57rnnrFu3bq6mQ391P7v69evnyvbBBx+4sezuueceV2YN9/Lqq6+6dVasWOGqjh5++OGYr/Pggw+6ajlN5XTWWWfZFVdc4WY56N69u3355Zd26KGHuvv+Z9TM4sccc4yr3lu6dKldc8017jmfffaZe1zvpaYqvXv3du+tm8oUafHixW5IGlXJqfyjRo1yVYITJ05Ms979999vxx57rCtf37597brrrnOfK9d4Cerbt6/XqFEjF7kp+nv++eddBFm7dm1v8uTJXn5EZgcAgp/ZEZ27Klas6JUsWdI76aSTvGHDhnlff/11mnVuvfVWl92pVKmSd+aZZ3rjx4/31q9fn2YdnS90DlyyZIm7/9VXX7ksxbZt2zJ8f51r9N7KroTfVq9e7R5XxmXUqFFRnxstixIrs9O9e/fQ/XXr1rnn3X777aFlCxcudMv0WCxnnXWWd/PNN8d8n2hluuyyy7wOHTqkWWfw4MEu0xOrfAcOHPCqVavmPfnkk6mT2Zk5c6Y98cQTrt6zaNGiduqpp7rGWZpG4oUXXsidiAwAgBygc9dvv/3m2uCo3Ywa/bZs2TJN5mH06NFu/sennnrKmjRp4v5qmiRlKsIbFCs7osbNooa79erVs5dffjnTMijrsmTJkjS3mjVrusduuOEGu/vuu11WZuTIkfbNN99k6XM2b9489P/q1au7v82aNUu3bOPGjaFe1XfddZdbR22AlE1Sm6U1akyegOXLl4caevt0/8cff3TvEa18arStjJpfltyQcLDz559/ukZdUq5cOXdfTjnlFJd2AwAglZUsWdI6dOjgqlc++eQT69mzpwsswlWuXNkuuugiu++++9wJXMGI/u9TldWyZcvcRb9/++6771xD5czoxH7YYYeluen58q9//ct+/vlnV4Wk4EpVPeoFlqjwTkSF/n8PsGjLNJm33Hvvva6qShN9z58/3wVgHTt2dI25c0NkJyd/YvGUCXYU6Kxatcr9X5Hu1KlTQxmfVO5jDwBANJrQOlpPq/AeR8ri+OsoCPniiy9cVig8O6P7CxcutO+//z5b5VFbGI1bpy7lN998s5uP0i+HhGdIcsrHH39s5513nmvTo2yVzvU//PBDmnX0/pm9d6NGjdxrRb62xucrUqSI5ZuJQK+66io3BkGbNm1s6NCh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h6x//fXXC0Q5Ro0aZUcddZTlV/Xr17eHHnooW68xceJEq1ChQkLbSVMXdOnSJXT/tNNOs4EDB2arHEAyEOwAueT333+36667zurWrWslSpSwGjVqWMeOHe3jjz+2oNCszSeccIKbwFATGjZp0iTpJ8NowdOgQYPsvffey5OgRO+vW5kyZaxly5Y2bdo0yy8y206vvfaa3XXXXTkahAF5gWAHyCVdu3a1r776yiZNmmQ//PCDvfHGG+7K+I8//rAg0EnxkksucZ/zs88+s8WLF9vo0aNt7969lmrKli1rlStXzpP3uvPOO23dunXuu2/VqpXbRp988knUdffs2WP5aTtVqlTJBbVAfkOwA+SCzZs324cffmj33HOPtW3b1urVq2fHHXecDRs2zM4999zQeg888IA1a9bMZQHq1Kljffv2te3bt6erepg1a5Y1bNjQSpcubRdeeKHt3LnTBVG6sq5YsaLdcMMNtn///tDztFxX4N26dXOvXatWLXv88cczLPPatWvt4osvdu+nk9p5551nv/zyS8z1Z86caSeffLINHjzYle2II45wVR6R7zNjxgyX4ShZsqQdcsghdscdd9i+ffuyVY7nn3/eZZGUMTv44IPt+uuvD31uOf/88112xb8fWT1z4MABF5TUrl3bvYYemzNnTuhxvZ+er0yGvj9t9xYtWtjChQstMwoGlMXT9tC2KFWqlNtW4d/LlVdeaeXKlbNrrrnGLX/11VdDn0fr3H///eled9u2bRl+n5ntSz5lvQ4//HD3fSjTqO0db3VfeDWW/r969Wq78cYbQ9msHTt2uM/1yiuvpHtPlUufAUgGgh0gl66QddNBfvfu3THXK1y4sD3yyCO2bNkyF7zMmzfPhgwZkmYdBTZa56WXXnIn5AULFriT+Ztvvulu//nPf+zpp59Od4K599573QlaGYahQ4fagAEDbO7cuVHLoWyMTnw6UStIU1Wbyn/mmWfGzD7ohK5yL126NObn02vpxK73/u6771w5FcApA5TVcjz55JPWr18/Fyh8++23LmN22GGHucc+//xz93fChAkuu+Lfj/Twww+7gOK+++6zb775xr2ngtAff/wxzXq33Xabq9pZsmSJC14UbGQUqEUqWrSoFStWLM021Hv638vtt9/uMmIK7i699FL3eRRwaLm2UyLfZ7z7krb9v//9b7dtFZTr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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "_, ax = plt.subplots()\n",
    "\n",
    "ax.plot(q_range, gt_2, 'g--', label='Ground Truth')\n",
    "ax.plot(q_range, est_ss_2, 'bP', label='SS Estimation')\n",
    "ax.plot(q_range, est_ssa_2, 'rs', label='SSA Estimation')\n",
    "ax.set_xscale('log', base=2)\n",
    "ax.set_title(f\"SSA/SS Estimation on AOL (n={m:.1e}, W={W:.1e})\")\n",
    "ax.set_ylabel(\"Estimated 3 Norm\")\n",
    "ax.set_xlabel(\"Sample Selection Probability\")\n",
    "ax.legend()\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
}
