{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Figures in the paper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# append the parent directory to the module search path. this is required to run the notebook from this folder\n",
    "import sys\n",
    "import os\n",
    "module_path = os.path.abspath(os.path.join('..'))\n",
    "if module_path not in sys.path:\n",
    "    sys.path.append(module_path)\n",
    "    \n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "import numpy as np\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# avoid type-3 fonts\n",
    "import matplotlib\n",
    "matplotlib.rcParams['pdf.fonttype'] = 42\n",
    "matplotlib.rcParams['ps.fonttype'] = 42\n",
    "\n",
    "sns.set_style(\"white\")\n",
    "sns.set_context(\"notebook\", rc={'axes.linewidth': 2, 'grid.linewidth': 1},  font_scale=2.5)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CIFAR-10 gradient norm regularization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the results from the experiment \n",
    "path = '../experiments/results/score_alignment_lpips'\n",
    "results = {}\n",
    "for file in os.listdir(path):\n",
    "    if file[-4:] != '.pkl':\n",
    "        continue\n",
    "    pos = file.find('gnorm_const=') \n",
    "    pos = pos + len('gnorm_const=')\n",
    "    reg_const = file[pos:pos+file[pos:].find('_')]\n",
    "    reg_const = float(reg_const)\n",
    "\n",
    "    distances = pickle.load(open(os.path.join(path, file), 'rb'))\n",
    "    if not reg_const in results:\n",
    "        results[reg_const] = []\n",
    "    results[reg_const].append(distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracies = pickle.load(open('../data/gnorm_accuracies.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "gnorm = list(results.keys())\n",
    "gnorm.sort()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "plt.figure(figsize=(10,6))\n",
    "ax1 = plt.gca()\n",
    "ax2 = ax1.twinx()\n",
    "\n",
    "y = [np.mean(accuracies[g])/100 for g in gnorm]\n",
    "y1 = [np.min(accuracies[g])/100 for g in gnorm]\n",
    "y2 = [np.max(accuracies[g])/100 for g in gnorm]\n",
    "\n",
    "ax1.plot(gnorm, y, 'o--', ms=15, color='#9467bd', label='Accuracy')\n",
    "ax1.fill_between(gnorm, y1, y2, color='#9467bd', alpha=.3)\n",
    "ax1.set_ylim([0.1,1.15])\n",
    "ax1.set_ylabel('Accuracy', color='#9467bd', weight='bold')\n",
    "ax1.yaxis.label.set_color('#9467bd')\n",
    "ax1.tick_params(axis='y', colors='#9467bd')\n",
    "\n",
    "\n",
    "mean_values = {k:np.mean([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y = [1-mean_values[v] for v in gnorm]\n",
    "min_values = {k:np.min([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y1 = [1-min_values[v] for v in gnorm]\n",
    "max_values = {k:np.max([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y2 = [1-max_values[v] for v in gnorm]\n",
    "\n",
    "ax2.plot(gnorm, y, 'o--', ms=15, color='#2ca02c')\n",
    "ax2.fill_between(gnorm, y1, y2, color='#2ca02c', alpha=.3)\n",
    "ax2.set_ylim([0.7, 0.89])\n",
    "#ax2.set_ylabel('1-LPIPS', color='#2ca02c')\n",
    "ax2.set_yticks([])\n",
    "\n",
    "ax1.set_xlabel('Regularization Constant', weight='bold')\n",
    "plt.xscale('log')\n",
    "#plt.title('Gradient Norm (CIFAR-10)')\n",
    "#ax1.legend(loc='lower center')\n",
    "plt.savefig('../figures/cifar10_gnorm_lpips.png', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the results from the experiment \n",
    "path = '../experiments/results/manifold_robustness'\n",
    "results = {}\n",
    "for file in os.listdir(path):\n",
    "    if file[-4:] != '.pkl':\n",
    "        continue\n",
    "    pos = file.find('gnorm_const=') \n",
    "    pos = pos + len('gnorm_const=')\n",
    "    reg_const = file[pos:pos+file[pos:].find('_')]\n",
    "    reg_const = float(reg_const)\n",
    "\n",
    "    on_robustness, off_robustnes  = pickle.load(open(os.path.join(path, file), 'rb'))\n",
    "    if not reg_const in results:\n",
    "        results[reg_const] = []\n",
    "    results[reg_const].append(({k:np.mean(v) for k, v in on_robustness.items()}, {k:np.mean(v) for k, v in off_robustnes.items()}))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "step_sizes = np.logspace(-3, 2, num=20)\n",
    "step_sizes = np.insert(step_sizes, 0, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,6))\n",
    "step = 16\n",
    "\n",
    "plot_values = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    plot_values.append(np.mean(replication_values))\n",
    "plt.plot(gnorm, plot_values, 'o--', label='On-Manifold Perturbation', ms=15)\n",
    "\n",
    "y1 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    y1.append(np.min(replication_values))\n",
    "y2 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    y2.append(np.max(replication_values))\n",
    "\n",
    "plt.fill_between(gnorm, y1, y2, color='b', alpha=.3)\n",
    "\n",
    "\n",
    "plot_values = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    plot_values.append(np.mean(replication_values))\n",
    "plt.plot(gnorm, plot_values, 'o--', label='Off-Manifold Perturbation', color='red', ms=15)\n",
    "\n",
    "y1 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    y1.append(np.min(replication_values))\n",
    "y2 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    y2.append(np.max(replication_values))\n",
    "\n",
    "plt.fill_between(gnorm, y1, y2, color='red', alpha=.3)\n",
    "\n",
    "plt.xscale('log')\n",
    "#plt.xlabel('Regularization Constant')\n",
    "plt.gca().set_xticks([])\n",
    "plt.ylabel('L1-Norm', weight='bold')\n",
    "plt.title(f'Gradient Norm (CIFAR-10)', weight='bold')\n",
    "#plt.legend(fontsize=20)\n",
    "plt.ylim([0, 1.9])\n",
    "plt.savefig('../figures/cifar10_gnorm_perturbation.png', bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CIFAR-10 smoothness regularization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the results from the experiment \n",
    "path = '../experiments/results/cifar10_smooth_score_alignment_lpips'\n",
    "results = {}\n",
    "for file in os.listdir(path):\n",
    "    if file[-4:] != '.pkl':\n",
    "        continue\n",
    "    pos = file.find('gnorm_const=') \n",
    "    pos = pos + len('gnorm_const=')\n",
    "    reg_const = file[pos:pos+file[pos:].find('_')]\n",
    "    reg_const = float(reg_const)\n",
    "\n",
    "    distances = pickle.load(open(os.path.join(path, file), 'rb'))\n",
    "    if not reg_const in results:\n",
    "        results[reg_const] = []\n",
    "    results[reg_const].append(distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracies = pickle.load(open('../data/smooth_accuracies.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "gnorm = list(results.keys())\n",
    "gnorm.sort()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,6))\n",
    "ax1 = plt.gca()\n",
    "ax2 = ax1.twinx()\n",
    "\n",
    "y = [np.mean(accuracies[g])/100 for g in gnorm]\n",
    "y1 = [np.min(accuracies[g])/100 for g in gnorm]\n",
    "y2 = [np.max(accuracies[g])/100 for g in gnorm]\n",
    "\n",
    "ax1.plot(gnorm, y, 'o--', ms=15, color='#9467bd', label='Accuracy')\n",
    "ax1.fill_between(gnorm, y1, y2, color='#9467bd', alpha=.3)\n",
    "ax1.set_ylim([0.1,1.15])\n",
    "#ax1.set_ylabel('Accuracy', color='#9467bd')\n",
    "ax1.set_yticks([])\n",
    "\n",
    "mean_values = {k:np.mean([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y = [1-mean_values[v] for v in gnorm]\n",
    "min_values = {k:np.min([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y1 = [1-min_values[v] for v in gnorm]\n",
    "max_values = {k:np.max([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y2 = [1-max_values[v] for v in gnorm]\n",
    "\n",
    "ax2.plot(gnorm, y, 'o--', ms=15, color='#2ca02c')\n",
    "ax2.fill_between(gnorm, y1, y2, color='#2ca02c', alpha=.3)\n",
    "ax2.set_ylim([0.7, 0.89])\n",
    "#ax2.set_ylabel('1-LPIPS', color='#2ca02c')\n",
    "ax2.tick_params(axis='y', colors='#2ca02c')\n",
    "\n",
    "\n",
    "ax1.set_xlabel('Regularization Constant', weight='bold')\n",
    "plt.xscale('log')\n",
    "#plt.title('Smoothness Penalty (CIFAR-10)')\n",
    "plt.savefig('../figures/cifar10_smooth_lpips.png', bbox_inches='tight')\n",
    "\n",
    "#ax2.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = '../experiments/results/cifar10_smooth_manifold_robustness'\n",
    "results = {}\n",
    "for file in os.listdir(path):\n",
    "    if file[-4:] != '.pkl':\n",
    "        continue\n",
    "    pos = file.find('gnorm_const=') \n",
    "    pos = pos + len('gnorm_const=')\n",
    "    reg_const = file[pos:pos+file[pos:].find('_')]\n",
    "    reg_const = float(reg_const)\n",
    "\n",
    "    on_robustness, off_robustnes  = pickle.load(open(os.path.join(path, file), 'rb'))\n",
    "    if not reg_const in results:\n",
    "        results[reg_const] = []\n",
    "    results[reg_const].append(({k:np.mean(v) for k, v in on_robustness.items()}, {k:np.mean(v) for k, v in off_robustnes.items()}))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "step_sizes = np.logspace(-3, 2, num=20)\n",
    "step_sizes = np.insert(step_sizes, 0, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,6))\n",
    "step = 16\n",
    "\n",
    "plot_values = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    plot_values.append(np.mean(replication_values))\n",
    "plt.plot(gnorm, plot_values, 'o--', label='On-Manifold Perturbation', ms=15)\n",
    "\n",
    "y1 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    y1.append(np.min(replication_values))\n",
    "y2 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    y2.append(np.max(replication_values))\n",
    "\n",
    "plt.fill_between(gnorm, y1, y2, color='b', alpha=.3)\n",
    "\n",
    "\n",
    "plot_values = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    plot_values.append(np.mean(replication_values))\n",
    "plt.plot(gnorm, plot_values, 'o--', label='Off-Manifold Perturbation', color='red', ms=15)\n",
    "\n",
    "y1 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    y1.append(np.min(replication_values))\n",
    "y2 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    y2.append(np.max(replication_values))\n",
    "\n",
    "plt.fill_between(gnorm, y1, y2, color='red', alpha=.3)\n",
    "\n",
    "plt.xscale('log')\n",
    "#plt.xlabel('Regularization Constant')\n",
    "plt.gca().set_xticks([])\n",
    "#plt.ylabel('L1 Softmax Deviation')\n",
    "plt.title(f'Smoothness Penalty (CIFAR-10)', weight='bold')\n",
    "plt.ylim([0, 1.9])\n",
    "plt.yticks([])\n",
    "plt.legend(fontsize=25)\n",
    "plt.savefig('../figures/cifar10_smooth_perturbation.png', bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CIFAR-10 Randomized Smoothing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the results from the experiment \n",
    "path = '../experiments/results/cifar10_randomized_smoothing_score_alignment_lpips'\n",
    "results = {}\n",
    "for file in os.listdir(path):\n",
    "    if file[-4:] != '.pkl':\n",
    "        continue\n",
    "    pos = file.find('rand_smooth_noise_level=') \n",
    "    pos = pos + len('rand_smooth_noise_level=')\n",
    "    reg_const = file[pos:pos+file[pos:].find('_')]\n",
    "    reg_const = float(reg_const)\n",
    "\n",
    "    distances = pickle.load(open(os.path.join(path, file), 'rb'))\n",
    "    if not reg_const in results:\n",
    "        results[reg_const] = []\n",
    "    results[reg_const].append(distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracies = pickle.load(open('../data/randomized_smoothing_accuracies.pkl', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "gnorm = list(results.keys())\n",
    "gnorm.sort()\n",
    "gnorm = gnorm[0:27]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,6))\n",
    "ax1 = plt.gca()\n",
    "ax2 = ax1.twinx()\n",
    "\n",
    "y = [np.mean(accuracies[g])/100 for g in gnorm]\n",
    "y1 = [np.min(accuracies[g])/100 for g in gnorm]\n",
    "y2 = [np.max(accuracies[g])/100 for g in gnorm]\n",
    "\n",
    "ax1.plot(gnorm, y, 'o--', ms=15, color='#9467bd', label='Accuracy')\n",
    "ax1.fill_between(gnorm, y1, y2, color='#9467bd', alpha=.3)\n",
    "ax1.set_ylim([0.1,1.15])\n",
    "#ax1.set_ylabel('Accuracy', color='#9467bd')\n",
    "ax1.set_yticks([])\n",
    "\n",
    "mean_values = {k:np.mean([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y = [1-mean_values[v] for v in gnorm]\n",
    "min_values = {k:np.min([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y1 = [1-min_values[v] for v in gnorm]\n",
    "max_values = {k:np.max([np.mean(l) for l in v])  for k, v in results.items()}\n",
    "y2 = [1-max_values[v] for v in gnorm]\n",
    "\n",
    "ax2.plot(gnorm, y, 'o--', ms=15, color='#2ca02c')\n",
    "ax2.fill_between(gnorm, y1, y2, color='#2ca02c', alpha=.3)\n",
    "ax2.set_ylim([0.2, 0.9])\n",
    "ax2.set_ylabel('1-LPIPS', color='#2ca02c', weight='bold')\n",
    "ax2.tick_params(axis='y', colors='#2ca02c')\n",
    "\n",
    "ax1.set_xlabel('Noise Level', weight='bold')\n",
    "plt.xscale('log')\n",
    "#plt.title('Randomized Smoothing (CIFAR-10)')\n",
    "plt.savefig('../figures/cifar10_randomized_smoothing_lpips.png', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = '../experiments/results/cifar10_randomized_smoothing_manifold_robustness'\n",
    "results = {}\n",
    "for file in os.listdir(path):\n",
    "    if file[-4:] != '.pkl':\n",
    "        continue\n",
    "    pos = file.find('rand_smooth_noise_level=') \n",
    "    pos = pos + len('rand_smooth_noise_level=')\n",
    "    reg_const = file[pos:pos+file[pos:].find('_')]\n",
    "    reg_const = float(reg_const)\n",
    "\n",
    "    on_robustness, off_robustnes  = pickle.load(open(os.path.join(path, file), 'rb'))\n",
    "    if not reg_const in results:\n",
    "        results[reg_const] = []\n",
    "    results[reg_const].append(({k:np.mean(v) for k, v in on_robustness.items()}, {k:np.mean(v) for k, v in off_robustnes.items()}))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "step_sizes = np.logspace(-3, 2, num=20)\n",
    "step_sizes = np.insert(step_sizes, 0, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,6))\n",
    "step = 16 # the size of the perturbation that we consider\n",
    "\n",
    "plot_values = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    plot_values.append(np.mean(replication_values))\n",
    "plt.plot(gnorm, plot_values, 'o--', label='On-Manifold Perturbation', ms=15)\n",
    "\n",
    "y1 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    y1.append(np.min(replication_values))\n",
    "y2 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for on_robustness, _ in results[gn]: # for each replication\n",
    "        replication_values.append(on_robustness[step_sizes[step]])\n",
    "    y2.append(np.max(replication_values))\n",
    "\n",
    "plt.fill_between(gnorm, y1, y2, color='b', alpha=.3)\n",
    "\n",
    "plot_values = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    plot_values.append(np.mean(replication_values))\n",
    "plt.plot(gnorm, plot_values, 'o--', label='Off-Manifold Perturbation', color='red', ms=15)\n",
    "\n",
    "y1 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    y1.append(np.min(replication_values))\n",
    "y2 = []\n",
    "for gn in gnorm:\n",
    "    replication_values = []\n",
    "    for _, off_robustness in results[gn]: # for each replication\n",
    "        replication_values.append(off_robustness[step_sizes[step]])\n",
    "    y2.append(np.max(replication_values))\n",
    "\n",
    "plt.fill_between(gnorm, y1, y2, color='red', alpha=.3)\n",
    "\n",
    "#plt.ylabel('L1 Softmax Deviation')\n",
    "#plt.xlabel('Noise Level')\n",
    "\n",
    "plt.xscale('log')\n",
    "plt.title('Randomized Smoothing (CIFAR-10)', weight='bold')\n",
    "#plt.legend(fontsize=20)\n",
    "plt.ylim([0, 1.9])\n",
    "plt.yticks([])\n",
    "plt.xticks([])\n",
    "plt.savefig('../figures/cifar10_randomized_smoothing_perturbation.png', bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "deeplearning",
   "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.10.8"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "36d4be3fdecffea904e02ae39f4d4fa6bdc0b9865970412f32cf489e5dafede0"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
