{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "#import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "# import os,sys,inspect\n",
    "# currentdir = os.path.dirname(os.path.abspath(inspect.getfile(inspect.currentframe())))\n",
    "# sys.path.insert(0,currentdir)\n",
    "# path=sys.path[0]+'/pickles/'\n",
    "\n",
    "from dpdl_privacy import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# IMDb"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Color plot for IMDb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average run time per epoch for nonDP:  11.910656674702961\n",
      "Average run time per epoch for DP Vanilla:  19317.0\n",
      "Average run time per epoch for DPJL10:  242.7458101272583\n",
      "Average run time per epoch for DPJL20:  446.24460536638895\n",
      "Average run time per epoch for DPJL30:  675.0070696989695\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYEAAAEPCAYAAACk43iMAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdeXhU5fnw8e89k8kKhH0NmIR9D4ssyuqCVCgIKoiouFSlYrVWrdC6IPjra2tbW4tLqRU3BDcQF1wQoQiyCBJAVBYhQiBsEQhLlsnM/f4xk5BlJjkhM8kk83yu61zJnHPmnPtgnGee7X5EVTEMwzDCk626AzAMwzCqjykEDMMwwpgpBAzDMMKYKQQMwzDCmCkEDMMwwpgpBAzDMMJYRHUHEAiNGzfWxMTE6g7DMIwaYNOmTcdUtUllrtFT4vQULkvn7iX3U1UdWZn7BVOtKAQSExPZuHFjdYdhGEYNICI/VfYap3DxJ9sFls6d5N7ZuLL3C6ZaUQgYhmFUJQFsVhvT3cGMpPJMIWAYhlFBIhBh9dMzP6ihVJopBAzDMM6DTao7gsAwhYARcpxOJ+np6eTk5FR3KEYNFh0dTUJCAg6HI/AXlwo0B4U4UwgYISc9PZ26deuSmJiISC35umVUKVUlMzOT9PR0kpKSAn79CvUJWLmeiB3YCBxQ1dEiMhO4HTjqPeUPqro0cHc8xxQCRsjJyckxBYBRKSJCo0aNOHr0aPknn9cNAl4TuBf4HqhXZN/TqvrXgN7Fh1pSoTFqG1MAGJUVzL+hgpqAlc1CnAnAKODFoAVcBlMIGEYQrVy5kvj4eHr16kXHjh0ZMmQIH374YeHxmTNn0qpVK1JSUujWrRvvv/++32uNHTuWgQMH+j2elpZGt27dAhq/4Yd3dJCVzYJ/AL+n9GDSu0Vkq4i8JCINAv0IBUwhYBhBNnjwYDZv3syOHTt45plnuPvuu1m+fHnh8fvuu4/U1FTefvttbr31Vtzu0gPLT5w4wTfffMOJEyfYu3dvVYZv+FDBmkBjEdlYZLuj8Doio4EjqrqpxC2eB9oCKUAG8LdgPYspBIxaISMjg7Zt23Lo0KGAXC8tLY3OnTtz++2307VrV0aMGEF2djapqakMGDCAHj16MG7cOI4fPw7AsGHDeOihh+jXrx8dOnTgyy+/9HndlJQUHn30UebMmVPqWOfOnYmIiODYsWOljr377rv88pe/5LrrrmPhwoWF+zdt2kTPnj0ZOHAgzz77bLH4Bw8eTO/evenduzdfffUV4KmZDB06lAkTJtChQwemT5/O/Pnz6devH927d+fHH3+s1L9bOBERSxtwTFX7FtnmFrnMxcAYEUkDFgKXiMjrqnpYVV2q6gb+A/QL1nOYQsCoFWbPnk1aWhqzZ88O2DV37drFtGnT2L59O/Xr1+fdd9/lpptu4s9//jNbt26le/fuPP7444Xn5+fns2HDBv7xj38U219S7969+eGHH0rtX79+PTabjSZNSqe1WbBgAZMmTWLSpEksWLCgcP8tt9zCM888w9q1a4ud37RpU5YtW8Y333zDm2++yT333FN4bMuWLfzzn/9k27ZtvPbaa+zcuZMNGzbwq1/9in/9618V+jcKWxKYPgFVnaGqCaqaCFwHfKGqN4hIiyKnjQO+DdajmELAqPEyMjKYN28ebrebefPmBaw2kJSUREpKCgB9+vThxx9/5MSJEwwdOhSAKVOmsGrVqsLzx48fX3huWlqa3+uWXNf76aefJiUlhQceeIA333yzVIfm4cOH2b17N4MGDaJDhw5ERETw7bffcvLkyWLx3HjjjYXvcTqd3H777XTv3p1rr72W7777rvDYhRdeSIsWLYiKiqJt27aMGDECgO7du5cZt3FOIDuG/fiLiGwTka3AcOC+QMVekhkiatR4s2fPLmxHd7lczJ49u1jTyPmKiooq/N1ut3PixAlL59vtdvLz/ecK2Lx5M507dy58fd999/HAAw8Uvl6/fj133nknALNmzSItLY3jx48XjnfPyspi4cKFPPDAA35HwDz99NM0a9aMLVu24Ha7iY6O9vlcNput8LXNZiszbuOcCqWNsEhVVwIrvb/fWObJAWRqAkaNVlALyMvLAyAvLy+gtYGi4uPjadCgQWF7/2uvvVb4LdyqrVu3Mnv2bKZNm+b3nP79+5OamkpqaipjxoxhwYIFfPLJJ6SlpZGWlsamTZtYuHAh9evXJz4+ntWrVwMwf/78wmucPHmSFi1aYLPZeO2113C5rKU9NqwLck2gypiagFGjFa0FFAhkbaCkV155halTp3L27FmSk5OZN29eue/58ssv6dWrF2fPnqVp06Y888wzXHrppZbul5aWxr59+xgwYEDhvqSkJOrV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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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": [
    "######### nonDP ########## \n",
    "dd = pickle.load(open('imdb/pickles/nonDP_LSTM.pickle','rb'))\n",
    "\n",
    "epochtime_list_nonDP=dd['time']\n",
    "accuracy_list_nonDP=dd['accuracy']\n",
    "\n",
    "print('Average run time per epoch for nonDP: ',np.mean(epochtime_list_nonDP))\n",
    "\n",
    "#print(dd['privacy_params'])\n",
    "\n",
    "######### DPVanilla ########## \n",
    "dd = pickle.load(open('imdb/pickles/DPVanilla_LSTM.pickle','rb'))\n",
    "\n",
    "epsilon_list_DPVanilla=dd['epsilon']\n",
    "epochtime_list_DPVanilla=dd['time']\n",
    "accuracy_list_DPVanilla=dd['accuracy']\n",
    "\n",
    "#print(dd['privacy_params'])\n",
    "\n",
    "print('Average run time per epoch for DP Vanilla: ',np.mean(epochtime_list_DPVanilla))\n",
    "\n",
    "\n",
    "######## DPJL ################\n",
    "JLdim_list=[10,20,30]\n",
    "marker_list=['o','*','v','P','p']\n",
    "\n",
    "epsilon_list_DPJL={}\n",
    "epochtime_list_DPJL={}\n",
    "accuracy_list_DPJL={}\n",
    "\n",
    "for JLdim in JLdim_list:\n",
    "    \n",
    "    dd = pickle.load(open(f'imdb/pickles/DPJL{JLdim}_LSTM.pickle','rb'))\n",
    "    \n",
    "    epochtime_list_DPJL[JLdim]=dd['time']\n",
    "    accuracy_list_DPJL[JLdim]=dd['accuracy']\n",
    "\n",
    "    #print(dd['privacy_params'])\n",
    "    print(f'Average run time per epoch for DPJL{JLdim}: ',np.mean(epochtime_list_DPJL[JLdim]))\n",
    "\n",
    "    \n",
    "    dd = pickle.load(open(f'imdb/pickles/DPJL{JLdim}_LSTM_epsilons.pickle','rb'))\n",
    "    \n",
    "    epsilon_list_DPJL[JLdim]=dd['epsilon']\n",
    "##############################\n",
    "\n",
    "\n",
    "plt.xscale('log')\n",
    "\n",
    "eps_concat = list(epsilon_list_DPVanilla)\n",
    "for JLdim in JLdim_list:\n",
    "    eps_concat+=list(epsilon_list_DPJL[JLdim])\n",
    "\n",
    "    \n",
    "min_eps, max_eps = min(eps_concat), max(eps_concat)\n",
    "\n",
    "plt.scatter(np.cumsum(epochtime_list_nonDP),accuracy_list_nonDP,marker='^',color='black',label='nonDP-Adam')\n",
    "\n",
    "plt.scatter(np.cumsum(epochtime_list_DPVanilla),accuracy_list_DPVanilla,\n",
    "            cmap='RdYlGn_r',c=epsilon_list_DPVanilla,marker='s',label='DP-Adam-Vanilla (TFP)')\n",
    "plt.clim(min_eps,max_eps)\n",
    "\n",
    "\n",
    "# plt.scatter(np.cumsum(epochtime_list_DPVanilla)*4000/19000,accuracy_list_DPVanilla,\n",
    "#             cmap='RdYlGn_r',c=epsilon_list_DPVanilla,marker='P',label='DP-Adam-Vanilla (GA)')\n",
    "# plt.clim(min_eps,max_eps)\n",
    "\n",
    "\n",
    "for i,JLdim in enumerate(JLdim_list):\n",
    "    plt.scatter(np.cumsum(epochtime_list_DPJL[JLdim]),accuracy_list_DPJL[JLdim],\n",
    "                cmap='RdYlGn_r',c=epsilon_list_DPJL[JLdim],marker=marker_list[i], label=f'DP-Adam-JL{JLdim}')\n",
    "    plt.clim(min_eps,max_eps)\n",
    "\n",
    "\n",
    "plt.colorbar(label=r'$\\epsilon$')\n",
    "\n",
    "plt.xlim(1,5e5)\n",
    "plt.ylim(0.48,0.95)\n",
    "\n",
    "plt.axhline(0.7,linestyle='dashed',color='gray')\n",
    "plt.ylabel('Test Accuracy',fontsize=16)\n",
    "plt.xlabel('Time (sec)',fontsize=16)\n",
    "plt.legend(loc='upper right',frameon=True)\n",
    "plt.savefig('Figures/LSTM_colorplot.pdf',format='pdf', bbox_inches = \"tight\",dpi=300)\n",
    "plt.show()\n",
    "\n",
    "epochs= len(epsilon_list_DPVanilla)\n",
    "\n",
    "plt.plot(np.arange(1,epochs+1),epsilon_list_DPVanilla,label=f'DP-Adam-Vanilla',color='k',linestyle='--')\n",
    "\n",
    "for i,JLdim in enumerate(JLdim_list):\n",
    "    plt.plot(np.arange(1,epochs+1),epsilon_list_DPJL[JLdim],label=f'DP-Adam-JL{JLdim}')\n",
    "    \n",
    "\n",
    "plt.ylabel('epsilon',fontsize=16)\n",
    "plt.xlabel('epochs',fontsize=16)\n",
    "plt.legend(loc='center right',frameon=True)\n",
    "plt.savefig('Figures/LSTM_epsilonplot.pdf',format='pdf', bbox_inches = \"tight\",dpi=300)\n",
    "plt.show()\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot for IMDb showing approximation of DPVanilla with DPJL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<dpdl_privacy.privacy_params object at 0x00000277660BE6D8>\n",
      "<dpdl_privacy.privacy_params object at 0x00000277660BE898>\n",
      "<dpdl_privacy.privacy_params object at 0x00000277660BEAC8>\n",
      "<dpdl_privacy.privacy_params object at 0x00000277660BE748>\n",
      "<dpdl_privacy.privacy_params object at 0x00000277660BE4A8>\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": [
    "######### nonDP ########## \n",
    "dd = pickle.load(open('imdb/pickles/nonDP_LSTM.pickle','rb'))\n",
    "\n",
    "epochtime_list_nonDP=dd['time']\n",
    "accuracy_list_nonDP=dd['accuracy']\n",
    "\n",
    "print(dd['privacy_params'])\n",
    "\n",
    "######### DPVanilla ########## \n",
    "dd = pickle.load(open('imdb/pickles/DPVanilla_LSTM.pickle','rb'))\n",
    "\n",
    "epochtime_list_DPVanilla=dd['time']\n",
    "accuracy_list_DPVanilla=dd['accuracy']\n",
    "\n",
    "print(dd['privacy_params'])\n",
    "\n",
    "epochs=dd['privacy_params'].epochs\n",
    "\n",
    "######## DPJL ################\n",
    "JLdim_list=[1,5,10]\n",
    "marker_list=['o','*','v','P','p']\n",
    "color_list=['r','b','g','magenta','cyan','pink']\n",
    "epochtime_list_DPJL={}\n",
    "accuracy_list_DPJL={}\n",
    "\n",
    "for JLdim in JLdim_list:\n",
    "    dd = pickle.load(open(f'imdb/pickles/DPJL{JLdim}_LSTM.pickle','rb'))\n",
    "    \n",
    "    epochtime_list_DPJL[JLdim]=dd['time']\n",
    "    accuracy_list_DPJL[JLdim]=dd['accuracy']\n",
    "\n",
    "    print(dd['privacy_params'])\n",
    "    \n",
    "##############################\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "#plt.scatter(np.arange(1,epochs+1),accuracy_list_nonDP,marker='^',label='nonDP',color='black')\n",
    "plt.plot(np.arange(1,epochs+1),accuracy_list_nonDP,linestyle='--',label='non-DP',color='black')\n",
    "\n",
    "#plt.scatter(np.arange(1,epochs+1),accuracy_list_DPVanilla,marker='s',label='DP Vanilla',color='black')\n",
    "plt.plot(np.arange(1,epochs+1),accuracy_list_DPVanilla,label='DP Adam Vanilla',color='black')\n",
    "\n",
    "\n",
    "for i,JLdim in enumerate(JLdim_list):\n",
    "    plt.scatter(np.arange(1,epochs+1),accuracy_list_DPJL[JLdim],\n",
    "                marker='o', label=f'JL{JLdim}',color=color_list[i],s=10)\n",
    "\n",
    "\n",
    "plt.ylim(0.48,1)\n",
    "\n",
    "plt.axhline(0.7,linestyle='dashed',color='gray')\n",
    "plt.ylabel('Test Accuracy',fontsize=16)\n",
    "plt.xlabel('epochs',fontsize=16)\n",
    "plt.legend(loc='upper right',frameon=True,ncol=2)\n",
    "plt.savefig('Figures/LSTM_approximation.pdf',format='pdf', bbox_inches = \"tight\",dpi=300)\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Average run time per epoch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average run time per epoch for nonDP:  11.910656674702961\n",
      "Average run time per epoch for DP Vanilla:  19317.0\n",
      "Average run time per epoch for DPJL1:  41.16319260597229\n",
      "Average run time per epoch for DPJL5:  128.26796897252402\n",
      "Average run time per epoch for DPJL10:  242.7458101272583\n",
      "Average run time per epoch for DPJL20:  446.24460536638895\n",
      "Average run time per epoch for DPJL30:  675.0070696989695\n"
     ]
    }
   ],
   "source": [
    "######### nonDP ########## \n",
    "dd = pickle.load(open('imdb/pickles/nonDP_LSTM.pickle','rb'))\n",
    "\n",
    "epochtime_list_nonDP=dd['time']\n",
    "accuracy_list_nonDP=dd['accuracy']\n",
    "\n",
    "print('Average run time per epoch for nonDP: ',np.mean(epochtime_list_nonDP))\n",
    "\n",
    "#print(dd['privacy_params'])\n",
    "\n",
    "######### DPVanilla ########## \n",
    "dd = pickle.load(open('imdb/pickles/DPVanilla_LSTM.pickle','rb'))\n",
    "\n",
    "epsilon_list_DPVanilla=dd['epsilon']\n",
    "epochtime_list_DPVanilla=dd['time']\n",
    "accuracy_list_DPVanilla=dd['accuracy']\n",
    "\n",
    "#print(dd['privacy_params'])\n",
    "\n",
    "print('Average run time per epoch for DP Vanilla: ',np.mean(epochtime_list_DPVanilla))\n",
    "\n",
    "\n",
    "######## DPJL ################\n",
    "JLdim_list=[1,5,10,20,30]\n",
    "marker_list=['o','*','v','P','p']\n",
    "\n",
    "epsilon_list_DPJL={}\n",
    "epochtime_list_DPJL={}\n",
    "accuracy_list_DPJL={}\n",
    "\n",
    "for JLdim in JLdim_list:\n",
    "    \n",
    "    dd = pickle.load(open(f'imdb/pickles/DPJL{JLdim}_LSTM.pickle','rb'))\n",
    "    \n",
    "    epochtime_list_DPJL[JLdim]=dd['time']\n",
    "    accuracy_list_DPJL[JLdim]=dd['accuracy']\n",
    "\n",
    "    #print(dd['privacy_params'])\n",
    "    print(f'Average run time per epoch for DPJL{JLdim}: ',np.mean(epochtime_list_DPJL[JLdim]))\n",
    "\n",
    "    \n",
    "\n",
    "##############################\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## epsilon vs JLdim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1d9a86fe710>]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "\n",
    "######### DPVanilla ########## \n",
    "dd = pickle.load(open('imdb/pickles/DPVanilla_LSTM.pickle','rb'))\n",
    "\n",
    "epsilon_list_DPVanilla=dd['epsilon']\n",
    "\n",
    "\n",
    "\n",
    "######## DPJL ################\n",
    "JLdim_list=[10,20,30]\n",
    "marker_list=['o','*','v','P','p']\n",
    "\n",
    "epsilon_list_DPJL={}\n",
    "\n",
    "\n",
    "for JLdim in JLdim_list:\n",
    "\n",
    "    \n",
    "    dd = pickle.load(open(f'imdb/pickles/DPJL{JLdim}_LSTM_epsilons.pickle','rb'))\n",
    "    \n",
    "    epsilon_list_DPJL[JLdim]=dd['epsilon']\n",
    "    \n",
    "\n",
    "epsilon_list_JLdim = [epsilon_list_DPJL[JLdim][-1] for JLdim in JLdim_list]\n",
    "\n",
    "plt.plot(JLdim_list,epsilon_list_JLdim)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MNIST"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Color coded plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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Kzk5OWRlZTkLUH/0+sxARPywhqhcCKRgDVXZkTHGnHB/IrISa+D7ImPMJMeySOBVIA04BFxrjCnvbVye6EhpHff/fTsf7S1harKNx66azIQEHVNAeYZzzz33uGXXXnstt912G3V1dVx88cXHrV+0aBGLFi2ipKSEa665ptO6devW9TmGjIwM7HY7RUVFnZaXlpayYcMGHnzwwU7Lp0yZQlxcHOnp6cyZM4errrqKSy+9lOrqampqanp9xw1AWFgY6enp7N27l1mzZjmXZ2dn4+XlxdatW5kyZQqrVq1i4UJrcMeVK1cSGRlJfX09M2fO5OqrryYqKora2lpmz57NsmXLuPfee3nuued44IEHehXHsmXLiIyMpLW1lTlz5rBt2zays7N7/T266suZwX8DDwJ7gSeBR7pMj/ZiH88DF3VZdh+w1hgzFljreD8stbTa+f0H+5n75AdsPlzOTy/L4i+3fk0LgVKnoONZwUcffcS0adOYO3cu9913H1lZWZ229fb25u233+b1119n3Lhx/PCHP+Thhx/GGNPputw777zD1KlTSUtL4z//+U+vfnZHbWcHLS0trFmzhm984xsA/OY3v3Ee/efm5rJ3717AOguZP38+ADNmzODQoUO9/v6vvfYa06dPZ9q0aXz55Zfs3Lmz15/tTl+uGVwDPGSMWXaqP8wY86GIpHVZfDlwruP1C8A64Men+jPc1ba8Cu77y3Z2FlRxwYQ4Hrk8i0RboKvDUqrPTnQkHxQUdML10dHRp3Qm0NWBAwfw9vYmNjaWXbt2Oa8ZtGltbXVeM7jssst45JFHEBFOO+00TjvtNC688EK+/e1v8/DDDxMcHMzBgwdJT09n3rx5zJs3j/nz59PU1NTtz66urubQoUOMGzeO+++/n7feeguALVu2sHDhQubOncs555xDdnY2sbGxrFu3jvfee49PPvmEoKAgzj33XOcDfL6+vs5i5O3tTUtLS6++/8GDB/nVr37FZ599RkREBIsWLer3Q4F9KQYhwCf9+mndizPGFAAYYwpEJLanDUVkMbAYICUlZRBCGXi1jS38z7++4vn/HCQ6xJ/l35rOvKx4vUtIqVNUXFzMkiVLuP3223v8f+Tt7e284AyQn5/PsWPHmD59OmAl7tTUVACWLl3KrbfeyqpVq7DZbBhjekysNTU13HbbbVxxxRVERESwbNky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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "batch_size_list=[250,1000]\n",
    "\n",
    "for B in batch_size_list:\n",
    "    ######### nonDP ########## \n",
    "    dd = pickle.load(open(f'mnist/pickles/nonDP_MNIST{B}.pickle','rb'))\n",
    "\n",
    "    epochtime_list_nonDP=dd['time']\n",
    "    accuracy_list_nonDP=dd['accuracy']\n",
    "\n",
    "\n",
    "    ######### DPVanilla ########## \n",
    "    dd = pickle.load(open(f'mnist/pickles/DPVanilla_MNIST_epsilons{B}.pickle','rb'))\n",
    "\n",
    "    epsilon_list_DPVanilla=dd['epsilon']\n",
    "    \n",
    "    ### TF implementation\n",
    "    if os.path.exists(f'mnist/pickles/DPVanilla_MNIST{B}.pickle'):\n",
    "        dd = pickle.load(open(f'mnist/pickles/DPVanilla_MNIST{B}.pickle','rb'))\n",
    "        epochtime_list_DPVanilla=dd['time']\n",
    "        accuracy_list_DPVanilla=dd['accuracy']\n",
    "    \n",
    "    ### GA implementation\n",
    "    dd = pickle.load(open(f'mnist/pickles/DPVanillaGA_MNIST{B}.pickle','rb'))\n",
    "\n",
    "    epochtime_list_DPVanillaGA=dd['time']\n",
    "    accuracy_list_DPVanillaGA=dd['accuracy']#[x.numpy() for x in dd['accuracy']]\n",
    "    \n",
    "    ######## DPJL ################\n",
    "    JLdim_list=[10,20,30]\n",
    "    marker_list=['o','*','v','P','p']\n",
    "\n",
    "    epsilon_list_DPJL={}\n",
    "    epochtime_list_DPJL={}\n",
    "    accuracy_list_DPJL={}\n",
    "\n",
    "    for JLdim in JLdim_list:\n",
    "\n",
    "        dd = pickle.load(open(f'mnist/pickles/DPJL{JLdim}_MNIST{B}.pickle','rb'))\n",
    "\n",
    "        epochtime_list_DPJL[JLdim]=dd['time']\n",
    "        accuracy_list_DPJL[JLdim]=dd['accuracy']\n",
    "\n",
    "\n",
    "        dd = pickle.load(open(f'mnist/pickles/DPJL{JLdim}_MNIST_epsilons{B}.pickle','rb'))\n",
    "\n",
    "        epsilon_list_DPJL[JLdim]=dd['epsilon']\n",
    "    ##############################\n",
    "\n",
    "\n",
    "    plt.xscale('log')\n",
    "\n",
    "    eps_concat = list(epsilon_list_DPVanilla)\n",
    "    for JLdim in JLdim_list:\n",
    "        eps_concat+=list(epsilon_list_DPJL[JLdim])\n",
    "\n",
    "\n",
    "    min_eps, max_eps = min(eps_concat), max(eps_concat)\n",
    "\n",
    "    plt.scatter(np.cumsum(epochtime_list_nonDP),accuracy_list_nonDP,marker='^',color='black',label='non DP')\n",
    "\n",
    "    if os.path.exists(f'mnist/pickles/DPVanilla_MNIST{B}.pickle'):\n",
    "        plt.scatter(np.cumsum(epochtime_list_DPVanilla),accuracy_list_DPVanilla,\n",
    "                cmap='RdYlGn_r',c=epsilon_list_DPVanilla,marker='s',label='DP-SGD-Vanilla (TFP)')\n",
    "        plt.clim(min_eps,max_eps)\n",
    "    \n",
    "    #print(epochtime_list_DPVanillaGA, accuracy_list_DPVanillaGA, epsilon_list_DPVanilla)\n",
    "\n",
    "\n",
    "    plt.scatter(np.cumsum(epochtime_list_DPVanillaGA),accuracy_list_DPVanillaGA,\n",
    "                cmap='RdYlGn_r',c=epsilon_list_DPVanilla,marker='p',label='DP-SGD-Vanilla (GA)')\n",
    "    plt.clim(min_eps,max_eps)\n",
    "\n",
    "\n",
    "    for i,JLdim in enumerate(JLdim_list):\n",
    "        plt.scatter(np.cumsum(epochtime_list_DPJL[JLdim]),accuracy_list_DPJL[JLdim],\n",
    "                    cmap='RdYlGn_r',c=epsilon_list_DPJL[JLdim],marker=marker_list[i], label=f'DP-SGD-JL{JLdim}')\n",
    "        plt.clim(min_eps,max_eps)\n",
    "\n",
    "\n",
    "    plt.colorbar(label=r'$\\epsilon$')\n",
    "\n",
    "    #plt.xlim(1,5e5)\n",
    "    plt.ylim(0.65,1)\n",
    "\n",
    "    plt.axhline(0.95,linestyle='dashed',color='gray')\n",
    "    plt.ylabel('Test Accuracy',fontsize=16)\n",
    "    plt.xlabel('Time (sec)',fontsize=16)\n",
    "    plt.legend(loc='center left',frameon=True)\n",
    "    plt.savefig(f'Figures/MNIST_colorplot{B}.pdf',format='pdf', bbox_inches = \"tight\",dpi=300)\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "    plt.plot(np.arange(1,epochs+1),epsilon_list_DPVanilla,label=f'DP-SGD-Vanilla',color='k',linestyle='--')\n",
    "\n",
    "    for i,JLdim in enumerate(JLdim_list):\n",
    "        plt.plot(np.arange(1,epochs+1),epsilon_list_DPJL[JLdim],label=f'DP-SGD-JL{JLdim}')\n",
    "\n",
    "\n",
    "    plt.ylabel('epsilon',fontsize=16)\n",
    "    plt.xlabel('epochs',fontsize=16)\n",
    "    plt.legend(loc='center right',frameon=True)\n",
    "    plt.savefig(f'Figures/MNIST_epsilonplot{B}.pdf',format='pdf', bbox_inches = \"tight\",dpi=300)\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## JL approximation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAY0AAAEPCAYAAAC+35gCAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOydd3xUVfr/32cmfdJDGilAQkINYkBQisAqRRERRdT1p666oK5+1+7a1oauuqzrrmUVbIArIqtiRQWRIiq9JIAQQiAQ0ntPppzfHyczmTQYJA0477zO6957zi1PJpPzuac9j5BSotFoNBqNKxi62gCNRqPRnD5o0dBoNBqNy2jR0Gg0Go3LaNHQaDQajcto0dBoNBqNy2jR0Gg0Go3LdKpoCCHeFULkCyF2t1EuhBCvCCHShRApQohkp7IpQoj9DWUPd57VGo1Go7HT2S2NhcCU45RfAiQ0pDnAGwBCCCPwekP5QOA6IcTADrVUo9FoNC3oVNGQUq4Hio9zynRgsVRsBAKFEJHACCBdSpkhpawHljacq9FoNJpOxK2rDWhGFHDU6TirIa+1/JFt3UQIMQfVUsFkMg3r379/+1uq0Wg0Zyjbtm0rlFKGtlbW3URDtJInj5PfKlLKBcACgOHDh8utW7e2j3UajUZzFiCEyGyrrLuJRhYQ43QcDWQDHm3kazQajaYT6W5Tbr8AbmyYRXU+UCalzAG2AAlCiD5CCA/g2oZzNRqNRtOJdGpLQwjxITAe6CGEyAKeBNwBpJRvAiuAS4F0oBq4uaHMIoS4C/gOMALvSin3dKbtGo1Go+lk0ZBSXneCcgnc2UbZCpSoaDQajaaL6G5jGhqNRvObkVJijxFkMBiQUmKxWDAYDAghHKm7UF9fT1VVFWazGYvFgtlsxmw2Exsbi4eHB7m5uWRmZmI2m7HZbFitVmw2G2PGjMHT05P9+/eTlpbmyLdvr7rqKtzcOqZ616KhOeuRUmKz2bBYLFgsFqxWKx4eHnh6erZLBVNZWUlhYSFlZWWOVF5ezu9//3uEEKxevZrt27c7Kgyz2QzAs88+C8A777zDhg0bsFgsuLu74+3tTXBwMHPnzgXg66+/5siRI3h7e+Pt7Y2Pjw9BQUGMGTMGgNTUVIqKiqivr3ckX19fJk2aBMD//vc/srOzHWUWi4WYmBhuueUWAJ5//nlycnKwWq2Oz2fw4MHcc889AMyePZvCwkJHmcViYdy4cTz22GMAjBs3joqKiiaf78yZM3nuuecA6N27NzabzVHhSymZM2cOTz75JJWVlcTHxzv+Rvb0l7/8hUceeYScnBzH9Var1SEY//jHP7j//vs5cOAA/fr1a/E3mT9/PnPmzGHHjh2MHDnSISoGgwGj0cg777zD1VdfzcaNG7n66qtxc3NzJKPRyKuvvsqECRP46aefeOCBB5pU+haLhcWLFzNy5Eg++eQTbrvttiZlZrOZrVu3kpyczLvvvssdd9zRwr79+/eTmJjI+++/z0MPPdSiPDs7m8jISJYsWcIzzzzToryiogJfX19Xv6InhRYNzSkjpaSgoIDy8vIm/9whISGEhYVhNpvZs2dPkzIpJdHR0fTs2ZPy8nK+/vprKisrqaqqcqQrrriCESNGkJaWxv33309VVRU1NTWOezz77LNMnjyZLVu2cOuttza5t81m480332TChAmsWrWKm2++2VFp2dM333zD2LFj+eCDD7jhhhta/F5btmxh+PDhLF68mL/85S94eXk1SR999BGxsbF8+eWXLFy4kIqKCocglJWVsXfvXgIDA5k7dy5///vfW9z/6quvxsPDg+XLl/P666878g0GA76+vg7RSElJYfXq1bi5uVFfX09NTQ3+/v4O0Zg/fz5ffvllk3vHx8eTnp4OwN13382aNWualA8dOtQhGvPmzWPLli1Nyi+88EKHaHzyySccPHiwScVptVod56anp1NcXNykvL6+3lEeFhZGQECAo8J1c3OjT58+jvLx48c3aQUIIbCvrXJ3d2fGjBlNKnSDwcDQoUMB8PX15b777sNgMDQpHzVqFAAhISHMnTvX8Z2wi1JycrLDtvvvv7/Jd9NqtRIXFwdAYGAgkyZNavHd8fPzc/yt/P39cXd3x83NDXd3d9zd3R0Vdq9evbjmmmualLu5uREeHg7AqFGjePnllx3X2c+xl1911VUMHjzY8dnZf8fg4GAA5syZw+WXX97kdzcajXh7e7f4vrUX4kwP96rXabQfZWVlHDhwgLS0NA4cOMCgQYOYOXMmJSUlji+xM48//jhz584lLy+PiIiIFuUvvvgiDz30EOnp6SQkJDQpc3Nz4z//+Q+zZ89m//79XHfddfj6+uLl5eX453jwwQcZP348u3fv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RHbt2sWJEye4//77ufvuu73Hu//++1m6dCldunRh8eLF9OvXj5kzZxIbG8vDDz/s93uYPHkya9eu5fjx41x//fUtnghv2rJp5P1vC9f1D9y8clX7r+tA+XsodvHixdx000107tyZpKQkBg0axJo1a7j44oubfA5flnvKDxs5ZdpiumyXy0VERAT5+fkALFiwgKysLMDpLlm/fj3r1q1j9uzZlJeXA84cC6NGjSI/P59LL73UO8tfIHJycli3bh0FBQV8+umnFBQUBLxve9IW6/pM7d69m4SEU+OO4uPj2b179xkf11oaftSMnNJIRQbaXfBgaktPwGobTJedlZXFggULSE1NZfHixd75E2bPns37778PwK5du9i2bRt9+vShU6dOXHPNNYCTwv3DDz8M+Prfe+895syZQ2VlJd988w1FRUW4XK6A929MU1oEra0t1nVLXU+NlpigyVoafmzevJkLu1yIJAt0CnVpTCi01XTZWVlZvPfee6xYsQKXy0VcXBwrV65kxYoVfPbZZ+Tn53sTFgJER0d7/1g0lsLd186dO/ntb3/LRx99REFBARMmTPCbrbW9a6t1fSbi4+PZtevUs9SlpaWce+65Z3xcCxp+FBYWMjRyqHVNham2nC574MCB9OnTh+nTp3u7pr777jt69epF165d2bJlC59//vkZfweHDh2iW7du9OzZk7179/KPf/zjjI/ZFrXluj4T1157LQsWLODkyZPs3LmTbdu2MWJEg4+2NYl1TzWgqqqKrV9uJb4y3oJGGGkv6bLBaW3MmDGDSZMmAXDVVVeRm5uLy+Vi8ODBjBo1qpnfwikZGRlkZmaSmppKcnIyl1xyyRkfs61oL3UdSGr0qKgopk6dyr59+5gwYQJut5vly5eTmprKDTfcwNChQ4mKiuL1118nMvLMp3cIemr0YGtOavTq6mq2LttKyoQUeBO4s3XKZk6x1OjG1NcWU6Nb91QDIiIibOSUMSakcnNzycrK4je/+U2oi1KLdU/5U/PQrQUNY0wIZGdnk52d3fiGQWYtDX+2AH08P8YYYwALGv5twVoZxhhThwUNf4qxoGGMMXXYPY2GVOJMATU21AUxxpi2xVoaDYkC3sCZ7cOEjXBJl206Vl0/8sgjpKSk4HK5mDRpkvehQrDU6EFNjW6Cy1KjByddtnF0pLpevny5VlRUqKrqo48+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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "batch_size_list=[250]\n",
    "\n",
    "for B in batch_size_list:\n",
    "\n",
    "    ######### nonDP ########## \n",
    "    dd = pickle.load(open(f'mnist/pickles/nonDP_MNIST{B}_approx.pickle','rb'))\n",
    "\n",
    "    accuracy_list_nonDP=dd['accuracy']\n",
    "\n",
    "\n",
    "    ######### DPVanilla ########## \n",
    "    dd = pickle.load(open(f'mnist/pickles/DPVanilla_MNIST{B}_approx.pickle','rb'))\n",
    "\n",
    "    accuracy_list_DPVanilla=dd['accuracy']\n",
    "\n",
    "\n",
    "    epochs=len(accuracy_list_DPVanilla)\n",
    "\n",
    "    ######## DPJL ################\n",
    "    JLdim_list=[1,3,10,20]\n",
    "    marker_list=['o','*','v','P','p']\n",
    "    color_list=['r','b','g','magenta','cyan','pink']\n",
    "    epochtime_list_DPJL={}\n",
    "    accuracy_list_DPJL={}\n",
    "\n",
    "    for JLdim in JLdim_list:\n",
    "        dd = pickle.load(open(f'mnist/pickles/DPJL{JLdim}_MNIST{B}_approx.pickle','rb'))\n",
    "\n",
    "        accuracy_list_DPJL[JLdim]=dd['accuracy']\n",
    "\n",
    "\n",
    "    ##############################\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    #plt.scatter(np.arange(1,epochs+1),accuracy_list_nonDP,marker='^',label='nonDP',color='black')\n",
    "    plt.plot(np.arange(1,epochs+1),accuracy_list_nonDP,linestyle='--',label='nonDP-SGD',color='black')\n",
    "\n",
    "    #plt.scatter(np.arange(1,epochs+1),accuracy_list_DPVanilla,marker='s',label='DP Vanilla',color='black')\n",
    "    plt.plot(np.arange(1,epochs+1),accuracy_list_DPVanilla,label='DP-SGD-Vanilla',color='black')\n",
    "\n",
    "\n",
    "    for i,JLdim in enumerate(JLdim_list):\n",
    "        plt.plot(np.arange(1,epochs+1),accuracy_list_DPJL[JLdim],label=f'DP-SGD-JL{JLdim}',color=color_list[i])\n",
    "\n",
    "\n",
    "    plt.ylim(0.7,1)\n",
    "\n",
    "    plt.axhline(0.95,linestyle='dotted',color='gray')\n",
    "    plt.ylabel('Test Accuracy',fontsize=16)\n",
    "    plt.xlabel('epochs',fontsize=16)\n",
    "    plt.legend(loc='lower right',frameon=True,ncol=2)\n",
    "    plt.savefig(f'Figures/MNIST_approximation{B}.pdf',format='pdf', bbox_inches = \"tight\",dpi=300)\n",
    "    plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## epsilon vs JLdim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "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": [
    "\n",
    "######### DPVanilla ########## \n",
    "dd = pickle.load(open('mnist/pickles/DPVanilla_MNIST_epsilons250.pickle','rb'))\n",
    "\n",
    "epsilon_list_DPVanilla=dd['epsilon']\n",
    "\n",
    "\n",
    "\n",
    "######## DPJL ################\n",
    "JLdim_list=[5,10,20,30]\n",
    "marker_list=['o','*','v','P','p']\n",
    "\n",
    "epsilon_list_DPJL={}\n",
    "\n",
    "\n",
    "for JLdim in JLdim_list:\n",
    "\n",
    "    \n",
    "    dd = pickle.load(open(f'mnist/pickles/DPJL{JLdim}_MNIST_epsilons250.pickle','rb'))\n",
    "    \n",
    "    epsilon_list_DPJL[JLdim]=dd['epsilon']\n",
    "    \n",
    "\n",
    "epsilon_list_JLdim = [epsilon_list_DPJL[JLdim][-1] for JLdim in JLdim_list]\n",
    "plt.scatter(JLdim_list,epsilon_list_JLdim)\n",
    "plt.plot(JLdim_list,epsilon_list_JLdim)\n",
    "plt.axhline(epsilon_list_DPVanilla[-1],linestyle='dashed',color='gray')\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xlabel('JLdim')\n",
    "plt.ylabel('epsilon')\n",
    "plt.show()"
   ]
  },
  {
   "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.7.1"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
