{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Parallel AMS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import hash_func\n",
    "import numpy as np\n",
    "\n",
    "def parallel_ams(timestep, r=5):\n",
    "    '''\n",
    "    Description:\n",
    "        Runs AMS algorithm in parallel\n",
    "    Parameters:\n",
    "        timestep: timestep to start ams estimation\n",
    "        r: number of algorithm repetitions\n",
    "    Outputs:\n",
    "        returns estimated 2 norm\n",
    "    '''\n",
    "    #hist: global var shared among threads\n",
    "    #stream: global var shared among threads\n",
    "    #m: global var shared among threads\n",
    "    \n",
    "    hist[timestep] = np.zeros(r)\n",
    "    for i in range(timestep, m):\n",
    "        # generate r random signs\n",
    "        for j in range(r):\n",
    "            v_i = 2*hash_func(j, stream[i], 2) - 1\n",
    "            hist[timestep][j] += v_i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def plot_result(hist):\n",
    "    '''\n",
    "    Description:\n",
    "        Helper function to plot results of parallelized AMS/AMSA\n",
    "    Inputs:\n",
    "        hist: histogram of norm estimates\n",
    "    '''\n",
    "    \n",
    "    indices = []\n",
    "    est = []\n",
    "    \n",
    "    for time, norms in hist.items():\n",
    "        indices.append(time)\n",
    "        est.append(np.sqrt(np.median(norms**2)))\n",
    "    _, ax = plt.subplots()\n",
    "    \n",
    "    ax.scatter(indices, est)\n",
    "    ax.set_xlabel(\"Starting Timestep\")\n",
    "    ax.set_ylabel(\"Estimated 2 Norm\")\n",
    "    ax.set_title(f\"Estimated 2 Norm per Timestep\")\n",
    "    \n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Uniform Stream Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjsAAAHHCAYAAABZbpmkAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAANLZJREFUeJzt3QmczWUf///PMGPGvsZwW0Yoy4giIncRNSJ7i62Qm1LKUtTchShbdyES3d0iIeUOyS9KQ1Em+5LSRIkJY5SY0Ixlvr/H5/r9z/nPmcU9M87MOeea1/Px+JrzXc4517nmmPM+1/L9BjmO4wgAAIClCvm6AAAAAHmJsAMAAKxG2AEAAFYj7AAAAKsRdgAAgNUIOwAAwGqEHQAAYDXCDgAAsBphBwAAWI2wAwAArEbYAfLJt99+K/fee6/UqFFDwsLC5G9/+5vceeedMmvWLI/jJk2aJCtXrhQbBQUFydChQ93rx44dkxdeeEF2794t/iYiIsKUN7MlOTnZ18UDkAPBOTkYQO5s3rxZ2rRpI9WrV5dBgwZJeHi4xMfHyzfffCOvvfaaPPHEEx5hR0NR165dxXYadsaPH2+CRePGjcXfaJmeeuqpDNuLFCnik/IAyB3CDpAPJk6cKKVLl5Zt27ZJmTJlPPYlJibm+nHPnTsnxYsX90IJkRltfevbt2+2jz9//rwUK1YsT8sEIOfoxgLywU8//SQNGjTIEHRUxYoV3be1i0QDzDvvvOPuMunfv7/Zp909uv79999L7969pWzZstKqVSv3fRctWiRNmjSRokWLSrly5aRnz56m9SitTZs2yX333WdamEJDQ6VatWoyYsQI+euvvzyO0+csUaKEHDlyRO655x5zWz/4Z8+e7e6Su+OOO0zQ0m65JUuW5LhOvvjiC7n55pvN7QEDBrhf74IFC9zHbNmyRdq3b2+CooaI22+/Xb7++muPx3HVy48//miCiR57zTXXyJgxY8RxHFMHXbp0kVKlSpkWtVdffVW8oXXr1hIZGSk7duyQ2267zZTvn//8p9mXkpIi48aNk9q1a7vrefTo0WZ7Wrqu9a/lLVmypHTu3Fl+/fVX83r0daX9fWjrV3qu155edt4LrvLr+0lbHbX8+jt++eWXMzyedtvpc1133XWmC7Zy5crSvXt3877WOtayaR1ndj/9fTzyyCM5rF3Auwg7QD7QQKAfivv27bvice+++675cPz73/9ubuuS/oNCw4q2IGh3l3aJuVqOHnroIalTp45MmzZNhg8fLjExMeZD+PTp0+77Llu2zNx3yJAhZqxQVFSU+an3Te/y5cty9913mw9q/QDUDzQdb6NhRANI06ZNZerUqeZDWu9/6NChHNVJvXr1ZMKECeb24MGD3a9Xy6zWr19vbiclJZngoK9XX4uGrK1bt2Z4vAceeEBSU1NlypQp0rx5c3nppZdkxowZZlyUfohrWTV8PP3007Jx48ZslfHixYvy22+/eSxafy6///67qSPt7tLn0tCgZdDQ8sorr0inTp1M/WqX5PTp000Z0/rHP/5h7nfXXXeZcoeEhEjHjh3lamT3vaD++OMP87ts1KiRCYF169aVZ555RtasWePxPtDAq92NGqD0uGHDhsmZM2fM+1nDloZMvc+pU6c8Hv/jjz82v7+ctI4BecIBkOc+++wzp3DhwmZp0aKFM3r0aOfTTz91Lly4kOHY4sWLO/369cuwfdy4cY7+l+3Vq5fH9l9++cU87sSJEz22f/vtt05wcLDH9vPnz2d43MmTJztBQUHO4cOH3dv0+fW5Jk2a5N72xx9/OEWLFjXHLl261L39hx9+MMdq+f4XPe7xxx93r2/bts1smz9/vsdxqampTp06dZyoqChzO235a9as6dx5550Z6mXw4MHubZcuXXKqVq1qyjplypQMryGz+k2vRo0a5nHTL67Xefvtt5v1uXPnetzv3XffdQoVKuRs2rTJY7sep8d//fXXZn337t1m/bHHHvM4rnfv3hnqU8ur5UnP9dpz815wlX/hwoXubSkpKU54eLjTo0cP97a3337bHDdt2rQMz+/63cTFxZlj5syZ47G/c+fOTkREhMfvEPAFWnaAfKCtC7GxseYb/549e0xLibaqaIvDqlWrcvRYjz76qMf68uXLTWvC/fff79ECoV02+u1+w4YN7mO1W8NFu8v0uJYtW5quiF27dmV4Lm15cNEuuOuvv950Xelzueg23ffzzz+Lt+jsrAMHDpjuOm09cb0mLXPbtm1Ny4y+5qzKWrhwYdPypK9r4MCBGV5DdsuqLUTr1q3zWNK2gmkrnHbBpaWtZ9pqpa0kaX8f2iKlXL+PTz75xPx88sknPe6vLTG5lZP3gtLuybStLjrwulmzZh718+GHH0qFChU8BtG7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pVOnTuasxfp3YuXKlR77s1OvetWCPn36mJMN6kl9Bw4cKGfPnpU8483rVBV0S5cudYoUKeK8/fbbznfffecMGjTIKVOmjHPixAlfFy1gRUVFOfPnz3f27dvn7N692+nQoYNTvXp15+zZs+5jHn30UadatWpOTEyMs337dueWW25xWrZs6dNyB7KtW7c6ERERzg033OAMGzbMvZ169o5Tp045NWrUcPr37+9s2bLF+fnnn51PP/3UOXjwoPuYKVOmOKVLl3ZWrlzp7Nmzx+ncubNTs2ZN56+//vJp2QPJxIkTnfLlyzurV692Dh065CxbtswpUaKE89prr7mPoZ5z55NPPnGee+45Z/ny5ea6VCtWrPDYn516bd++vdOoUSPnm2++cTZt2uTUrl3b6dWrl5NXCDtepBceffzxx93rly9fdqpUqeJMnjzZp+WySWJiovnP9eWXX5r106dPOyEhIeYPmcv+/fvNMbGxsT4saWD6888/nTp16jjr1q1zbr/9dnfYoZ6955lnnnFatWqV5f7U1FQnPDzc+de//uXepvUfGhrqvPfee/lUysDXsWNH5+GHH/bY1r17d6dPnz7mNvXsHenDTnbq9fvvvzf327Ztm/uYNWvWOEFBQebi3nmBbiwvuXDhguzYscM017kUKlTIrMfGxvq0bDY5c+aM+VmuXDnzU+v84sWLHvVet25dqV69OvWeC9pN1bFjR4/6VNSz96xatcpc2ua+++4zXbM33nijvPXWW+79hw4dMmeCT1vXeu0f7RanrrOvZcuW5hqJP/74o1nfs2ePfPXVV3L33Xebdeo5b2SnXvWndl3p/wMXPV4/M7ds2ZIn5bLmDMq+9ttvv5k+4vSXqND1H374wWflsole4FXHkNx6660SGRlptul/Kr0YbPoLuWq96z5k39KlS2Xnzp2ybdu2DPuoZ+/5+eefZc6cOeaafv/85z9NfT/55JOmfvUaf676zOxvCXWdfc8++6y56raG8sKFC5u/zxMnTjTjRBT1nDeyU6/6U4N+WsHBweZLbF7VPWEHAdXqsG/fPvPtDN4VHx8vw4YNk3Xr1pnB9cjb0K7faCdNmmTWtWVH39dz5841YQfe8cEHH8jixYtlyZIl0qBBA9m9e7f5sqSDaqnngoduLC+pUKGC+faQfnaKroeHh/usXLbQ656tXr1aNmzYIFWrVnVv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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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AOAoZH4AAICjEPwAAABHIfgBAACOQvADAAAcheAnhN566y2pXLmy5M+fXxo0aCDLli2L9ClFtREjRsi1115rZtouU6aMtGnTRjZu3OhxzOnTp6VHjx5SsmRJKVSokLRr10727Nnjccz27duldevWUrBgQfM8zzzzjJw/f97jmG+//Vauvvpq02lQtWpVGT9+vDjZyJEjzezmTz31lGsb1zp4du7cKR07djTXskCBAlK7dm1ZsWKFa7/2nQwePFjKlStn9jdr1kw2b97s8RwHDx6UBx54wEwIV6xYMenatascP37c45iff/5ZbrjhBvM3R2fPHT16tDjJhQsXZNCgQVKlShVzHS+//HIZNmyYx7pPXOvsWbhwodxxxx1mJmX9WzFt2jSP/eG8rpMnT5YaNWqYY/R3adasWYG/IO32QvB9+umnVr58+awPPvjAWrdundWtWzerWLFi1p49eyJ9alGrZcuW1ocffmitXbvWWr16tXXbbbdZFStWtI4fP+465vHHH7cqVKhgzZs3z1qxYoXVsGFD6/rrr3ftP3/+vFWrVi2rWbNm1o8//mjNmjXLKlWqlDVw4EDXMb/++qtVsGBBq2/fvtb69eutN954w8qdO7c1Z84cy4mWLVtmVa5c2apTp47Vu3dv13audXAcPHjQqlSpktWlSxdr6dKl5pp8/fXX1pYtW1zHjBw50ipatKg1bdo066effrLuvPNOq0qVKtapU6dcx9x6663WVVddZS1ZssT6/vvvrapVq1odOnRw7T9y5IhVtmxZ64EHHjC/Q5988olVoEAB691337Wc4h//+IdVsmRJa+bMmda2bdusyZMnW4UKFbJee+011zFc6+zR3+9nn33WmjJlikaS1tSpUz32h+u6Ll682PwNGT16tPmb8txzz1l58+a11qxZE9DrIfgJkeuuu87q0aOH6/GFCxes8uXLWyNGjIjoecWSvXv3ml+y7777zjw+fPiw+SHXP2i2DRs2mGNSU1Ndv6C5cuWy0tLSXMe88847VpEiRawzZ86Yx3/729+sK6+80uNr3XfffSb4cppjx45Z1apVs+bOnWvddNNNruCHax08/fv3t5o0aZLh/vT0dCs5Odn65z//6dqm1z8xMdH88Vf6R16v/fLly13HzJ4920pISLB27txpHr/99ttW8eLFXdfe/trVq1e3nKJ169bWww8/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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils import generate_stream_uniform, plot_stream\n",
    "\n",
    "n_uniform = 100\n",
    "m_uniform = 10000\n",
    "num_threads = 100\n",
    "\n",
    "stream_uniform, freq_uniform = generate_stream_uniform(n_uniform, m_uniform)\n",
    "plot_stream(stream_uniform)\n",
    "\n",
    "# init shared variables\n",
    "hist = {}\n",
    "m=m_uniform\n",
    "stream=stream_uniform\n",
    "\n",
    "# process the stream and spawn threads\n",
    "for time in range(m):\n",
    "    if time % num_threads == 0:\n",
    "        parallel_ams(time)\n",
    "\n",
    "# visualize the results\n",
    "plot_result(hist)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Skewed Stream Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2TM2b95sBQYGWu+88461b98+a86cOVaBAgWs2bNnO8uMHj3a/O5YsmSJtXPnTuvRRx+1KlasaP3zzz9erbs/6dq1q3XzzTdbS5cutQ4ePGgtXLjQKlmypPXKK684y3CeMzcT9eeffzaLxowJEyaYrw8fPpzuc9qiRQvr1ltvtX788Ufr+++/NzNb27dvb2UlApEXfPDBB+ZDI2/evGYa/g8//ODtKvk1/Q+X2jJ9+nRnGf2P9txzz1nFihUzHyyPPfaYCU3wbCDiPHvO119/bdWuXdv8AVW9enXr448/dtuv05fffPNNKyQkxJRp2rSpFRsb67X6+qOEhATz86u/j/Ply2fdcsst1uuvv24lJiY6y3CeM27NmjWp/k7WAJrec3rq1CkTgAoVKmQFBwdb3bt3N0ErKwXoP1nX/gQAAOD7GEMEAABsj0AEAABsj0AEAABsj0AEAABsj0AEAABsj0AEAABsj0AEAABsj0AEAABsj0AEIMucPHlS+vTpI+XLl5egoCBzD6OIiAjZuHGjs0xAQIAsXrxY/E1YWJhMnDjR748DwP8V+P8eAcDj2rZtK5cvX5aZM2fKLbfcYu5orTd1PHXqVIZeR19Db44MAFmFFiIAWULvVr1hwwYZM2aM3H///eZO7XfeeadERUXJI4884mxlUY899phpYXGsDxs2TOrXry+ffPKJuTt2vnz5nK/5zDPPyE033STBwcHywAMPyI4dO5zveeDAAXn00UclJCREChUqJHfccYesXLnSrV76Hm+//bZ06dLFlNF6ffXVV6Y1S5+r2+rWrStbt25N97GmdRxqyZIlctttt5lj0FA4fPhwSUpKcu7X8h999JE8/PDDUqBAAalRo4bExMTI/v37pUmTJlKwYEG5++67zbEByDoEIgBZQoOFLtqNlJiYmGqZLVu2mMfp06fL8ePHnetKA8GXX34pCxculO3bt5ttTzzxhMTHx8uyZctk27ZtJmg0bdpU/v77b7P//Pnz8tBDD5lWqJ9//llatGghrVq1kiNHjri973vvvSf33HOPKRMZGSmdO3c2AalTp07y008/SaVKlcx6em/1mNZxaCDU13nhhRdkz549JvjMmDFD3nnnHbfnv/XWW6acHmf16tWlQ4cO8uyzz5rwqMFM69GvX78MnH0AGZalt44FYGv/+9//zJ3v9U7id999txUVFWXt2LHDrYz+Glq0aJHbtqFDh1p58uSx4uPjnds2bNhg7np96dIlt7KVKlWyPvroozTrUKtWLeuDDz5wrleoUMHq1KmTc/348eOmDnr3bYeYmBizTfelRV/nvffeu+5x6F28R44c6bbts88+s0qXLu32vDfeeCPFe3/66afObZ9//rk5hwCyDi1EALJ0DNGxY8dMl5S21qxdu9a06mgryb/RriztGnPQrjFtASpRooSz9UmXgwcPOruTdP/LL79sup2KFi1q9v/6668pWoi0S8xBu9dUnTp1UmzT1qgboXUeMWKEW3179uxpWpEuXryYofpcunRJEhISbqg+ANLGoGoAWUrHzjz44INmefPNN80YoKFDh0q3bt2u+zwdO+NKw07p0qVNqEpOw4/SMBQdHS3vvvuuVK5cWfLnzy+PP/64GZTtKk+ePG5jeNLadu3atUwds2uddcxQmzZtUuxzjIvKzvoASBuBCEC2qlmzptv0dP3gv3r16r8+T1uW4uLiJDAw0G3Qsiudzq9BSwc3OwLJoUOHJDukdhxa59jYWBPOAPg2uswAZAmdWq+zwGbPni07d+40XVsLFiyQsWPHmtlcDhpudBC0hp3Tp0+n+XrNmjWT8PBwad26taxYscIEnU2bNsnrr7/unBFWpUoV5yBs7a7SwcnZ1aqS2nEMGTJEZs2aZVqJdu/ebbrv5s2bJ2+88Ua21AlA+hGIAGQJHS/TsGFDM6OrcePGUrt2bdNlpmNoPvzwQ2e58ePHm26ucuXKya233prm62m30bfffmteq3v37lK1alVp166dHD582DnuZsKECVKsWDEzTV1nl+lFILWVJjukdhz6/kuXLjUBTi8BcNddd5nzoeOjAPiWAB1Z7e1KAAAAeBMtRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAwPYIRAAAQOzu/wA8wgAhxtSEzwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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NHGqsWPHmi7y/fr1c23jPGesP//8Uzp06GDOZ548eaRmzZryyy+/uG7X+TRDhw6VkiVLmtsbN24s27Zt83iMw4cPS/v27U1jvcKFC0uXLl3k5MmTHvusW7dO7rjjDvN7RzsVjx8/Xpzk0qVLMmTIEClfvrw5jxUrVpRRo0Z5rNXFuU6bpUuXSqtWrUzXav19MXv2bI/bM/O8zpw5U2644Qazj/4szZ071/8XpLPYkPk+++wzK1euXNb7779vbdy40eratatVuHBha9++fcE+tJDWrFkz64MPPrA2bNhgrV271mrRooVVpkwZ6+TJk659unfvbpUuXdpauHCh9csvv1i33nqrddttt7luv3jxolWjRg2rcePG1po1a6y5c+daUVFR1uDBg137/P7771bevHmtAQMGWJs2bbLefPNNK3v27Nb8+fMtp1m5cqVVrlw5q1atWlbfvn1d2znPGefw4cNW2bJlrc6dO1srVqww52XBggVWQkKCa5+xY8dahQoVsmbPnm39+uuv1n333WeVL1/eOnPmjGufe+65x6pdu7a1fPly68cff7QqVapktWvXznX7sWPHrBIlSljt27c3P0OffvqplSdPHuutt96ynOLll1+2ihUrZn377bfW9u3brZkzZ1r58+e3Xn/9ddc+nOu00Z/xF1980frqq6802rRmzZrlcXtmnde4uDjze2T8+PHm98pLL71k5cyZ01q/fr1fr4cAKUhuueUWq2fPnq7rly5dskqVKmWNGTMmqMeV1ezfv9/8IP7www/m+tGjR80Pgv7Ss23evNnsEx8f7/ohzpYtm5WUlOTaZ8qUKVbBggWtc+fOmevPP/+8Vb16dY/neuSRR0yA5iQnTpywKleubMXGxlr/+Mc/XAES5zljDRw40Lr99ttTvP3y5ctWdHS09corr7i26XsQGRlpPiCUfhDo+f/5559d+8ybN8+KiIiw/vzzT3P93//+t1WkSBHX+befu0qVKpZTtGzZ0nryySc9tj3wwAPmA1dxrjOGeAVImXleH374YfM+u6tfv7719NNP+/UaGGILgvPnz8uqVatMetF9vTe9Hh8fH9Rjy2qOHTtmvhYtWtR81fN64cIFj3OradYyZcq4zq1+1ZRriRIlXPs0a9bMLI64ceNG1z7uj2Hv47T3R4fQdIjM+1xwnjPWN998IzfddJM89NBDZiiybt268s4777hu3759uyQlJXmcK11fSofm3c+3Dkno49h0f/3dsmLFCtc+DRs2lFy5cnmcbx2mPnLkiDjBbbfdJgsXLpStW7ea67/++qssW7ZMmjdvbq5zrgNjeyae14z6vUKAFAQHDx404+DuHxxKr+s3EHxz+fJlUxPToEEDqVGjhtmm509/cPSHLKVzq1+TO/f2bVfbRz/cz5w5I07w2WefyerVq03dlzfOc8b6/fffZcqUKVK5cmVZsGCB9OjRQ/r06SMffvihx/m62u8M/arBlbscOXKYPx78eU/C3aBBg+TRRx81AX3OnDlNMKq/R7TuRXGuAyMpE89rSvv4e95z+LU3EGLZjQ0bNpi//pCxdu/eLX379pXY2FhT5IjAB/v6V/Po0aPNdf3Q1u/tqVOnSqdOnYJ9eGHliy++kOnTp8uMGTOkevXqsnbtWhMgaWEx5xruyCAFQVRUlGTPnv2KGT96PTo6OmjHlZX06tVLvv32W1m8eLFcd911ru16/nQI8+jRoymeW/2a3Lm3b7vaPjqzQmdfhDsdQtu/f7+ZXaZ/wenlhx9+kDfeeMP8X/8a4zxnHJ3VU61aNY9tVatWNbMA3c/X1X5n6Fd9z9zpjEGdFeTPexLudCalnUXSIeCOHTtK//79XZlSznVgRGfieU1pH3/POwFSEOjQRL169cw4uPtfkHo9JiYmqMcW6rT2T4OjWbNmyaJFi8xUXXd6XjVt7n5udWxaP2jsc6tf169f7/GDqJkS/VC2P6R0H/fHsPdxyvtz9913m3Okf13bF81w6DCE/X/Oc8bRYWLvdhVaI1O2bFnzf/0+11/u7udKhyG1LsP9fGvAqsGtTX9G9HeL1nnY++hUbK0fcz/fVapUkSJFiogTnD592tS0uNM/WPU8Kc51YJTPxPOaYb9X/CrpRoZO89fq/WnTppnK/W7duplp/u4zfnClHj16mGmiS5Yssfbu3eu6nD592mP6uU79X7RokZl+HhMTYy7e08+bNm1qWgXolPJrrrkm2ennzz33nJmdNXnyZEdOP3fnPotNcZ4ztpVCjhw5zBT0bdu2WdOnTzfn5ZNPPvGYIq2/I77++mtr3bp11v3335/sFOm6deuaVgHLli0zMxDdp0jrrCGdIt2xY0czRVp/D+nzhPPUc2+dOnWyrr32Wtc0f52Sru0ndEaljXOdNjrrVVt66EXDi9dee838f+fOnZl6XnWav/48/etf/zK/V4YNG8Y0/6xGe77oB4z2Q9Jp/9r3AVenP3TJXbQ3kk1/2J555hkzFVR/cNq0aWOCKHc7duywmjdvbvpn6C/Hf/7zn9aFCxc89lm8eLFVp04d8/5UqFDB4zmcyDtA4jxnrDlz5piAUv9wuuGGG6y3337b43adJj1kyBDz4aD73H333daWLVs89jl06JD5MNG+PtpO4YknnjAfWu60/4y2FNDH0EBBP7Sc5Pjx4+b7WH/35s6d23zPae8e92njnOu00Z/l5H4/a1Ca2ef1iy++sK6//nrze0VbiXz33Xd+v54I/SdtCTMAAIDwRA0SAACAFwIkAAAALwRIAAAAXgiQAAAAvBAgAQAAeCFAAgAA8EKABAAA4IUACUBI6ty5s7Ru3TrYhxEyxwEgcxEgAfBw4MAB6dGjh5QpU0YiIyPN+knNmjWTuLg41z4REREye/bsDHm+HTt2mMfTNd7cvf766zJt2jQJJH3eq12GDx+eKceRGoI0IPPlCMJzAghhbdu2lfPnz8uHH34oFSpUMKtg68KPhw4dyvDn0udJSaFChSTQ9u7d6/r/559/LkOHDvVYNDZ//vzmAsCB/F6cBEDYOnLkiFk7SRcDTknZsmU91lnS6yohIcG67777rOLFi1v58uWzbrrpJis2NvaK+44cOdIsNFmgQAGzRpP3uk265pvS23QxS5tu7927t1nYVtd/0/WcdBFKd7owZYMGDcwaTVWrVjXPr485a9asVF+7rgGnCyF7S+44evXqZdbz0oU39fXqumknT560OnfubNaQqlixojV37lyPx9GFMnUhTj03ep8OHTpYBw4ccN0+c+ZMsxabrg9WtGhRs06VPqa+Ru9zpGteqV27dlkPPfSQOW49J3r+dQFW72MfPny4WQtPz/nTTz/tse4YgOQxxAbgioyJDp+dO3cu2X1+/vln8/WDDz4wGRj7+smTJ6VFixYm27RmzRq55557pFWrVrJr1y6P+//rX/+S2rVrm32GDBkiK1euNNu///5783hfffVVisenWa18+fLJihUrZPz48TJy5EiJjY01t126dMkMQ+XNm9fc/vbbb8uLL76YYefG+ziioqLMsffu3dsMST700ENy2223yerVq6Vp06bSsWNHOX36tNn/6NGjctddd0ndunXll19+kfnz55vM3MMPP2xu19fdrl07efLJJ2Xz5s2yZMkSeeCBB/QPWHn22WfNfno+dT+96PNcuHDBDH0WKFBAfvzxRzMEqu+d7ueemdP3w37MTz/91JzfESNGBOS8AGElhcAJgEP95z//MdkIzWTcdttt1uDBg83q2e58zcroKtpvvvmmRwapdevWHvtoxkMfb82aNalmbnQFb3c333yzNXDgQPP/efPmWTly5LD27t3ruj1QGST347h48aLJCmlWzKbHoM8bHx9vro8aNcpq2rSpx+Pu3r3b7KOrma9atcr8f8eOHckem/cxqI8//tiqUqWKWSHdppmhPHnyWAsWLHDdT7NRp06dcu0zZcoUk+W6dOlSqucEcDIySACuqEHas2ePfPPNNyYboZmHG2+8MdVCZc0gabajatWqUrhwYZPN0MyFdwbppptuSvOx1apVy+N6yZIlZf/+/eb/WjtUunRpU1Ruu+WWW9L8XL4eR/bs2aVYsWJSs2ZN17YSJUqYr/ax/frrr7J48WJXhk4vN9xwg7ktMTHRZNTuvvtu8xiaiXrnnXfkyJEjVz0GfcyEhASTQbIfs2jRonL27FnzmDZ9bM2q2WJiYsx7tXv37gw8I0D4oUgbwBVy584tTZo0MRcdBnvqqadk2LBhZjZVSjQ40uEuHUKrVKmS5MmTRx588MErCrF1iCytcubM6XFdZ5pdvnw5zY+Xkcfhvk2vK/vYNCDR4cZx48Zd8Vga5GmQpefup59+kv/+97/y5ptvmuFBHSosX758ssegj1mvXj2ZPn36Fbddc8016X6NgNMRIAFIVbVq1Tym9WswoDU/7rQGRgOoNm3auD7AdQp/anLlymW+ej+ev6pUqWKyIlrbY2dw7PqoYNMM3JdffinlypWTHDmS/7WrQVWDBg3MRWfTlS1bVmbNmiUDBgww58j7/Ohj6sy74sWLS8GCBa+aaTpz5owJWNXy5ctNtkmzbQBSxhAbABedyq/FxJ988omsW7dOtm/fLjNnzjQF0ffff79rP/2g1+LfpKQk11BQ5cqVTQGw9jPSD+XHHnvMp+yOfsDrh7dduHzs2LE0HbtmuypWrCidOnUyx64B20svveSR0QmWnj17yuHDh00htgZtOgS2YMECeeKJJ0zgo5mi0aNHmwJuHZLU86j9qHS40j7f+pp0GPHgwYOmQLt9+/amUFzfFy3S1vdKh0P79Okjf/zxh+u5NYPXpUsX2bRpk8ydO9dkAnv16iXZsvHrH7gafkIAuGhmoX79+jJhwgRp2LCh1KhRwwyxde3aVSZNmuTa79VXXzVDQpqF0JlZ6rXXXpMiRYqYGVY6nKQzrDTLkRrNqLzxxhvy1ltvSalSpTwCMX/oMJVmuTRzdfPNN5thQXsWmw4ZBpO+Lg3YNBjSGW5aa9SvXz9Tq6WBimaAli5damYBXn/99Saw03PcvHlzc389/5oh0/otHT7Tx9K6Ir2PNvTUGW8aTGkgpDVI7hklrW3S4FXfz0ceeUTuu+8+0wATwNVFaKV2KvsAQJakgcTtt99uipk1u+Q0OuSpLQYyqus54CTUIAEIG1qzo1kwzZhoUNS3b19T0+PE4AhA+hAgAQgbJ06ckIEDB5o6Hq3Pady4sRmqAgB/McQGAADghSJtAAAALwRIAAAAXgiQAAAAvBAgAQAAeCFAAgAA8EKABAAA4IUACQAAwAsBEgAAgBcCJAAAAPH0/0smKCzXyI56AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils import generate_stream_skewed, plot_stream\n",
    "n_skewed = 100\n",
    "m_skewed = 10000\n",
    "num_threads = 100\n",
    "\n",
    "stream_skewed, freq_skewed = generate_stream_skewed(n=n_skewed,m=m_skewed, q=1, k=2)\n",
    "plot_stream(stream_skewed)\n",
    "\n",
    "# init shared variables\n",
    "hist = {}\n",
    "m=m_skewed\n",
    "stream=stream_skewed\n",
    "\n",
    "# process the stream and spawn threads\n",
    "for time in range(m):\n",
    "    if time % num_threads == 0:\n",
    "        parallel_ams(time)\n",
    "\n",
    "#visualize the result\n",
    "plot_result(hist)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Implement Thread Pruning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prune_threads():\n",
    "    # i is index, t_i is thread identity\n",
    "    i = 0\n",
    "    while (i < len(threads_vec)):\n",
    "        # check boundary\n",
    "        if (i >= len(threads_vec) - 2):\n",
    "            i += 1\n",
    "            continue\n",
    "        t_i = threads_vec[i]\n",
    "        ams_t = np.sqrt(np.median(hist[t_i]**2))\n",
    "        # check adjacent thread\n",
    "        t_i2 = threads_vec[i+2]\n",
    "        ams_t2 = np.sqrt(np.median(hist[t_i2]**2))\n",
    "        # check distance, prune hist, threads\n",
    "        if (max(ams_t, ams_t2)/min(ams_t, ams_t2) <= 2):\n",
    "            # remove the thread in between\n",
    "            t_i1 = threads_vec[i+1]\n",
    "            threads_vec.pop(i+1)\n",
    "            hist.pop(t_i1)\n",
    "            i -= 1\n",
    "        i += 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Uniform Stream Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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fu/evRk+18WLF8027jcAAOBMARN2Fi9eLKdPn5auXbuax/Hx8aZkpkiRIh7babDRdfY27kHHXm+vy8iECRNMErRv0dHRPnhFAAAgEARM2Hn33XelZcuWUqZMGZ8/1/Dhw02Rl32Li4vz+XMCAIAcPDfWr7/+Kl988YUsXLjQtSwqKspUbWlpj3vpjvbG0nX2Nlu3bvXYl91by94mPeHh4eYGAACcLyBKdmbPnm26jWvPKlvdunUld+7csnr1atey/fv3m67mDRs2NI/1fs+ePZKQkODaRnt0aSOlmJiYbH4VAAAgEPm9ZCc1NdWEnS5dukiuXP87HG1L06NHDxk0aJAUK1bMBJi+ffuagKM9sVTz5s1NqOncubNMmjTJtNMZMWKEGZuHkhsAABAQYUerr7S0RnthpTVlyhQJDQ01gwlqDyrtaTV9+nTX+rCwMNNVvVevXiYE5c+f34SmcePGZfOrAAAAgSqgxtnxF8bZAQAg+ATdODsAAAC+QNgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACO5vew8/vvv0unTp2kePHikjdvXqlZs6Zs377dtd6yLBk1apSULl3arG/atKkcOHDAYx8nT56Ujh07SqFChaRIkSLSo0cPOXfunB9eDQAACDR+DTunTp2Sxo0bS+7cuWX58uWyb98+ee2116Ro0aKubSZNmiRTp06VmTNnypYtWyR//vwSGxsrSUlJrm006Ozdu1dWrVolS5culQ0bNsjTTz/tp1cFAAACSYilRSd+MmzYMNm4caN8+eWX6a7XQytTpow8//zzMnjwYLMsMTFRSpUqJXPmzJHHH39cvv/+e4mJiZFt27ZJvXr1zDYrVqyQVq1ayW+//WZ+/1rOnDkjhQsXNvvW0iEAABD4Mnv99mvJzqeffmoCSvv27SUyMlLq1Kkjs2bNcq0/dOiQxMfHm6orm76oBg0ayObNm81jvdeqKzvoKN0+NDTUlASl5+LFi+YEud8AAIAz+TXs/PzzzzJjxgypXLmyrFy5Unr16iX9+vWTuXPnmvUadJSW5LjTx/Y6vdeg5C5XrlxSrFgx1zZpTZgwwYQm+xYdHe2jVwgAAHJ02ElNTZXbb79dxo8fb0p1tJ1Nz549TfscXxo+fLgp8rJvcXFxPn0+AACQQ8OO9rDS9jbuqlevLocPHzY/R0VFmftjx455bKOP7XV6n5CQ4LE+OTnZ9NCyt0krPDzc1O253wAAgDP5NexoT6z9+/d7LPvxxx+lXLly5ucKFSqYwLJ69WrXem1fo21xGjZsaB7r/enTp2XHjh2ubdasWWNKjbRtDwAAyNly+fPJBw4cKI0aNTLVWB06dJCtW7fK22+/bW4qJCREBgwYIC+//LJp16PhZ+TIkaaHVZs2bVwlQS1atHBVf12+fFn69OljemplpicWAABwNr92PVc6Lo62odGBAjXMDBo0yAQXmx7e6NGjTQDSEpwmTZrI9OnTpUqVKq5ttMpKA86SJUtML6x27dqZsXkKFCiQqWOg6zkAAMEns9dvv4edQEDYAQAg+ATFODsAAAC+RtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACORtgBAACO5tewM2bMGAkJCfG4VatWzbU+KSlJevfuLcWLF5cCBQpIu3bt5NixYx77OHz4sLRu3Vry5csnkZGRMmTIEElOTvbDqwEAAIEol78P4NZbb5UvvvjC9ThXrv8d0sCBA+Wzzz6TBQsWSOHChaVPnz7Stm1b2bhxo1mfkpJigk5UVJRs2rRJjh49Kk8++aTkzp1bxo8f75fXAwAAAovfw46GGw0raSUmJsq7774r8+fPl/vvv98smz17tlSvXl2+/vprufPOO+Xzzz+Xffv2mbBUqlQpqV27trz00ksydOhQU2qUJ08eP7wiAAAQ9GHnyJEj8tVXX0lCQoKkpqZ6rOvXr1+W9nXgwAEpU6aMRERESMOGDWXChAlStmxZ2bFjh1y+fFmaNm3q2laruHTd5s2bTdjR+5o1a5qgY4uNjZVevXrJ3r17pU6dOuk+58WLF83NdubMmSwdMwAAcHDYmTNnjjzzzDOm1ETb0mg7G5v+nJWw06BBA7O/qlWrmiqosWPHyl133SXfffedxMfHm+coUqSIx+9osNF1Su/dg4693l6XEQ1U+lwAAMD5shx2Ro4cKaNGjZLhw4dLaOiNtW9u2bKl6+datWqZ8FOuXDn56KOPJG/evOIreuyDBg3yKNmJjo722fMBAAD/yXJaOX/+vDz++OM3HHTSo6U4VapUkZ9++sm047l06ZKcPn3aYxvtjWW38dH7tL2z7MfptQOyhYeHS6FChTxuAADAmbKcWHr06GF6R/nCuXPn5ODBg1K6dGmpW7eu6VW1evVq1/r9+/ebrubatkfp/Z49e0zbIduqVatMeImJifHJMQIAgOASYlmWlZVf0O7eDz74oFy4cME0DtZA4m7y5MmZ3tfgwYPloYceMlVX2uh59OjRsnv3btPDqmTJkqah8bJly0y7Hg0wffv2Nb+n3cztY9EeWNrAedKkSaadTufOneWpp57KUtdzrcbSru3aA4xSHgAAgkNmr99ZbrOjjXtXrlxpGhWrtA2Us+K3336TJ554Qk6cOGHCTZMmTUy3cv1ZTZkyxVSX6WCC2ntKe1pNnz7d9fthYWGydOlSE4q0lCd//vzSpUsXGTduXFZfFgAAcKgsl+wULVrUhJCuXbuKU1CyAwCAc6/fWW6zo417GzdufKPHBwAAkC2yHHb69+8vb775pm+OBgAAwMuy3GZn69atsmbNGtNWRue1SttAeeHChd48PgAAgOwNOzoWjk7GCQAA4Liwk5ycLPfdd580b978qoP2AQAABGWbHZ2h/Nlnn/WYRBMAAMBRDZTr168vu3bt8s3RAAAA+LvNznPPPSfPP/+8GRBQp3TQgfzc6YSeAAAAgSLLgwqmNwGojpysu9F7ncIh2DCoIAAAwcdn00UcOnToRo8NAAAg22Q57OiknQAAAI4NO+rgwYPy+uuvy/fff28ex8TEmJGVK1as6O3jAwAAyN7eWDrjuYYbHUlZGyPrbcuWLWY05VWrVt3Y0QAAAPi7gXKdOnUkNjZWJk6c6LF82LBh8vnnn8vOnTsl2NBAGQCA4OOzWc+16qpHjx5XLO/evbvs27cv60cKAADgQ1kOOyVLlpTdu3dfsVyXRUZGeuu4AAAA/NNAuWfPnvL000/Lzz//LI0aNTLLNm7cKK+88ooMGjTIO0cFAADgrzY7urn2xHrttdfkyJEjZlmZMmVkyJAh0q9fPzOwYLChzQ4AAOLY63eWw467s2fPmvuCBQtKMCPsAAAQfHw2grK7YA85AADA+TIddu67775rVlHp+tWrV3vjuAAAALI37NSuXfuq1Vnz58+XixcveueoAAAAsjvsTJky5YplycnJMm3aNPnb3/4mN910k7z00kveOi4AAACvuO42O/PmzZNRo0bJhQsXZMyYMaY7eq5cN9QECAAAwOuynE5WrFhhpoY4dOiQDB482Iytkz9/fu8fGQAAQHaGHZ34c+jQofL111/Ls88+K1988YWUKFHCG8cAAADgM5keZyc0NFTy5s1rqqsqVKiQ4XY6sGCwYZwdAACCj9cHFSxfvnymup7rNBLBhrADAEDw8fqggr/88ou3jg0AACBwZz0HAAAIJoQdAADgaIQdAADgaIQdAADgaIQdAADgaAETdiZOnGi6rg8YMMC1LCkpSXr37i3FixeXAgUKSLt27eTYsWMev3f48GFp3bq15MuXTyIjI2XIkCFmzi4AAIAshZ3Lly/LCy+8IJUqVZL69evLe++957FeQ0hYWNh1ndVt27bJW2+9JbVq1fJYPnDgQFmyZIksWLBA1q9fL0eOHJG2bdu61qekpJigc+nSJdm0aZPMnTtX5syZY+bsAgAAyFLY0ZnN//nPf5qpIpo3b27mxHrmmWc8tsnk+IQezp07Jx07dpRZs2ZJ0aJFXct1gKB3331XJk+eLPfff7/UrVtXZs+ebUKNTlmhPv/8c9m3b5+8//77Urt2bWnZsqWZeV1nYtcABAAAEJqVWc7feecdM/nnyy+/LNu3b5c1a9ZIt27dXCHnWiMsp0erqbR0pmnTph7Ld+zYYUqT3JdXq1ZNypYtK5s3bzaP9b5mzZpSqlQp1zaxsbFmRMW9e/dm+VgAAEAODju///671KhRw/VYq7PWrVtnSlo6d+5sqpSy6oMPPpCdO3fKhAkTrlgXHx8vefLkkSJFings12Cj6+xt3IOOvd5el5GLFy+aQOR+AwAAOTzsREVFycGDBz2W3XTTTbJ27VrT5qZr165ZeuK4uDjp37+/KTGKiIiQ7KThSufSsG/R0dHZ+vwAACAAw462m5k/f/4Vy8uUKWOqsw4dOpSlJ9ZqqoSEBLn99tslV65c5qaNkKdOnWp+1hIabXdz+vTpKxpCa/BSep+2d5b92N4mPcOHDzdtguybBi8AAOBMmZ4IdOTIkfLDDz+ku05LeDSorFq1KtNP/MADD8iePXs8lmn7H22XM3ToUFPakjt3blm9erXpcq72799vupo3bNjQPNZ7bTitoUm7nSs9Bp35NCYmJsPnDg8PNzcAAOB8Idb1dKHykXvvvdf0qnr99dfN4169esmyZctMd3INMH379jXLtZ2Q0nZCur2WLk2aNMm009H2Q0899ZSMHz/e61PEAwCAwJHZ63emS3b8YcqUKRIaGmpKdrRRsfa0mj59umu9juuzdOlSE4q0lCd//vzSpUsXGTdunF+PGwAABI6AKtnxF0p2AABw7vU7YKaLAAAA8AXCDgAAcDTCDgAAcLRMNVDWOasyOxXEyZMnb/SYACDbpKRasvXQSUk4mySRBSOkfoViEhaa9alvAAR52LG7gqsTJ06YubG0Z5Q93o3OUbVy5UozFg8ABIsV3x2VsUv2ydHEJNey0oUjZPRDMdKiRmm/HhsAP/bG0m7g9913n/Tp08dj+T/+8Q/54osvZPHixRJs6I0F5Myg0+v9nZL2C9Au05nR6XYCD5BTe2NpCU6LFi2uWK7LNOwAQDBUXWmJTnp/6dnLdL1uByD4ZTnsFC9eXD755JMrlusyXQcAgU7b6LhXXaWlEUfX63YAgl+WR1AeO3asmY5h3bp10qBBA7Nsy5YtsmLFCpk1a5YvjhEAvEobI3tzOwAOCztdu3aV6tWrm9nJFy5caJbp46+++soVfgAgkGmvK29uByCwXdfcWBpq5s2b5/2jAYBsoN3LtddVfGJSuu12tJFyVOH/dkMHkEMHFTx48KCMGDFC/vrXv0pCQoJZtnz5ctm7d6+3jw8AvE7H0dHu5SrtiDr2Y13PeDtADg0769evl5o1a5p2Ov/5z3/k3LlzZvk333wjo0eP9sUxAoDXabdy7V6uJTju9DHdzoEcPs6ODiTYvn17GTRokBQsWNCEnFtuuUW2bt0qbdu2ld9++02CDePsADkXIygDwSuz1+8st9nZs2ePzJ8//4rlkZGR8scff2T9SAHAjzTYNKzIsBmAk2W5GqtIkSJy9OjRK5bv2rVLbrrpJm8dFwAAgH/CzuOPPy5Dhw6V+Ph4MzloamqqbNy4UQYPHixPPvmkd44KAADAX2Fn/PjxUq1aNYmOjjaNk2NiYuTuu++WRo0amR5aAAAAQd1A2RYXF2fa72jgqVOnjlSuXFmCFQ2UAQAIPj6bCHTcuHFy/vx5U7LTqlUr6dChgwk6Fy5cMOsAAACCumQnLCzMNFDW3lfuTpw4YZalpKRIsKFkBwCA4OOzkh3NRtowOS0db6dYMYZWBwAAgSXT4+wULVrUhBy9ValSxSPwaGmOtt159tlnfXWcAAAAvg07r7/+uinV6d69u4wdO9YUG9ny5Mkj5cuXN6MrAwAABGXY6dKli7mvUKGC6WaeO3duXx4XAACAV2R5uoh77rnH9XNSUpJcunTJYz0NfAEAQCDJcgNl7Xbep08f0/Mqf/78pi2P+w0AACCow86QIUNkzZo1MmPGDAkPD5d33nnHtOEpU6aM/POf//TNUQIAAGRXNdaSJUtMqLn33nulW7ductddd0mlSpWkXLlyMm/ePOnYseP1HgsAAID/S3ZOnjwpt9xyi6t9jj5WTZo0kQ0bNnj/CAEAALIz7GjQOXTokPlZJwT96KOPXCU+RYoUuZFjAQAA8H/Y0aorHS1ZDRs2TKZNmyYREREycOBA054HAADAEbOe23799VfZsWOHabdTq1YtCUbMjQUAgHOv31luoJyWNkzWGwAAQCC6rrCzbds2Wbt2rSQkJEhqaqrHusmTJ3vr2AAAALK/zc748eOlQYMGMnv2bNm+fbvs2rXLddu9e3eW9qVj9WjVlxY96U3n1lq+fLnHCM29e/eW4sWLS4ECBaRdu3Zy7Ngxj30cPnxYWrduLfny5TMDHWq7oeTk5Ky+LAAA4FBZLtl544035L333pOuXbve8JPffPPNMnHiRKlcubKZZHTu3LnyyCOPmOB06623mkbPn332mSxYsMDUyenIzW3btpWNGze6ZlvXoBMVFSWbNm2So0ePypNPPmnm7dJQBgAAkOUGyqVLlzbj6WhA8YVixYrJ3//+d3n00UelZMmSMn/+fPOz+uGHH6R69eqyefNmufPOO00p0IMPPihHjhyRUqVKmW1mzpwpQ4cOlePHj5vZ2DODBsoAAASfzF6/s1yNpaUt2t3c27SU5oMPPpA///zTVGdpD6/Lly9L06ZNXdvouD5ly5Y1YUfpfc2aNV1BR8XGxpoXv3fvXq8fIwAAyAHVWIMHDzZVRxUrVpSYmBhTZeRu4cKFWdrfnj17TLjR9jnaLmfRokVmv9r+R0tm0g5UqMEmPj7e/Kz37kHHXm+vy8jFixfNzabhCAAAOFOWw06/fv1MT6z77rvPNBwOCQm5oQOoWrWqCTZaBPXxxx9Lly5dZP369eJLEyZMMJOXAgAA58ty2NFGxP/5z39M6Y43aOmNDkio6tata7q1ayPoxx57TC5duiSnT5/2KN3R3ljaIFnp/datWz32Z/fWsrdJz/Dhw2XQoEEeJTvR0dFeeT0AACCwhF5PA2KtwvIVHbdHq5g0+GgV2erVq13r9u/fb7qaa7WX0nutBtPxfmyrVq0yjZS0Kiwj4eHhru7u9g0AADhTlkt2xowZI6NHjzbj7OjYNjdCS1hatmxpGh2fPXvW9Lxat26drFy50rSu7tGjhymB0YClgaRv374m4GhPLNW8eXMTajp37iyTJk0y7XRGjBhhxubRQAMAAJDlsDN16lQ5ePCgaQhcvnz5Kxoo79y5M9P70hIZHRdHx8fRcKMDDGrQadasmVk/ZcoUCQ0NNYMJammP9rSaPn266/fDwsJk6dKl0qtXLxOC8ufPb9r8jBs3LqsvCwAAOFSWx9m5VsNeLfUJNoyzAwCAOPb6fcOznjsBYQcAgODjs0EFAQAAHNdmRxsI//jjj1KiRAkpWrToVcfWOXnypDePDwAAwPdhRxsKFyxY0PXzjQ4kCAAAkF1os0ObHQAAgpLP2uxod2/3QfxsJ06cMOsAAAACSZbDTkYFQToOjk79AAAAEJSDCupggkrb67zzzjtmhnJbSkqKbNiwQapVq+abowQAAPB12NGGyXbJzsyZMz2qrLRER0dT1uUAAABBGXYOHTpk7u+77z5ZuHCh6YIOAADguDY7a9eu9Qg6WoW1e/duOXXqlLePDQAAIPvDzoABA+Tdd991BZ27775bbr/9domOjjYzlgMAAAR12FmwYIHcdttt5uclS5bIL7/8Ij/88IMMHDhQXnzxRV8cIwAAQPaFHR1PJyoqyvy8bNkyad++vVSpUkW6d+8ue/bsuf4jAQAACISwU6pUKdm3b5+pwlqxYoU0a9bMLD9//jyDCgIAgODtjWXr1q2bdOjQQUqXLm3G3GnatKlZvmXLFsbZAQAAwR92xowZIzVq1JC4uDhThRUeHm6Wa6nOsGHDfHGMAAAA142JQJkIFACAoOT1iUBbtWpldmabOHGinD592qPhckxMzI0cMwAAgNdlOuysXLnSTPZpGz9+vJw8edL1ODk5Wfbv3+/9IwQAAMiOsJO2tovaLwAA4Miu5wAAAI4MO9rNXG9plwEAADii67lWW3Xt2tXV1TwpKUmeffZZyZ8/v3ns3p4HAAAg6MJOly5dPB536tTpim2efPJJ7xwVAABAdoed2bNne+s5AQAAsg0NlAEAgKMRdgAAgKMRdgAAgKMRdgAAgKMRdgAAgKMRdgAAgKMRdgAAgKMRdgAAgKMRdgAAgKP5NexMmDBB7rjjDilYsKBERkZKmzZtZP/+/R7b6BxcvXv3luLFi0uBAgWkXbt2cuzYMY9tDh8+LK1bt5Z8+fKZ/QwZMkSSk5Oz+dUAAIBA5News379ehNkvv76a1m1apVcvnxZmjdvLn/++adrm4EDB8qSJUtkwYIFZvsjR45I27ZtXetTUlJM0Ll06ZJs2rRJ5s6dK3PmzJFRo0b56VUBAIBAEmLpdOYB4vjx46ZkRkPN3XffLYmJiVKyZEmZP3++PProo2abH374QapXry6bN2+WO++8U5YvXy4PPvigCUGlSpUy28ycOVOGDh1q9pcnT55rPu+ZM2ekcOHC5vkKFSrk89cJAABuXGav3wHVZkcPVhUrVszc79ixw5T2NG3a1LVNtWrVpGzZsibsKL2vWbOmK+io2NhYcwL27t2b7vNcvHjRrHe/AQAAZwqYsJOamioDBgyQxo0bS40aNcyy+Ph4UzJTpEgRj2012Og6exv3oGOvt9dl1FZIk6B9i46O9tGrAgAA/hYwYUfb7nz33XfywQcf+Py5hg8fbkqR7FtcXJzPnxMAkHUpqZZsPnhCPtn9u7nXx0BW5ZIA0KdPH1m6dKls2LBBbr75ZtfyqKgo0/D49OnTHqU72htL19nbbN261WN/dm8te5u0wsPDzQ0AELhWfHdUxi7ZJ0cTk1zLSheOkNEPxUiLGqX9emwILn4t2dG20Rp0Fi1aJGvWrJEKFSp4rK9bt67kzp1bVq9e7VqmXdO1q3nDhg3NY73fs2ePJCQkuLbRnl3aUCkmJiYbXw0AwJtBp9f7Oz2CjopPTDLLdT0QFCU7WnWlPa0++eQTM9aO3cZG29HkzZvX3Pfo0UMGDRpkGi1rgOnbt68JONoTS2lXdQ01nTt3lkmTJpl9jBgxwuyb0hsACD5aVaUlOulVWOmyEBGzvllMlISF6iMggEt2ZsyYYdrM3HvvvVK6dGnX7cMPP3RtM2XKFNO1XAcT1O7oWjW1cOFC1/qwsDBTBab3GoI6deokTz75pIwbN85PrwoAcCO2Hjp5RYlO2sCj63U7IOBLdjIzxE9ERIRMmzbN3DJSrlw5WbZsmZePDgDgDwlnk7y6HRAwvbEAAFCRBSO8uh1A2AEABJT6FYqZXlcZtcbR5bpetwMyg7ADAAgo2uhYu5ertIHHfqzraZyMzCLsAAACjo6jM6PT7RJV2LOqSh/rcsbZQdANKggAQFoaaLR7ufa60sbI2kZHq64o0UFWEXYAAAFLg03DisX9fRgIclRjAQAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAARyPsAAAAR/Nr2NmwYYM89NBDUqZMGQkJCZHFixd7rLcsS0aNGiWlS5eWvHnzStOmTeXAgQMe25w8eVI6duwohQoVkiJFikiPHj3k3Llz2fxKAABAoPJr2Pnzzz/ltttuk2nTpqW7ftKkSTJ16lSZOXOmbNmyRfLnzy+xsbGSlJTk2kaDzt69e2XVqlWydOlSE6CefvrpbHwVAICcICXVks0HT8gnu3839/oYwSHE0uKTAKAlO4sWLZI2bdqYx3pYWuLz/PPPy+DBg82yxMREKVWqlMyZM0cef/xx+f777yUmJka2bdsm9erVM9usWLFCWrVqJb/99pv5/cw4c+aMFC5c2OxfS4gAAHC34rujMnbJPjma+L8/tksXjpDRD8VIixql/XpsOdmZTF6/A7bNzqFDhyQ+Pt5UXdn0BTVo0EA2b95sHuu9Vl3ZQUfp9qGhoaYkKCMXL140J8j9BgBARkGn1/s7PYKOik9MMst1PQJbwIYdDTpKS3Lc6WN7nd5HRkZ6rM+VK5cUK1bMtU16JkyYYIKTfYuOjvbJawAABDetqtISnfSqQOxlup4qrcAWsGHHl4YPH26KvOxbXFycvw8JABCAth46eUWJjjuNOLpet0PgCtiwExUVZe6PHTvmsVwf2+v0PiEhwWN9cnKy6aFlb5Oe8PBwU7fnfgMAIK2Es0le3Q7+EbBhp0KFCiawrF692rVM29ZoW5yGDRuax3p/+vRp2bFjh2ubNWvWSGpqqmnbAwDAjYgsGOHV7eAfucSPdDycn376yaNR8u7du02bm7Jly8qAAQPk5ZdflsqVK5vwM3LkSNPDyu6xVb16dWnRooX07NnTdE+/fPmy9OnTx/TUymxPLAAAMlK/QjHT60obI6fXKidEaxkKR5jtELj8WrKzfft2qVOnjrmpQYMGmZ91IEH1wgsvSN++fc24OXfccYcJR9q1PCLifwl63rx5Uq1aNXnggQdMl/MmTZrI22+/7bfXBABwjrDQENO93A427uzHul63Q+AKmHF2/IlxdgAAV8M4O8F9/fZrNRYAAMFAA02zmCjT60obI2sbHa26okQnOBB2AADIBA02DSsW9/dhwEm9sQAAALyBsAMAAByNsAMAAByNsAMAAByNsAMAAByNsAMAAByNsAMAAByNsAMAAByNsAMAAByNsAMAAByN6SIAAAhyKakW83ZdBWEHAIAgxozs10Y1FgAAQRx0er2/0yPoqPjEJLNc14OwAwBA0FZdaYmOlc46e5muT0lNb4uchbADAEAQ0jY6aUt03GnE0fVbD52UnI6wAwBAENLGyN7czskIOwAABCHtdeXN7ZyMsAMAQBDS7uXa6yqjDua6XNfXr1BMcjrCDgAAQUjH0dHu5Spt4LEf6/owxtsh7AAAEKx0HJ0ZnW6XqMKeVVX6WJczzs5/MaggAABBTANNs5goRlC+CsIOAABBToNNw4rFffocKUE8JQVhBwAAOHpKCtrsAAAAR09JQdgBAACOnpKCsAMAAG54SgoNPJsPnpBPdv9u7gMpANFmBwAA3NBUE6v2xcugj3YHbJseSnYAAMANTTXx3sZfrigB0sfPBkibHsIOAAC4rikp1LV6nw9buMfvVVqEHQAAcN1TUlwrx5w+f1n+seYn8SfCDgAAuK4pKXo0Li+ZMW3tAdn40x9+K+EJsSwrcJpL+8mZM2ekcOHCkpiYKIUKFfL34QAAEHBS0hlBWR8/MevrTO/D242WM3v9pmQHAABkekqKR2rfZO71sQaewhGZ79h91E8DETom7EybNk3Kly8vERER0qBBA9m6dau/DwkAAEcLCw2RZjGlsvQ7lh8GInRE2Pnwww9l0KBBMnr0aNm5c6fcdtttEhsbKwkJCf4+NAAAHK1x5ZJZ/h17IMLs4oiwM3nyZOnZs6d069ZNYmJiZObMmZIvXz557733/H1oAAA4WlShzI3Fc70DFnpD0IedS5cuyY4dO6Rp06auZaGhoebx5s2b0/2dixcvmkZN7jcAAJB12m4nqlC4zwYs9IagDzt//PGHpKSkSKlSnnWG+jg+Pj7d35kwYYJpvW3foqOjs+loAQBwXrudMQ/fmqXfKZ4/jwlJ2SXow871GD58uOmmZt/i4uL8fUgAAAStFjVKy/S/1sn09i89UsOEpOwS9BOBlihRQsLCwuTYsWMey/VxVFRUur8THh5ubgAAwDta1Soj0yVEnpu/86rbPXN3BWlVK3snBw36kp08efJI3bp1ZfXq1a5lqamp5nHDhg39emwAAOQkrWqVlpmdbpci+XJfsa5AeJgp/Rne6r/TT2SnoC/ZUdrtvEuXLlKvXj2pX7++vP766/Lnn3+a3lkAACB7q7SaxUTJ1wdPyOaf/zCzaOkghHfe8t+BCP3BEWHnsccek+PHj8uoUaNMo+TatWvLihUrrmi0DAAAfE9DTePKJcwtEDA3FnNjAQAQlJgbCwAAgLADAACcjrADAAAcjbADAAAcjbADAAAcjbADAAAcjbADAAAcjbADAAAczREjKN8oe1xFHZwIAAAEB/u6fa3xkQk7InL27FlzHx0d7e9DAQAA13Ed15GUM8J0Ef83S/qRI0ekYMGCEhIS4tXEqQEqLi6OaSh8jHOdPTjP2YPznH0418F9njXCaNApU6aMhIZm3DKHkh1tuBQaKjfffLPP9q9vLP+JsgfnOntwnrMH5zn7cK6D9zxfrUTHRgNlAADgaIQdAADgaIQdHwoPD5fRo0ebe/gW5zp7cJ6zB+c5+3Cuc8Z5poEyAABwNEp2AACAoxF2AACAoxF2AACAoxF2AACAoxF2fGjatGlSvnx5iYiIkAYNGsjWrVv9fUgBa8KECXLHHXeYUawjIyOlTZs2sn//fo9tkpKSpHfv3lK8eHEpUKCAtGvXTo4dO+axzeHDh6V169aSL18+s58hQ4ZIcnKyxzbr1q2T22+/3fQKqFSpksyZM0dyqokTJ5pRwwcMGOBaxnn2nt9//106depkzmXevHmlZs2asn37dtd67R8yatQoKV26tFnftGlTOXDggMc+Tp48KR07djQDsRUpUkR69Ogh586d89jm22+/lbvuust81+gotZMmTZKcIiUlRUaOHCkVKlQw57BixYry0ksvecyVxHm+Phs2bJCHHnrIjE6s3xOLFy/2WJ+d53XBggVSrVo1s43+P1q2bFnWXoz2xoL3ffDBB1aePHms9957z9q7d6/Vs2dPq0iRItaxY8f8fWgBKTY21po9e7b13XffWbt377ZatWpllS1b1jp37pxrm2effdaKjo62Vq9ebW3fvt268847rUaNGrnWJycnWzVq1LCaNm1q7dq1y1q2bJlVokQJa/jw4a5tfv75ZytfvnzWoEGDrH379llvvvmmFRYWZq1YscLKabZu3WqVL1/eqlWrltW/f3/Xcs6zd5w8edIqV66c1bVrV2vLli3mnKxcudL66aefXNtMnDjRKly4sLV48WLrm2++sR5++GGrQoUK1oULF1zbtGjRwrrtttusr7/+2vryyy+tSpUqWU888YRrfWJiolWqVCmrY8eO5v/Pv//9bytv3rzWW2+9ZeUEf/vb36zixYtbS5cutQ4dOmQtWLDAKlCggPXGG2+4tuE8Xx/9v/3iiy9aCxcu1ORoLVq0yGN9dp3XjRs3mu+PSZMmme+TESNGWLlz57b27NmT6ddC2PGR+vXrW71793Y9TklJscqUKWNNmDDBr8cVLBISEsx/rvXr15vHp0+fNh9u/SKzff/992abzZs3u/5jhoaGWvHx8a5tZsyYYRUqVMi6ePGiefzCCy9Yt956q8dzPfbYYyZs5SRnz561KleubK1atcq65557XGGH8+w9Q4cOtZo0aZLh+tTUVCsqKsr6+9//7lqm5z88PNx84Sv9Ytdzv23bNtc2y5cvt0JCQqzff//dPJ4+fbpVtGhR17m3n7tq1apWTtC6dWure/fuHsvatm1rLp6K8+wdacNOdp7XDh06mPfZXYMGDaxnnnkm08dPNZYPXLp0SXbs2GGK9Nzn39LHmzdv9uuxBYvExERzX6xYMXOv5/Py5cse51SLNMuWLes6p3qvxZulSpVybRMbG2smoNu7d69rG/d92NvktPdFq6m0GirtueA8e8+nn34q9erVk/bt25uqvjp1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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set up shared variables\n",
    "num_threads_max = 20 # treat as hyperparam\n",
    "threads_vec = [] # stores thread identity (timestep)\n",
    "\n",
    "stream = stream_uniform\n",
    "m = m_uniform\n",
    "hist = {} # thread id : list of ams values\n",
    "\n",
    "plot_stream(stream_uniform)\n",
    "\n",
    "for time in range(0, m, num_threads_max):\n",
    "    # check if threads is full\n",
    "    if (len(threads_vec) == num_threads_max):\n",
    "        prune_threads()\n",
    "    # if there is space, spawn a new thread\n",
    "    if (len(threads_vec) < num_threads_max):\n",
    "        parallel_ams(time)\n",
    "        threads_vec.append(time)\n",
    "\n",
    "plot_result(hist)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Skewed Stream Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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zJkz5o9w06ZNZv7ChQvmj0B/7Bx++OEHU2bbtm3OP2BfX18rJibGWWb27NlWoUKFrLi4ODP/17/+1apSpYrbez377LMmILOTS5cuWffff7+1Zs0a65FHHnEGRJznjDFs2DDr4YcfTnV9YmKiFRwcbE2ZMsW5TM+9v7+/uSgo/fHX875r1y5nma+//try8fGxfvvtNzP/7rvvWkWLFnWed8d7V6xY0bKLVq1aWT179nRb1rZtW3ORVZzru5c0IMrKc9qhQwfzGbuqX7++1bdv33QdA01mHnDjxg3Zs2ePqT50vV+azm/bts2j+5aTxMbGmsdixYqZRz2nN2/edDuvWoVaunRp53nVR61ODQoKcpaJiIgwNxU8fPiws4zrNhxl7PbZaJOYNnklPRec54zxxRdfSN26daV9+/amSbFWrVry3nvvOddHRUVJTEyM2znSezJp87rredZmBt2Og5bX35MdO3Y4yzRu3Fj8/PzczrM2N58/f17soEGDBrJu3Tr58ccfzfyBAwfku+++kxYtWph5znXGy8pzmlG/JQREHvDnn3+aNm3Xi4XSef0C4fYSExNNTkvDhg2latWqZpmeO/2j0T+w1M6rPqZ03h3rblVGL+bXrl0TO/j0009l7969Jm8rKc5zxvj5559l9uzZcv/998vq1aulf//+MmjQIPnwww/dztOtfif0UYMpV7lz5zb/SUjPZ+HtXnvtNXnuuedM4J4nTx4TfOrvh+auKM51xsvKc5pamfSec+52jxxbe/H999+b/+UhY506dUpeeuklWbNmjUlQROYF9fo/4wkTJph5vUjrd3rOnDkSGRnp6d3zKp999pksXLhQPv74Y6lSpYrs37/fBESaDMy5hgM1RB5QokQJyZUrV7JeOTofHBzssf3KKQYOHCgrV66UDRs2yH333edcrudOmyMvXLiQ6nnVx5TOu2PdrcpoLwjtKeHttEnszJkzpveX/m9Np02bNsnMmTPNc/2fF+f57mnPm7CwMLdllStXNr3zXM/TrX4n9FE/K1fak0977qTns/B22sPRUUukTbldu3aVV155xVkDyrnOeFl5TlMrk95zTkDkAdrcUKdOHdOm7fq/RZ0PDw/36L5lZ5q3p8HQ0qVLZf369aYLrSs9p1od7npetZ1ZLzCO86qPhw4dcvsj1JoQvQg7Lk5axnUbjjJ2+WyaNm1qzpH+L9oxaU2GNi84nnOe75429yYdNkJzXMqUKWOe6/dbf9Bdz5E2J2puhet51sBUg1gH/dvQ3xPN1XCU0e7Rmvflep4rVqwoRYsWFTu4evWqyUtxpf8p1fOkONcZLyvPaYb9lqQrBRsZ2u1es+0XLFhgMu379Oljut279sqBu/79+5sunBs3brSio6Od09WrV926g2tX/PXr15vu4OHh4WZK2h28efPmpuu+dvG+5557UuwOPnToUNN7atasWbbqDp4S115mivOcMUMa5M6d23QJ/+mnn6yFCxea8/HRRx+5dVvW34Xly5dbBw8etJ566qkUuy3XqlXLdN3/7rvvTM9A127L2rNHuy137drVdFvW3x59H2/tCp6SyMhI695773V2u9du4joMhPZ0dOBc31lPVB1WQycNJ6ZOnWqe//LLL1l6TrXbvf4tvfnmm+a3ZPTo0XS7z2l03BW9qOh4RNoNX8dhQOr0Dy6lSccmctA/tBdeeMF009Q/mqefftoETa5OnDhhtWjRwoxloT+Kr776qnXz5k23Mhs2bLBq1qxpPpty5cq5vYcdJQ2IOM8ZY8WKFSZw1P8cVapUyZo7d67beu26PHLkSHNB0DJNmza1jh496lbm7Nmz5gKi4+rosAY9evQwFypXOgaMdvHXbWhgoBcqO7l48aL5/urvbUBAgPmu6fg5rl25Odfpp3+/Kf0mawCa1ef0s88+sx544AHzW6LDeXz55ZfpPh4f/efOKsQAAAC8AzlEAADA9giIAACA7REQAQAA2yMgAgAAtkdABAAAbI+ACAAA2B4BEQAAsD0CIgDZUvfu3aVNmzae3o1ssx8AMhcBEQA3f/zxh/Tv319Kly4t/v7+5n5EERERsmXLFmcZHx8fWbZsWYa834kTJ8z29D5prmbMmCELFiyQzKTve6tpzJgxWbIft0NQBmS+3FnwHgBykHbt2pm72X/44YdSrlw5c9dovXHi2bNnM/y99H1SU7hwYcls0dHRzueLFi2SUaNGud1wtUCBAmYCYAPpvtkHAK91/vx5cy8ivYFuasqUKeN23yKdV8eOHbOefPJJKzAw0MqfP79Vt25da82aNcleO27cOHOjxoIFC5p7HiW9D5LeN03pOr0ZpIMuf/HFF83NYPUeanp/JL2Joyu9sWPDhg3NPY8qV65s3l+3uXTp0tseu95HTW8enFRK+zFw4EBzbyy9caUer96D7PLly1b37t3NPZnKly9vffXVV27b0RtN6o0s9dzoa7p06WL98ccfzvWLFy829zXTe20VK1bM3PdJt6nHmPQc6T2k1MmTJ6327dub/dZzoudfb16adN/HjBlj7ien57xv375u9/AC8D80mQFIViOizWFxcXEpltm1a5d5nD9/vqlhccxfvnxZWrZsaWqT9u3bJ48//ri0bt1aTp486fb6N998U2rUqGHKjBw5Unbu3GmWr1271mxvyZIlqe6f1lrlz59fduzYIZMnT5Zx48bJmjVrzLqEhATTrJQvXz6zfu7cufL6669n2LlJuh8lSpQw+/7iiy+aJsb27dtLgwYNZO/evdK8eXPp2rWrXL161ZS/cOGC/OUvf5FatWrJ7t27ZdWqVabmrUOHDma9HnfHjh2lZ8+e8sMPP8jGjRulbdu2+h9WGTJkiCmn51PL6aTvc/PmTdOUWbBgQfn2229Nk6Z+dlrOteZNPw/HNj/55BNzfseOHZsp5wXI0f5/YAQAxn/+8x9T26A1FQ0aNLCGDx9u7jbtKq21LnrX6bffftuthqhNmzZuZbRGQ7e3b9++29bM6B2vXT344IPWsGHDzPOvv/7ayp07txUdHe1cn1k1RK77ER8fb2p9tNbLQfdB33fbtm1mfvz48Vbz5s3dtnvq1ClTRu/+vWfPHvP8xIkTKe5b0n1Q//73v62KFSuaO4o7aM1P3rx5rdWrVztfp7VNV65ccZaZPXu2qcVKSEi47TkB7IQaIgDJcoh+//13+eKLL0xtg9Ys1K5d+7aJxVpDpLUZlStXliJFipjaCq2ZSFpDVLdu3Tvet+rVq7vNlyxZUs6cOWOea+5PqVKlTBK4Q7169e74vdK6H7ly5ZLixYtLtWrVnMuCgoLMo2PfDhw4IBs2bHDWwOlUqVIls+748eOmxqxp06ZmG1rT9N5778n58+dvuQ+6zWPHjpkaIsc2ixUrJtevXzfbdNBta62ZQ3h4uPmsTp06lYFnBMj5SKoGkExAQIA89thjZtJmreeff15Gjx5tejulRoMhbb7SJrEKFSpI3rx55ZlnnkmWOK1NXncqT548bvPaEywxMfGOt5eR++G6TOeVY980ANHmwzfeeCPZtjSo06BKz93WrVvlm2++kbfffts092nTX2hoaIr7oNusU6eOLFy4MNm6e+65566PEbAbAiIAtxUWFubWzV4v/pqz40pzWDRgevrpp50XbO1Sfzt+fn7mMen20qtixYqm1kNzcxw1NI78Jk/TGrbPP/9cypYtK7lzp/yzq0FUw4YNzaS93cqUKSNLly6VwYMHm3OU9PzoNrVnXGBgoBQqVOiWNUnXrl0zAaravn27qU3S2jQA/4cmMwBO2rVek38/+ugjOXjwoERFRcnixYtNAvNTTz3lLKcXdk3WjYmJcTbt3H///SZhV8cT0otwp06d0lR7oxd0vVg7Eo1jY2PvaN+1Nqt8+fISGRlp9l0DtBEjRrjV2HjKgAED5Ny5cyZxWoM0bdJavXq19OjRwwQ6WhM0YcIEk3CtTYx6HnU8KG1+dJxvPSZtFvzzzz9NQnXnzp1NYrd+LppUrZ+VNm8OGjRIfv31V+d7aw1dr1695MiRI/LVV1+Zmr6BAweKry8//4Ar/iIAOGnNQf369WXatGnSuHFjqVq1qmky6927t7zzzjvOcm+99ZZp4tFaBu05paZOnSpFixY1PaC0eUh7QGktxu1ojcnMmTPln//8p4SEhLgFXumhzU5ai6U1Uw8++KBp5nP0MtMmQE/S49IATYMf7YGmuUIvv/yyybXSwERreDZv3mx66T3wwAMmkNNz3KJFC/N6Pf9aA6b5V9ocptvSvCB9jQ6gqT3SNHjSwEdziFxrjDQ3SYNV/TyfffZZefLJJ82AkwDc+WhmdZJlAOAVNHB4+OGHTfKx1h7ZjTZhapf/jBpVHPBm5BAB8Bqac6O1XFojokHQSy+9ZHJy7BgMAUgfAiIAXuPSpUsybNgwk4ej+TXNmjUzTU8AcDs0mQEAANsjqRoAANgeAREAALA9AiIAAGB7BEQAAMD2CIgAAIDtERABAADbIyACAAC2R0AEAABsj4AIAACI3f0/N7GlF6oYIUkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set up shared variables\n",
    "num_threads_max = 20 # treat as hyperparam\n",
    "threads_vec = [] # stores thread identity (timestep)\n",
    "\n",
    "stream = stream_skewed\n",
    "m = m_skewed\n",
    "hist = {} # thread id : list of ams values\n",
    "\n",
    "plot_stream(stream_skewed)\n",
    "\n",
    "# try skewed\n",
    "for time in range(0, m, num_threads_max):\n",
    "    # check if threads is full\n",
    "    if (len(threads_vec) == num_threads_max):\n",
    "        prune_threads()\n",
    "    # if there is space, spawn a new thread\n",
    "    if (len(threads_vec) < num_threads_max):\n",
    "        parallel_ams(time)\n",
    "        threads_vec.append(time)\n",
    "\n",
    "plot_result(hist)"
   ]
  }
 ],
 "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
}
