{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "sys.path.append(os.path.realpath('../..'))\n",
    "# sys.path.append(os.path.realpath('.'))\n",
    "import toy.ops as ops\n",
    "import toy.data as data\n",
    "import toy.net as net\n",
    "import toy.train as train\n",
    "import toy.ground_truth as gt\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import pandas as pd\n",
    "import re\n",
    "import toy.ground_truth as gt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "rhos = [1.0, 0.9999, 0.9995, 0.999, 0.995, 0.99, 0.95, 0.90]\n",
    "fold = 5\n",
    "\n",
    "current_dir = '../../experiment/KD_training/Imperfect_Teacher_Distillation'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "datanum = 16384\n",
    "fig = plt.figure(figsize=(8,6))\n",
    "plt.subplots_adjust(left=0.14, right=0.99, bottom=0.10, top=0.92)\n",
    "\n",
    "for rho in rhos:\n",
    "    data = []\n",
    "    for i in range(fold):\n",
    "        dir = current_dir + '/rho-{:.04f}/datanum-{:06d}/fold-{:02d}/log'.format(rho, datanum, i)\n",
    "#         print(dir, os.path.exists(dir))\n",
    "\n",
    "        test_err = np.mean(pd.read_csv(dir + '/test.csv').values[-5:,1])\n",
    "#         test_err = np.min(pd.read_csv(dir + '/test.csv').values[:,1])\n",
    "#         print(test_err)\n",
    "        data.append(test_err)\n",
    "    data = np.array(data)\n",
    "#     plt.scatter((1-rho)*np.ones_like(data), data)\n",
    "    plt.bar('{:.04f}'.format(rho), np.mean(data),yerr=np.std(data),width=0.4)\n",
    "    \n",
    "plt.ylim(0.012,0.020)\n",
    "\n",
    "\n",
    "\n",
    "plt.ylabel('test error', fontdict={'size':20})\n",
    "plt.xlabel(r'$\\rho$', fontdict={'size':20})\n",
    "\n",
    "plt.tick_params(labelsize=13)\n",
    "\n",
    "\n",
    "plt.savefig('../../figure/05b.pdf', format='pdf') \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "datanum = 4096\n",
    "fig = plt.figure(figsize=(8,6))\n",
    "plt.subplots_adjust(left=0.14, right=0.99, bottom=0.10, top=0.92)\n",
    "\n",
    "for rho in rhos:\n",
    "    data = []\n",
    "    for i in range(fold):\n",
    "        dir = current_dir + '/rho-{:.04f}/datanum-{:06d}/fold-{:02d}/log'.format(rho, datanum, i)\n",
    "#         print(dir, os.path.exists(dir))\n",
    "\n",
    "        test_err = np.mean(pd.read_csv(dir + '/test.csv').values[-5:,1])\n",
    "#         test_err = np.min(pd.read_csv(dir + '/test.csv').values[:,1])\n",
    "#         print(test_err)\n",
    "        data.append(test_err)\n",
    "    data = np.array(data)\n",
    "#     plt.scatter((1-rho)*np.ones_like(data), data)\n",
    "    plt.bar('{:.04f}'.format(rho), np.mean(data),yerr=np.std(data),width=0.4)\n",
    "    \n",
    "plt.ylim(0.021,0.037)\n",
    "\n",
    "\n",
    "\n",
    "plt.ylabel('test error', fontdict={'size':20})\n",
    "plt.xlabel(r'$\\rho$', fontdict={'size':20})\n",
    "\n",
    "plt.tick_params(labelsize=13)\n",
    "\n",
    "\n",
    "# plt.savefig('../../figure/r2.pdf', format='pdf') \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "datanum = 1024\n",
    "fig = plt.figure(figsize=(8,6))\n",
    "plt.subplots_adjust(left=0.14, right=0.99, bottom=0.10, top=0.92)\n",
    "\n",
    "for rho in rhos:\n",
    "    data = []\n",
    "    for i in range(fold):\n",
    "        dir = current_dir + '/rho-{:.04f}/datanum-{:06d}/fold-{:02d}/log'.format(rho, datanum, i)\n",
    "#         print(dir, os.path.exists(dir))\n",
    "\n",
    "        test_err = np.mean(pd.read_csv(dir + '/test.csv').values[-5:,1])\n",
    "#         test_err = np.min(pd.read_csv(dir + '/test.csv').values[:,1])\n",
    "#         print(test_err)\n",
    "        data.append(test_err)\n",
    "    data = np.array(data)\n",
    "#     plt.scatter((1-rho)*np.ones_like(data), data)\n",
    "    plt.bar('{:.04f}'.format(rho), np.mean(data),yerr=np.std(data),width=0.4)\n",
    "    \n",
    "plt.ylim(0.041,0.063)\n",
    "\n",
    "\n",
    "\n",
    "plt.ylabel('test error', fontdict={'size':20})\n",
    "plt.xlabel(r'$\\rho$', fontdict={'size':20})\n",
    "\n",
    "plt.tick_params(labelsize=13)\n",
    "\n",
    "\n",
    "# plt.savefig('../../figure/r3.pdf', format='pdf') \n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "datanums = [16384, 8192, 4096, 2048, 1024, 512, 256, 128, 64, 32]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(8,6))\n",
    "plt.subplots_adjust(left=0.14, right=0.99, bottom=0.10, top=0.92)\n",
    "\n",
    "for rho in rhos:\n",
    "    data = []\n",
    "    for datanum in datanums:\n",
    "        point_data = []\n",
    "        for i in range(fold):\n",
    "            dir = current_dir + '/rho-{:.04f}/datanum-{:06d}/fold-{:02d}/log'.format(rho, datanum, i)\n",
    "#             test_err = np.mean(pd.read_csv(dir + '/test.csv').values[-5:,1])\n",
    "            test_err = np.min(pd.read_csv(dir + '/test.csv').values[:,1])\n",
    "            point_data.append(test_err)\n",
    "        point_data = np.mean(point_data)\n",
    "        data.append(point_data)\n",
    "    data = np.array(data)\n",
    "    plt.plot(datanums, data, label='{:.0e}'.format(1 - rho), marker='.')\n",
    "    \n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.legend(\n",
    "    loc='best',\n",
    "    title=r'$1-\\rho$',\n",
    "    fontsize=10,\n",
    "    labelspacing=0.2,\n",
    "    title_fontsize = 10,\n",
    ")\n",
    "\n",
    "plt.ylabel('test error', fontdict={'size':20})\n",
    "plt.xlabel(r'$n$', fontdict={'size':20})\n",
    "plt.tick_params(labelsize=13)\n",
    "\n",
    "\n",
    "# plt.savefig('../../figure/r0.pdf', format='pdf')"
   ]
  },
  {
   "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
