{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd \n",
    "from plotnine import * \n",
    "\n",
    "import matplotlib as mpl\n",
    "mpl.rc('text', usetex=True) # for plotting latex\n",
    "mpl.rc('text.latex', preamble=r'\\usepackage{amssymb}')\n",
    "# mpl.verbose.level = 'debug-annoying'\n",
    "\n",
    "from mizani.formatters import scientific_format # for plotting axis "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['balanced_test_05302021_1134PM.csv', 'preact_test_05312021_0841AM.csv', 'balanced_test_06012021_1110PM.csv', 'balanced_test_05312021_0354PM.csv', 'balanced_train_05312021_0955AM.csv', 'preact_train_05312021_0841AM.csv', 'preact_train_06012021_1021AM.csv', '.ipynb_checkpoints', 'preact_test_05312021_1041AM.csv', 'preact_train_05312021_1041AM.csv', 'balanced_test_05312021_1235PM.csv', 'preact_test_06012021_1021AM.csv', 'balanced_test_05312021_0734PM.csv', 'balanced_test_05312021_0532PM.csv', 'balanced_train_05312021_1235PM.csv', 'preact_train_05302021_1040PM.csv', 'balanced_train_05312021_0532PM.csv', 'balanced_train_05312021_0734PM.csv', 'preact_test_05302021_1040PM.csv', 'balanced_test_05312021_0955AM.csv', 'balanced_train_06012021_1110PM.csv', 'balanced_train_05302021_1134PM.csv', 'balanced_train_05312021_0354PM.csv']\n"
     ]
    }
   ],
   "source": [
    "# print(os.listdir('./csv/'))\n",
    "\n",
    "# learning_rate = 1e-3\n",
    "# preact 05302021_1040PM\n",
    "# balanced 05302021_1134PM\n",
    "\n",
    "# learning_rate = 1e-2\n",
    "# preact 05312021_0841AM\n",
    "# balanced 05312021_0955AM\n",
    "\n",
    "# learning_rate = 5e-2\n",
    "# preact_str = '05312021_1041AM'\n",
    "# balanced_str = '05312021_1235PM' # channel wise\n",
    "# balanced_str = '05312021_0354PM' # pixel wise \n",
    "\n",
    "# ResNet 101 - learning_rate = 1e-2\n",
    "preact_str = '06012021_1021AM'\n",
    "balanced_str = '06012021_1110PM'\n",
    "\n",
    "df_preact_train = pd.read_csv('./csv/preact_train_' + preact_str + '.csv')\n",
    "df_preact_test = pd.read_csv('./csv/preact_test_' + preact_str + '.csv')\n",
    "df_balanced_train = pd.read_csv('./csv/balanced_train_' + balanced_str + '.csv')\n",
    "df_balanced_test = pd.read_csv('./csv/balanced_test_' + balanced_str + '.csv') "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/h/mufan/condaenvs/jax/plotnine/geoms/geom_path.py:75: PlotnineWarning: geom_path: Removed 2 rows containing missing values.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/h/mufan/condaenvs/jax/plotnine/ggplot.py:721: PlotnineWarning: Saving 6 x 4 in image.\n",
      "/h/mufan/condaenvs/jax/plotnine/ggplot.py:722: PlotnineWarning: Filename: Figures/cifar_resnet101.pdf\n",
      "/h/mufan/condaenvs/jax/plotnine/geoms/geom_path.py:75: PlotnineWarning: geom_path: Removed 2 rows containing missing values.\n"
     ]
    },
    {
     "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>index</th>\n",
       "      <th>epoch</th>\n",
       "      <th>batch</th>\n",
       "      <th>loss</th>\n",
       "      <th>accuracy</th>\n",
       "      <th>type</th>\n",
       "      <th>arch</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>199</th>\n",
       "      <td>78199</td>\n",
       "      <td>199</td>\n",
       "      <td>390</td>\n",
       "      <td>0.000964</td>\n",
       "      <td>0.99998</td>\n",
       "      <td>Training</td>\n",
       "      <td>Vanilla ResNet</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>399</th>\n",
       "      <td>19999</td>\n",
       "      <td>199</td>\n",
       "      <td>99</td>\n",
       "      <td>0.239069</td>\n",
       "      <td>0.94930</td>\n",
       "      <td>Test</td>\n",
       "      <td>Vanilla ResNet</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>599</th>\n",
       "      <td>78199</td>\n",
       "      <td>199</td>\n",
       "      <td>390</td>\n",
       "      <td>0.000502</td>\n",
       "      <td>0.99998</td>\n",
       "      <td>Training</td>\n",
       "      <td>Balanced ResNet</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>799</th>\n",
       "      <td>19999</td>\n",
       "      <td>199</td>\n",
       "      <td>99</td>\n",
       "      <td>0.272754</td>\n",
       "      <td>0.94700</td>\n",
       "      <td>Test</td>\n",
       "      <td>Balanced ResNet</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     index  epoch  batch      loss  accuracy      type             arch\n",
       "199  78199    199    390  0.000964   0.99998  Training   Vanilla ResNet\n",
       "399  19999    199     99  0.239069   0.94930      Test   Vanilla ResNet\n",
       "599  78199    199    390  0.000502   0.99998  Training  Balanced ResNet\n",
       "799  19999    199     99  0.272754   0.94700      Test  Balanced ResNet"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_preact_train['type'] = 'Training'\n",
    "df_preact_test['type'] = 'Test'\n",
    "df_preact_train['arch'] = 'Vanilla ResNet'\n",
    "df_preact_test['arch'] = 'Vanilla ResNet'\n",
    "\n",
    "df_balanced_train['type'] = 'Training'\n",
    "df_balanced_test['type'] = 'Test'\n",
    "df_balanced_train['arch'] = 'Balanced ResNet'\n",
    "df_balanced_test['arch'] = 'Balanced ResNet'\n",
    "\n",
    "def format_filter_df(df):\n",
    "    batch_max = np.max(df['batch'])\n",
    "    df2 = df[df['batch'] == batch_max]\n",
    "    df2 = df2.rename( columns = {'train loss': 'loss', 'test loss': 'loss', \n",
    "                                'train accuracy': 'accuracy', 'test accuracy': 'accuracy'} )\n",
    "    return df2\n",
    "\n",
    "df_preact_train2 = format_filter_df(df_preact_train)\n",
    "df_preact_test2 = format_filter_df(df_preact_test)\n",
    "df_balanced_train2 = format_filter_df(df_balanced_train)\n",
    "df_balanced_test2 = format_filter_df(df_balanced_test)\n",
    "df_merge = pd.concat([df_preact_train2, df_preact_test2, df_balanced_train2, df_balanced_test2]).reset_index() \n",
    "df_merge['accuracy'] = df_merge['accuracy'] / 100\n",
    "\n",
    "plt_merge = ggplot(df_merge, aes( x = 'epoch', y = 'accuracy', color = 'arch', linetype = 'type')) + \\\n",
    "    geom_line() + \\\n",
    "    scale_color_manual( values = ['#e41a1c', '#377eb8'], \n",
    "                        breaks = ['Vanilla ResNet', 'Balanced ResNet'] ) + \\\n",
    "    scale_linetype_manual( values = ['dashed', 'solid'], breaks = ['Training', 'Test'] ) + \\\n",
    "    scale_y_continuous( limits = [0.75, 1] ) + \\\n",
    "    labs( x = 'Epoch', y = '' ) + \\\n",
    "    theme(legend_title = element_blank(), figure_size = (6,4), subplots_adjust = {'wspace':0.1}, \n",
    "          legend_position = 'bottom', \n",
    "          legend_box = 'horizontal', \n",
    "          legend_box_spacing = 0.55, \n",
    "          text = element_text( size = 16 ) ) \n",
    "print(plt_merge)\n",
    "# plt_merge.save(filename = 'cifar_resnet18.pdf', path = 'Figures/' )\n",
    "# plt_merge.save(filename = 'cifar_resnet101.pdf', path = 'Figures/' )\n",
    "\n",
    "df_merge[df_merge['epoch']==199]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
