{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "%aimport log_plotter\n",
    "from log_plotter import get_accuracies, get_levels, plot_levels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "logdir = '/h/iman/Code/nuqsgd/runs'\n",
    "lg_tags = ['estim_sgd', 'nuq_method', 'nuq_sym', 'nuq_inv','nuq_mul']  # , 'ngpu', 'bits', 'mul', 'bucket_size'\n",
    "orders = ['SuperSGD', 'ALQ-N', 'AMQ-N', 'Qinf', 'TRN', 'NUQ,p=0.5', 'SGD', 'ALQ', 'AMQ']\n",
    "lg_replace = [('p2_', 'P='), ('estim_sgd', 'SGD'), ('nuq_mul_', 'p='), ('nuq_bucket_size_', 'BS='), ('ngpu_', 'GPU='), ('nuq_method', ''), ('_q', 'Q'), ('nuq_inv_', 'Inv'), ('nuq_sym_', 'Sym'), ('_amq_nb', 'AMQ'), ('_amq', 'AMQ-N'), ('_alq_nb', 'ALQ'), ('_trn', 'TRN'), ('_alq', 'ALQ-N'), ('_qinf', 'Qinf'), ('kfac', 'K-FAC'), ('SGD,K-FAC', 'K-FAC'), ('estim_ntk', 'NTK'), ('adamw', 'AdamW'), ('adam', 'Adam'), ('lr_', 'LR='), ('LR=0.001', 'LR=1e-3'), ('LR=0.0001', 'LR=1e-4'), ('LR=0.0005', 'LR=5e-4'), ('LR=0.0002', 'LR=2e-4'), ('batch_size_', 'bs='), ('optim_start_', 'Start='), ('damping_', '$\\epsilon=$'), ('_l2q', 'L2Q'), ('_none', 'SuperSGD'), ('nuq_layer_1', 'w/o layers'), ('nuq_layer_0', 'w/ layers'),('_nuq', 'NUQ')]\n",
    "tag_names = ['est_var', 'nb_error', 'Vloss', 'Tloss', 'Vacc']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def format_levels(unf_levels):\n",
    "    reformed_levels = {}\n",
    "    for key, vals in unf_levels.items():\n",
    "        for method in vals[0]:\n",
    "            # sample data ((0.0, 76.3499984741211), 'NUQ')\n",
    "            method_name = method[1]\n",
    "            value = method[0]\n",
    "\n",
    "            if method_name not in list(reformed_levels):\n",
    "                reformed_levels[method_name] = [value]\n",
    "            else:\n",
    "                reformed_levels[method_name].append(value)\n",
    "    return reformed_levels"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ResNet-32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "patterns = ['.*runs_cifar10_full/.*(f23|r2)_(000.*estim_sgd|037.*nuq_method_none.*|.*resnet32.*nuq_bits_3.*nuq_bucket_size_16.*,(?!(.*nuq_sym.*|.*nuq_inv)))'] # resnet110 for paper\n",
    "levels = get_levels(patterns, lg_replace, lg_tags, logdir, 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OrderedDict([('ALQ', [-1.0, -0.13037915527820587, -0.018461534380912782, -0.00508661475032568, 0.0046255383640527725, 0.017798911780118942, 0.12570485472679138, 1.0]), ('ALQ-N', [-1.0, -0.12515452206134797, -0.017935097590088843, -0.00487457774579525, 0.0047873626463115215, 0.01783512905240059, 0.12379290908575058, 1.0]), ('AMQ', [-1.0, -0.23219155371189118, -0.05391341000795365, -0.01265745423734188, 0.01265745423734188, 0.05431222543120384, 0.23304982483386993, 1.0]), ('AMQ-N', [-1.0, -0.23163762986660003, -0.05365607142448425, -0.012483714148402214, 0.012483714148402214, 0.05381407588720322, 0.2319786101579666, 1.0]), ('NUQ,p=0.5', [-1.0, -0.5, -0.25, -0.125, 0.125, 0.25, 0.5, 1.0]), ('Qinf', [-1.0, -0.7142857313156128, -0.4285714328289032, -0.1428571492433548, 0.1428571492433548, 0.4285714328289032, 0.7142857313156128, 1.0]), ('TRN', [-1.0, 0.0, 1.0])])\n",
      "['ALQ', 'AMQ', 'ALQ-N', 'AMQ-N', 'Qinf', 'TRN', 'NUQ,p=0.5']\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": [
    "plot_levels(format_levels(levels), 'resnet-32')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ResNet-110"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "======= Vacc ========\n",
      "90.97\\% & $\\pm$ & 0.01\n",
      "90.95\\% & $\\pm$ & 0.06\n",
      "91.02\\% & $\\pm$ & 0.03\n",
      "89.53\\% & $\\pm$ & 0.05\n",
      "84.55\\% & $\\pm$ & 0.05\n",
      "86.65\\% & $\\pm$ & 0.08\n",
      "91.16\\% & $\\pm$ & 0.04\n",
      "91.05\\% & $\\pm$ & 0.05\n",
      "88.75\\% & $\\pm$ & 0.04\n",
      "======= Tacc ========\n",
      "100.00\\% & $\\pm$ & 0.01\n",
      "99.99\\% & $\\pm$ & 0.00\n",
      "99.99\\% & $\\pm$ & 0.00\n",
      "99.99\\% & $\\pm$ & 0.00\n",
      "89.22\\% & $\\pm$ & 0.08\n",
      "99.87\\% & $\\pm$ & 0.01\n",
      "99.97\\% & $\\pm$ & 0.01\n",
      "100.00\\% & $\\pm$ & 0.00\n",
      "99.95\\% & $\\pm$ & 0.01\n"
     ]
    }
   ],
   "source": [
    "patterns = ['.*runs_cifar10_full/.*(f21|r2)_(000.*estim_sgd|037.*nuq_method_none.*|.*resnet110.*nuq_bits_3.*nuq_bucket_size_16.*,(?!(.*nuq_sym.*|.*nuq_inv)))'] # resnet110 for paper\n",
    "acc = get_accuracies(patterns, lg_replace, lg_tags, logdir, latex=True, notitle=True)"
   ]
  }
 ],
 "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
