{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "import numpy as np\n",
    "import math\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def summary_test(file_path):\n",
    "    \n",
    "    history = [pickle.load(open(file_path + \"/node\" + str(j) + \".pk\", \"rb\")) for j in range(8)]\n",
    "    tmp = np.array(history[0][\"test_loss\"])\n",
    "    tmp2 = np.array(history[0][\"test_acc\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"test_loss\"])\n",
    "        tmp2 += np.array(history[j][\"test_acc\"])\n",
    "    \n",
    "    test_loss = tmp/8\n",
    "    test_acc = tmp2/8\n",
    "    \n",
    "    tmp = np.array(history[0][\"diff_param\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"diff_param\"])\n",
    "    diff_param = tmp/8\n",
    "\n",
    "    \n",
    "    return test_loss, test_acc, diff_param\n",
    "\n",
    "\n",
    "def summary_val(file_path):\n",
    "    \n",
    "    history = [pickle.load(open(file_path + \"/node\" + str(j) + \".pk\", \"rb\")) for j in range(8)]\n",
    "    tmp = np.array(history[0][\"val_loss\"])\n",
    "    tmp2 = np.array(history[0][\"val_acc\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"val_loss\"])\n",
    "        tmp2 += np.array(history[j][\"val_acc\"])\n",
    "    \n",
    "    test_loss = tmp/8\n",
    "    test_acc = tmp2/8\n",
    "    \n",
    "    tmp = np.array(history[0][\"diff_param\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"diff_param\"])\n",
    "    diff_param = tmp/8\n",
    "\n",
    "    \n",
    "    return test_loss, test_acc, diff_param\n",
    "\n",
    "\n",
    "def summary_train(file_path):\n",
    "    \n",
    "    history = [pickle.load(open(file_path + \"/node\" + str(j) + \".pk\", \"rb\")) for j in range(8)]\n",
    "    tmp = np.array(history[0][\"train_loss\"])\n",
    "    tmp2 = np.array(history[0][\"train_acc\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"train_loss\"])\n",
    "        tmp2 += np.array(history[j][\"train_acc\"])\n",
    "    \n",
    "    test_loss = tmp/8\n",
    "    test_acc = tmp2/8\n",
    "    \n",
    "    tmp = np.array(history[0][\"diff_param\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"diff_param\"])\n",
    "    diff_param = tmp/8\n",
    "\n",
    "    \n",
    "    return test_loss, test_acc, diff_param\n",
    "\n",
    "def summary_all_train(file_path):\n",
    "    \n",
    "    history = [pickle.load(open(file_path + \"/node\" + str(j) + \".pk\", \"rb\")) for j in range(8)]\n",
    "    tmp = np.array(history[0][\"all_train_loss\"])\n",
    "    tmp2 = np.array(history[0][\"all_train_acc\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"all_train_loss\"])\n",
    "        tmp2 += np.array(history[j][\"all_train_acc\"])\n",
    "    \n",
    "    test_loss = tmp/8\n",
    "    test_acc = tmp2/8\n",
    "    \n",
    "    tmp = np.array(history[0][\"diff_param\"])\n",
    "    for j in range(1, 8):\n",
    "        tmp += np.array(history[j][\"diff_param\"])\n",
    "    diff_param = tmp/8\n",
    "\n",
    "    \n",
    "    return test_loss, test_acc, diff_param\n",
    "\n",
    "def summary_baseline(file_path):\n",
    "    \n",
    "    history = pickle.load(open(file_path + \"/node.pk\", \"rb\"))\n",
    "    \n",
    "    test_loss = np.array(history[\"test_loss\"])\n",
    "    test_acc = np.array(history[\"test_acc\"])\n",
    "    \n",
    "    return test_loss, test_acc\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def search_best_lr(path, method, n_class, lr_list):\n",
    "    \n",
    "    best_acc = -1\n",
    "    best_lr = -1\n",
    "    \n",
    "    for lr in lr_list:\n",
    "        _, acc, _ = summary_val(path + \"/class_\" + str(n_class) + \"/\" + method + \"_lr_\" + str(lr))\n",
    "            \n",
    "        #print(lr, acc[-1])\n",
    "        if best_acc < acc[-1]:\n",
    "            best_acc = acc[-1]\n",
    "            best_lr = lr\n",
    "    return best_lr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def average_acc(acc_list):\n",
    "    avg = []\n",
    "    std = []\n",
    "    for i in range(len(acc_list[0])):\n",
    "        avg.append(np.average([acc_list[j][i] * 100 for j in range(len(acc_list))]))\n",
    "        std.append(np.std([acc_list[j][i] * 100 for j in range(len(acc_list))]))\n",
    "        \n",
    "    return avg, std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DSGDm: best lr 0.005\n",
      "\t 35.6\n",
      "QG-DSGDm: best lr 0.005\n",
      "\t 49.4\n",
      "DecentLaM: best lr 0.005\n",
      "\t 54.9\n",
      "Momentum Tracking: best lr 0.001\n",
      "\t 66.8\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, '4-class')"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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mTMnsW1kZCTjx4+nVatWANx///0sXbqUKVOm0KpVK8qXL0/58jqfUZMmTbJU7hugcOHCKSaqEhIS6NChA6VKlWLKlCkMGTIkzTl9+vShXbt2hIaGUrx4cf7++2/GjBmTpesacg8zkrVDfEw40QKBPnlbZAs6Yi0DrpRi8eLFVKpUiWbNmqUo9d2+fXvi4uISS8ksXbqURo0apRDY5ERHR7N69Woee+wx3NzcEvsREdq2bcuaNWtStPfz80sUWABvb2+qVatmtyrtrfL333/TpEkTgoKC8PDwoFChQly/fp2DBw/abW8T98mTJzN//nyio6N5/PHHc8weQ85iRrJ2iIy9Bj4Q4JO3K9U6awSZV7AVMCxTpgwXL17k5MmTeHraX4F3+fLlxNd69eql2+eVK1dISEjgww8/5MMPP7TbxmKx4Oamxx+py2yDFtqcKrM9f/58nnjiCZ555hk++OADihcvjpubGw899FC611BK0bt3b/78808qVapEly5dKFy4MFevXs0Rmww5ixFZO0RYIgGTgcvVLFy4EB8fHxo2bEixYsWoUqUKf//9t922tnLbxYsXJzQ0NN0+g4KCcHNzY+DAgfTp08duG5vA5gZTp07lzjvv5LfffkvcFxcXx5UrV9I/Ce0yGD16NPv27UssnW7ImxiRtUMkegRhksO4jlmzZjFv3jxeffVV/Pz86NixIzNnzsTf35+aNWume1779u356KOP2LVrl90RbaFChWjRogW7du2iQYMGOSKotuqz0dHRDlfLtXHjxo00ftw///wz05LiNWvWZODAgVy6dIkOHTpkzWBDrmJENjUiRCg9C21GsrnDzp07CQsLIzY2llOnTrFgwQKmT59Ou3btGD16NAC9e/fm119/pU2bNgwdOpR69eoRGxvL0aNHmTdvHnPmzMHPz48hQ4YwefJk2rZty7vvvkvdunUJCwtj7ty5TJgwgYCAAD7//HPuv/9+OnTowP/+9z/KlClDWFgY27dvJyEhgU8++SRL9teuXRuAzz77jAcffBB3d3eCg4MTj//333/MmDEjzXlt2rShY8eOzJkzhyFDhtC5c2e2bdvG119/TVBQUKbX/fbbb7Nkp8E1GJFNTVQUkZ7WNIcml2yu8NhjjwHg4+NDyZIladCgAVOnTqVHjx6JMaeenp4sWbKETz75hIkTJ3L8+HEKFSpE1apV6dSpU2KUQFBQEOvXr+fdd9/lk08+4fLly5QqVYrWrVsntmnQoAFbt25l5MiRDBo0iGvXrlGiRAkaNGhAv379smx/586dGTBgAOPHj2fUqFHJqyoDMHPmTGbOnJnmvK1bt/Liiy9y+vRpfvnlF3744QcaNWrE/Pnz6datW5btMORNVPI/hoJIcHCwhISEOH7CiRNM/7MKj1tgT/891ClZx3nGZYEDBw5Qq1YtV5thMNw2ZPY/p5TaJiLB6TawYkK4UnPpEpHWCWzjkzUYDNnFiGxqwsKIsDpRjE/WYDBkFyOyqQkLI9Jd/2h8sgaDIbsYkU1N2EUi3MDXzQMPNzMvaDAYsocR2dRcOUekBQI9fVxticFgKAAYkU1NuM4lG+BpqiIYDIbsY0Q2Nc0aECkQ6FXI1ZYYDIYCgBHZ1LS/X49kTekZg8GQAxiRTU18pPbJmsgCg8GQAxiRTU3cdT2SNTGyBoMhBzAimxrbSNYnbR5RQ86RvBz4oUOH0hxPXgL733//dYGFOceJEycYMWIEx44dc7UpQNpS7OltI0aMcLotjpRMf/bZZxNTWeZHTCBoauIirSPZIFdbcltgK3GdOoH2H3/8QUBAAJGRkS6yLOc4ceIEI0eO5L777ssTdbg6deqUog7Z9u3bGThwIF9//TWNGjVK3G8rq+Nq3nvvPV599VVXm3HLGJFNRVxsODcFAn2Lu9qU24JHH32Uv/76i1GjRiVm3IqOjmbmzJl07949RTJrQ85QokQJSpQokfjeVoGhVq1aNG3aNN3zYmJiEnPn5iZVq1bN9WvmJMZdkIrIaF3GJMDX1PfKDZ5++mlOnjzJunXrEvfNnj2bhIQEunfvbvecv/76i3r16uHj40Px4sV5+umnOXfuXIo2lStX5qmnnuLPP/+kRo0a+Pr60qJFCw4fPkxUVBR9+/alWLFilCpViqFDhxIfH5/i/LCwMPr370+5cuXw9vamZs2aTJw4MUUb22P3pk2b6N27N4GBgZQtW5ZBgwYlCteqVasSa4S1a9cu8VF81apVAHYfy0+cOIFSKsUXjK08eUhICM2aNcPX15caNWqwcOFCAD7//HMqV65MYGAgXbt25dKlS479AtLBdm9r1qzhscceIygoiCZNmgA6RWOPHj0oX758oh3Dhw8nOjo6TT+zZ8+mefPm+Pv7ExgYSOPGjTOs5HDjxg0efvhhypQpw65duxLvPbm7wPb5/PDDD7z//vuUKVOGoKAgHn74Yc6cOZOmv/79+1OsWDECAgLo1q0bGzZsSPP5OhMzkk1FZLQu+xHonbfrexUUKlWqxP3338+ff/5JixYtAO0q6NatG/7+acPoJk6cSN++fXniiScYPXo0Z8+eZfjw4WzevJnt27enOGfNmjUcPXqUMWPGEBsby+DBg+nevTt33HEHd955J1OnTmXNmjV89NFHVK1alQEDBgC6DHjz5s2Jjo5mxIgRVKlShSVLltC/f39iYmJ45ZVXUtj09NNP07NnT2bNmsXGjRsZMWIERYoUYeTIkTRo0IDvvvsuzeO4LdF3VoiIiKBPnz68/vrrlC1blo8//pju3bszcOBADh06xHfffceFCxcYPHgwAwcOTLdUT1bo3bs3PXv2ZMaMGYlfRKdOnaJ+/fo8++yzBAQEsG/fPkaNGsWxY8eYOnVq4rnffPMNgwYN4pFHHuH333/H39+f7du3c+LECbvXunLlCp07dyYsLIwNGzZQpUqVDG0bPXo0zZo145dffuHixYsMHTqU3r17s3r16sQ2L730EtOnT2fEiBEEBwezfPlyevfune3PJSsYkU1FRIwuRpcfksMMXjyYned3utSG+qXr82XHL7PVR58+fRg6dChff/01V69e5d9//+Wff/5J0y4hIYH33nuPBx54IMU/c82aNWnRogW//PILgwYNStx//fp1Fi9eTOHC+gvz/PnzvPrqqzRu3Jhx48YBenS5cOFCpk+fniiyX331FSdPnmTPnj1Uq1YNgLZt2xIeHs7IkSPp379/ipIxvXr1YuTIkYntNm/ezJQpUxg5ciSBgYGJgprZ43hmREZGMmHChMSS6GXLlqVevXosWLCA/fv34+6uMxvt3buXb775hoSEhMR9t0qPHj0YO3Zsin3JnzBEhObNmxMYGEifPn347rvvKFasGBEREQwfPpxu3boxa9asxPbplco5deoUHTp0wN/fn/Xr16dwZ6RHpUqVmDx5cuL7S5cu8cYbb3D27FnKli3LwYMHmTx5Mp988gnDhg0D9O/7xo0bfPPNN1n6HLKDcRekItJP+39MmsPc47HHHiMmJob58+czadIkSpcuTZs2bdK0O3jwIBcvXkwzErnvvvuoVKlSihEMwL333psosEBibbDU/+g1a9ZMrIwLsHjxYpo0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\n",
      "text/plain": [
       "<Figure size 360x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_class = 4\n",
    "colors = [\"red\", \"orange\", \"blue\", \"green\", \"black\", \"navy\"]\n",
    "methods = [\"dsgdm\", \"qg_dsgdm\", \"decentlam\", \"momentum_tracking\"]\n",
    "labels = [\"DSGDm\", \"QG-DSGDm\", \"DecentLaM\", \"Momentum Tracking\"]\n",
    "results = []\n",
    "\n",
    "plt.figure(figsize=(5,6))\n",
    "\n",
    "for method, label, color in zip(methods, labels, colors):\n",
    "        \n",
    "    acc_list = []\n",
    "\n",
    "    for seed in [0, ]:\n",
    "        lr = search_best_lr(\"../results/cifar_lenet/\" + str(seed), method, n_class, [0.005,0.001,0.0005])\n",
    "        _, acc, __ = summary_test(\"../results/cifar_lenet/\" + str(seed) + \"/class_\" + str(n_class) + \"/\" + method + \"_lr_\" + str(lr))\n",
    "        acc_list.append(acc)\n",
    "        \n",
    "    avg, _ = average_acc(acc_list)\n",
    "    print(f\"{label}: best lr {lr}\\n\\t {avg[-1]:.1f}\")\n",
    "\n",
    "    plt.plot([i*10 for i in range(len(acc))], avg, label=label, color=color, alpha=1.0)\n",
    "plt.legend(fontsize=16)\n",
    "plt.ylabel(\"Accuracy\", fontsize=18)\n",
    "plt.xlabel(\"Epoch\", fontsize=18)\n",
    "plt.yticks(fontsize=16)\n",
    "plt.xticks(fontsize=16)\n",
    "plt.title(f\"{n_class}-class\", fontsize=18)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
