{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import random\n",
    "import matplotlib.pylab as plt\n",
    "import tensorflow as tf\n",
    "from tqdm.notebook import tqdm\n",
    "from tensorflow.keras import Sequential, layers\n",
    "from tensorflow.keras.callbacks import ModelCheckpoint\n",
    "\n",
    "sys.path.append('D:\\\\AAI\\\\ICLR\\\\')\n",
    "import adversarials\n",
    "\n",
    "%matplotlib inline\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Datasets"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generate the Tiling Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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CKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgiOruTa8BAAAAgDiiBgAAAGAMoQYAAABgCKEGAAAAYAihBgAAAGAIoQYAAABgCKEGAAAAYIhvAkj08nOYfXiNAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1440x360 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "class_t0 = np.zeros((6,6))\n",
    "class_t1 = np.zeros((6,6))\n",
    "class_t2 = np.zeros((6,6))\n",
    "class_t3 = np.zeros((6,6))\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_t0[i,j] = 1\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_t1[i,5-j] = 1\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_t2[5-i,5-j] = 1\n",
    "        \n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_t3[5-i,j] = 1\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(1,4, figsize=(20,5))\n",
    "axes[0].axis('off')\n",
    "axes[0].set_title('Tiling class 0')\n",
    "axes[0].imshow(class_t0, cmap='Blues_r')\n",
    "axes[1].axis('off')\n",
    "axes[1].set_title('Tiling class 1')\n",
    "axes[1].imshow(class_t1, cmap='Blues_r')\n",
    "axes[2].axis('off')\n",
    "axes[2].set_title('Tiling class 2')\n",
    "axes[2].imshow(class_t2, cmap='Blues_r')\n",
    "axes[3].axis('off')\n",
    "axes[3].set_title('Tiling class 3')\n",
    "axes[3].imshow(class_t3, cmap='Blues_r');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a1d9727117ba44a490a9585c37b69de9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=9999.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "((40000, 6, 6), (40000,))"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "c0 = np.expand_dims(class_t0, axis=0)\n",
    "c1 = np.expand_dims(class_t1, axis=0)\n",
    "c2 = np.expand_dims(class_t2, axis=0)\n",
    "c3 = np.expand_dims(class_t3, axis=0)\n",
    "\n",
    "images_tiling = np.concatenate((c0, c1, c2, c3), axis=0)\n",
    "labels = [0,1,2,3]\n",
    "\n",
    "\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(images_tiling[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Tiling Class' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "\n",
    "for i in tqdm(range(9999)):\n",
    "    images_tiling = np.concatenate((images_tiling, c0, c1, c2, c3), axis=0)\n",
    "    labels.append(0)\n",
    "    labels.append(1)\n",
    "    labels.append(2)\n",
    "    labels.append(3)\n",
    "\n",
    "labels = np.array(labels)\n",
    "\n",
    "'''with open('./Fig.4/Tiling Dataset/tiling.pkl','wb') as f:\n",
    "    pickle.dump(images_tiling, f)\n",
    "with open('labels.pkl','wb') as f:\n",
    "    pickle.dump(labels, f)\n",
    "'''\n",
    "\n",
    "images_tiling.shape, labels.shape\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generate the Overlapping Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBOblr0AAAAA9t6Oi7ctewk8wA7bsnXZS2CJHFEDAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0MSmZS8AAHZcvG3ZSwAAgBYcUQMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANDEpmUvYH932Jaty14CAPAQsOPibcteAg8Cv1sC7P8cUQMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQhFADAAAA0IRQAwAAANCEUAMAAADQxKZlLwAAAIC9d9iWrcteAvAAckQNAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE5uWvQAAOGzL1mUvgQfBbZduW/YSAADac0QNAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBNCDQAAAEATQg0AAABAE0INAAAAQBM1xlj2GgAAAACII2oAAAAA2hBqAAAAAJoQagAAAACaEGoAAAAAmhBqAAAAAJoQagAAAACa+D97kERWuOTSpQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1440x360 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "class_o0 = np.zeros((6,6))\n",
    "class_o1 = np.zeros((6,6))\n",
    "class_o2 = np.zeros((6,6))\n",
    "class_o3 = np.zeros((6,6))\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_o0[i,j+2] = 1\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_o1[i+2,5-j] = 1\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_o2[5-i,j+1] = 1\n",
    "\n",
    "for i in range(3):\n",
    "    for j in range(3):\n",
    "        class_o3[i+1,j] = 1\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(1,4, figsize=(20,5))\n",
    "axes[0].axis('off')\n",
    "axes[0].set_title('Overlapping class 0')\n",
    "axes[0].imshow(class_o0, cmap='Blues_r')\n",
    "axes[1].axis('off')\n",
    "axes[1].set_title('Overlapping class 1')\n",
    "axes[1].imshow(class_o1, cmap='Blues_r')\n",
    "axes[2].axis('off')\n",
    "axes[2].set_title('Overlapping class 2')\n",
    "axes[2].imshow(class_o2, cmap='Blues_r')\n",
    "axes[3].axis('off')\n",
    "axes[3].set_title('Overlapping class 3')\n",
    "axes[3].imshow(class_o3, cmap='Blues_r');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "61e10491c91c413abe84c0f83b988aa3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=9999.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "((40000, 6, 6), (40000,))"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "c0 = np.expand_dims(class_o0, axis=0)\n",
    "c1 = np.expand_dims(class_o1, axis=0)\n",
    "c2 = np.expand_dims(class_o2, axis=0)\n",
    "c3 = np.expand_dims(class_o3, axis=0)\n",
    "\n",
    "images_overlapping = np.concatenate((c0, c1, c2, c3), axis=0)\n",
    "\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(images_overlapping[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Overlapping Class' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "\n",
    "for i in tqdm(range(9999)):\n",
    "    images_overlapping = np.concatenate((images_overlapping, c0, c1, c2, c3), axis=0)\n",
    "\n",
    "'''with open('./Fig.4/Overlapping Dataset/overlapping.pkl','wb') as f:\n",
    "    pickle.dump(images_overlapping, f)\n",
    "'''\n",
    "    \n",
    "images_overlapping.shape, labels.shape\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./Fig.4/Tiling Dataset/tiling.pkl','rb') as f:\n",
    "    images_tiling = pickle.load(f)\n",
    "    \n",
    "with open('./Fig.4/Overlapping Dataset/overlapping.pkl','rb') as f:\n",
    "    images_overlapping = pickle.load(f)\n",
    "\n",
    "with open('./Fig.4/labels.pkl','rb') as f:\n",
    "    labels = pickle.load(f)\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PNCs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def avg_img(images, labels):\n",
    "    '''\n",
    "    This function gets either of MNIST & Fashion_MNIST\n",
    "    datasets and compute average images for all classes. \n",
    "    \n",
    "    \n",
    "    Arguments\n",
    "    ---------------------------------------------\n",
    "    ** images (numpy.ndarray)\n",
    "    \n",
    "    ** labels (numpy.ndarray)\n",
    "    \n",
    "    \n",
    "    Returns\n",
    "    ---------------------------------------------\n",
    "    ** avgs (list of numpy.ndarrays)\n",
    "    A list of average images for all classes\n",
    "    \n",
    "    '''\n",
    "    # set an empty list for the average images\n",
    "    avgs = []\n",
    "    \n",
    "    # for each class\n",
    "    for label in range(4):\n",
    "        \n",
    "        # generate a list of all samples of that class\n",
    "        samples = [images[i] for i in range(len(images)) if labels[i]==label]\n",
    "        \n",
    "        # calculate the average array of all the samples\n",
    "        avg = sum(samples)/len(images)\n",
    "        \n",
    "        # add the average image to the average list\n",
    "        avgs.append(avg)\n",
    "        \n",
    "    return avgs\n",
    "\n",
    "\n",
    "def pnc_img(avgs):\n",
    "    '''\n",
    "    This function gets list of average images and returns\n",
    "    the PNC images. \n",
    "    \n",
    "    \n",
    "    Arguments\n",
    "    ---------------------------------------------\n",
    "    ** avgs (list of numpy.ndarrays)\n",
    "    A list of average images\n",
    "    \n",
    "    \n",
    "    Returns\n",
    "    ---------------------------------------------\n",
    "    ** pncs (list of numpy.ndarrays)\n",
    "    A list of PNC images\n",
    "    \n",
    "    '''\n",
    "    # set an empty list for the PNC images\n",
    "    pncs = []\n",
    "    \n",
    "    # for each class\n",
    "    for label in range(4):\n",
    "    \n",
    "        # calculate the negative set\n",
    "        neg_set = sum(avgs) - avgs[label]\n",
    "        # normalize the negative set\n",
    "        neg_set = (neg_set - neg_set.min()) / (neg_set.max() - neg_set.min())\n",
    "        # we already have the normalized positive set\n",
    "        pos_set = avgs[label]\n",
    "        # calculate PNCs\n",
    "        pnc = pos_set - neg_set\n",
    "        \n",
    "        # normalizing the pnc in range [0 1]\n",
    "        pnc = (pnc - pnc.min()) / (pnc.max() - pnc.min())\n",
    "        \n",
    "        # add the PNC image to the PNC list\n",
    "        pncs.append(pnc)\n",
    "        \n",
    "    return pncs"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Tiling Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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AABQEgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAAJBk77pO/KxXXLuuUwMMy/82rt9X//Cd6x6BAX3hNo8LtuaxsV6eNwEWy5VEAAAAACiJAAAAAFASAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAALAmVXVJVd1dVUeq6vrHWfeKqnq4ql6zyvlgt1ESAQAAsHJVtSfJu5JcmuSCJFdW1QUnWPf2JLesdkLYfZREAAAArMNFSY509z3d/VCSm5JcvsW6NyX5tSQPrHI42I2URAAAAKzDWUnum9k+Ot33n1TVWUl+JMn+Fc4Fu5aSCAAAgHWoLfb1pu1fSHJddz980hururqqDlXVoWPHji1iPth19q57AAAAAHalo0nOmdk+O8n9m9ZsJLmpqpLkzCSXVdXx7v71zTfW3QeSHEiSjY2NzWUTMAclEQAAAOtwW5LzqurcJJ9JckWS184u6O5zH/2+qm5M8oGtCiJgMZREAAAArFx3H6+qazP51LI9SW7o7sNVdc30uPchghVTEgEAALAW3X0wycFN+7Ysh7r7DauYCXYzb1wNAAAAgJIIAAAAACURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAACwJlV1SVXdXVVHqur6LY6/rqrumH59pKouXMecsFsoiQAAAFi5qtqT5F1JLk1yQZIrq+qCTcs+neR7u/ulSd6W5MBqp4TdRUkEAADAOlyU5Eh339PdDyW5Kcnlswu6+yPd/YXp5q1Jzl7xjLCrKIkAAABYh7OS3DezfXS670R+LMlvnuhgVV1dVYeq6tCxY8cWNCLsLkoiAAAA1qG22NdbLqz6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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get the average images for the MNIST dataset\n",
    "tiling_avgs = avg_img(images_tiling, labels)\n",
    "\n",
    "# plot MNIST average images\n",
    "adversarials.plot_ten(tiling_avgs, 'Tiling avg, class')\n",
    "\n",
    "\n",
    "# get the PNC images for the MNIST dataset\n",
    "tiling_pncs = pnc_img(tiling_avgs)\n",
    "\n",
    "# plot MNIST PNC images\n",
    "adversarials.plot_ten(tiling_pncs, 'Tiling PNC, class')\n",
    "\n",
    "\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(tiling_pncs[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Tiling PNC Class' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Overlapping Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get the average images for the MNIST dataset\n",
    "overlapping_avgs = avg_img(images_overlapping, labels)\n",
    "\n",
    "# plot MNIST average images\n",
    "adversarials.plot_ten(overlapping_avgs, 'Overlapping avg, class')\n",
    "\n",
    "# get the PNC images for the MNIST dataset\n",
    "overlapping_pncs = pnc_img(overlapping_avgs)\n",
    "\n",
    "# plot MNIST PNC images\n",
    "adversarials.plot_ten(overlapping_pncs, 'Overlapping PNC, class')\n",
    "\n",
    "\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(overlapping_pncs[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Overlapping PNC Class' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Tailing Perturbations"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## FC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "flatten (Flatten)            (None, 36)                0         \n",
      "_________________________________________________________________\n",
      "dense (Dense)                (None, 36)                1332      \n",
      "_________________________________________________________________\n",
      "dense_1 (Dense)              (None, 200)               7400      \n",
      "_________________________________________________________________\n",
      "dense_2 (Dense)              (None, 50)                10050     \n",
      "_________________________________________________________________\n",
      "dense_3 (Dense)              (None, 4)                 204       \n",
      "=================================================================\n",
      "Total params: 18,986\n",
      "Trainable params: 18,986\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "Epoch 1/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 1.3827 - accuracy: 0.2945\n",
      "Epoch 00001: val_loss improved from inf to 1.37543, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.3822 - accuracy: 0.2978 - val_loss: 1.3754 - val_accuracy: 0.2500\n",
      "Epoch 2/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 1.3678 - accuracy: 0.4277\n",
      "Epoch 00002: val_loss improved from 1.37543 to 1.36017, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.3676 - accuracy: 0.4256 - val_loss: 1.3602 - val_accuracy: 0.7500\n",
      "Epoch 3/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 1.3526 - accuracy: 0.6071\n",
      "Epoch 00003: val_loss improved from 1.36017 to 1.34268, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 1.3524 - accuracy: 0.6075 - val_loss: 1.3427 - val_accuracy: 0.7500\n",
      "Epoch 4/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 1.3314 - accuracy: 0.7837\n",
      "Epoch 00004: val_loss improved from 1.34268 to 1.31868, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.3313 - accuracy: 0.7850 - val_loss: 1.3187 - val_accuracy: 0.7500\n",
      "Epoch 5/150\n",
      "486/500 [============================>.] - ETA: 0s - loss: 1.3001 - accuracy: 0.9450\n",
      "Epoch 00005: val_loss improved from 1.31868 to 1.27756, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.2995 - accuracy: 0.9455 - val_loss: 1.2776 - val_accuracy: 1.0000\n",
      "Epoch 6/150\n",
      "484/500 [============================>.] - ETA: 0s - loss: 1.2479 - accuracy: 0.9995\n",
      "Epoch 00006: val_loss improved from 1.27756 to 1.20928, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.2467 - accuracy: 0.9995 - val_loss: 1.2093 - val_accuracy: 1.0000\n",
      "Epoch 7/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 1.1561 - accuracy: 0.9977\n",
      "Epoch 00007: val_loss improved from 1.20928 to 1.08455, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.1533 - accuracy: 0.9978 - val_loss: 1.0845 - val_accuracy: 1.0000\n",
      "Epoch 8/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.9857 - accuracy: 1.0000\n",
      "Epoch 00008: val_loss improved from 1.08455 to 0.86207, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.9831 - accuracy: 1.0000 - val_loss: 0.8621 - val_accuracy: 1.0000\n",
      "Epoch 9/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.7129 - accuracy: 1.0000\n",
      "Epoch 00009: val_loss improved from 0.86207 to 0.55601, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.7118 - accuracy: 1.0000 - val_loss: 0.5560 - val_accuracy: 1.0000\n",
      "Epoch 10/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.4277 - accuracy: 1.0000\n",
      "Epoch 00010: val_loss improved from 0.55601 to 0.30398, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.4209 - accuracy: 1.0000 - val_loss: 0.3040 - val_accuracy: 1.0000\n",
      "Epoch 11/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.2288 - accuracy: 1.0000\n",
      "Epoch 00011: val_loss improved from 0.30398 to 0.16542, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.2268 - accuracy: 1.0000 - val_loss: 0.1654 - val_accuracy: 1.0000\n",
      "Epoch 12/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.1281 - accuracy: 1.0000\n",
      "Epoch 00012: val_loss improved from 0.16542 to 0.09859, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.1281 - accuracy: 1.0000 - val_loss: 0.0986 - val_accuracy: 1.0000\n",
      "Epoch 13/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0808 - accuracy: 1.0000\n",
      "Epoch 00013: val_loss improved from 0.09859 to 0.06499, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0800 - accuracy: 1.0000 - val_loss: 0.0650 - val_accuracy: 1.0000\n",
      "Epoch 14/150\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0551 - accuracy: 1.0000\n",
      "Epoch 00014: val_loss improved from 0.06499 to 0.04648, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0549 - accuracy: 1.0000 - val_loss: 0.0465 - val_accuracy: 1.0000\n",
      "Epoch 15/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0405 - accuracy: 1.0000\n",
      "Epoch 00015: val_loss improved from 0.04648 to 0.03529, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0405 - accuracy: 1.0000 - val_loss: 0.0353 - val_accuracy: 1.0000\n",
      "Epoch 16/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0315 - accuracy: 1.0000\n",
      "Epoch 00016: val_loss improved from 0.03529 to 0.02801, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0314 - accuracy: 1.0000 - val_loss: 0.0280 - val_accuracy: 1.0000\n",
      "Epoch 17/150\n",
      "484/500 [============================>.] - ETA: 0s - loss: 0.0254 - accuracy: 1.0000\n",
      "Epoch 00017: val_loss improved from 0.02801 to 0.02298, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0254 - accuracy: 1.0000 - val_loss: 0.0230 - val_accuracy: 1.0000\n",
      "Epoch 18/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0211 - accuracy: 1.0000\n",
      "Epoch 00018: val_loss improved from 0.02298 to 0.01934, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0211 - accuracy: 1.0000 - val_loss: 0.0193 - val_accuracy: 1.0000\n",
      "Epoch 19/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0180 - accuracy: 1.0000\n",
      "Epoch 00019: val_loss improved from 0.01934 to 0.01660, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0179 - accuracy: 1.0000 - val_loss: 0.0166 - val_accuracy: 1.0000\n",
      "Epoch 20/150\n",
      "463/500 [==========================>...] - ETA: 0s - loss: 0.0156 - accuracy: 1.0000\n",
      "Epoch 00020: val_loss improved from 0.01660 to 0.01449, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0155 - accuracy: 1.0000 - val_loss: 0.0145 - val_accuracy: 1.0000\n",
      "Epoch 21/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0136 - accuracy: 1.0000\n",
      "Epoch 00021: val_loss improved from 0.01449 to 0.01281, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0136 - accuracy: 1.0000 - val_loss: 0.0128 - val_accuracy: 1.0000\n",
      "Epoch 22/150\n",
      "466/500 [==========================>...] - ETA: 0s - loss: 0.0122 - accuracy: 1.0000\n",
      "Epoch 00022: val_loss improved from 0.01281 to 0.01146, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0121 - accuracy: 1.0000 - val_loss: 0.0115 - val_accuracy: 1.0000\n",
      "Epoch 23/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0109 - accuracy: 1.0000\n",
      "Epoch 00023: val_loss improved from 0.01146 to 0.01034, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0109 - accuracy: 1.0000 - val_loss: 0.0103 - val_accuracy: 1.0000\n",
      "Epoch 24/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0099 - accuracy: 1.0000\n",
      "Epoch 00024: val_loss improved from 0.01034 to 0.00940, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0099 - accuracy: 1.0000 - val_loss: 0.0094 - val_accuracy: 1.0000\n",
      "Epoch 25/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0090 - accuracy: 1.0000\n",
      "Epoch 00025: val_loss improved from 0.00940 to 0.00861, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0090 - accuracy: 1.0000 - val_loss: 0.0086 - val_accuracy: 1.0000\n",
      "Epoch 26/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0083 - accuracy: 1.0000\n",
      "Epoch 00026: val_loss improved from 0.00861 to 0.00793, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0083 - accuracy: 1.0000 - val_loss: 0.0079 - val_accuracy: 1.0000\n",
      "Epoch 27/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0076 - accuracy: 1.0000\n",
      "Epoch 00027: val_loss improved from 0.00793 to 0.00734, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0076 - accuracy: 1.0000 - val_loss: 0.0073 - val_accuracy: 1.0000\n",
      "Epoch 28/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0071 - accuracy: 1.0000\n",
      "Epoch 00028: val_loss improved from 0.00734 to 0.00683, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0071 - accuracy: 1.0000 - val_loss: 0.0068 - val_accuracy: 1.0000\n",
      "Epoch 29/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.0066 - accuracy: 1.0000\n",
      "Epoch 00029: val_loss improved from 0.00683 to 0.00638, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0066 - accuracy: 1.0000 - val_loss: 0.0064 - val_accuracy: 1.0000\n",
      "Epoch 30/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0062 - accuracy: 1.0000\n",
      "Epoch 00030: val_loss improved from 0.00638 to 0.00598, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0062 - accuracy: 1.0000 - val_loss: 0.0060 - val_accuracy: 1.0000\n",
      "Epoch 31/150\n",
      "469/500 [===========================>..] - ETA: 0s - loss: 0.0058 - accuracy: 1.0000\n",
      "Epoch 00031: val_loss improved from 0.00598 to 0.00563, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0058 - accuracy: 1.0000 - val_loss: 0.0056 - val_accuracy: 1.0000\n",
      "Epoch 32/150\n",
      "475/500 [===========================>..] - ETA: 0s - loss: 0.0055 - accuracy: 1.0000\n",
      "Epoch 00032: val_loss improved from 0.00563 to 0.00531, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0055 - accuracy: 1.0000 - val_loss: 0.0053 - val_accuracy: 1.0000\n",
      "Epoch 33/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0052 - accuracy: 1.0000\n",
      "Epoch 00033: val_loss improved from 0.00531 to 0.00502, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0052 - accuracy: 1.0000 - val_loss: 0.0050 - val_accuracy: 1.0000\n",
      "Epoch 34/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0049 - accuracy: 1.0000\n",
      "Epoch 00034: val_loss improved from 0.00502 to 0.00477, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0049 - accuracy: 1.0000 - val_loss: 0.0048 - val_accuracy: 1.0000\n",
      "Epoch 35/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0047 - accuracy: 1.0000\n",
      "Epoch 00035: val_loss improved from 0.00477 to 0.00453, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0046 - accuracy: 1.0000 - val_loss: 0.0045 - val_accuracy: 1.0000\n",
      "Epoch 36/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 0.0044 - accuracy: 1.0000\n",
      "Epoch 00036: val_loss improved from 0.00453 to 0.00432, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0044 - accuracy: 1.0000 - val_loss: 0.0043 - val_accuracy: 1.0000\n",
      "Epoch 37/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.0042 - accuracy: 1.0000\n",
      "Epoch 00037: val_loss improved from 0.00432 to 0.00412, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0042 - accuracy: 1.0000 - val_loss: 0.0041 - val_accuracy: 1.0000\n",
      "Epoch 38/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 0.0040 - accuracy: 1.0000\n",
      "Epoch 00038: val_loss improved from 0.00412 to 0.00394, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0040 - accuracy: 1.0000 - val_loss: 0.0039 - val_accuracy: 1.0000\n",
      "Epoch 39/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0039 - accuracy: 1.0000\n",
      "Epoch 00039: val_loss improved from 0.00394 to 0.00377, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0039 - accuracy: 1.0000 - val_loss: 0.0038 - val_accuracy: 1.0000\n",
      "Epoch 40/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0037 - accuracy: 1.0000\n",
      "Epoch 00040: val_loss improved from 0.00377 to 0.00362, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0037 - accuracy: 1.0000 - val_loss: 0.0036 - val_accuracy: 1.0000\n",
      "Epoch 41/150\n",
      "475/500 [===========================>..] - ETA: 0s - loss: 0.0035 - accuracy: 1.0000\n",
      "Epoch 00041: val_loss improved from 0.00362 to 0.00348, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0035 - accuracy: 1.0000 - val_loss: 0.0035 - val_accuracy: 1.0000\n",
      "Epoch 42/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 0.0034 - accuracy: 1.0000\n",
      "Epoch 00042: val_loss improved from 0.00348 to 0.00334, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0034 - accuracy: 1.0000 - val_loss: 0.0033 - val_accuracy: 1.0000\n",
      "Epoch 43/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0033 - accuracy: 1.0000\n",
      "Epoch 00043: val_loss improved from 0.00334 to 0.00322, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0033 - accuracy: 1.0000 - val_loss: 0.0032 - val_accuracy: 1.0000\n",
      "Epoch 44/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 0.0032 - accuracy: 1.0000\n",
      "Epoch 00044: val_loss improved from 0.00322 to 0.00310, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0032 - accuracy: 1.0000 - val_loss: 0.0031 - val_accuracy: 1.0000\n",
      "Epoch 45/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0030 - accuracy: 1.0000\n",
      "Epoch 00045: val_loss improved from 0.00310 to 0.00300, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0030 - accuracy: 1.0000 - val_loss: 0.0030 - val_accuracy: 1.0000\n",
      "Epoch 46/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0029 - accuracy: 1.0000\n",
      "Epoch 00046: val_loss improved from 0.00300 to 0.00290, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0029 - accuracy: 1.0000 - val_loss: 0.0029 - val_accuracy: 1.0000\n",
      "Epoch 47/150\n",
      "464/500 [==========================>...] - ETA: 0s - loss: 0.0029 - accuracy: 1.0000\n",
      "Epoch 00047: val_loss improved from 0.00290 to 0.00280, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0028 - accuracy: 1.0000 - val_loss: 0.0028 - val_accuracy: 1.0000\n",
      "Epoch 48/150\n",
      "484/500 [============================>.] - ETA: 0s - loss: 0.0028 - accuracy: 1.0000\n",
      "Epoch 00048: val_loss improved from 0.00280 to 0.00271, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0028 - accuracy: 1.0000 - val_loss: 0.0027 - val_accuracy: 1.0000\n",
      "Epoch 49/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0027 - accuracy: 1.0000\n",
      "Epoch 00049: val_loss improved from 0.00271 to 0.00263, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0027 - accuracy: 1.0000 - val_loss: 0.0026 - val_accuracy: 1.0000\n",
      "Epoch 50/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0026 - accuracy: 1.0000\n",
      "Epoch 00050: val_loss improved from 0.00263 to 0.00255, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0026 - accuracy: 1.0000 - val_loss: 0.0025 - val_accuracy: 1.0000\n",
      "Epoch 51/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0025 - accuracy: 1.0000\n",
      "Epoch 00051: val_loss improved from 0.00255 to 0.00247, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0025 - accuracy: 1.0000 - val_loss: 0.0025 - val_accuracy: 1.0000\n",
      "Epoch 52/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0024 - accuracy: 1.0000\n",
      "Epoch 00052: val_loss improved from 0.00247 to 0.00240, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0024 - accuracy: 1.0000 - val_loss: 0.0024 - val_accuracy: 1.0000\n",
      "Epoch 53/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0024 - accuracy: 1.0000\n",
      "Epoch 00053: val_loss improved from 0.00240 to 0.00233, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0024 - accuracy: 1.0000 - val_loss: 0.0023 - val_accuracy: 1.0000\n",
      "Epoch 54/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0023 - accuracy: 1.0000\n",
      "Epoch 00054: val_loss improved from 0.00233 to 0.00227, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0023 - accuracy: 1.0000 - val_loss: 0.0023 - val_accuracy: 1.0000\n",
      "Epoch 55/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 0.0022 - accuracy: 1.0000\n",
      "Epoch 00055: val_loss improved from 0.00227 to 0.00221, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0022 - accuracy: 1.0000 - val_loss: 0.0022 - val_accuracy: 1.0000\n",
      "Epoch 56/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0022 - accuracy: 1.0000\n",
      "Epoch 00056: val_loss improved from 0.00221 to 0.00215, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0022 - accuracy: 1.0000 - val_loss: 0.0022 - val_accuracy: 1.0000\n",
      "Epoch 57/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 0.0021 - accuracy: 1.0000\n",
      "Epoch 00057: val_loss improved from 0.00215 to 0.00210, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0021 - accuracy: 1.0000 - val_loss: 0.0021 - val_accuracy: 1.0000\n",
      "Epoch 58/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0021 - accuracy: 1.0000\n",
      "Epoch 00058: val_loss improved from 0.00210 to 0.00205, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0021 - accuracy: 1.0000 - val_loss: 0.0020 - val_accuracy: 1.0000\n",
      "Epoch 59/150\n",
      "481/500 [===========================>..] - ETA: 0s - loss: 0.0020 - accuracy: 1.0000\n",
      "Epoch 00059: val_loss improved from 0.00205 to 0.00200, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0020 - accuracy: 1.0000 - val_loss: 0.0020 - val_accuracy: 1.0000\n",
      "Epoch 60/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 0.0020 - accuracy: 1.0000\n",
      "Epoch 00060: val_loss improved from 0.00200 to 0.00195, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0020 - accuracy: 1.0000 - val_loss: 0.0019 - val_accuracy: 1.0000\n",
      "Epoch 61/150\n",
      "481/500 [===========================>..] - ETA: 0s - loss: 0.0019 - accuracy: 1.0000\n",
      "Epoch 00061: val_loss improved from 0.00195 to 0.00190, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0019 - accuracy: 1.0000 - val_loss: 0.0019 - val_accuracy: 1.0000\n",
      "Epoch 62/150\n",
      "469/500 [===========================>..] - ETA: 0s - loss: 0.0019 - accuracy: 1.0000\n",
      "Epoch 00062: val_loss improved from 0.00190 to 0.00186, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0019 - accuracy: 1.0000 - val_loss: 0.0019 - val_accuracy: 1.0000\n",
      "Epoch 63/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0018 - accuracy: 1.0000\n",
      "Epoch 00063: val_loss improved from 0.00186 to 0.00182, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0018 - accuracy: 1.0000 - val_loss: 0.0018 - val_accuracy: 1.0000\n",
      "Epoch 64/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0018 - accuracy: 1.0000\n",
      "Epoch 00064: val_loss improved from 0.00182 to 0.00178, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0018 - accuracy: 1.0000 - val_loss: 0.0018 - val_accuracy: 1.0000\n",
      "Epoch 65/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0018 - accuracy: 1.0000\n",
      "Epoch 00065: val_loss improved from 0.00178 to 0.00174, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0018 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 66/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0017 - accuracy: 1.0000\n",
      "Epoch 00066: val_loss improved from 0.00174 to 0.00170, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0017 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 67/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0017 - accuracy: 1.0000\n",
      "Epoch 00067: val_loss improved from 0.00170 to 0.00167, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0017 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 68/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00068: val_loss improved from 0.00167 to 0.00163, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 69/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00069: val_loss improved from 0.00163 to 0.00160, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 70/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00070: val_loss improved from 0.00160 to 0.00157, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 71/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00071: val_loss improved from 0.00157 to 0.00154, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 72/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00072: val_loss improved from 0.00154 to 0.00151, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 73/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00073: val_loss improved from 0.00151 to 0.00148, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 74/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00074: val_loss improved from 0.00148 to 0.00145, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 75/150\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00075: val_loss improved from 0.00145 to 0.00143, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 76/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00076: val_loss improved from 0.00143 to 0.00140, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 77/150\n",
      "470/500 [===========================>..] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00077: val_loss improved from 0.00140 to 0.00138, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 78/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00078: val_loss improved from 0.00138 to 0.00135, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 79/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00079: val_loss improved from 0.00135 to 0.00133, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 80/150\n",
      "465/500 [==========================>...] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00080: val_loss improved from 0.00133 to 0.00131, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 81/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00081: val_loss improved from 0.00131 to 0.00129, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 82/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00082: val_loss improved from 0.00129 to 0.00126, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 83/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00083: val_loss improved from 0.00126 to 0.00124, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 84/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00084: val_loss improved from 0.00124 to 0.00122, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 85/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00085: val_loss improved from 0.00122 to 0.00121, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 86/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00086: val_loss improved from 0.00121 to 0.00119, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 87/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00087: val_loss improved from 0.00119 to 0.00117, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 88/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00088: val_loss improved from 0.00117 to 0.00115, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 89/150\n",
      "484/500 [============================>.] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00089: val_loss improved from 0.00115 to 0.00113, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 90/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00090: val_loss improved from 0.00113 to 0.00112, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 91/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00091: val_loss improved from 0.00112 to 0.00110, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 92/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00092: val_loss improved from 0.00110 to 0.00109, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 93/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00093: val_loss improved from 0.00109 to 0.00107, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 94/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00094: val_loss improved from 0.00107 to 0.00106, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 95/150\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00095: val_loss improved from 0.00106 to 0.00104, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 96/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00096: val_loss improved from 0.00104 to 0.00103, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 97/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00097: val_loss improved from 0.00103 to 0.00101, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 98/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00098: val_loss improved from 0.00101 to 0.00100, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 9.9954e-04 - val_accuracy: 1.0000\n",
      "Epoch 99/150\n",
      "466/500 [==========================>...] - ETA: 0s - loss: 9.9338e-04 - accuracy: 1.0000\n",
      "Epoch 00099: val_loss improved from 0.00100 to 0.00099, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 9.9307e-04 - accuracy: 1.0000 - val_loss: 9.8650e-04 - val_accuracy: 1.0000\n",
      "Epoch 100/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 9.8015e-04 - accuracy: 1.0000\n",
      "Epoch 00100: val_loss improved from 0.00099 to 0.00097, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 9.8015e-04 - accuracy: 1.0000 - val_loss: 9.7379e-04 - val_accuracy: 1.0000\n",
      "Epoch 101/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 9.6764e-04 - accuracy: 1.0000\n",
      "Epoch 00101: val_loss improved from 0.00097 to 0.00096, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 9.6754e-04 - accuracy: 1.0000 - val_loss: 9.6135e-04 - val_accuracy: 1.0000\n",
      "Epoch 102/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 9.5563e-04 - accuracy: 1.0000\n",
      "Epoch 00102: val_loss improved from 0.00096 to 0.00095, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.5524e-04 - accuracy: 1.0000 - val_loss: 9.4917e-04 - val_accuracy: 1.0000\n",
      "Epoch 103/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 9.4377e-04 - accuracy: 1.0000\n",
      "Epoch 00103: val_loss improved from 0.00095 to 0.00094, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.4324e-04 - accuracy: 1.0000 - val_loss: 9.3729e-04 - val_accuracy: 1.0000\n",
      "Epoch 104/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 9.3150e-04 - accuracy: 1.0000\n",
      "Epoch 00104: val_loss improved from 0.00094 to 0.00093, saving model to fc.hdf5\n",
      "500/500 [==============================] - 3s 5ms/step - loss: 9.3151e-04 - accuracy: 1.0000 - val_loss: 9.2573e-04 - val_accuracy: 1.0000\n",
      "Epoch 105/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 9.2006e-04 - accuracy: 1.0000\n",
      "Epoch 00105: val_loss improved from 0.00093 to 0.00091, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 9.2005e-04 - accuracy: 1.0000 - val_loss: 9.1439e-04 - val_accuracy: 1.0000\n",
      "Epoch 106/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 9.0914e-04 - accuracy: 1.0000\n",
      "Epoch 00106: val_loss improved from 0.00091 to 0.00090, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.0887e-04 - accuracy: 1.0000 - val_loss: 9.0332e-04 - val_accuracy: 1.0000\n",
      "Epoch 107/150\n",
      "472/500 [===========================>..] - ETA: 0s - loss: 8.9823e-04 - accuracy: 1.0000\n",
      "Epoch 00107: val_loss improved from 0.00090 to 0.00089, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.9793e-04 - accuracy: 1.0000 - val_loss: 8.9254e-04 - val_accuracy: 1.0000\n",
      "Epoch 108/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 8.8736e-04 - accuracy: 1.0000\n",
      "Epoch 00108: val_loss improved from 0.00089 to 0.00088, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 8.8725e-04 - accuracy: 1.0000 - val_loss: 8.8193e-04 - val_accuracy: 1.0000\n",
      "Epoch 109/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 8.7715e-04 - accuracy: 1.0000\n",
      "Epoch 00109: val_loss improved from 0.00088 to 0.00087, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 8.7680e-04 - accuracy: 1.0000 - val_loss: 8.7166e-04 - val_accuracy: 1.0000\n",
      "Epoch 110/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 8.6660e-04 - accuracy: 1.0000\n",
      "Epoch 00110: val_loss improved from 0.00087 to 0.00086, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 8.6658e-04 - accuracy: 1.0000 - val_loss: 8.6148e-04 - val_accuracy: 1.0000\n",
      "Epoch 111/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 8.5662e-04 - accuracy: 1.0000\n",
      "Epoch 00111: val_loss improved from 0.00086 to 0.00085, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 8.5659e-04 - accuracy: 1.0000 - val_loss: 8.5162e-04 - val_accuracy: 1.0000\n",
      "Epoch 112/150\n",
      "486/500 [============================>.] - ETA: 0s - loss: 8.4697e-04 - accuracy: 1.0000\n",
      "Epoch 00112: val_loss improved from 0.00085 to 0.00084, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.4682e-04 - accuracy: 1.0000 - val_loss: 8.4198e-04 - val_accuracy: 1.0000\n",
      "Epoch 113/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 8.3735e-04 - accuracy: 1.0000\n",
      "Epoch 00113: val_loss improved from 0.00084 to 0.00083, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 8.3725e-04 - accuracy: 1.0000 - val_loss: 8.3254e-04 - val_accuracy: 1.0000\n",
      "Epoch 114/150\n",
      "465/500 [==========================>...] - ETA: 0s - loss: 8.2816e-04 - accuracy: 1.0000\n",
      "Epoch 00114: val_loss improved from 0.00083 to 0.00082, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 8.2788e-04 - accuracy: 1.0000 - val_loss: 8.2324e-04 - val_accuracy: 1.0000\n",
      "Epoch 115/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 8.1878e-04 - accuracy: 1.0000\n",
      "Epoch 00115: val_loss improved from 0.00082 to 0.00081, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.1871e-04 - accuracy: 1.0000 - val_loss: 8.1416e-04 - val_accuracy: 1.0000\n",
      "Epoch 116/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 8.0974e-04 - accuracy: 1.0000\n",
      "Epoch 00116: val_loss improved from 0.00081 to 0.00081, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.0974e-04 - accuracy: 1.0000 - val_loss: 8.0529e-04 - val_accuracy: 1.0000\n",
      "Epoch 117/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 8.0095e-04 - accuracy: 1.0000\n",
      "Epoch 00117: val_loss improved from 0.00081 to 0.00080, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 8.0095e-04 - accuracy: 1.0000 - val_loss: 7.9659e-04 - val_accuracy: 1.0000\n",
      "Epoch 118/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 7.9233e-04 - accuracy: 1.0000\n",
      "Epoch 00118: val_loss improved from 0.00080 to 0.00079, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.9233e-04 - accuracy: 1.0000 - val_loss: 7.8811e-04 - val_accuracy: 1.0000\n",
      "Epoch 119/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 7.8421e-04 - accuracy: 1.0000\n",
      "Epoch 00119: val_loss improved from 0.00079 to 0.00078, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.8389e-04 - accuracy: 1.0000 - val_loss: 7.7971e-04 - val_accuracy: 1.0000\n",
      "Epoch 120/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 7.7572e-04 - accuracy: 1.0000\n",
      "Epoch 00120: val_loss improved from 0.00078 to 0.00077, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 7.7563e-04 - accuracy: 1.0000 - val_loss: 7.7155e-04 - val_accuracy: 1.0000\n",
      "Epoch 121/150\n",
      "463/500 [==========================>...] - ETA: 0s - loss: 7.6781e-04 - accuracy: 1.0000\n",
      "Epoch 00121: val_loss improved from 0.00077 to 0.00076, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 7.6752e-04 - accuracy: 1.0000 - val_loss: 7.6351e-04 - val_accuracy: 1.0000\n",
      "Epoch 122/150\n",
      "490/500 [============================>.] - ETA: 0s - loss: 7.5958e-04 - accuracy: 1.0000\n",
      "Epoch 00122: val_loss improved from 0.00076 to 0.00076, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.5958e-04 - accuracy: 1.0000 - val_loss: 7.5568e-04 - val_accuracy: 1.0000\n",
      "Epoch 123/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 7.5185e-04 - accuracy: 1.0000\n",
      "Epoch 00123: val_loss improved from 0.00076 to 0.00075, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.5179e-04 - accuracy: 1.0000 - val_loss: 7.4796e-04 - val_accuracy: 1.0000\n",
      "Epoch 124/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 7.4437e-04 - accuracy: 1.0000\n",
      "Epoch 00124: val_loss improved from 0.00075 to 0.00074, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 7.4414e-04 - accuracy: 1.0000 - val_loss: 7.4037e-04 - val_accuracy: 1.0000\n",
      "Epoch 125/150\n",
      "486/500 [============================>.] - ETA: 0s - loss: 7.3680e-04 - accuracy: 1.0000\n",
      "Epoch 00125: val_loss improved from 0.00074 to 0.00073, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 7.3665e-04 - accuracy: 1.0000 - val_loss: 7.3293e-04 - val_accuracy: 1.0000\n",
      "Epoch 126/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 7.2944e-04 - accuracy: 1.0000\n",
      "Epoch 00126: val_loss improved from 0.00073 to 0.00073, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.2930e-04 - accuracy: 1.0000 - val_loss: 7.2566e-04 - val_accuracy: 1.0000\n",
      "Epoch 127/150\n",
      "486/500 [============================>.] - ETA: 0s - loss: 7.2217e-04 - accuracy: 1.0000\n",
      "Epoch 00127: val_loss improved from 0.00073 to 0.00072, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.2208e-04 - accuracy: 1.0000 - val_loss: 7.1851e-04 - val_accuracy: 1.0000\n",
      "Epoch 128/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 7.1509e-04 - accuracy: 1.0000\n",
      "Epoch 00128: val_loss improved from 0.00072 to 0.00071, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.1500e-04 - accuracy: 1.0000 - val_loss: 7.1149e-04 - val_accuracy: 1.0000\n",
      "Epoch 129/150\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 7.0823e-04 - accuracy: 1.0000\n",
      "Epoch 00129: val_loss improved from 0.00071 to 0.00070, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.0806e-04 - accuracy: 1.0000 - val_loss: 7.0460e-04 - val_accuracy: 1.0000\n",
      "Epoch 130/150\n",
      "486/500 [============================>.] - ETA: 0s - loss: 7.0130e-04 - accuracy: 1.0000\n",
      "Epoch 00130: val_loss improved from 0.00070 to 0.00070, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.0124e-04 - accuracy: 1.0000 - val_loss: 6.9784e-04 - val_accuracy: 1.0000\n",
      "Epoch 131/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 6.9460e-04 - accuracy: 1.0000\n",
      "Epoch 00131: val_loss improved from 0.00070 to 0.00069, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 6.9454e-04 - accuracy: 1.0000 - val_loss: 6.9123e-04 - val_accuracy: 1.0000\n",
      "Epoch 132/150\n",
      "490/500 [============================>.] - ETA: 0s - loss: 6.8804e-04 - accuracy: 1.0000\n",
      "Epoch 00132: val_loss improved from 0.00069 to 0.00068, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 6.8796e-04 - accuracy: 1.0000 - val_loss: 6.8474e-04 - val_accuracy: 1.0000\n",
      "Epoch 133/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 6.8157e-04 - accuracy: 1.0000\n",
      "Epoch 00133: val_loss improved from 0.00068 to 0.00068, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 6.8150e-04 - accuracy: 1.0000 - val_loss: 6.7834e-04 - val_accuracy: 1.0000\n",
      "Epoch 134/150\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 6.7528e-04 - accuracy: 1.0000\n",
      "Epoch 00134: val_loss improved from 0.00068 to 0.00067, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 6.7516e-04 - accuracy: 1.0000 - val_loss: 6.7202e-04 - val_accuracy: 1.0000\n",
      "Epoch 135/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 6.6904e-04 - accuracy: 1.0000\n",
      "Epoch 00135: val_loss improved from 0.00067 to 0.00067, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 6.6892e-04 - accuracy: 1.0000 - val_loss: 6.6583e-04 - val_accuracy: 1.0000\n",
      "Epoch 136/150\n",
      "486/500 [============================>.] - ETA: 0s - loss: 6.6285e-04 - accuracy: 1.0000\n",
      "Epoch 00136: val_loss improved from 0.00067 to 0.00066, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 6.6280e-04 - accuracy: 1.0000 - val_loss: 6.5975e-04 - val_accuracy: 1.0000\n",
      "Epoch 137/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 6.5683e-04 - accuracy: 1.0000\n",
      "Epoch 00137: val_loss improved from 0.00066 to 0.00065, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 6.5678e-04 - accuracy: 1.0000 - val_loss: 6.5377e-04 - val_accuracy: 1.0000\n",
      "Epoch 138/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 6.5090e-04 - accuracy: 1.0000\n",
      "Epoch 00138: val_loss improved from 0.00065 to 0.00065, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 6.5086e-04 - accuracy: 1.0000 - val_loss: 6.4793e-04 - val_accuracy: 1.0000\n",
      "Epoch 139/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 6.4511e-04 - accuracy: 1.0000\n",
      "Epoch 00139: val_loss improved from 0.00065 to 0.00064, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 6.4505e-04 - accuracy: 1.0000 - val_loss: 6.4215e-04 - val_accuracy: 1.0000\n",
      "Epoch 140/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 6.3931e-04 - accuracy: 1.0000\n",
      "Epoch 00140: val_loss improved from 0.00064 to 0.00064, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 6.3933e-04 - accuracy: 1.0000 - val_loss: 6.3643e-04 - val_accuracy: 1.0000\n",
      "Epoch 141/150\n",
      "490/500 [============================>.] - ETA: 0s - loss: 6.3375e-04 - accuracy: 1.0000\n",
      "Epoch 00141: val_loss improved from 0.00064 to 0.00063, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 6.3370e-04 - accuracy: 1.0000 - val_loss: 6.3089e-04 - val_accuracy: 1.0000\n",
      "Epoch 142/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 6.2831e-04 - accuracy: 1.0000\n",
      "Epoch 00142: val_loss improved from 0.00063 to 0.00063, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 6.2818e-04 - accuracy: 1.0000 - val_loss: 6.2544e-04 - val_accuracy: 1.0000\n",
      "Epoch 143/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 6.2283e-04 - accuracy: 1.0000\n",
      "Epoch 00143: val_loss improved from 0.00063 to 0.00062, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 6.2274e-04 - accuracy: 1.0000 - val_loss: 6.2005e-04 - val_accuracy: 1.0000\n",
      "Epoch 144/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 6.1747e-04 - accuracy: 1.0000\n",
      "Epoch 00144: val_loss improved from 0.00062 to 0.00061, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 6.1739e-04 - accuracy: 1.0000 - val_loss: 6.1475e-04 - val_accuracy: 1.0000\n",
      "Epoch 145/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 6.1213e-04 - accuracy: 1.0000\n",
      "Epoch 00145: val_loss improved from 0.00061 to 0.00061, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 6.1213e-04 - accuracy: 1.0000 - val_loss: 6.0951e-04 - val_accuracy: 1.0000\n",
      "Epoch 146/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 6.0702e-04 - accuracy: 1.0000\n",
      "Epoch 00146: val_loss improved from 0.00061 to 0.00060, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 6.0695e-04 - accuracy: 1.0000 - val_loss: 6.0442e-04 - val_accuracy: 1.0000\n",
      "Epoch 147/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 6.0197e-04 - accuracy: 1.0000\n",
      "Epoch 00147: val_loss improved from 0.00060 to 0.00060, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 6.0186e-04 - accuracy: 1.0000 - val_loss: 5.9932e-04 - val_accuracy: 1.0000\n",
      "Epoch 148/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 5.9685e-04 - accuracy: 1.0000\n",
      "Epoch 00148: val_loss improved from 0.00060 to 0.00059, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 5.9685e-04 - accuracy: 1.0000 - val_loss: 5.9441e-04 - val_accuracy: 1.0000\n",
      "Epoch 149/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 5.9200e-04 - accuracy: 1.0000\n",
      "Epoch 00149: val_loss improved from 0.00059 to 0.00059, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 5.9191e-04 - accuracy: 1.0000 - val_loss: 5.8943e-04 - val_accuracy: 1.0000\n",
      "Epoch 150/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 5.8706e-04 - accuracy: 1.0000\n",
      "Epoch 00150: val_loss improved from 0.00059 to 0.00058, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 5.8705e-04 - accuracy: 1.0000 - val_loss: 5.8464e-04 - val_accuracy: 1.0000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "\"\\n# calculate the AAIs, with normal noise and 30 ADEs,\\n# each generated over at least 1,000 iteration of gradient descent\\n# and fill the stats dataframe\\nfc_stats = The_Mother_Code.generate_aai(list(range(10)), 'normal', (6,6),\\n                                           fc, 30, channel=False,\\n                                           max_itr=1000, target_loss=0,\\n                                           target_conf=1.1, stats=None)\\n\\n# plot the AAIs\\nThe_Mother_Code.plot_ten(fc_stats.aai.to_list(), 'Tiling DS AAI')\\n# and save them\\n# for each image\\nfor i in range(4):\\n    # set the figure frame\\n    fig = plt.figure()\\n    # set the size\\n    fig.set_size_inches(8, 8)\\n    # turn off the tickes\\n    plt.axis('off')\\n    # plot the image\\n    plt.imshow(fc_stats.aai.to_list()[i], cmap='Blues_r')\\n    # save it\\n    plt.savefig('Tilting_aai' + ' ' + str(i), dpi = 100)\\n\\n    # and close it\\n    plt.close(fig)\\n\\n# save the stats\\nfc_stats.to_pickle('fc.pkl')\\n# and display them\\nfc_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\\n             'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]\""
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# set a Fully Connected model (fc-)\n",
    "fc = Sequential()\n",
    "fc.add(layers.Flatten(input_shape=(6, 6)))\n",
    "fc.add(layers.Dense(units=36, activation='sigmoid'))\n",
    "fc.add(layers.Dense(units=200, activation='sigmoid'))\n",
    "fc.add(layers.Dense(units=50, activation='sigmoid'))\n",
    "fc.add(layers.Dense(units=4, activation='softmax'))\n",
    "fc.summary()\n",
    "\n",
    "# set a SGD optimizer with an lr of .01 (-s01)\n",
    "optimizer = tf.keras.optimizers.SGD(lr=.01)\n",
    "\n",
    "# compile the mode with sparse categorical cross entropy loss\n",
    "fc.compile(optimizer=optimizer,\n",
    "              loss='sparse_categorical_crossentropy',\n",
    "              metrics=['accuracy'])\n",
    "\n",
    "# save the weights when the loss hit a minimum with the validation set\n",
    "checkpointer = ModelCheckpoint(filepath='fc.hdf5', monitor='val_loss',\n",
    "                               verbose=1, save_best_only=True)\n",
    "\n",
    "# train the model with batch size of 64,\n",
    "# for 150 epochs, and using cross-validation\n",
    "# with 20% of the train set\n",
    "fc.fit(x=images_tiling, \n",
    "          y=labels,\n",
    "          batch_size=64,\n",
    "          epochs=150,\n",
    "          validation_split=0.2,\n",
    "          shuffle=True,\n",
    "          callbacks=[checkpointer])\n",
    "\n",
    "# load the weights corresponding to the smallest loss value\n",
    "fc.load_weights('fc.hdf5')\n",
    "\n",
    "\n",
    "# calculate the AAIs, with normal noise and 30 ADEs,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "fc_stats = adversarials.generate_aai(list(range(10)), 'normal', (6,6),\n",
    "                                           fc, 30, channel=False,\n",
    "                                           max_itr=1000, target_loss=0,\n",
    "                                           target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(fc_stats.aai.to_list(), 'Tiling DS AAI')\n",
    "# and save them\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(fc_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Tilting_aai' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "fc_stats.to_pickle('fc.pkl')\n",
    "# and display them\n",
    "fc_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "             'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Noise Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=4.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>loss</th>\n",
       "      <th>iter</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>success</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.008582</td>\n",
       "      <td>1000</td>\n",
       "      <td>0</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.006451</td>\n",
       "      <td>1000</td>\n",
       "      <td>1</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.007006</td>\n",
       "      <td>1000</td>\n",
       "      <td>2</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:04</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.007049</td>\n",
       "      <td>1000</td>\n",
       "      <td>3</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:04</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed      loss  iter prediction  confidence success  \\\n",
       "0            0  normal  0.008582  1000          0        0.99    True   \n",
       "1            1  normal  0.006451  1000          1        0.99    True   \n",
       "2            2  normal  0.007006  1000          2        0.99    True   \n",
       "3            3  normal  0.007049  1000          3        0.99    True   \n",
       "\n",
       "   duration  \n",
       "0  00:00:05  \n",
       "1  00:00:05  \n",
       "2  00:00:04  \n",
       "3  00:00:04  "
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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/+IXP2/Q/ZPkm998bND977vv4UH3H6s77xz2eau7B93/0H/6yqD7v+z04bP54F8dHnT/gR8Co/XVrw/7z2XHC5496P53HRr2f7MPffLmQfdPkpyyY9Dtjz/xpEH3B55ZXEkEAAAAgJIIAAAAACURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAADCQqrqwqu6oqv1VddUa599UVbdOvz5RVecOMSdsFkoiAAAAlq6qtiS5OslFSXYmuayqdq5a9rkkP9Ddr0zyriS7lzslbC5KIgAAAIZwXpL93X1ndz+S5Lokl8wu6O5PdPf905s3Jdmx5BlhU1ESAQAAMITtSe6euX1geuxIfjbJR450sqour6q9VbX34MGDGzQibC5KIgAAAIZQaxzrNRdW/WAmJdE7jnRn3b27u1e6e2Xbtm0bNCJsLluHHgAAAIBN6UCSM2Zu70hyz+pFVfXKJO9PclF3f3lJs8Gm5EoiAAAAhnBzkrOq6syqOj7JpUmun11QVS9J8uEkP9Xdnx1gRthUXEkEAADA0nX34aq6MskNSbYkuaa791XVFdPzu5L8UpJTkryvqpLkcHevDDUzPNMNVhL1mq80XZ6v3f+1Qfd//gueP+j+jz34wKD7J0kOfn7Q7R843nPLWk5/ybCv337Oc44bdP9Dhx4adP/nPOf4QfdPkte+4kWD7v8nX//moPuP1Zf23zXo/ie+eNj/bTj9jFMG3f/wo48Nun+SbN2y1lt3LM83vvnooPuP1TcOD/vY+Pojw/5zeXjg/V+08tpB90+SQ/ccGnT/45417L87PVXdvSfJnlXHds18/3NJfm7Zc8Fm5eVmAAAAACiJAAAAAFASAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAAECURAAAAAFESAQAAABAlEQAAAABREgEAAAAQJREAAAAAURIBAAAA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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set one with the required columns:\n",
    "#     'target label': (int) the target label\n",
    "#     'feed': (str) the input type used for generating the ADE \n",
    "#     'perturbation': (numpy.ndarray) adversarial perturbation,\n",
    "#                                     the ADE minus the initial feed\n",
    "#     'loss': (float) the loss value of the final ADE\n",
    "#     'iter': (int) the number of iterations of modifying\n",
    "#                   the feed before getting the final ADE\n",
    "#     'prediction': (int) the class index which the generated ADE is\n",
    "#                         tagged with by the network\n",
    "#     'confidence': (float) the confidence of the network in labeling\n",
    "#                           the ADE\n",
    "#     'success': (boolean) if the ADE is tagged with the desired\n",
    "#                          target label\n",
    "#     'duration': (HH:MM:SS) time spent for generating the ADE\n",
    "columns = ['target label', 'feed', 'perturbation', 'loss', 'iter',\n",
    "           'prediction', 'confidence', 'success', 'duration']\n",
    "nf_stats = pd.DataFrame(columns = columns)\n",
    "\n",
    "# for every class in the MNIST dataset\n",
    "for target_label in tqdm(range(4)):\n",
    "    # generate the feed with a numpy array of normal noise\n",
    "    feed = adversarials.generate_input('normal', (6,6))\n",
    "    # generate ADE and get the data\n",
    "    ade, loss, _, itr, success, duration = adversarials.generate_ade(feed,\n",
    "                                                                        fc,\n",
    "                                                                        target_label,\n",
    "                                                                        channel=False,\n",
    "                                                                        max_itr=1000,\n",
    "                                                                        target_loss=0,\n",
    "                                                                        target_conf=1.01)\n",
    "    \n",
    "    # get the network prediction and its confidence for that prediction\n",
    "    # of the ADE\n",
    "    pred, conf = adversarials.classify(ade, fc, channel=False)\n",
    "    \n",
    "    # calculate the perturbation by subtracting the initial feed\n",
    "    # from the final ADE\n",
    "    perturbation = ade - feed\n",
    "    \n",
    "    # fill a row in the stats dataframe with the obtained info\n",
    "    nf_stats.loc[target_label] = [target_label, 'normal', perturbation, loss, itr,\n",
    "                                  pred, conf, success, duration]\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(nf_stats.perturbation.to_list(), 'NoiseFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(nf_stats.perturbation.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('noise_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "nf_stats.to_pickle('NoiseFeed.pkl')\n",
    "# and display them\n",
    "nf_stats[['target label', 'feed', 'loss', 'iter', 'prediction',\n",
    "          'confidence', 'success', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Zero Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.42s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.14s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.00s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:04<00:00,  5.00s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.008526</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>0</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006869</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>1</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.007491</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>2</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.007236</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>3</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:04</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label   feed ades# trials  success  avg loss avg iter  avg conf  \\\n",
       "0            0  blank     1      1      1.0  0.008526     1000      0.99   \n",
       "1            1  blank     1      1      1.0  0.006869     1000      0.99   \n",
       "2            2  blank     1      1      1.0  0.007491     1000      0.99   \n",
       "3            3  blank     1      1      1.0  0.007236     1000      0.99   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0        0.99  00:00:05  \n",
       "1          1        0.99  00:00:05  \n",
       "2          2        0.99  00:00:05  \n",
       "3          3        0.99  00:00:04  "
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# calculate the AAIs, with blank noise and one single ADE,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "zf_stats = adversarials.generate_aai(list(range(4)), 'blank', (6,6),\n",
    "                                        fc, 1, channel=False,\n",
    "                                        max_itr=1000, target_loss=0,\n",
    "                                        target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the perturbations\n",
    "adversarials.plot_ten(zf_stats.aai.to_list(), 'ZeroFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(zf_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('zero_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "zf_stats.to_pickle('ZeroFeed.pkl')\n",
    "# and display them\n",
    "zf_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "          'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential_5\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "conv2d_2 (Conv2D)            (None, 4, 4, 128)         1280      \n",
      "_________________________________________________________________\n",
      "conv2d_3 (Conv2D)            (None, 2, 2, 256)         295168    \n",
      "_________________________________________________________________\n",
      "flatten_5 (Flatten)          (None, 1024)              0         \n",
      "_________________________________________________________________\n",
      "dense_19 (Dense)             (None, 512)               524800    \n",
      "_________________________________________________________________\n",
      "dense_20 (Dense)             (None, 256)               131328    \n",
      "_________________________________________________________________\n",
      "dense_21 (Dense)             (None, 10)                2570      \n",
      "=================================================================\n",
      "Total params: 955,146\n",
      "Trainable params: 955,146\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "Epoch 1/30\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0199 - accuracy: 0.9984\n",
      "Epoch 00001: val_loss improved from inf to 0.00000, saving model to cnn.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0196 - accuracy: 0.9985 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 2/30\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00002: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 3/30\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00003: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 4/30\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00004: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 5/30\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00005: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 6/30\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00006: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 7/30\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00007: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 8/30\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00008: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 9/30\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00009: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 10/30\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00010: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 11/30\n",
      "486/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00011: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 12/30\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00012: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 13/30\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00013: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 14/30\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00014: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 15/30\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00015: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 16/30\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00016: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 17/30\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00017: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 18/30\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00018: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 19/30\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00019: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 20/30\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00020: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 21/30\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00021: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 22/30\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00022: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 23/30\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00023: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 24/30\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00024: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 25/30\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00025: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 26/30\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00026: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 27/30\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00027: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 28/30\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00028: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 29/30\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00029: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 30/30\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00030: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [03:02<00:00,  6.07s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:58<00:00,  5.94s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:57<00:00,  5.93s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [03:06<00:00,  6.21s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.000097</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:03:02</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.00</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.48</td>\n",
       "      <td>00:02:58</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.000105</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:02:57</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>29</td>\n",
       "      <td>30</td>\n",
       "      <td>0.97</td>\n",
       "      <td>0.000193</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:03:06</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed ades# trials  success  avg loss avg iter avg conf  \\\n",
       "0            0  normal    30     30     1.00  0.000097     1000      1.0   \n",
       "1            1  normal     0     30     0.00      None     None     None   \n",
       "2            2  normal    30     30     1.00  0.000105     1000      1.0   \n",
       "3            3  normal    29     30     0.97  0.000193     1000      1.0   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0        1.00  00:03:02  \n",
       "1          0        0.48  00:02:58  \n",
       "2          2        1.00  00:02:57  \n",
       "3          3        1.00  00:03:06  "
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set a CNN model (cn1-)\n",
    "cnn = Sequential()\n",
    "cnn.add(layers.Conv2D(128, (3,3), input_shape=(6,6,1), activation = 'relu'))\n",
    "cnn.add(layers.Conv2D(256, (3,3), activation = 'relu'))\n",
    "cnn.add(layers.Flatten())\n",
    "cnn.add(layers.Dense(512, activation = 'relu'))\n",
    "cnn.add(layers.Dense(256, activation = 'relu'))\n",
    "cnn.add(layers.Dense(10, activation='softmax'))\n",
    "cnn.summary()\n",
    "\n",
    "\n",
    "# set a Adam optimizer with an lr of .001 (-a001)\n",
    "optimizer = tf.keras.optimizers.Adam(lr=.001)\n",
    "\n",
    "# compile the mode with sparse categorical cross entropy loss\n",
    "cnn.compile(optimizer=optimizer,\n",
    "              loss='sparse_categorical_crossentropy',\n",
    "              metrics=['accuracy'])\n",
    "\n",
    "# save the weights when the loss hit a minimum with the validation set\n",
    "checkpointer = ModelCheckpoint(filepath='cnn.hdf5', monitor='val_loss',\n",
    "                               verbose=1, save_best_only=True)\n",
    "\n",
    "# train the model with batch size of 64,\n",
    "# for 50 epochs, and using cross-validation\n",
    "# with 20% of the train set\n",
    "cnn.fit(x=np.expand_dims(images_tiling, axis=3), \n",
    "            y=labels,\n",
    "            batch_size=64,\n",
    "            epochs=30,\n",
    "            validation_split=0.2,\n",
    "            shuffle=True,\n",
    "            callbacks=[checkpointer])\n",
    "\n",
    "# load the weights corresponding to the smallest loss value\n",
    "cnn.load_weights('cnn.hdf5')\n",
    "\n",
    "\n",
    "# calculate the AAIs, with normal noise and 30 ADEs,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "cnn_stats = adversarials.generate_aai(list(range(4)), 'normal', (6,6),\n",
    "                                             cnn, 30, channel=True,\n",
    "                                             max_itr=1000, target_loss=0,\n",
    "                                             target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(cnn_stats.aai.to_list(), 'Tiling AAI')\n",
    "# and save them\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(cnn_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Tilting_aai' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "\n",
    "# save the stats\n",
    "cnn_stats.to_pickle('cnn.pkl')\n",
    "# and display them\n",
    "cnn_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "               'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Noise Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=4.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>loss</th>\n",
       "      <th>iter</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>success</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.000117</td>\n",
       "      <td>1000</td>\n",
       "      <td>0</td>\n",
       "      <td>1.00</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>16.118095</td>\n",
       "      <td>1000</td>\n",
       "      <td>0</td>\n",
       "      <td>0.95</td>\n",
       "      <td>False</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.000134</td>\n",
       "      <td>1000</td>\n",
       "      <td>2</td>\n",
       "      <td>1.00</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.000195</td>\n",
       "      <td>1000</td>\n",
       "      <td>3</td>\n",
       "      <td>1.00</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed       loss  iter prediction  confidence success  \\\n",
       "0            0  normal   0.000117  1000          0        1.00    True   \n",
       "1            1  normal  16.118095  1000          0        0.95   False   \n",
       "2            2  normal   0.000134  1000          2        1.00    True   \n",
       "3            3  normal   0.000195  1000          3        1.00    True   \n",
       "\n",
       "   duration  \n",
       "0  00:00:06  \n",
       "1  00:00:06  \n",
       "2  00:00:06  \n",
       "3  00:00:06  "
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set one with the required columns:\n",
    "#     'target label': (int) the target label\n",
    "#     'feed': (str) the input type used for generating the ADE \n",
    "#     'perturbation': (numpy.ndarray) adversarial perturbation,\n",
    "#                                     the ADE minus the initial feed\n",
    "#     'loss': (float) the loss value of the final ADE\n",
    "#     'iter': (int) the number of iterations of modifying\n",
    "#                   the feed before getting the final ADE\n",
    "#     'prediction': (int) the class index which the generated ADE is\n",
    "#                         tagged with by the network\n",
    "#     'confidence': (float) the confidence of the network in labeling\n",
    "#                           the ADE\n",
    "#     'success': (boolean) if the ADE is tagged with the desired\n",
    "#                          target label\n",
    "#     'duration': (HH:MM:SS) time spent for generating the ADE\n",
    "columns = ['target label', 'feed', 'perturbation', 'loss', 'iter',\n",
    "           'prediction', 'confidence', 'success', 'duration']\n",
    "nf_stats = pd.DataFrame(columns = columns)\n",
    "\n",
    "# for every class in the MNIST dataset\n",
    "for target_label in tqdm(range(4)):\n",
    "    # generate the feed with a numpy array of normal noise\n",
    "    feed = adversarials.generate_input('normal', (6,6))\n",
    "    # generate ADE and get the data\n",
    "    ade, loss, _, itr, success, duration = adversarials.generate_ade(feed,\n",
    "                                                                        cnn,\n",
    "                                                                        target_label,\n",
    "                                                                        channel=True,\n",
    "                                                                        max_itr=1000,\n",
    "                                                                        target_loss=0,\n",
    "                                                                        target_conf=1.01)\n",
    "    \n",
    "    # get the network prediction and its confidence for that prediction\n",
    "    # of the ADE\n",
    "    pred, conf = adversarials.classify(ade, cnn, channel=True)\n",
    "    \n",
    "    # calculate the perturbation by subtracting the initial feed\n",
    "    # from the final ADE\n",
    "    perturbation = ade - feed\n",
    "    \n",
    "    # fill a row in the stats dataframe with the obtained info\n",
    "    nf_stats.loc[target_label] = [target_label, 'normal', perturbation, loss, itr,\n",
    "                                  pred, conf, success, duration]\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(nf_stats.perturbation.to_list(), 'NoiseFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(nf_stats.perturbation.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('noise_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "nf_stats.to_pickle('NoiseFeed.pkl')\n",
    "# and display them\n",
    "nf_stats[['target label', 'feed', 'loss', 'iter', 'prediction',\n",
    "          'confidence', 'success', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Zero Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:06<00:00,  6.45s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.97s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.95s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.97s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000158</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000630</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000180</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000325</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label   feed ades# trials  success  avg loss avg iter  avg conf  \\\n",
       "0            0  blank     1      1      1.0  0.000158     1000       1.0   \n",
       "1            1  blank     1      1      1.0  0.000630     1000       1.0   \n",
       "2            2  blank     1      1      1.0  0.000180     1000       1.0   \n",
       "3            3  blank     1      1      1.0  0.000325     1000       1.0   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0         1.0  00:00:06  \n",
       "1          1         1.0  00:00:05  \n",
       "2          2         1.0  00:00:05  \n",
       "3          3         1.0  00:00:05  "
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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52D9uJIIAACAoVyb5PxnOX9BkrOmt8syeUc7YJ0oiQAAABhEd386yVeeZclFST7cEzclOXn6mljAOvDuZgAAAIzVtkzexe5p+6bHHli+sKouy+Rqoxx33HGvO/vssxcyIIzNLbfc8lB3bz2cz1USAQAAMFa1wrEVX1i3u3cl2ZUkS0tLvXv37vWcC0arqr5wuJ/r6WYAAACM1b4kZ8zc357k/oFmgSPeYFcSvf5XPjXo26qdesoxQ26fU47fMuj+e+57ZND9k+Sb3zww6P4HDjw16P53/NMfX+m3IoP7yV03D5rNbw3893LyccNm8+fOPePQi9bZXz7y6KD733r/44Puf/V/vWOU2XzTb/zpoNl87LEnhtw+3/zmk4Puf8IJw/63IUm2bNk06P6bNg37u8X/8K7vG2U2v/cX//2g2fzGN7415PZ5/LFvDLr/i049YdD9k2Tz5mGzMfT+N//j89Y7m9cnuaKqrkvyhiSPdPe3PdUMWBuebgYAAMAgquojSc5LclpV7UvyniRHJUl370xyQ5ILk+xJ8niSdwwzKWwMSiIAAAAG0d2XHOJ8J3nngsaBDc9rEgEAAACgJAIAAABASQQAAABAlEQAAAAAREkEAAAAQJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAREkEAAAAQJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAREkEAAAAQJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAREkEAAAAQJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAJNk81ManveiYobZOklz4vS8edP//avupg+7/vj+9Z9D9k+S2v/zyoPt/61tPDrr/WH31sScG3f+BB7426P7HH79l0P2/75LXDLp/knzvN04adP8tmx4YdP+xevTRgbP5xYcH3f/hLw37M+M7d7xs0P2TZNvpJw66/1Pdg+4/Vk88cWDQ/R/84kOD7v/EF/5i0P2f/O6/M+j+SXLMccP+f82ppx476P7AkcWVRAAAAAAoiQAAABhGVZ1fVXdV1Z6qumqF8ydV1e9X1eeq6vaqescQc8JGoSQCAABg4apqU5Krk1yQZEeSS6pqx7Jl70xyR3efk+S8JL9eVcO+PgAcwZREAAAADOHcJHu6e293P5HkuiQXLVvTSU6o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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# calculate the AAIs, with blank noise and one single ADE,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "zf_stats = adversarials.generate_aai(list(range(4)), 'blank', (6,6),\n",
    "                                        cnn, 1, channel=True,\n",
    "                                        max_itr=1000, target_loss=0,\n",
    "                                        target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the perturbations\n",
    "adversarials.plot_ten(zf_stats.aai.to_list(), 'ZeroFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(zf_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('zero_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "zf_stats.to_pickle('ZeroFeed.pkl')\n",
    "# and display them\n",
    "zf_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "          'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Overlapping Perturbations"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## FC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential_11\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "flatten_12 (Flatten)         (None, 36)                0         \n",
      "_________________________________________________________________\n",
      "dense_43 (Dense)             (None, 36)                1332      \n",
      "_________________________________________________________________\n",
      "dense_44 (Dense)             (None, 200)               7400      \n",
      "_________________________________________________________________\n",
      "dense_45 (Dense)             (None, 50)                10050     \n",
      "_________________________________________________________________\n",
      "dense_46 (Dense)             (None, 4)                 204       \n",
      "=================================================================\n",
      "Total params: 18,986\n",
      "Trainable params: 18,986\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "Epoch 1/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 1.3829 - accuracy: 0.2892\n",
      "Epoch 00001: val_loss improved from inf to 1.37616, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.3828 - accuracy: 0.2896 - val_loss: 1.3762 - val_accuracy: 0.2500\n",
      "Epoch 2/150\n",
      "472/500 [===========================>..] - ETA: 0s - loss: 1.3705 - accuracy: 0.3758\n",
      "Epoch 00002: val_loss improved from 1.37616 to 1.36358, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 1.3702 - accuracy: 0.3864 - val_loss: 1.3636 - val_accuracy: 0.5000\n",
      "Epoch 3/150\n",
      "467/500 [===========================>..] - ETA: 0s - loss: 1.3574 - accuracy: 0.5240\n",
      "Epoch 00003: val_loss improved from 1.36358 to 1.34838, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 1.3568 - accuracy: 0.5198 - val_loss: 1.3484 - val_accuracy: 0.5000\n",
      "Epoch 4/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 1.3387 - accuracy: 0.6635\n",
      "Epoch 00004: val_loss improved from 1.34838 to 1.32774, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 1.3381 - accuracy: 0.6636 - val_loss: 1.3277 - val_accuracy: 0.2500\n",
      "Epoch 5/150\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 1.3109 - accuracy: 0.8278\n",
      "Epoch 00005: val_loss improved from 1.32774 to 1.29087, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.3102 - accuracy: 0.8279 - val_loss: 1.2909 - val_accuracy: 1.0000\n",
      "Epoch 6/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 1.2638 - accuracy: 0.9223\n",
      "Epoch 00006: val_loss improved from 1.29087 to 1.23053, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 1.2637 - accuracy: 0.9215 - val_loss: 1.2305 - val_accuracy: 0.7500\n",
      "Epoch 7/150\n",
      "472/500 [===========================>..] - ETA: 0s - loss: 1.1843 - accuracy: 0.9449\n",
      "Epoch 00007: val_loss improved from 1.23053 to 1.11931, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 1.1809 - accuracy: 0.9480 - val_loss: 1.1193 - val_accuracy: 1.0000\n",
      "Epoch 8/150\n",
      "481/500 [===========================>..] - ETA: 0s - loss: 1.0354 - accuracy: 0.9990\n",
      "Epoch 00008: val_loss improved from 1.11931 to 0.92837, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 1.0314 - accuracy: 0.9990 - val_loss: 0.9284 - val_accuracy: 1.0000\n",
      "Epoch 9/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.8052 - accuracy: 0.9980\n",
      "Epoch 00009: val_loss improved from 0.92837 to 0.67565, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.8038 - accuracy: 0.9980 - val_loss: 0.6756 - val_accuracy: 1.0000\n",
      "Epoch 10/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.5580 - accuracy: 1.0000\n",
      "Epoch 00010: val_loss improved from 0.67565 to 0.44372, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.5557 - accuracy: 1.0000 - val_loss: 0.4437 - val_accuracy: 1.0000\n",
      "Epoch 11/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.3558 - accuracy: 1.0000\n",
      "Epoch 00011: val_loss improved from 0.44372 to 0.27481, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.3538 - accuracy: 1.0000 - val_loss: 0.2748 - val_accuracy: 1.0000\n",
      "Epoch 12/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.2176 - accuracy: 1.0000\n",
      "Epoch 00012: val_loss improved from 0.27481 to 0.16881, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.2173 - accuracy: 1.0000 - val_loss: 0.1688 - val_accuracy: 1.0000\n",
      "Epoch 13/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.1373 - accuracy: 1.0000\n",
      "Epoch 00013: val_loss improved from 0.16881 to 0.10818, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.1357 - accuracy: 1.0000 - val_loss: 0.1082 - val_accuracy: 1.0000\n",
      "Epoch 14/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0900 - accuracy: 1.0000\n",
      "Epoch 00014: val_loss improved from 0.10818 to 0.07407, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0896 - accuracy: 1.0000 - val_loss: 0.0741 - val_accuracy: 1.0000\n",
      "Epoch 15/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0633 - accuracy: 1.0000\n",
      "Epoch 00015: val_loss improved from 0.07407 to 0.05398, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0632 - accuracy: 1.0000 - val_loss: 0.0540 - val_accuracy: 1.0000\n",
      "Epoch 16/150\n",
      "475/500 [===========================>..] - ETA: 0s - loss: 0.0475 - accuracy: 1.0000\n",
      "Epoch 00016: val_loss improved from 0.05398 to 0.04141, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0473 - accuracy: 1.0000 - val_loss: 0.0414 - val_accuracy: 1.0000\n",
      "Epoch 17/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0371 - accuracy: 1.0000\n",
      "Epoch 00017: val_loss improved from 0.04141 to 0.03307, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0370 - accuracy: 1.0000 - val_loss: 0.0331 - val_accuracy: 1.0000\n",
      "Epoch 18/150\n",
      "470/500 [===========================>..] - ETA: 0s - loss: 0.0302 - accuracy: 1.0000\n",
      "Epoch 00018: val_loss improved from 0.03307 to 0.02726, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0300 - accuracy: 1.0000 - val_loss: 0.0273 - val_accuracy: 1.0000\n",
      "Epoch 19/150\n",
      "466/500 [==========================>...] - ETA: 0s - loss: 0.0252 - accuracy: 1.0000\n",
      "Epoch 00019: val_loss improved from 0.02726 to 0.02302, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0250 - accuracy: 1.0000 - val_loss: 0.0230 - val_accuracy: 1.0000\n",
      "Epoch 20/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0214 - accuracy: 1.0000\n",
      "Epoch 00020: val_loss improved from 0.02302 to 0.01982, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0214 - accuracy: 1.0000 - val_loss: 0.0198 - val_accuracy: 1.0000\n",
      "Epoch 21/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0185 - accuracy: 1.0000\n",
      "Epoch 00021: val_loss improved from 0.01982 to 0.01735, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0185 - accuracy: 1.0000 - val_loss: 0.0173 - val_accuracy: 1.0000\n",
      "Epoch 22/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 0.0164 - accuracy: 1.0000\n",
      "Epoch 00022: val_loss improved from 0.01735 to 0.01538, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0163 - accuracy: 1.0000 - val_loss: 0.0154 - val_accuracy: 1.0000\n",
      "Epoch 23/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0146 - accuracy: 1.0000\n",
      "Epoch 00023: val_loss improved from 0.01538 to 0.01378, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0146 - accuracy: 1.0000 - val_loss: 0.0138 - val_accuracy: 1.0000\n",
      "Epoch 24/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0131 - accuracy: 1.0000\n",
      "Epoch 00024: val_loss improved from 0.01378 to 0.01247, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0131 - accuracy: 1.0000 - val_loss: 0.0125 - val_accuracy: 1.0000\n",
      "Epoch 25/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0119 - accuracy: 1.0000\n",
      "Epoch 00025: val_loss improved from 0.01247 to 0.01137, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0119 - accuracy: 1.0000 - val_loss: 0.0114 - val_accuracy: 1.0000\n",
      "Epoch 26/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0109 - accuracy: 1.0000\n",
      "Epoch 00026: val_loss improved from 0.01137 to 0.01043, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0109 - accuracy: 1.0000 - val_loss: 0.0104 - val_accuracy: 1.0000\n",
      "Epoch 27/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0100 - accuracy: 1.0000\n",
      "Epoch 00027: val_loss improved from 0.01043 to 0.00963, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0100 - accuracy: 1.0000 - val_loss: 0.0096 - val_accuracy: 1.0000\n",
      "Epoch 28/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0093 - accuracy: 1.0000\n",
      "Epoch 00028: val_loss improved from 0.00963 to 0.00894, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0093 - accuracy: 1.0000 - val_loss: 0.0089 - val_accuracy: 1.0000\n",
      "Epoch 29/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0086 - accuracy: 1.0000\n",
      "Epoch 00029: val_loss improved from 0.00894 to 0.00833, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0086 - accuracy: 1.0000 - val_loss: 0.0083 - val_accuracy: 1.0000\n",
      "Epoch 30/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0081 - accuracy: 1.0000\n",
      "Epoch 00030: val_loss improved from 0.00833 to 0.00780, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0081 - accuracy: 1.0000 - val_loss: 0.0078 - val_accuracy: 1.0000\n",
      "Epoch 31/150\n",
      "470/500 [===========================>..] - ETA: 0s - loss: 0.0076 - accuracy: 1.0000\n",
      "Epoch 00031: val_loss improved from 0.00780 to 0.00733, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0076 - accuracy: 1.0000 - val_loss: 0.0073 - val_accuracy: 1.0000\n",
      "Epoch 32/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0071 - accuracy: 1.0000\n",
      "Epoch 00032: val_loss improved from 0.00733 to 0.00691, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0071 - accuracy: 1.0000 - val_loss: 0.0069 - val_accuracy: 1.0000\n",
      "Epoch 33/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0067 - accuracy: 1.0000\n",
      "Epoch 00033: val_loss improved from 0.00691 to 0.00653, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0067 - accuracy: 1.0000 - val_loss: 0.0065 - val_accuracy: 1.0000\n",
      "Epoch 34/150\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0064 - accuracy: 1.0000\n",
      "Epoch 00034: val_loss improved from 0.00653 to 0.00619, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0064 - accuracy: 1.0000 - val_loss: 0.0062 - val_accuracy: 1.0000\n",
      "Epoch 35/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 0.0060 - accuracy: 1.0000\n",
      "Epoch 00035: val_loss improved from 0.00619 to 0.00588, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0060 - accuracy: 1.0000 - val_loss: 0.0059 - val_accuracy: 1.0000\n",
      "Epoch 36/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0057 - accuracy: 1.0000\n",
      "Epoch 00036: val_loss improved from 0.00588 to 0.00560, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0057 - accuracy: 1.0000 - val_loss: 0.0056 - val_accuracy: 1.0000\n",
      "Epoch 37/150\n",
      "469/500 [===========================>..] - ETA: 0s - loss: 0.0055 - accuracy: 1.0000\n",
      "Epoch 00037: val_loss improved from 0.00560 to 0.00534, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0055 - accuracy: 1.0000 - val_loss: 0.0053 - val_accuracy: 1.0000\n",
      "Epoch 38/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0052 - accuracy: 1.0000\n",
      "Epoch 00038: val_loss improved from 0.00534 to 0.00511, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0052 - accuracy: 1.0000 - val_loss: 0.0051 - val_accuracy: 1.0000\n",
      "Epoch 39/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0050 - accuracy: 1.0000\n",
      "Epoch 00039: val_loss improved from 0.00511 to 0.00489, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0050 - accuracy: 1.0000 - val_loss: 0.0049 - val_accuracy: 1.0000\n",
      "Epoch 40/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0048 - accuracy: 1.0000\n",
      "Epoch 00040: val_loss improved from 0.00489 to 0.00469, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0048 - accuracy: 1.0000 - val_loss: 0.0047 - val_accuracy: 1.0000\n",
      "Epoch 41/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0046 - accuracy: 1.0000\n",
      "Epoch 00041: val_loss improved from 0.00469 to 0.00450, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0046 - accuracy: 1.0000 - val_loss: 0.0045 - val_accuracy: 1.0000\n",
      "Epoch 42/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0044 - accuracy: 1.0000\n",
      "Epoch 00042: val_loss improved from 0.00450 to 0.00433, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0044 - accuracy: 1.0000 - val_loss: 0.0043 - val_accuracy: 1.0000\n",
      "Epoch 43/150\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0043 - accuracy: 1.0000\n",
      "Epoch 00043: val_loss improved from 0.00433 to 0.00417, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0043 - accuracy: 1.0000 - val_loss: 0.0042 - val_accuracy: 1.0000\n",
      "Epoch 44/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 0.0041 - accuracy: 1.0000\n",
      "Epoch 00044: val_loss improved from 0.00417 to 0.00403, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0041 - accuracy: 1.0000 - val_loss: 0.0040 - val_accuracy: 1.0000\n",
      "Epoch 45/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0040 - accuracy: 1.0000\n",
      "Epoch 00045: val_loss improved from 0.00403 to 0.00389, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0040 - accuracy: 1.0000 - val_loss: 0.0039 - val_accuracy: 1.0000\n",
      "Epoch 46/150\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 0.0038 - accuracy: 1.0000\n",
      "Epoch 00046: val_loss improved from 0.00389 to 0.00376, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0038 - accuracy: 1.0000 - val_loss: 0.0038 - val_accuracy: 1.0000\n",
      "Epoch 47/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0037 - accuracy: 1.0000\n",
      "Epoch 00047: val_loss improved from 0.00376 to 0.00363, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0037 - accuracy: 1.0000 - val_loss: 0.0036 - val_accuracy: 1.0000\n",
      "Epoch 48/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0036 - accuracy: 1.0000\n",
      "Epoch 00048: val_loss improved from 0.00363 to 0.00352, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0036 - accuracy: 1.0000 - val_loss: 0.0035 - val_accuracy: 1.0000\n",
      "Epoch 49/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 0.0035 - accuracy: 1.0000\n",
      "Epoch 00049: val_loss improved from 0.00352 to 0.00341, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0035 - accuracy: 1.0000 - val_loss: 0.0034 - val_accuracy: 1.0000\n",
      "Epoch 50/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0034 - accuracy: 1.0000\n",
      "Epoch 00050: val_loss improved from 0.00341 to 0.00331, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0034 - accuracy: 1.0000 - val_loss: 0.0033 - val_accuracy: 1.0000\n",
      "Epoch 51/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0033 - accuracy: 1.0000\n",
      "Epoch 00051: val_loss improved from 0.00331 to 0.00321, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0033 - accuracy: 1.0000 - val_loss: 0.0032 - val_accuracy: 1.0000\n",
      "Epoch 52/150\n",
      "481/500 [===========================>..] - ETA: 0s - loss: 0.0032 - accuracy: 1.0000\n",
      "Epoch 00052: val_loss improved from 0.00321 to 0.00312, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0032 - accuracy: 1.0000 - val_loss: 0.0031 - val_accuracy: 1.0000\n",
      "Epoch 53/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0031 - accuracy: 1.0000\n",
      "Epoch 00053: val_loss improved from 0.00312 to 0.00304, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0031 - accuracy: 1.0000 - val_loss: 0.0030 - val_accuracy: 1.0000\n",
      "Epoch 54/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0030 - accuracy: 1.0000\n",
      "Epoch 00054: val_loss improved from 0.00304 to 0.00295, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0030 - accuracy: 1.0000 - val_loss: 0.0030 - val_accuracy: 1.0000\n",
      "Epoch 55/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0029 - accuracy: 1.0000\n",
      "Epoch 00055: val_loss improved from 0.00295 to 0.00288, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0029 - accuracy: 1.0000 - val_loss: 0.0029 - val_accuracy: 1.0000\n",
      "Epoch 56/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0028 - accuracy: 1.0000\n",
      "Epoch 00056: val_loss improved from 0.00288 to 0.00280, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0028 - accuracy: 1.0000 - val_loss: 0.0028 - val_accuracy: 1.0000\n",
      "Epoch 57/150\n",
      "481/500 [===========================>..] - ETA: 0s - loss: 0.0028 - accuracy: 1.0000\n",
      "Epoch 00057: val_loss improved from 0.00280 to 0.00273, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0028 - accuracy: 1.0000 - val_loss: 0.0027 - val_accuracy: 1.0000\n",
      "Epoch 58/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.0027 - accuracy: 1.0000\n",
      "Epoch 00058: val_loss improved from 0.00273 to 0.00266, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0027 - accuracy: 1.0000 - val_loss: 0.0027 - val_accuracy: 1.0000\n",
      "Epoch 59/150\n",
      "465/500 [==========================>...] - ETA: 0s - loss: 0.0026 - accuracy: 1.0000\n",
      "Epoch 00059: val_loss improved from 0.00266 to 0.00260, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0026 - accuracy: 1.0000 - val_loss: 0.0026 - val_accuracy: 1.0000\n",
      "Epoch 60/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0026 - accuracy: 1.0000\n",
      "Epoch 00060: val_loss improved from 0.00260 to 0.00254, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0026 - accuracy: 1.0000 - val_loss: 0.0025 - val_accuracy: 1.0000\n",
      "Epoch 61/150\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0025 - accuracy: 1.0000\n",
      "Epoch 00061: val_loss improved from 0.00254 to 0.00248, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0025 - accuracy: 1.0000 - val_loss: 0.0025 - val_accuracy: 1.0000\n",
      "Epoch 62/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0025 - accuracy: 1.0000\n",
      "Epoch 00062: val_loss improved from 0.00248 to 0.00243, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0025 - accuracy: 1.0000 - val_loss: 0.0024 - val_accuracy: 1.0000\n",
      "Epoch 63/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0024 - accuracy: 1.0000\n",
      "Epoch 00063: val_loss improved from 0.00243 to 0.00237, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0024 - accuracy: 1.0000 - val_loss: 0.0024 - val_accuracy: 1.0000\n",
      "Epoch 64/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0023 - accuracy: 1.0000\n",
      "Epoch 00064: val_loss improved from 0.00237 to 0.00232, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0023 - accuracy: 1.0000 - val_loss: 0.0023 - val_accuracy: 1.0000\n",
      "Epoch 65/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0023 - accuracy: 1.0000\n",
      "Epoch 00065: val_loss improved from 0.00232 to 0.00227, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0023 - accuracy: 1.0000 - val_loss: 0.0023 - val_accuracy: 1.0000\n",
      "Epoch 66/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0022 - accuracy: 1.0000\n",
      "Epoch 00066: val_loss improved from 0.00227 to 0.00222, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0022 - accuracy: 1.0000 - val_loss: 0.0022 - val_accuracy: 1.0000\n",
      "Epoch 67/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0022 - accuracy: 1.0000\n",
      "Epoch 00067: val_loss improved from 0.00222 to 0.00218, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0022 - accuracy: 1.0000 - val_loss: 0.0022 - val_accuracy: 1.0000\n",
      "Epoch 68/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0022 - accuracy: 1.0000\n",
      "Epoch 00068: val_loss improved from 0.00218 to 0.00213, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0022 - accuracy: 1.0000 - val_loss: 0.0021 - val_accuracy: 1.0000\n",
      "Epoch 69/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0021 - accuracy: 1.0000\n",
      "Epoch 00069: val_loss improved from 0.00213 to 0.00209, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0021 - accuracy: 1.0000 - val_loss: 0.0021 - val_accuracy: 1.0000\n",
      "Epoch 70/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.0021 - accuracy: 1.0000\n",
      "Epoch 00070: val_loss improved from 0.00209 to 0.00205, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0021 - accuracy: 1.0000 - val_loss: 0.0021 - val_accuracy: 1.0000\n",
      "Epoch 71/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0020 - accuracy: 1.0000\n",
      "Epoch 00071: val_loss improved from 0.00205 to 0.00201, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0020 - accuracy: 1.0000 - val_loss: 0.0020 - val_accuracy: 1.0000\n",
      "Epoch 72/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.0020 - accuracy: 1.0000\n",
      "Epoch 00072: val_loss improved from 0.00201 to 0.00198, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0020 - accuracy: 1.0000 - val_loss: 0.0020 - val_accuracy: 1.0000\n",
      "Epoch 73/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0020 - accuracy: 1.0000\n",
      "Epoch 00073: val_loss improved from 0.00198 to 0.00194, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0020 - accuracy: 1.0000 - val_loss: 0.0019 - val_accuracy: 1.0000\n",
      "Epoch 74/150\n",
      "465/500 [==========================>...] - ETA: 0s - loss: 0.0019 - accuracy: 1.0000\n",
      "Epoch 00074: val_loss improved from 0.00194 to 0.00190, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0019 - accuracy: 1.0000 - val_loss: 0.0019 - val_accuracy: 1.0000\n",
      "Epoch 75/150\n",
      "475/500 [===========================>..] - ETA: 0s - loss: 0.0019 - accuracy: 1.0000\n",
      "Epoch 00075: val_loss improved from 0.00190 to 0.00187, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0019 - accuracy: 1.0000 - val_loss: 0.0019 - val_accuracy: 1.0000\n",
      "Epoch 76/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0019 - accuracy: 1.0000\n",
      "Epoch 00076: val_loss improved from 0.00187 to 0.00184, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0019 - accuracy: 1.0000 - val_loss: 0.0018 - val_accuracy: 1.0000\n",
      "Epoch 77/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0018 - accuracy: 1.0000\n",
      "Epoch 00077: val_loss improved from 0.00184 to 0.00181, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0018 - accuracy: 1.0000 - val_loss: 0.0018 - val_accuracy: 1.0000\n",
      "Epoch 78/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0018 - accuracy: 1.0000\n",
      "Epoch 00078: val_loss improved from 0.00181 to 0.00178, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0018 - accuracy: 1.0000 - val_loss: 0.0018 - val_accuracy: 1.0000\n",
      "Epoch 79/150\n",
      "479/500 [===========================>..] - ETA: 0s - loss: 0.0018 - accuracy: 1.0000\n",
      "Epoch 00079: val_loss improved from 0.00178 to 0.00175, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0018 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 80/150\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0017 - accuracy: 1.0000\n",
      "Epoch 00080: val_loss improved from 0.00175 to 0.00172, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 0.0017 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 81/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0017 - accuracy: 1.0000\n",
      "Epoch 00081: val_loss improved from 0.00172 to 0.00169, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0017 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 82/150\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0017 - accuracy: 1.0000\n",
      "Epoch 00082: val_loss improved from 0.00169 to 0.00166, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 0.0017 - accuracy: 1.0000 - val_loss: 0.0017 - val_accuracy: 1.0000\n",
      "Epoch 83/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00083: val_loss improved from 0.00166 to 0.00164, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 84/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00084: val_loss improved from 0.00164 to 0.00161, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 85/150\n",
      "479/500 [===========================>..] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00085: val_loss improved from 0.00161 to 0.00159, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 86/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00086: val_loss improved from 0.00159 to 0.00156, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0016 - val_accuracy: 1.0000\n",
      "Epoch 87/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0016 - accuracy: 1.0000\n",
      "Epoch 00087: val_loss improved from 0.00156 to 0.00154, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0016 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 88/150\n",
      "472/500 [===========================>..] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00088: val_loss improved from 0.00154 to 0.00152, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 89/150\n",
      "465/500 [==========================>...] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00089: val_loss improved from 0.00152 to 0.00149, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 90/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00090: val_loss improved from 0.00149 to 0.00147, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 91/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0015 - accuracy: 1.0000\n",
      "Epoch 00091: val_loss improved from 0.00147 to 0.00145, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0015 - accuracy: 1.0000 - val_loss: 0.0015 - val_accuracy: 1.0000\n",
      "Epoch 92/150\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00092: val_loss improved from 0.00145 to 0.00143, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 93/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00093: val_loss improved from 0.00143 to 0.00141, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 94/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00094: val_loss improved from 0.00141 to 0.00139, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 95/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00095: val_loss improved from 0.00139 to 0.00137, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 96/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 0.0014 - accuracy: 1.0000\n",
      "Epoch 00096: val_loss improved from 0.00137 to 0.00136, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0014 - accuracy: 1.0000 - val_loss: 0.0014 - val_accuracy: 1.0000\n",
      "Epoch 97/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00097: val_loss improved from 0.00136 to 0.00134, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 98/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00098: val_loss improved from 0.00134 to 0.00132, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 99/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00099: val_loss improved from 0.00132 to 0.00130, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 100/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00100: val_loss improved from 0.00130 to 0.00129, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 101/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00101: val_loss improved from 0.00129 to 0.00127, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 102/150\n",
      "467/500 [===========================>..] - ETA: 0s - loss: 0.0013 - accuracy: 1.0000\n",
      "Epoch 00102: val_loss improved from 0.00127 to 0.00126, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0013 - accuracy: 1.0000 - val_loss: 0.0013 - val_accuracy: 1.0000\n",
      "Epoch 103/150\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00103: val_loss improved from 0.00126 to 0.00124, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 104/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00104: val_loss improved from 0.00124 to 0.00123, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 105/150\n",
      "479/500 [===========================>..] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00105: val_loss improved from 0.00123 to 0.00121, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 106/150\n",
      "479/500 [===========================>..] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00106: val_loss improved from 0.00121 to 0.00120, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 107/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00107: val_loss improved from 0.00120 to 0.00118, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 108/150\n",
      "472/500 [===========================>..] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00108: val_loss improved from 0.00118 to 0.00117, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 109/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0012 - accuracy: 1.0000\n",
      "Epoch 00109: val_loss improved from 0.00117 to 0.00116, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0012 - accuracy: 1.0000 - val_loss: 0.0012 - val_accuracy: 1.0000\n",
      "Epoch 110/150\n",
      "466/500 [==========================>...] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00110: val_loss improved from 0.00116 to 0.00114, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 111/150\n",
      "467/500 [===========================>..] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00111: val_loss improved from 0.00114 to 0.00113, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 112/150\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00112: val_loss improved from 0.00113 to 0.00112, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 113/150\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00113: val_loss improved from 0.00112 to 0.00110, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 114/150\n",
      "472/500 [===========================>..] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00114: val_loss improved from 0.00110 to 0.00109, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 115/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00115: val_loss improved from 0.00109 to 0.00108, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 116/150\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00116: val_loss improved from 0.00108 to 0.00107, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 117/150\n",
      "469/500 [===========================>..] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00117: val_loss improved from 0.00107 to 0.00106, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0011 - val_accuracy: 1.0000\n",
      "Epoch 118/150\n",
      "484/500 [============================>.] - ETA: 0s - loss: 0.0011 - accuracy: 1.0000\n",
      "Epoch 00118: val_loss improved from 0.00106 to 0.00105, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0011 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 119/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00119: val_loss improved from 0.00105 to 0.00104, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 120/150\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00120: val_loss improved from 0.00104 to 0.00103, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 121/150\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00121: val_loss improved from 0.00103 to 0.00102, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 122/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00122: val_loss improved from 0.00102 to 0.00100, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 0.0010 - accuracy: 1.0000 - val_loss: 0.0010 - val_accuracy: 1.0000\n",
      "Epoch 123/150\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0010 - accuracy: 1.0000\n",
      "Epoch 00123: val_loss improved from 0.00100 to 0.00099, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.9992e-04 - accuracy: 1.0000 - val_loss: 9.9493e-04 - val_accuracy: 1.0000\n",
      "Epoch 124/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 9.9031e-04 - accuracy: 1.0000\n",
      "Epoch 00124: val_loss improved from 0.00099 to 0.00099, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 9.9000e-04 - accuracy: 1.0000 - val_loss: 9.8508e-04 - val_accuracy: 1.0000\n",
      "Epoch 125/150\n",
      "477/500 [===========================>..] - ETA: 0s - loss: 9.8048e-04 - accuracy: 1.0000\n",
      "Epoch 00125: val_loss improved from 0.00099 to 0.00098, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.8027e-04 - accuracy: 1.0000 - val_loss: 9.7546e-04 - val_accuracy: 1.0000\n",
      "Epoch 126/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 9.7079e-04 - accuracy: 1.0000\n",
      "Epoch 00126: val_loss improved from 0.00098 to 0.00097, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 9.7072e-04 - accuracy: 1.0000 - val_loss: 9.6602e-04 - val_accuracy: 1.0000\n",
      "Epoch 127/150\n",
      "492/500 [============================>.] - ETA: 0s - loss: 9.6134e-04 - accuracy: 1.0000\n",
      "Epoch 00127: val_loss improved from 0.00097 to 0.00096, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.6133e-04 - accuracy: 1.0000 - val_loss: 9.5670e-04 - val_accuracy: 1.0000\n",
      "Epoch 128/150\n",
      "484/500 [============================>.] - ETA: 0s - loss: 9.5231e-04 - accuracy: 1.0000\n",
      "Epoch 00128: val_loss improved from 0.00096 to 0.00095, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 9.5213e-04 - accuracy: 1.0000 - val_loss: 9.4759e-04 - val_accuracy: 1.0000\n",
      "Epoch 129/150\n",
      "478/500 [===========================>..] - ETA: 0s - loss: 9.4329e-04 - accuracy: 1.0000\n",
      "Epoch 00129: val_loss improved from 0.00095 to 0.00094, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.4310e-04 - accuracy: 1.0000 - val_loss: 9.3863e-04 - val_accuracy: 1.0000\n",
      "Epoch 130/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 9.3457e-04 - accuracy: 1.0000\n",
      "Epoch 00130: val_loss improved from 0.00094 to 0.00093, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.3424e-04 - accuracy: 1.0000 - val_loss: 9.2982e-04 - val_accuracy: 1.0000\n",
      "Epoch 131/150\n",
      "476/500 [===========================>..] - ETA: 0s - loss: 9.2574e-04 - accuracy: 1.0000\n",
      "Epoch 00131: val_loss improved from 0.00093 to 0.00092, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.2550e-04 - accuracy: 1.0000 - val_loss: 9.2118e-04 - val_accuracy: 1.0000\n",
      "Epoch 132/150\n",
      "468/500 [===========================>..] - ETA: 0s - loss: 9.1719e-04 - accuracy: 1.0000\n",
      "Epoch 00132: val_loss improved from 0.00092 to 0.00091, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 9.1694e-04 - accuracy: 1.0000 - val_loss: 9.1270e-04 - val_accuracy: 1.0000\n",
      "Epoch 133/150\n",
      "498/500 [============================>.] - ETA: 0s - loss: 9.0854e-04 - accuracy: 1.0000\n",
      "Epoch 00133: val_loss improved from 0.00091 to 0.00090, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 9.0852e-04 - accuracy: 1.0000 - val_loss: 9.0439e-04 - val_accuracy: 1.0000\n",
      "Epoch 134/150\n",
      "495/500 [============================>.] - ETA: 0s - loss: 9.0034e-04 - accuracy: 1.0000\n",
      "Epoch 00134: val_loss improved from 0.00090 to 0.00090, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 9.0026e-04 - accuracy: 1.0000 - val_loss: 8.9617e-04 - val_accuracy: 1.0000\n",
      "Epoch 135/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 8.9216e-04 - accuracy: 1.0000\n",
      "Epoch 00135: val_loss improved from 0.00090 to 0.00089, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 8.9216e-04 - accuracy: 1.0000 - val_loss: 8.8813e-04 - val_accuracy: 1.0000\n",
      "Epoch 136/150\n",
      "466/500 [==========================>...] - ETA: 0s - loss: 8.8435e-04 - accuracy: 1.0000\n",
      "Epoch 00136: val_loss improved from 0.00089 to 0.00088, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.8418e-04 - accuracy: 1.0000 - val_loss: 8.8027e-04 - val_accuracy: 1.0000\n",
      "Epoch 137/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 8.7639e-04 - accuracy: 1.0000\n",
      "Epoch 00137: val_loss improved from 0.00088 to 0.00087, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.7635e-04 - accuracy: 1.0000 - val_loss: 8.7250e-04 - val_accuracy: 1.0000\n",
      "Epoch 138/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 8.6892e-04 - accuracy: 1.0000\n",
      "Epoch 00138: val_loss improved from 0.00087 to 0.00086, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 8.6863e-04 - accuracy: 1.0000 - val_loss: 8.6479e-04 - val_accuracy: 1.0000\n",
      "Epoch 139/150\n",
      "479/500 [===========================>..] - ETA: 0s - loss: 8.6115e-04 - accuracy: 1.0000\n",
      "Epoch 00139: val_loss improved from 0.00086 to 0.00086, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 8.6105e-04 - accuracy: 1.0000 - val_loss: 8.5728e-04 - val_accuracy: 1.0000\n",
      "Epoch 140/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 8.5371e-04 - accuracy: 1.0000\n",
      "Epoch 00140: val_loss improved from 0.00086 to 0.00085, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 3ms/step - loss: 8.5360e-04 - accuracy: 1.0000 - val_loss: 8.4990e-04 - val_accuracy: 1.0000\n",
      "Epoch 141/150\n",
      "488/500 [============================>.] - ETA: 0s - loss: 8.4638e-04 - accuracy: 1.0000\n",
      "Epoch 00141: val_loss improved from 0.00085 to 0.00084, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.4627e-04 - accuracy: 1.0000 - val_loss: 8.4266e-04 - val_accuracy: 1.0000\n",
      "Epoch 142/150\n",
      "471/500 [===========================>..] - ETA: 0s - loss: 8.3926e-04 - accuracy: 1.0000\n",
      "Epoch 00142: val_loss improved from 0.00084 to 0.00084, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 8.3907e-04 - accuracy: 1.0000 - val_loss: 8.3549e-04 - val_accuracy: 1.0000\n",
      "Epoch 143/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 8.3202e-04 - accuracy: 1.0000\n",
      "Epoch 00143: val_loss improved from 0.00084 to 0.00083, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 8.3198e-04 - accuracy: 1.0000 - val_loss: 8.2852e-04 - val_accuracy: 1.0000\n",
      "Epoch 144/150\n",
      "465/500 [==========================>...] - ETA: 0s - loss: 8.2530e-04 - accuracy: 1.0000\n",
      "Epoch 00144: val_loss improved from 0.00083 to 0.00082, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 8.2501e-04 - accuracy: 1.0000 - val_loss: 8.2158e-04 - val_accuracy: 1.0000\n",
      "Epoch 145/150\n",
      "496/500 [============================>.] - ETA: 0s - loss: 8.1817e-04 - accuracy: 1.0000\n",
      "Epoch 00145: val_loss improved from 0.00082 to 0.00081, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.1813e-04 - accuracy: 1.0000 - val_loss: 8.1470e-04 - val_accuracy: 1.0000\n",
      "Epoch 146/150\n",
      "499/500 [============================>.] - ETA: 0s - loss: 8.1139e-04 - accuracy: 1.0000\n",
      "Epoch 00146: val_loss improved from 0.00081 to 0.00081, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 8.1137e-04 - accuracy: 1.0000 - val_loss: 8.0803e-04 - val_accuracy: 1.0000\n",
      "Epoch 147/150\n",
      "474/500 [===========================>..] - ETA: 0s - loss: 8.0489e-04 - accuracy: 1.0000\n",
      "Epoch 00147: val_loss improved from 0.00081 to 0.00080, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 8.0472e-04 - accuracy: 1.0000 - val_loss: 8.0139e-04 - val_accuracy: 1.0000\n",
      "Epoch 148/150\n",
      "473/500 [===========================>..] - ETA: 0s - loss: 7.9837e-04 - accuracy: 1.0000\n",
      "Epoch 00148: val_loss improved from 0.00080 to 0.00079, saving model to fc.hdf5\n",
      "500/500 [==============================] - 1s 2ms/step - loss: 7.9818e-04 - accuracy: 1.0000 - val_loss: 7.9490e-04 - val_accuracy: 1.0000\n",
      "Epoch 149/150\n",
      "493/500 [============================>.] - ETA: 0s - loss: 7.9180e-04 - accuracy: 1.0000\n",
      "Epoch 00149: val_loss improved from 0.00079 to 0.00079, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 7.9174e-04 - accuracy: 1.0000 - val_loss: 7.8850e-04 - val_accuracy: 1.0000\n",
      "Epoch 150/150\n",
      "497/500 [============================>.] - ETA: 0s - loss: 7.8539e-04 - accuracy: 1.0000\n",
      "Epoch 00150: val_loss improved from 0.00079 to 0.00078, saving model to fc.hdf5\n",
      "500/500 [==============================] - 2s 5ms/step - loss: 7.8540e-04 - accuracy: 1.0000 - val_loss: 7.8224e-04 - val_accuracy: 1.0000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:31<00:00,  5.06s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:32<00:00,  5.10s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:33<00:00,  5.11s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:34<00:00,  5.14s/it]\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 30/30 [00:00<00:00, 104.01it/s]\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 30/30 [00:00<00:00, 100.48it/s]\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 30/30 [00:00<00:00, 102.71it/s]\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 30/30 [00:00<00:00, 100.61it/s]\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 30/30 [00:00<00:00, 102.77it/s]\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 30/30 [00:00<00:00, 104.19it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.00706</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>0</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:02:31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006367</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>1</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:02:32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006942</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>2</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:02:33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.00616</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>3</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:02:34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.0</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.45</td>\n",
       "      <td>00:00:00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.0</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.45</td>\n",
       "      <td>00:00:00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>6</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.0</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.45</td>\n",
       "      <td>00:00:00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.0</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.45</td>\n",
       "      <td>00:00:00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>8</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.0</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.45</td>\n",
       "      <td>00:00:00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>9</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.0</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>0</td>\n",
       "      <td>0.45</td>\n",
       "      <td>00:00:00</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed ades# trials  success  avg loss avg iter avg conf  \\\n",
       "0            0  normal    30     30      1.0   0.00706     1000     0.99   \n",
       "1            1  normal    30     30      1.0  0.006367     1000     0.99   \n",
       "2            2  normal    30     30      1.0  0.006942     1000     0.99   \n",
       "3            3  normal    30     30      1.0   0.00616     1000     0.99   \n",
       "4            4  normal     0     30      0.0      None     None     None   \n",
       "5            5  normal     0     30      0.0      None     None     None   \n",
       "6            6  normal     0     30      0.0      None     None     None   \n",
       "7            7  normal     0     30      0.0      None     None     None   \n",
       "8            8  normal     0     30      0.0      None     None     None   \n",
       "9            9  normal     0     30      0.0      None     None     None   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0        1.00  00:02:31  \n",
       "1          1        1.00  00:02:32  \n",
       "2          2        1.00  00:02:33  \n",
       "3          3        1.00  00:02:34  \n",
       "4          0        0.45  00:00:00  \n",
       "5          0        0.45  00:00:00  \n",
       "6          0        0.45  00:00:00  \n",
       "7          0        0.45  00:00:00  \n",
       "8          0        0.45  00:00:00  \n",
       "9          0        0.45  00:00:00  "
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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OGrW+rvvuvOs9ZNk3z12mbX+C8744qz1//CpR9esG7CC1/7dN2btzetmvmLyzH+5YNb6h91l71nrJ8kDD95n1voXX3mzPz6wrl76qCNb9uZT3/K5Wbvjnned99j83Ve9a9b6+9/76FnrJ8mln/v7Weuf8Jz/Mmv9D/7XB7fszae97fMb+lr/PXeb97aUB++/+6z1k+TfL7l61vpXXjPvv5vvPvWYlr25xzEv2NC9CVd9/g3L9qYzagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJjatNvHIO++5XtuxrBuGYdb6V197w6z1d900f472vcuunrX+kXfaY9b6Xf36r50+a/297nPsrPV/cPYnZq3/k//zhbPWT5J/v+SaWetfcPm89bu69Ac/nLX+P33j4lnr73rQEbPWv/T8C2etnyQ7H36/WetfdsW8/2539QdPvf+s9a+9bt6fKffafdUf+W93J//hP8xaP0nud8h+s9bfqXabtT6wfZk/CQAAAAAgiaAGAAAAoA1BDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANLFptYmPPfLO67Udy3r1x74+a/0bfmyYtf681Ud77LrzrPWvvPb6Wet3tfs97z9r/R+c87VZ6+9234fMWv+FDz9i1vpJctUP5+2NffbYZdb6XX3r25fNWv9hDzhw1vo/vOT7s9bP+f82b/0k19/l8Fnr77zzj8xav6sLL79m1vp33GfXWetvvvq6Weuf9dYzZq2fJGftuse8G7DTvD9Tv/KxL521PrA2zqgBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJrYtNrEs7936TptxvI+8Kb3z1v/jLvPWj+bVv141sVjHnfMrPUPPGDPWet3dfUll867AQfcbdby13z/wlnrX3DZNbPWT5Kdd6pZ6++zxy6z1u/q4HvsN2v9Vz/uPrPWf+6x95i1fgf/44NfmbX+nffdfdb6Xd15391mrf/1CzbPWn//vXadtX72vsO89ZPsfMBdZq1//df+adb6wPbFGTUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmNq028ZyLr1mv7VjWTnc7fNb6N/zbZ2etn8PuP2/9JIffZe9Z6x+8366z1u/qMU948Kz1j7zrvMfFV867fNb6115/w6z1k2T3XXeZtf73N/9w1voH7e+7YTlzH5sPPPyAWetfePm8P7ckyS47z/s7sIs3z/8edPTGT54za/1/OOfSWevvvfuqP/Lf/i6/cN76Sa6/4fp5N+DQ+81bH9iuOKMGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhi02oTz7v06vXajpb2esBPzFp/06ZVP551cYc95t2Gj/7r92et/ysnHDFr/ZUcdIc9Z61/7kVXzlr/vAs2z1r//V8+f9b6SXLe5T+ctf5lV147a/23Pv1+s9Zfyb577DJr/Qsvv2ZD179k5uMySS66eN7vx0c+4MBZ63f12XMvm7X+7rvuPGv9O++z26z173XiibPWT5JDDtp31vqH32XvWesD2xdn1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANCEoAYAAACgCUENAAAAQBOCGgAAAIAmBDUAAAAATdQwDHNvAwAAAABxRg0AAABAG4IaAAAAgCYENQAAAABNCGoAAAAAmhDUAAAAADQhqAEAAABoQlADAAAA0ISgBgAAAKAJQQ0AAABAE4IaAAAAgCYENQAAAABNCGoAAAAAmhDUAAAAADQhqAEAAABoQlADAAAA0ISgBgAAAKAJQQ0AAABAE4IaAAAAgCYENQAAAABNCGoAAAAAmhDUAAAAADQhqAEAAABoQlADAAAA0ISgBgAAAKAJQQ0AAABAE4IaAAAAgCYENQAAAABNCGqWqKqhqo5chzpfqqpH3N51YEehN6EnvQk96U3oSW+yLdoHNVX17Kr6QlVdWVXnV9XvV9X+c2/Xf9QwDEcNw/Cx23q90/t1fVVtnsY5VfXmqrrXkvmeV1VfqaorquqCqvrLqtrnFtb9lqq6rqoOXGH6XlPNv1pm2jer6lHbuM2bfan0pzfXZnvszWn6EVX1gWl7Lqqq12zrPjMPvbk222NvVtXpS/7NvKaqrljLfrP+9ObabKe9WVX1iqr6TlVdVlUfq6qj1rLfrD+9uTbbaW/uVlW/V1XnVdUlVfXGqtplLfu93loHNVX1oiSvTvKrSfZL8pAkhyb5cFXtehvX2nRbrm9mnxqGYe+M79mjklyV5LNVdXSSVNUJSX47ydOGYdgnyX2SvHe1FVbVXklOTnJZkmesMNuTk1yT5NFVdfdbs80L42NrXJ51pDdvte2qN6fP8sNJzkpytyT3SPL2bV2e9ac3b7XtqjeHYfiFxX8zk7wryZ9s6/KsP715q21XvZnkKUmem+ThSe6Q5FNJ/ngNy7PO9Oattr315kuSPCjJ0UnuleTYJC9dw/LrbxiGliPJvkk2J3nqktf3TvK9jF+CB2Y8KO6wMP2YJBcl2WV6/twkX05ySZIPJTl0Yd4hyS8l+VqScxZeO3J6/Lgkn09yeZJvJTltYdnDpnl/Lsl5Sb6b5EUL009L8r4k70lyRZLPJbn/wvRvJnnUwrzvTfK2ad4vJXnQwrzHTttxRcYfxN6T5BUrvG/PTvKJZV7/QJL3TY9fnOT9a/w8Tpneg19O8sUV5jkrySunfX3xkmlb93dbt9noOfTmhurNn0vy8bmPOWObjwW9eeO8O3RvLplvr2k/T5j7GDRW/Iz05o3z7tC9meS/J3nvwvOjklw99zForHgs6M0b593Re/Ofkjxl4fnTk3xr7mNwtdH5jJqHJdk9yRmLLw7DsDnJmUl+ehiG8zIm1ScvzPL0jAfItVX1hCS/keRJSe6c5OMZf+u06AlJHpzkvstsww8yHjD7Z2yiX5zWuegnk9wzyaOTvGTJ6VYnZTzQ75DknUnev8opVj+T5N1TrT9P8oZk62+0/yzJW6b1vCvJE1dYx2rOyJjuJ8lnkjymql5eVT9eVbttw/KnTrXfneTeVXXs4sSqOiTJI5K8YxqnrHH7jqnxsoqvVtXLdrDEeUejN7NhevMhSb5ZVWdO/fmxqvqxNSzP+tKb2TC9uejkJBcm+btbuTy3P72ZDdOb705yZFXda3p/Tk3ywTUsz/rSm9kwvVnTWHx+j6rabw3rWF9zJ0WrJGrPTHL+CtNeleTD0+PnJzlrelwZU7jjp+dnJnnewnI7JbkyU8qZMaF85JJ1b004l6n72iS/Nz0+bJr33gvTX5Pkj6bHpyX59JLa303y8KWJ3zTv3yzMe98kV02Pj0/ynSS1MP0TWXvCeWKSaxeePzbJXyS5NGOS/LtJdl5hnYckuSHJA6bnH0ryuiXzvDTJ2dPjA5Ncn+SYhelb93eZ9R+R5PDpPfqxJP8vya/PfQwayw+9uaF686+TXDtt064ZTwv+RpJd5z4OjWU/L705bIzeXLKej2ThN7BGv6E3N05vZvy38nXT+3ldknOSHD73MWgsP/TmhurNVyT5+4xh2t0yBklDkrvPfRyuNDqfUXNRkjutcGbF3afpyXi610OnGw4dn/EN//g07dAkr6uqS6vq0iQXZ2yugxbW9a2VNqCqHlxVH62qC6vqsiS/kOROS2ZbXP7cjAfNzaYNw3BDkm8vmb7o/IXHVybZfdr3A5N8Z5iOsFva5lUclHH/t2zPmcMwPD5janpSxoZ7/grLPivJl4dhOHt6/o4kT1+S1p4yvZ5hTJ7/NmMqeouGYfjGMAznDMNwwzAMX0jyWxmvP6QnvblBejPjqb6fmLbph0l+J8kdM15nTD96c+P0ZpKkqg5OckLGU9npS29unN78zST/KcnBGc/UeHmSs6pqz21cnvWlNzdOb74y46VdZyf5ZJL3Z/xl5Pe2cfl11zmo+VTGGwU9afHF6SZDj834G6QMw3Bpxt/6PjXjaWjvWjjIvpXk54dh2H9h7DEMwycXVrl4QC71zoynhR08DMN+SU7PTU+ZSsYv4i0OyXj94M2mVdVOGW/EuTh9W3w3yUFVtVj34JVmXsUTc+MXylZTOPKRjNf7Hb3CsqckOaLGu6CfnzENvVPGzyFV9bCMp+P9+sI8D07ytFt5CdOQm7/P9KE3RxuhN/8lq38O9KI3RxuhNxfrfHIYhm+sYRnWn94cbYTevH+S9wzD8O1hGK4bhuEtSQ7I8pe8MD+9Odrhe3MYhquGYXjBMAwHDcNwRJLvJ/nsMAzXr30310fboGYYhssyptCvr6oTq2qXqjos4zV4385N76D+zowf7snT4y1Oz/hhHpUkVbVfVT1lDZuxT5KLh2G4uqqOy9iYS72sqvacajwn442XtnhgVT1pOnhemPGL4NNrqJ+MXyDXJ3lBVW2qqpOSHLctC1bVzlV1eFW9PuP1fC+fXj+pqn62qg6o0XEZfyN3s22rqocm+ZGp5gOmcXTG93lLgnlqxr8Mc98l8+yZqbluYTsfW1V3nR7fO8nLkvzfbdlH1p/e3GqH782Mf+HpIVX1qKraOeN7dVHGG+bRjN7caiP05hanZLynAI3pza02Qm/+Y5KnVNVdq2qnqnpWkl2S/Nu27CfrS29utcP3ZlUdVFUHTtvykIz/v/mb27KPs1nrtVLrPZI8L8kXM56Cf0GSP0hywJJ59sh09+plln9Wki/kxjtpv2lh2s2uD1x8LePlN+dO6/5AxhsuvX2adlhuehfu85P82sJ6TstN78L9+STHLkz/Zm56zeDbF6ZtWfem6fmDMp6mtTnjF8cZSV62wvv17IyNtjnjzanOTfLWJPdZmOf4jAnxRdO2fXVx25es7/Qkf7rM68dl/CI4MOMdzh+/zDxvzI13/t66v8vM9zvTZ/uDjPe/+K1Md1E3+g69ueP35jT9SRl/wLw8yceSHDX3sWesPvTmhunNh07bu8/cx5yxbUNv7vi9mfFyp/+V8QyFyzP+ZZoT5z72jNWH3twQvXn8NP3KJP+a5BlzH3e3NGracNZoSlvPyRgoXLfM9NMyNuAzb4fan0ly+jAMb76t1w3bO70JPelN6ElvQk96c2Nre+kTN6qqE6rqbtOpaKcmuV/8qT+Ynd6EnvQm9KQ3oSe92c+tudEr6+9Hk7w3yd5Jvp7kycMwfHfeTQKiN6ErvQk96U3oSW8249InAAAAgCZc+gQAAADQhKAGAAAAoIlV71GzxzEvcF0UG9pVn39Dzb0Ny9GbbHR6E3rSm9CT3oSeVupNZ9QAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaENQAAAAANCGoAQAAAGhCUAMAAADQhKAGAAAAoAlBDQAAAEATghoAAACAJgQ1AAAAAE0IagAAAACaqGEY5t4GAAAAAOKMGgAAAIA2BDUAAAAATQhqAAAAAJoQ1AAAAAA0IagBAAAAaEJQAwAAANDE/wfoW+K/4IeEbwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set a Fully Connected model (fc-)\n",
    "fc = Sequential()\n",
    "fc.add(layers.Flatten(input_shape=(6, 6)))\n",
    "fc.add(layers.Dense(units=36, activation='sigmoid'))\n",
    "fc.add(layers.Dense(units=200, activation='sigmoid'))\n",
    "fc.add(layers.Dense(units=50, activation='sigmoid'))\n",
    "fc.add(layers.Dense(units=4, activation='softmax'))\n",
    "fc.summary()\n",
    "\n",
    "# set a SGD optimizer with an lr of .01 (-s01)\n",
    "optimizer = tf.keras.optimizers.SGD(lr=.01)\n",
    "\n",
    "# compile the mode with sparse categorical cross entropy loss\n",
    "fc.compile(optimizer=optimizer,\n",
    "              loss='sparse_categorical_crossentropy',\n",
    "              metrics=['accuracy'])\n",
    "\n",
    "# save the weights when the loss hit a minimum with the validation set\n",
    "checkpointer = ModelCheckpoint(filepath='fc.hdf5', monitor='val_loss',\n",
    "                               verbose=1, save_best_only=True)\n",
    "\n",
    "# train the model with batch size of 64,\n",
    "# for 150 epochs, and using cross-validation\n",
    "# with 20% of the train set\n",
    "fc.fit(x=images_overlapping, \n",
    "          y=labels,\n",
    "          batch_size=64,\n",
    "          epochs=150,\n",
    "          validation_split=0.2,\n",
    "          shuffle=True,\n",
    "          callbacks=[checkpointer])\n",
    "\n",
    "# load the weights corresponding to the smallest loss value\n",
    "fc.load_weights('fc.hdf5')\n",
    "\n",
    "\n",
    "# calculate the AAIs, with normal noise and 30 ADEs,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "fc_stats = adversarials.generate_aai(list(range(10)), 'normal', (6,6),\n",
    "                                           fc, 30, channel=False,\n",
    "                                           max_itr=1000, target_loss=0,\n",
    "                                           target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(fc_stats.aai.to_list(), 'Overlapping DS AAI')\n",
    "# and save them\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(fc_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('overlapping_aai' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "fc_stats.to_pickle('fc.pkl')\n",
    "# and display them\n",
    "fc_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "             'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Noise Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f614959c21bd42418021811a10f4f660",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=4.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>loss</th>\n",
       "      <th>iter</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>success</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.007038</td>\n",
       "      <td>1000</td>\n",
       "      <td>0</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.006184</td>\n",
       "      <td>1000</td>\n",
       "      <td>1</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.006966</td>\n",
       "      <td>1000</td>\n",
       "      <td>2</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.006137</td>\n",
       "      <td>1000</td>\n",
       "      <td>3</td>\n",
       "      <td>0.99</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed      loss  iter prediction  confidence success  \\\n",
       "0            0  normal  0.007038  1000          0        0.99    True   \n",
       "1            1  normal  0.006184  1000          1        0.99    True   \n",
       "2            2  normal  0.006966  1000          2        0.99    True   \n",
       "3            3  normal  0.006137  1000          3        0.99    True   \n",
       "\n",
       "   duration  \n",
       "0  00:00:05  \n",
       "1  00:00:05  \n",
       "2  00:00:05  \n",
       "3  00:00:05  "
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set one with the required columns:\n",
    "#     'target label': (int) the target label\n",
    "#     'feed': (str) the input type used for generating the ADE \n",
    "#     'perturbation': (numpy.ndarray) adversarial perturbation,\n",
    "#                                     the ADE minus the initial feed\n",
    "#     'loss': (float) the loss value of the final ADE\n",
    "#     'iter': (int) the number of iterations of modifying\n",
    "#                   the feed before getting the final ADE\n",
    "#     'prediction': (int) the class index which the generated ADE is\n",
    "#                         tagged with by the network\n",
    "#     'confidence': (float) the confidence of the network in labeling\n",
    "#                           the ADE\n",
    "#     'success': (boolean) if the ADE is tagged with the desired\n",
    "#                          target label\n",
    "#     'duration': (HH:MM:SS) time spent for generating the ADE\n",
    "columns = ['target label', 'feed', 'perturbation', 'loss', 'iter',\n",
    "           'prediction', 'confidence', 'success', 'duration']\n",
    "nf_stats = pd.DataFrame(columns = columns)\n",
    "\n",
    "# for every class in the MNIST dataset\n",
    "for target_label in tqdm(range(4)):\n",
    "    # generate the feed with a numpy array of normal noise\n",
    "    feed = adversarials.generate_input('normal', (6,6))\n",
    "    # generate ADE and get the data\n",
    "    ade, loss, _, itr, success, duration = adversarials.generate_ade(feed,\n",
    "                                                                        fc,\n",
    "                                                                        target_label,\n",
    "                                                                        channel=False,\n",
    "                                                                        max_itr=1000,\n",
    "                                                                        target_loss=0,\n",
    "                                                                        target_conf=1.01)\n",
    "    \n",
    "    # get the network prediction and its confidence for that prediction\n",
    "    # of the ADE\n",
    "    pred, conf = adversarials.classify(ade, fc, channel=False)\n",
    "    \n",
    "    # calculate the perturbation by subtracting the initial feed\n",
    "    # from the final ADE\n",
    "    perturbation = ade - feed\n",
    "    \n",
    "    # fill a row in the stats dataframe with the obtained info\n",
    "    nf_stats.loc[target_label] = [target_label, 'normal', perturbation, loss, itr,\n",
    "                                  pred, conf, success, duration]\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(nf_stats.perturbation.to_list(), 'NoiseFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(nf_stats.perturbation.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('noise_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "nf_stats.to_pickle('NoiseFeed.pkl')\n",
    "# and display them\n",
    "nf_stats[['target label', 'feed', 'loss', 'iter', 'prediction',\n",
    "          'confidence', 'success', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Zero Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.70s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.30s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.05s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.46s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006570</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>0</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006330</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>1</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006723</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>2</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.006179</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.99</td>\n",
       "      <td>3</td>\n",
       "      <td>0.99</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label   feed ades# trials  success  avg loss avg iter  avg conf  \\\n",
       "0            0  blank     1      1      1.0  0.006570     1000      0.99   \n",
       "1            1  blank     1      1      1.0  0.006330     1000      0.99   \n",
       "2            2  blank     1      1      1.0  0.006723     1000      0.99   \n",
       "3            3  blank     1      1      1.0  0.006179     1000      0.99   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0        0.99  00:00:05  \n",
       "1          1        0.99  00:00:05  \n",
       "2          2        0.99  00:00:05  \n",
       "3          3        0.99  00:00:05  "
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# calculate the AAIs, with blank noise and one single ADE,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "zf_stats = adversarials.generate_aai(list(range(4)), 'blank', (6,6),\n",
    "                                        fc, 1, channel=False,\n",
    "                                        max_itr=1000, target_loss=0,\n",
    "                                        target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the perturbations\n",
    "adversarials.plot_ten(zf_stats.aai.to_list(), 'ZeroFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(zf_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('zero_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "zf_stats.to_pickle('ZeroFeed.pkl')\n",
    "# and display them\n",
    "zf_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "          'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential_8\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "conv2d_6 (Conv2D)            (None, 4, 4, 128)         1280      \n",
      "_________________________________________________________________\n",
      "conv2d_7 (Conv2D)            (None, 2, 2, 256)         295168    \n",
      "_________________________________________________________________\n",
      "flatten_8 (Flatten)          (None, 1024)              0         \n",
      "_________________________________________________________________\n",
      "dense_29 (Dense)             (None, 512)               524800    \n",
      "_________________________________________________________________\n",
      "dense_30 (Dense)             (None, 256)               131328    \n",
      "_________________________________________________________________\n",
      "dense_31 (Dense)             (None, 10)                2570      \n",
      "=================================================================\n",
      "Total params: 955,146\n",
      "Trainable params: 955,146\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "Epoch 1/50\n",
      "500/500 [==============================] - ETA: 0s - loss: 0.0193 - accuracy: 0.9980\n",
      "Epoch 00001: val_loss improved from inf to 0.00000, saving model to cnn.hdf5\n",
      "500/500 [==============================] - 2s 4ms/step - loss: 0.0193 - accuracy: 0.9980 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 2/50\n",
      "480/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00002: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 3/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00003: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 4/50\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00004: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 5/50\n",
      "486/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00005: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 6/50\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00006: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 7/50\n",
      "484/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00007: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 8/50\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00008: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 9/50\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00009: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 10/50\n",
      "486/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00010: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 11/50\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00011: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 12/50\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00012: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 13/50\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00013: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 14/50\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00014: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 15/50\n",
      "487/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00015: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 16/50\n",
      "486/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00016: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 17/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00017: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 18/50\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00018: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 19/50\n",
      "489/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00019: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 20/50\n",
      "488/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00020: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 21/50\n",
      "482/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00021: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 22/50\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00022: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 23/50\n",
      "485/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00023: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 24/50\n",
      "483/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00024: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 25/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00025: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 26/50\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00026: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 27/50\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00027: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 28/50\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00028: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 29/50\n",
      "496/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00029: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 30/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00030: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 31/50\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00031: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 32/50\n",
      "494/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00032: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 33/50\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00033: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 34/50\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00034: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 35/50\n",
      "491/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00035: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 36/50\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00036: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 37/50\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00037: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 38/50\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00038: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 39/50\n",
      "481/500 [===========================>..] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00039: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 40/50\n",
      "495/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00040: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 41/50\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00041: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 42/50\n",
      "493/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00042: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 43/50\n",
      "498/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00043: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 44/50\n",
      "497/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00044: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 45/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00045: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 46/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00046: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 47/50\n",
      "490/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00047: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 48/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00048: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 49/50\n",
      "499/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00049: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n",
      "Epoch 50/50\n",
      "492/500 [============================>.] - ETA: 0s - loss: 0.0000e+00 - accuracy: 1.0000\n",
      "Epoch 00050: val_loss did not improve from 0.00000\n",
      "500/500 [==============================] - 1s 3ms/step - loss: 0.0000e+00 - accuracy: 1.0000 - val_loss: 0.0000e+00 - val_accuracy: 1.0000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [02:58<00:00,  5.95s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [03:03<00:00,  6.11s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [03:02<00:00,  6.08s/it]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 30/30 [03:01<00:00,  6.06s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>1</td>\n",
       "      <td>30</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.000163</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:02:58</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>30</td>\n",
       "      <td>30</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.000002</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:03:03</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>3</td>\n",
       "      <td>30</td>\n",
       "      <td>0.10</td>\n",
       "      <td>0.000281</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2</td>\n",
       "      <td>1.00</td>\n",
       "      <td>00:03:02</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>0</td>\n",
       "      <td>30</td>\n",
       "      <td>0.00</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>1</td>\n",
       "      <td>0.89</td>\n",
       "      <td>00:03:01</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed ades# trials  success  avg loss avg iter avg conf  \\\n",
       "0            0  normal     1     30     0.03  0.000163     1000      1.0   \n",
       "1            1  normal    30     30     1.00  0.000002     1000      1.0   \n",
       "2            2  normal     3     30     0.10  0.000281     1000      1.0   \n",
       "3            3  normal     0     30     0.00      None     None     None   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0        1.00  00:02:58  \n",
       "1          1        1.00  00:03:03  \n",
       "2          2        1.00  00:03:02  \n",
       "3          1        0.89  00:03:01  "
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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AAAAAKIkAgAAACBKIgAAAACiJAIAAAAgSiIAAAAAkmweauOqGmrrJMktd3110P1/+cdOGHT/177rhkH3T5J7v7Z30P0vueITg+5/21u2Dbr/vtx455cG3f+1v/WXg+7/2McO9r/FJMkH/9WLB90/Sa6/9e5B9/+3Lz1p0P3H6oRvfeKG3v/X/uivB93/k1e+d9D9k+ST79s06P6v+pc/M+j+r146dtD9AWAjcCURAAAAAEoiAAAAAJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAREkEAAAAQJREAAAAAERJBAAAwECq6oyqurmqdlXVxftYc3pVfayqbqyqD633jLCRbB56AAAAADaeqtqU5JIkP5pkd5Jrq+rK7v7kzJojkrw1yRndfWtVfdsgw8IG4UoiAAAAhnBqkl3dfUt335fk8iTblq15ZZIruvvWJOnuL6zzjLChKIkAAAAYwjFJbpu5vXt6bNazkxxZVR+squuq6tx93VlVnV9VO6tq5549exYwLjz6KYkAAAAYQq1wrJfd3pzk+UlemuQlSX6xqp690p11947uXurupS1btqztpLBBeE0iAAAAhrA7ybEzt7cmuX2FNXd09z1J7qmqDyc5Jcmn1mdE2FhcSQQAAMAQrk1yfFUdV1WHJzk7yZXL1rwnyQ9U1eaqenySFya5aZ3nhA3DlUQAAACsu+7eW1UXJrk6yaYkl3b3jVV1wfT89u6+qaren+T6JA8keXt3f2K4qeHRTUkEAADAILr7qiRXLTu2fdntf5/k36/nXLBReboZAAAAAEoiAAAAAJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAREkEAAAAQJREAAAAAERJBAAAAECURAAAAABESQQAAABAlEQAAAAAJNk81MaHbRq2n3rqEw4bdP8jt/3HQffP3X837P5Jcs/fD7r9z/7iawfdf6y+/QmPHXT/HecuDbr/1Z/eM+j+R77gwkH3T5Kf/lf/bND9d995z6D7//HxLxp0/3259va7B93/50995qD7v++C7x10/3Of+JhB90+S9/7mpYPu//kv3jvo/gDA4rmSCAAAAAAlEQAAAABKIgAAAACiJAIAAAAgSiIAAAAAoiQCAAAAIEoiAAAAAKIkAgAAACBKIgAAAACiJAIAAAAgSiIAAAAAoiQCAAAAIEoiAAAA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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set a CNN model (cn1-)\n",
    "cnn = Sequential()\n",
    "cnn.add(layers.Conv2D(128, (3,3), input_shape=(6,6,1), activation = 'relu'))\n",
    "cnn.add(layers.Conv2D(256, (3,3), activation = 'relu'))\n",
    "cnn.add(layers.Flatten())\n",
    "cnn.add(layers.Dense(512, activation = 'relu'))\n",
    "cnn.add(layers.Dense(256, activation = 'relu'))\n",
    "cnn.add(layers.Dense(10, activation='softmax'))\n",
    "cnn.summary()\n",
    "\n",
    "\n",
    "# set a Adam optimizer with an lr of .001 (-a001)\n",
    "optimizer = tf.keras.optimizers.Adam(lr=.001)\n",
    "\n",
    "# compile the mode with sparse categorical cross entropy loss\n",
    "cnn.compile(optimizer=optimizer,\n",
    "              loss='sparse_categorical_crossentropy',\n",
    "              metrics=['accuracy'])\n",
    "\n",
    "# save the weights when the loss hit a minimum with the validation set\n",
    "checkpointer = ModelCheckpoint(filepath='cnn.hdf5', monitor='val_loss',\n",
    "                               verbose=1, save_best_only=True)\n",
    "\n",
    "# train the model with batch size of 64,\n",
    "# for 50 epochs, and using cross-validation\n",
    "# with 20% of the train set\n",
    "cnn.fit(x=np.expand_dims(images_overlapping, axis=3), \n",
    "            y=labels,\n",
    "            batch_size=64,\n",
    "            epochs=50,\n",
    "            validation_split=0.2,\n",
    "            shuffle=True,\n",
    "            callbacks=[checkpointer])\n",
    "\n",
    "# load the weights corresponding to the smallest loss value\n",
    "cnn.load_weights('cnn.hdf5')\n",
    "\n",
    "\n",
    "# calculate the AAIs, with normal noise and 30 ADEs,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "cnn_stats = adversarials.generate_aai(list(range(4)), 'normal', (6,6),\n",
    "                                             cnn, 30, channel=True,\n",
    "                                             max_itr=1000, target_loss=0,\n",
    "                                             target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(cnn_stats.aai.to_list(), 'Overlapping AAI')\n",
    "# and save them\n",
    "# for each image\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(cnn_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('Overlapping_aai' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "\n",
    "# save the stats\n",
    "cnn_stats.to_pickle('cnn.pkl')\n",
    "# and display them\n",
    "cnn_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "               'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Noise Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bf4089d25688438395b733252472e127",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=4.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>loss</th>\n",
       "      <th>iter</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>success</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>normal</td>\n",
       "      <td>16.118097</td>\n",
       "      <td>1000</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>normal</td>\n",
       "      <td>0.000001</td>\n",
       "      <td>1000</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>normal</td>\n",
       "      <td>16.118097</td>\n",
       "      <td>1000</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>normal</td>\n",
       "      <td>16.118097</td>\n",
       "      <td>1000</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label    feed       loss  iter prediction  confidence success  \\\n",
       "0            0  normal  16.118097  1000          1         1.0   False   \n",
       "1            1  normal   0.000001  1000          1         1.0    True   \n",
       "2            2  normal  16.118097  1000          1         1.0   False   \n",
       "3            3  normal  16.118097  1000          1         1.0   False   \n",
       "\n",
       "   duration  \n",
       "0  00:00:06  \n",
       "1  00:00:06  \n",
       "2  00:00:06  \n",
       "3  00:00:05  "
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set one with the required columns:\n",
    "#     'target label': (int) the target label\n",
    "#     'feed': (str) the input type used for generating the ADE \n",
    "#     'perturbation': (numpy.ndarray) adversarial perturbation,\n",
    "#                                     the ADE minus the initial feed\n",
    "#     'loss': (float) the loss value of the final ADE\n",
    "#     'iter': (int) the number of iterations of modifying\n",
    "#                   the feed before getting the final ADE\n",
    "#     'prediction': (int) the class index which the generated ADE is\n",
    "#                         tagged with by the network\n",
    "#     'confidence': (float) the confidence of the network in labeling\n",
    "#                           the ADE\n",
    "#     'success': (boolean) if the ADE is tagged with the desired\n",
    "#                          target label\n",
    "#     'duration': (HH:MM:SS) time spent for generating the ADE\n",
    "columns = ['target label', 'feed', 'perturbation', 'loss', 'iter',\n",
    "           'prediction', 'confidence', 'success', 'duration']\n",
    "nf_stats = pd.DataFrame(columns = columns)\n",
    "\n",
    "# for every class in the MNIST dataset\n",
    "for target_label in tqdm(range(4)):\n",
    "    # generate the feed with a numpy array of normal noise\n",
    "    feed = adversarials.generate_input('normal', (6,6))\n",
    "    # generate ADE and get the data\n",
    "    ade, loss, _, itr, success, duration = adversarials.generate_ade(feed,\n",
    "                                                                        cnn,\n",
    "                                                                        target_label,\n",
    "                                                                        channel=True,\n",
    "                                                                        max_itr=1000,\n",
    "                                                                        target_loss=0,\n",
    "                                                                        target_conf=1.01)\n",
    "    \n",
    "    # get the network prediction and its confidence for that prediction\n",
    "    # of the ADE\n",
    "    pred, conf = adversarials.classify(ade, cnn, channel=True)\n",
    "    \n",
    "    # calculate the perturbation by subtracting the initial feed\n",
    "    # from the final ADE\n",
    "    perturbation = ade - feed\n",
    "    \n",
    "    # fill a row in the stats dataframe with the obtained info\n",
    "    nf_stats.loc[target_label] = [target_label, 'normal', perturbation, loss, itr,\n",
    "                                  pred, conf, success, duration]\n",
    "\n",
    "# plot the AAIs\n",
    "adversarials.plot_ten(nf_stats.perturbation.to_list(), 'NoiseFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(nf_stats.perturbation.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('noise_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "nf_stats.to_pickle('NoiseFeed.pkl')\n",
    "# and display them\n",
    "nf_stats[['target label', 'feed', 'loss', 'iter', 'prediction',\n",
    "          'confidence', 'success', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Zero Feed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:06<00:00,  6.28s/it]\n",
      "C:\\Users\\sahar\\Anaconda3\\envs\\tf-gpu\\lib\\site-packages\\numpy\\core\\_asarray.py:83: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n",
      "  return array(a, dtype, copy=False, order=order)\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.95s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.94s/it]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████████| 1/1 [00:05<00:00,  5.95s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>target label</th>\n",
       "      <th>feed</th>\n",
       "      <th>ades#</th>\n",
       "      <th>trials</th>\n",
       "      <th>success</th>\n",
       "      <th>avg loss</th>\n",
       "      <th>avg iter</th>\n",
       "      <th>avg conf</th>\n",
       "      <th>prediction</th>\n",
       "      <th>confidence</th>\n",
       "      <th>duration</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000619</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000211</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000674</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>blank</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000511</td>\n",
       "      <td>1000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3</td>\n",
       "      <td>1.0</td>\n",
       "      <td>00:00:05</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  target label   feed ades# trials  success  avg loss avg iter  avg conf  \\\n",
       "0            0  blank     1      1      1.0  0.000619     1000       1.0   \n",
       "1            1  blank     1      1      1.0  0.000211     1000       1.0   \n",
       "2            2  blank     1      1      1.0  0.000674     1000       1.0   \n",
       "3            3  blank     1      1      1.0  0.000511     1000       1.0   \n",
       "\n",
       "  prediction  confidence  duration  \n",
       "0          0         1.0  00:00:06  \n",
       "1          1         1.0  00:00:05  \n",
       "2          2         1.0  00:00:05  \n",
       "3          3         1.0  00:00:05  "
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# calculate the AAIs, with blank noise and one single ADE,\n",
    "# each generated over at least 1,000 iteration of gradient descent\n",
    "# and fill the stats dataframe\n",
    "zf_stats = adversarials.generate_aai(list(range(4)), 'blank', (6,6),\n",
    "                                        cnn, 1, channel=True,\n",
    "                                        max_itr=1000, target_loss=0,\n",
    "                                        target_conf=1.1, stats=None)\n",
    "\n",
    "# plot the perturbations\n",
    "adversarials.plot_ten(zf_stats.aai.to_list(), 'ZeroFeed')\n",
    "# and save them\n",
    "for i in range(4):\n",
    "    # set the figure frame\n",
    "    fig = plt.figure()\n",
    "    # set the size\n",
    "    fig.set_size_inches(8, 8)\n",
    "    # turn off the tickes\n",
    "    plt.axis('off')\n",
    "    # plot the image\n",
    "    plt.imshow(zf_stats.aai.to_list()[i], cmap='Blues_r')\n",
    "    # save it\n",
    "    plt.savefig('zero_feed' + ' ' + str(i), dpi = 100)\n",
    "\n",
    "    # and close it\n",
    "    plt.close(fig)\n",
    "\n",
    "# save the stats\n",
    "zf_stats.to_pickle('ZeroFeed.pkl')\n",
    "# and display them\n",
    "zf_stats[['target label', 'feed', 'ades#', 'trials', 'success', 'avg loss',\n",
    "          'avg iter', 'avg conf', 'prediction', 'confidence', 'duration']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generate ADE with a sample of another class should be impossible based on your haypothesis/claim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": [
    "plt.imshow(images_tiling[3], cmap='Blues_r');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": [
    "feed = images_tiling[0].astype(np.float32)\n",
    "target_label = 1\n",
    "ade, loss, conf, itr, success, duration = adversarials.generate_ade(feed,\n",
    "                                                                     fc,\n",
    "                                                                     target_label,\n",
    "                                                                     channel=False,\n",
    "                                                                     max_itr=1000,\n",
    "                                                                     target_loss=3e-3,\n",
    "                                                                     target_conf=1.01)\n",
    "fig, ax = plt.subplots()\n",
    "adversarials.classify_plot(ade, fc, ax)"
   ]
  }
 ],
 "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
