{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": false
   },
   "outputs": [],
   "source": [
    "import tensorflow as tf\n",
    "from tensorboard.backend.event_processing import event_accumulator as ea\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "from matplotlib import colors as colors\n",
    "# import seaborn as sns\n",
    "# sns.set(style=\"darkgrid\")\n",
    "# sns.set_context(\"paper\")\n",
    "# plt.rc('axes', labelsize=16) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "plt.rc('axes', labelsize=16) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "logdir='MNIST_twolayer_conv_relu_0.5_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('train_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('train_loss/dual')]\n",
    "primal_train_loss_05 = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss_05 = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "\n",
    "logdir='MNIST_twolayer_conv_relu_0.25_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "scalar_list = acc.Tags()['scalars']\n",
    "primal_train_loss_025 = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss_025 = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "logdir='MNIST_twolayer_conv_relu_0.75_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "scalar_list = acc.Tags()['scalars']\n",
    "primal_train_loss_075 = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss_075 = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,5))\n",
    "# plt.title('Training of 3x3 kernel for MNIST, noise std = 0.5')  \n",
    "plt.semilogy(epochs, primal_train_loss_025, label='Nonconvex SGD Primal, noise std=0.25', linewidth=3, linestyle='--')\n",
    "plt.semilogy(epochs_dual, dual_train_loss_025, label='Convex SGD Dual, noise std=0.25', linewidth=3)\n",
    "plt.semilogy(epochs, primal_train_loss_05, label='Nonconvex SGD Primal, noise std=0.5', linewidth=3, linestyle='--')\n",
    "plt.semilogy(epochs_dual, dual_train_loss_05, label='Convex SGD Dual, noise std=0.5', linewidth=3)\n",
    "plt.semilogy(epochs, primal_train_loss_075, label='Nonconvex SGD Primal, noise std=0.75', linewidth=3, linestyle='--')\n",
    "plt.semilogy(epochs_dual, dual_train_loss_075, label='Convex SGD Dual, noise std=0.75', linewidth=3)\n",
    "plt.legend()\n",
    "plt.ylim(1e-3, 1e-1)\n",
    "plt.ylabel('Training loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": false
   },
   "outputs": [],
   "source": [
    "logdir='MNIST_twolayer_conv_relu_0.5_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('test_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('test_loss/dual')]\n",
    "primal_train_loss_05 = [s.value for s in acc.Scalars('test_loss/primal')]\n",
    "dual_train_loss_05 = [s.value for s in acc.Scalars('test_loss/dual')]\n",
    "\n",
    "\n",
    "logdir='MNIST_twolayer_conv_relu_0.25_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "scalar_list = acc.Tags()['scalars']\n",
    "primal_train_loss_025 = [s.value for s in acc.Scalars('test_loss/primal')]\n",
    "dual_train_loss_025 = [s.value for s in acc.Scalars('test_loss/dual')]\n",
    "\n",
    "logdir='MNIST_twolayer_conv_relu_0.75_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "scalar_list = acc.Tags()['scalars']\n",
    "primal_train_loss_075 = [s.value for s in acc.Scalars('test_loss/primal')]\n",
    "dual_train_loss_075 = [s.value for s in acc.Scalars('test_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,5))\n",
    "# plt.title('Training of 3x3 kernel for MNIST, noise std = 0.5')  \n",
    "plt.semilogy(epochs, primal_train_loss_025, label='Nonconvex SGD Primal, noise std=0.25', linewidth=3, linestyle='--')\n",
    "plt.semilogy(epochs_dual, dual_train_loss_025, label='Convex SGD Dual, noise std=0.25', linewidth=3)\n",
    "plt.semilogy(epochs, primal_train_loss_05, label='Nonconvex SGD Primal, noise std=0.5', linewidth=3, linestyle='--')\n",
    "plt.semilogy(epochs_dual, dual_train_loss_05, label='Convex SGD Dual, noise std=0.5', linewidth=3)\n",
    "plt.semilogy(epochs, primal_train_loss_075, label='Nonconvex SGD Primal, noise std=0.75', linewidth=3, linestyle='--')\n",
    "plt.semilogy(epochs_dual, dual_train_loss_075, label='Convex SGD Dual, noise std=0.75', linewidth=3)\n",
    "plt.legend()\n",
    "plt.ylim(1e-3, 1e-1)\n",
    "plt.ylabel('Testing loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "scalar_list_temp = ['test_loss/primal','test_loss/dual']\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('train_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('train_loss/dual')]\n",
    "primal_train_loss = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.title('Testing of 3x3 kernel for MNIST, noise std = 0.5')  \n",
    "plt.semilogy(epochs, primal_train_loss, label='Nonconvex SGD Primal')\n",
    "plt.semilogy(epochs_dual, dual_train_loss, label='Convex SGD Dual')\n",
    "plt.legend()\n",
    "plt.ylim(1e-2, 1e-1)\n",
    "plt.ylabel('Testing loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "logdir='MNIST_twolayer_conv_relu_0.25_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "scalar_list = acc.Tags()['scalars']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "scalar_list_temp = ['train_loss/primal','train_loss/dual']\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('train_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('train_loss/dual')]\n",
    "primal_train_loss = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.title('Training of 3x3 kernel for MNIST, noise std = 0.25')  \n",
    "plt.semilogy(epochs, primal_train_loss, label='Nonconvex SGD Primal')\n",
    "plt.semilogy(epochs_dual, dual_train_loss, label='Convex SGD Dual')\n",
    "plt.legend()\n",
    "plt.ylim(1e-3, 1e-1)\n",
    "plt.ylabel('Training loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "scalar_list_temp = ['test_loss/primal','test_loss/dual']\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('train_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('train_loss/dual')]\n",
    "primal_train_loss = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.title('Testing of 3x3 kernel for MNIST, noise std = 0.25')  \n",
    "plt.semilogy(epochs, primal_train_loss, label='Nonconvex SGD Primal')\n",
    "plt.semilogy(epochs_dual, dual_train_loss, label='Convex SGD Dual')\n",
    "plt.legend()\n",
    "plt.ylim(1e-3, 1e-1)\n",
    "plt.ylabel('Testing loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "logdir='MNIST_twolayer_conv_relu_0.75_3'\n",
    "acc = ea.EventAccumulator(logdir)\n",
    "acc.Reload()\n",
    "scalar_list = acc.Tags()['scalars']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "scalar_list_temp = ['train_loss/primal','train_loss/dual']\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('train_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('train_loss/dual')]\n",
    "primal_train_loss = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.title('Training of 3x3 kernel for MNIST, noise std = 0.75')  \n",
    "plt.semilogy(epochs, primal_train_loss, label='Nonconvex SGD Primal')\n",
    "plt.semilogy(epochs_dual, dual_train_loss, label='Convex SGD Dual')\n",
    "plt.legend()\n",
    "plt.ylim(1e-2, 1e-1)\n",
    "plt.ylabel('Training loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "scalar_list_temp = ['test_loss/primal','test_loss/dual']\n",
    "\n",
    "epochs = [int(s.step) for s in acc.Scalars('train_loss/primal')]\n",
    "epochs_dual = [int(s.step) for s in acc.Scalars('train_loss/dual')]\n",
    "primal_train_loss = [s.value for s in acc.Scalars('train_loss/primal')]\n",
    "dual_train_loss = [s.value for s in acc.Scalars('train_loss/dual')]\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.title('Testing of 3x3 kernel for MNIST, noise std = 0.75')  \n",
    "plt.semilogy(epochs, primal_train_loss, label='Nonconvex SGD Primal')\n",
    "plt.semilogy(epochs_dual, dual_train_loss, label='Convex SGD Dual')\n",
    "plt.legend()\n",
    "plt.ylim(1e-2, 1e-1)\n",
    "plt.ylabel('Testing loss')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "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.6.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
