{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tensorboard.backend.event_processing import event_accumulator"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../')\n",
    "%aimport log_plotter\n",
    "from log_plotter import get_run_names_events, get_data_pth_events, OOMFormater\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy import interpolate\n",
    "import matplotlib.ticker as mtick"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "patterns = ['.*init2.*']\n",
    "logdir = '/home/iman/nuqsgd/runs/'\n",
    "events = get_run_names_events(logdir, patterns)\n",
    "tag_name = 'tot_var_norm'\n",
    "data = get_data_pth_events(logdir, events, [tag_name])[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "def plot_smooth_o1(x, y, *args, **kwargs):\n",
    "    plot_smooth(x, y, 100, 1, *args, **kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#1f77b4 0.5\n",
      "#ff7f0e 0.625\n",
      "#2ca02c 0.75\n",
      "#d62728 0.875\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tot_len = len(data[:4])\n",
    "for index, record in enumerate(data[:4]):\n",
    "    record = record[tag_name]\n",
    "    x = record[0]\n",
    "    y = record[1]\n",
    "    x_smooth = np.linspace(x.min(), x.max(), 100)\n",
    "    tck = interpolate.splrep(x, y, s=0)\n",
    "    y_smooth = interpolate.splev(x_smooth, tck, der=0)\n",
    "    lw = 5-4*index/tot_len\n",
    "    ls=['-','-', '-', '-'][index%4]\n",
    "\n",
    "\n",
    "    p = plt.plot(x_smooth, y_smooth, alpha=(index) / (tot_len) * 0.5 + 0.5, linestyle=ls, linewidth=lw)\n",
    "    print(p[0].get_color(), (index) / (tot_len) * 0.5 + 0.5)\n",
    "\n",
    "bot, top = plt.ylim()\n",
    "plt.ylabel('Average Variance')\n",
    "plt.xlabel('Iterations')\n",
    "ax = plt.gca()\n",
    "# ax.set_yscale('log')\n",
    "ax.yaxis.set_major_formatter(mtick.ScalarFormatter())\n",
    "ax.ticklabel_format(style='sci', axis='x', scilimits=(0,0))\n",
    "ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "\n",
    "\n",
    "plt.vlines(40000, bot, top, linestyle='--')\n",
    "plt.vlines(60000, bot, top, linestyle='--')\n",
    "plt.savefig('figs/variance-change.pdf', bbox_inches='tight', dpi=100)\n"
   ]
  }
 ],
 "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.7.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
