{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../..'); sys.path.append('../'); \n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "from sklearn.model_selection import train_test_split\n",
    "import utils\n",
    "import imageio"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(200, 2, 32, 32, 1) (200,)\n"
     ]
    }
   ],
   "source": [
    "dat = np.load('imgs_size/RMTS_size_pretrain.npz')\n",
    "X = dat['x']\n",
    "y = dat['y']\n",
    "X = 255 - X\n",
    "X = np.expand_dims(X, axis=4)\n",
    "print(X.shape, y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 108x540 with 20 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def display_sample(X, y, to_show=5):\n",
    "    seq_len = int(X.shape[1]/2)\n",
    "    fig, axarr = plt.subplots(to_show, 2*seq_len, figsize=(1.5*seq_len, .75*to_show))\n",
    "    plt.rcParams['axes.titlepad'] = -14  \n",
    "    for i in range(to_show):\n",
    "        ind = np.random.choice(range(len(X)), 1)[0]\n",
    "        for j in range(2*seq_len):\n",
    "            axarr[i,j].imshow(X[i,j], cmap='gray_r')\n",
    "            axarr[i,j].axis('off')\n",
    "            if (j == 2*seq_len-1):\n",
    "                axarr[i,j].set_title('%d' % y[i], loc='right')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "display_sample(X, y, to_show=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((180, 2, 32, 32, 1), (20, 2, 32, 32, 1))"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.10)\n",
    "X_train.shape, X_test.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from simplest_abstractor import SimplestAbstractorCNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"simplest_abstractor_cnn\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  104704    \n",
      "                                                                 \n",
      " cnn_embedder (TimeDistribut  multiple                 104704    \n",
      " ed)                                                             \n",
      "                                                                 \n",
      " flatten_1 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " query_projection (Dense)    multiple                  4160      \n",
      "                                                                 \n",
      " key_projection (Dense)      multiple                  4160      \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  672       \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 113,749\n",
      "Trainable params: 9,025\n",
      "Non-trainable params: 104,724\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True, name='binary_crossentropy')\n",
    "create_opt = lambda : tf.keras.optimizers.Adam(learning_rate=0.001)\n",
    "\n",
    "cnn_abstractor = SimplestAbstractorCNN(num_classes=2, sequence_len=2, symbol_dim=10, embedding_dim=64)\n",
    "cnn_abstractor.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "cnn_abstractor(X_train[:32])\n",
    "cnn_abstractor.summary()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/100\n",
      "2/2 [==============================] - 5s 1s/step - loss: 0.7064 - binary_accuracy: 0.5167 - val_loss: 0.7000 - val_binary_accuracy: 0.5167\n",
      "Epoch 2/100\n",
      "2/2 [==============================] - 0s 121ms/step - loss: 0.6990 - binary_accuracy: 0.5167 - val_loss: 0.6932 - val_binary_accuracy: 0.5167\n",
      "Epoch 3/100\n",
      "2/2 [==============================] - 0s 106ms/step - loss: 0.6930 - binary_accuracy: 0.5167 - val_loss: 0.6875 - val_binary_accuracy: 0.5167\n",
      "Epoch 4/100\n",
      "2/2 [==============================] - 0s 104ms/step - loss: 0.6870 - binary_accuracy: 0.5167 - val_loss: 0.6828 - val_binary_accuracy: 0.5167\n",
      "Epoch 5/100\n",
      "2/2 [==============================] - 0s 92ms/step - loss: 0.6816 - binary_accuracy: 0.5167 - val_loss: 0.6786 - val_binary_accuracy: 0.5167\n",
      "Epoch 6/100\n",
      "2/2 [==============================] - 0s 115ms/step - loss: 0.6785 - binary_accuracy: 0.5167 - val_loss: 0.6747 - val_binary_accuracy: 0.5167\n",
      "Epoch 7/100\n",
      "2/2 [==============================] - 0s 84ms/step - loss: 0.6742 - binary_accuracy: 0.5167 - val_loss: 0.6710 - val_binary_accuracy: 0.5167\n",
      "Epoch 8/100\n",
      "2/2 [==============================] - 0s 114ms/step - loss: 0.6704 - binary_accuracy: 0.5278 - val_loss: 0.6672 - val_binary_accuracy: 0.6444\n",
      "Epoch 9/100\n",
      "2/2 [==============================] - 0s 80ms/step - loss: 0.6667 - binary_accuracy: 0.6611 - val_loss: 0.6632 - val_binary_accuracy: 0.8167\n",
      "Epoch 10/100\n",
      "2/2 [==============================] - 0s 100ms/step - loss: 0.6627 - binary_accuracy: 0.8167 - val_loss: 0.6587 - val_binary_accuracy: 0.8889\n",
      "Epoch 11/100\n",
      "2/2 [==============================] - 0s 85ms/step - loss: 0.6579 - binary_accuracy: 0.8944 - val_loss: 0.6535 - val_binary_accuracy: 0.9278\n",
      "Epoch 12/100\n",
      "2/2 [==============================] - 0s 89ms/step - loss: 0.6527 - binary_accuracy: 0.9278 - val_loss: 0.6476 - val_binary_accuracy: 0.9389\n",
      "Epoch 13/100\n",
      "2/2 [==============================] - 0s 89ms/step - loss: 0.6467 - binary_accuracy: 0.9389 - val_loss: 0.6410 - val_binary_accuracy: 0.9389\n",
      "Epoch 14/100\n",
      "2/2 [==============================] - 0s 94ms/step - loss: 0.6400 - binary_accuracy: 0.9389 - val_loss: 0.6337 - val_binary_accuracy: 0.9389\n",
      "Epoch 15/100\n",
      "2/2 [==============================] - 0s 86ms/step - loss: 0.6325 - binary_accuracy: 0.9389 - val_loss: 0.6256 - val_binary_accuracy: 0.9389\n",
      "Epoch 16/100\n",
      "2/2 [==============================] - 0s 99ms/step - loss: 0.6244 - binary_accuracy: 0.9333 - val_loss: 0.6167 - val_binary_accuracy: 0.9389\n",
      "Epoch 17/100\n",
      "2/2 [==============================] - 0s 82ms/step - loss: 0.6154 - binary_accuracy: 0.9389 - val_loss: 0.6071 - val_binary_accuracy: 0.9389\n",
      "Epoch 18/100\n",
      "2/2 [==============================] - 0s 105ms/step - loss: 0.6058 - binary_accuracy: 0.9389 - val_loss: 0.5966 - val_binary_accuracy: 0.9389\n",
      "Epoch 19/100\n",
      "2/2 [==============================] - 0s 89ms/step - loss: 0.5953 - binary_accuracy: 0.9389 - val_loss: 0.5853 - val_binary_accuracy: 0.9389\n",
      "Epoch 20/100\n",
      "2/2 [==============================] - 0s 94ms/step - loss: 0.5835 - binary_accuracy: 0.9389 - val_loss: 0.5729 - val_binary_accuracy: 0.9444\n",
      "Epoch 21/100\n",
      "2/2 [==============================] - 0s 88ms/step - loss: 0.5710 - binary_accuracy: 0.9444 - val_loss: 0.5596 - val_binary_accuracy: 0.9500\n",
      "Epoch 22/100\n",
      "2/2 [==============================] - 0s 100ms/step - loss: 0.5576 - binary_accuracy: 0.9500 - val_loss: 0.5452 - val_binary_accuracy: 0.9556\n",
      "Epoch 23/100\n",
      "2/2 [==============================] - 0s 87ms/step - loss: 0.5432 - binary_accuracy: 0.9556 - val_loss: 0.5298 - val_binary_accuracy: 0.9556\n",
      "Epoch 24/100\n",
      "2/2 [==============================] - 0s 98ms/step - loss: 0.5276 - binary_accuracy: 0.9556 - val_loss: 0.5135 - val_binary_accuracy: 0.9556\n",
      "Epoch 25/100\n",
      "2/2 [==============================] - 0s 87ms/step - loss: 0.5110 - binary_accuracy: 0.9556 - val_loss: 0.4962 - val_binary_accuracy: 0.9611\n",
      "Epoch 26/100\n",
      "2/2 [==============================] - 0s 100ms/step - loss: 0.4938 - binary_accuracy: 0.9667 - val_loss: 0.4781 - val_binary_accuracy: 0.9722\n",
      "Epoch 27/100\n",
      "2/2 [==============================] - 0s 109ms/step - loss: 0.4754 - binary_accuracy: 0.9722 - val_loss: 0.4592 - val_binary_accuracy: 0.9778\n",
      "Epoch 28/100\n",
      "2/2 [==============================] - 0s 122ms/step - loss: 0.4563 - binary_accuracy: 0.9778 - val_loss: 0.4395 - val_binary_accuracy: 0.9833\n",
      "Epoch 29/100\n",
      "2/2 [==============================] - 0s 93ms/step - loss: 0.4366 - binary_accuracy: 0.9833 - val_loss: 0.4191 - val_binary_accuracy: 0.9833\n",
      "Epoch 30/100\n",
      "2/2 [==============================] - 0s 99ms/step - loss: 0.4161 - binary_accuracy: 0.9833 - val_loss: 0.3984 - val_binary_accuracy: 0.9833\n",
      "Epoch 31/100\n",
      "2/2 [==============================] - 0s 104ms/step - loss: 0.3954 - binary_accuracy: 0.9833 - val_loss: 0.3779 - val_binary_accuracy: 0.9833\n",
      "Epoch 32/100\n",
      "2/2 [==============================] - 0s 84ms/step - loss: 0.3750 - binary_accuracy: 0.9833 - val_loss: 0.3575 - val_binary_accuracy: 0.9833\n",
      "Epoch 33/100\n",
      "2/2 [==============================] - 0s 104ms/step - loss: 0.3547 - binary_accuracy: 0.9833 - val_loss: 0.3373 - val_binary_accuracy: 0.9833\n",
      "Epoch 34/100\n",
      "2/2 [==============================] - 0s 101ms/step - loss: 0.3344 - binary_accuracy: 0.9833 - val_loss: 0.3173 - val_binary_accuracy: 0.9833\n",
      "Epoch 35/100\n",
      "2/2 [==============================] - 0s 111ms/step - loss: 0.3145 - binary_accuracy: 0.9833 - val_loss: 0.2979 - val_binary_accuracy: 0.9833\n",
      "Epoch 36/100\n",
      "2/2 [==============================] - 0s 98ms/step - loss: 0.2952 - binary_accuracy: 0.9833 - val_loss: 0.2793 - val_binary_accuracy: 0.9833\n",
      "Epoch 37/100\n",
      "2/2 [==============================] - 0s 167ms/step - loss: 0.2768 - binary_accuracy: 0.9833 - val_loss: 0.2619 - val_binary_accuracy: 0.9833\n",
      "Epoch 38/100\n",
      "2/2 [==============================] - 0s 94ms/step - loss: 0.2597 - binary_accuracy: 0.9833 - val_loss: 0.2458 - val_binary_accuracy: 0.9833\n",
      "Epoch 39/100\n",
      "2/2 [==============================] - 0s 68ms/step - loss: 0.2436 - binary_accuracy: 0.9833 - val_loss: 0.2309 - val_binary_accuracy: 0.9833\n",
      "Epoch 40/100\n",
      "2/2 [==============================] - 0s 81ms/step - loss: 0.2289 - binary_accuracy: 0.9833 - val_loss: 0.2170 - val_binary_accuracy: 0.9833\n",
      "Epoch 41/100\n",
      "2/2 [==============================] - 0s 69ms/step - loss: 0.2150 - binary_accuracy: 0.9833 - val_loss: 0.2040 - val_binary_accuracy: 0.9833\n",
      "Epoch 42/100\n",
      "2/2 [==============================] - 0s 64ms/step - loss: 0.2022 - binary_accuracy: 0.9833 - val_loss: 0.1918 - val_binary_accuracy: 0.9833\n",
      "Epoch 43/100\n",
      "2/2 [==============================] - 0s 66ms/step - loss: 0.1901 - binary_accuracy: 0.9833 - val_loss: 0.1804 - val_binary_accuracy: 0.9833\n",
      "Epoch 44/100\n",
      "2/2 [==============================] - 0s 65ms/step - loss: 0.1790 - binary_accuracy: 0.9833 - val_loss: 0.1698 - val_binary_accuracy: 0.9833\n",
      "Epoch 45/100\n",
      "2/2 [==============================] - 0s 63ms/step - loss: 0.1684 - binary_accuracy: 0.9833 - val_loss: 0.1599 - val_binary_accuracy: 0.9833\n",
      "Epoch 46/100\n",
      "2/2 [==============================] - 0s 65ms/step - loss: 0.1585 - binary_accuracy: 0.9833 - val_loss: 0.1506 - val_binary_accuracy: 0.9833\n",
      "Epoch 47/100\n",
      "2/2 [==============================] - 0s 62ms/step - loss: 0.1493 - binary_accuracy: 0.9833 - val_loss: 0.1420 - val_binary_accuracy: 0.9833\n",
      "Epoch 48/100\n",
      "2/2 [==============================] - 0s 67ms/step - loss: 0.1407 - binary_accuracy: 0.9833 - val_loss: 0.1339 - val_binary_accuracy: 0.9833\n",
      "Epoch 49/100\n",
      "2/2 [==============================] - 0s 66ms/step - loss: 0.1329 - binary_accuracy: 0.9833 - val_loss: 0.1265 - val_binary_accuracy: 0.9833\n",
      "Epoch 50/100\n",
      "2/2 [==============================] - 0s 60ms/step - loss: 0.1255 - binary_accuracy: 0.9833 - val_loss: 0.1195 - val_binary_accuracy: 0.9833\n",
      "Epoch 51/100\n",
      "2/2 [==============================] - 0s 67ms/step - loss: 0.1187 - binary_accuracy: 0.9833 - val_loss: 0.1131 - val_binary_accuracy: 0.9833\n",
      "Epoch 52/100\n",
      "2/2 [==============================] - 0s 65ms/step - loss: 0.1122 - binary_accuracy: 0.9833 - val_loss: 0.1071 - val_binary_accuracy: 0.9833\n",
      "Epoch 53/100\n",
      "2/2 [==============================] - 0s 65ms/step - loss: 0.1063 - binary_accuracy: 0.9833 - val_loss: 0.1015 - val_binary_accuracy: 0.9833\n",
      "Epoch 54/100\n",
      "2/2 [==============================] - 0s 63ms/step - loss: 0.1007 - binary_accuracy: 0.9833 - val_loss: 0.0962 - val_binary_accuracy: 0.9833\n",
      "Epoch 55/100\n",
      "2/2 [==============================] - 0s 64ms/step - loss: 0.0955 - binary_accuracy: 0.9833 - val_loss: 0.0914 - val_binary_accuracy: 0.9833\n",
      "Epoch 56/100\n",
      "2/2 [==============================] - 0s 63ms/step - loss: 0.0907 - binary_accuracy: 0.9833 - val_loss: 0.0868 - val_binary_accuracy: 0.9833\n",
      "Epoch 57/100\n",
      "2/2 [==============================] - 0s 65ms/step - loss: 0.0863 - binary_accuracy: 0.9833 - val_loss: 0.0826 - val_binary_accuracy: 0.9833\n",
      "Epoch 58/100\n",
      "2/2 [==============================] - 0s 64ms/step - loss: 0.0821 - binary_accuracy: 0.9833 - val_loss: 0.0787 - val_binary_accuracy: 0.9889\n",
      "Epoch 59/100\n",
      "2/2 [==============================] - 0s 59ms/step - loss: 0.0783 - binary_accuracy: 0.9889 - val_loss: 0.0750 - val_binary_accuracy: 0.9889\n",
      "Epoch 60/100\n",
      "2/2 [==============================] - 0s 65ms/step - loss: 0.0746 - binary_accuracy: 0.9889 - val_loss: 0.0716 - val_binary_accuracy: 0.9889\n",
      "Epoch 61/100\n",
      "2/2 [==============================] - 0s 64ms/step - loss: 0.0711 - binary_accuracy: 0.9889 - val_loss: 0.0684 - val_binary_accuracy: 0.9889\n",
      "Epoch 62/100\n",
      "2/2 [==============================] - 0s 63ms/step - loss: 0.0678 - binary_accuracy: 0.9889 - val_loss: 0.0653 - val_binary_accuracy: 0.9889\n",
      "Epoch 63/100\n",
      "2/2 [==============================] - 0s 76ms/step - loss: 0.0649 - binary_accuracy: 0.9889 - val_loss: 0.0624 - val_binary_accuracy: 0.9889\n",
      "Epoch 64/100\n",
      "2/2 [==============================] - 0s 91ms/step - loss: 0.0619 - binary_accuracy: 0.9889 - val_loss: 0.0596 - val_binary_accuracy: 0.9889\n",
      "Epoch 65/100\n",
      "2/2 [==============================] - 0s 61ms/step - loss: 0.0592 - binary_accuracy: 0.9889 - val_loss: 0.0570 - val_binary_accuracy: 0.9889\n",
      "Epoch 66/100\n",
      "2/2 [==============================] - 0s 64ms/step - loss: 0.0567 - binary_accuracy: 0.9889 - val_loss: 0.0545 - val_binary_accuracy: 0.9889\n",
      "Epoch 67/100\n",
      "2/2 [==============================] - 0s 63ms/step - loss: 0.0541 - binary_accuracy: 0.9944 - val_loss: 0.0522 - val_binary_accuracy: 0.9944\n",
      "Epoch 68/100\n",
      "2/2 [==============================] - 0s 63ms/step - loss: 0.0519 - binary_accuracy: 0.9944 - val_loss: 0.0500 - val_binary_accuracy: 0.9944\n",
      "Epoch 69/100\n",
      "2/2 [==============================] - 0s 75ms/step - loss: 0.0497 - binary_accuracy: 0.9944 - val_loss: 0.0479 - val_binary_accuracy: 0.9944\n",
      "Epoch 70/100\n",
      "2/2 [==============================] - 0s 134ms/step - loss: 0.0477 - binary_accuracy: 0.9944 - val_loss: 0.0460 - val_binary_accuracy: 1.0000\n",
      "Epoch 71/100\n",
      "2/2 [==============================] - 0s 82ms/step - loss: 0.0458 - binary_accuracy: 1.0000 - val_loss: 0.0442 - val_binary_accuracy: 1.0000\n",
      "Epoch 72/100\n",
      "2/2 [==============================] - 0s 95ms/step - loss: 0.0439 - binary_accuracy: 1.0000 - val_loss: 0.0425 - val_binary_accuracy: 1.0000\n",
      "Epoch 73/100\n",
      "2/2 [==============================] - 0s 83ms/step - loss: 0.0422 - binary_accuracy: 1.0000 - val_loss: 0.0408 - val_binary_accuracy: 1.0000\n",
      "Epoch 74/100\n",
      "2/2 [==============================] - 0s 126ms/step - loss: 0.0405 - binary_accuracy: 1.0000 - val_loss: 0.0392 - val_binary_accuracy: 1.0000\n",
      "Epoch 75/100\n",
      "2/2 [==============================] - 0s 88ms/step - loss: 0.0391 - binary_accuracy: 1.0000 - val_loss: 0.0377 - val_binary_accuracy: 1.0000\n",
      "Epoch 76/100\n",
      "2/2 [==============================] - 0s 100ms/step - loss: 0.0374 - binary_accuracy: 1.0000 - val_loss: 0.0363 - val_binary_accuracy: 1.0000\n",
      "Epoch 77/100\n",
      "2/2 [==============================] - 0s 77ms/step - loss: 0.0362 - binary_accuracy: 1.0000 - val_loss: 0.0350 - val_binary_accuracy: 1.0000\n",
      "Epoch 78/100\n",
      "2/2 [==============================] - 0s 100ms/step - loss: 0.0349 - binary_accuracy: 1.0000 - val_loss: 0.0338 - val_binary_accuracy: 1.0000\n",
      "Epoch 79/100\n",
      "2/2 [==============================] - 0s 86ms/step - loss: 0.0336 - binary_accuracy: 1.0000 - val_loss: 0.0326 - val_binary_accuracy: 1.0000\n",
      "Epoch 80/100\n",
      "2/2 [==============================] - 0s 101ms/step - loss: 0.0324 - binary_accuracy: 1.0000 - val_loss: 0.0315 - val_binary_accuracy: 1.0000\n",
      "Epoch 81/100\n",
      "2/2 [==============================] - 0s 85ms/step - loss: 0.0313 - binary_accuracy: 1.0000 - val_loss: 0.0304 - val_binary_accuracy: 1.0000\n",
      "Epoch 82/100\n",
      "2/2 [==============================] - 0s 93ms/step - loss: 0.0303 - binary_accuracy: 1.0000 - val_loss: 0.0294 - val_binary_accuracy: 1.0000\n",
      "Epoch 83/100\n",
      "2/2 [==============================] - 0s 80ms/step - loss: 0.0292 - binary_accuracy: 1.0000 - val_loss: 0.0284 - val_binary_accuracy: 1.0000\n",
      "Epoch 84/100\n",
      "2/2 [==============================] - 0s 97ms/step - loss: 0.0283 - binary_accuracy: 1.0000 - val_loss: 0.0275 - val_binary_accuracy: 1.0000\n",
      "Epoch 85/100\n",
      "2/2 [==============================] - 0s 80ms/step - loss: 0.0274 - binary_accuracy: 1.0000 - val_loss: 0.0266 - val_binary_accuracy: 1.0000\n",
      "Epoch 86/100\n",
      "2/2 [==============================] - 0s 93ms/step - loss: 0.0265 - binary_accuracy: 1.0000 - val_loss: 0.0258 - val_binary_accuracy: 1.0000\n",
      "Epoch 87/100\n",
      "2/2 [==============================] - 0s 87ms/step - loss: 0.0257 - binary_accuracy: 1.0000 - val_loss: 0.0250 - val_binary_accuracy: 1.0000\n",
      "Epoch 88/100\n",
      "2/2 [==============================] - 0s 98ms/step - loss: 0.0249 - binary_accuracy: 1.0000 - val_loss: 0.0242 - val_binary_accuracy: 1.0000\n",
      "Epoch 89/100\n",
      "2/2 [==============================] - 0s 84ms/step - loss: 0.0241 - binary_accuracy: 1.0000 - val_loss: 0.0235 - val_binary_accuracy: 1.0000\n",
      "Epoch 90/100\n",
      "2/2 [==============================] - 0s 93ms/step - loss: 0.0234 - binary_accuracy: 1.0000 - val_loss: 0.0228 - val_binary_accuracy: 1.0000\n",
      "Epoch 91/100\n",
      "2/2 [==============================] - 0s 87ms/step - loss: 0.0227 - binary_accuracy: 1.0000 - val_loss: 0.0221 - val_binary_accuracy: 1.0000\n",
      "Epoch 92/100\n",
      "2/2 [==============================] - 0s 104ms/step - loss: 0.0220 - binary_accuracy: 1.0000 - val_loss: 0.0214 - val_binary_accuracy: 1.0000\n",
      "Epoch 93/100\n",
      "2/2 [==============================] - 0s 82ms/step - loss: 0.0214 - binary_accuracy: 1.0000 - val_loss: 0.0208 - val_binary_accuracy: 1.0000\n",
      "Epoch 94/100\n",
      "2/2 [==============================] - 0s 100ms/step - loss: 0.0207 - binary_accuracy: 1.0000 - val_loss: 0.0202 - val_binary_accuracy: 1.0000\n",
      "Epoch 95/100\n",
      "2/2 [==============================] - 0s 114ms/step - loss: 0.0201 - binary_accuracy: 1.0000 - val_loss: 0.0196 - val_binary_accuracy: 1.0000\n",
      "Epoch 96/100\n",
      "2/2 [==============================] - 0s 95ms/step - loss: 0.0196 - binary_accuracy: 1.0000 - val_loss: 0.0191 - val_binary_accuracy: 1.0000\n",
      "Epoch 97/100\n",
      "2/2 [==============================] - 0s 101ms/step - loss: 0.0190 - binary_accuracy: 1.0000 - val_loss: 0.0185 - val_binary_accuracy: 1.0000\n",
      "Epoch 98/100\n",
      "2/2 [==============================] - 0s 93ms/step - loss: 0.0185 - binary_accuracy: 1.0000 - val_loss: 0.0180 - val_binary_accuracy: 1.0000\n",
      "Epoch 99/100\n",
      "2/2 [==============================] - 0s 93ms/step - loss: 0.0179 - binary_accuracy: 1.0000 - val_loss: 0.0175 - val_binary_accuracy: 1.0000\n",
      "Epoch 100/100\n",
      "2/2 [==============================] - 0s 79ms/step - loss: 0.0175 - binary_accuracy: 1.0000 - val_loss: 0.0170 - val_binary_accuracy: 1.0000\n"
     ]
    }
   ],
   "source": [
    "history = cnn_abstractor.fit(X_train, y_train, validation_data=(X_train, y_train), epochs=100, verbose=1, batch_size=128)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEGCAYAAABhMDI9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABF3ElEQVR4nO3dd3iUZfbw8e+ZmVRC6ISegNIJvcMCgoooigoqVkDFxYLob3XFteGq79rXhiK64qKs0lwray/oIkLovUgNNbT0ZDIz9/vHTLJJSEKSmckzCedzXbmSeeaZmZPJPTnP3cUYg1JKKZXPZnUASimlQosmBqWUUkVoYlBKKVWEJgallFJFaGJQSilVhMPqACqqYcOGJiEhweowVA21atWqY8aYRla8tpZtFUwVKdvVLjEkJCSQlJRkdRiqhhKRvVa9tpZtFUwVKdvalKSUUqoITQxKKaWK0MSglFKqiGrXx6DKlpeXR3JyMjk5OVaHEtIiIyNp0aIFYWFhVodSIfr3VWcSiLKtiaGGSU5Opnbt2iQkJCAiVocTkowxHD9+nOTkZFq3bm11OBWif19VlkCVbW1KqmFycnJo0KCB/tMog4jQoEGDSl91i8g7InJURDaWcr+IyCsislNE1otIT78CLkT/vqos/pbtfJoYaiD9p3Fmfr5H7wIXlXH/KKCt7+s24A1/Xqw4/fuqsgSifAS1KUlELgJeBuzA28aYp4vdfz9wfaFYOgKNjDEnKvpay34/xpZD6dwyuHo1DajqxxizVEQSyjhlDDDXeNe0Xy4idUWkqTHmUNVEqALKlYPJOkm204Un1HcpsDmIadDU76cJWmIQETswE7gASAZWisinxpjN+ecYY54DnvOdfylwb2WSAsDHaw6wePUB+iTUo2uLun7HryovJiaGjIwMq8OwUnNgf6Hbyb5jpyUGEbkNb62CVq1aVUlwqgI8Hji+C3HnEhXqSQFwSjgQwokB6AvsNMbsAhCRD/FeSW0u5fxrgQ8q+2Izmq+k3+avuH9hDJ9OHUSEw17Zp1LKXyXV5Uv8t2KMmQ3MBujdu3c1+NcDe/bsYfTo0WzcWLSL5dZbb+X//u//6NSpk0WRBYbb5cKZkwmAw5lGmDuX3aYptsjaxDeoZXF0ZYsI0PMEs4+htKum04hINN4228Wl3H+biCSJSFJKSkqJLxadfYSxnq9pl/IVj39WWu5RVckYw/3330+XLl1ITExk/vz5ABw6dIghQ4bQvXt3unTpws8//4zb7WbixIkF5/7973+3OHq/JAMtC91uARy0KJYq8/bbbwckKbhcrgBEUzketxv30S1Epe0iKm0XYTnHOGVqkUUUzepE4Xa7LYutKgWzxlDuqybgUuC/pTUjleuqaugDsOsHnjv0LhesOIf3m8ZyQ//4SoRdczz+2SY2H0wL6HN2ahbLY5d2Lte5H330EWvXrmXdunUcO3aMPn36MGTIEP71r38xcuRIHnroIdxuN1lZWaxdu5YDBw4UXIWeOnUqoHFXsU+Bu3y15H5AajD6F6z8+7pcLiZMmMCaNWto164dc+fO5eKLL+b555+nd+/exMTEMG3aND7//HOioqL45JNPiIuL47PPPuPJJ5/E6XTSoEED5s2bR1xcHDNmzODgwYPs2bOHhg0bsn//fl599VW6d+8OwKBBg3jjjTfo2rXrabGsWLGCe+65h+zsbKKiopgzZw7t27fH7XbzwAMP8NVXXyEiTJ48malTp7Jy5UqmTZtGZmYmERERfPfddyxevJikpCSefuzPxOBi1KQ/M23aNIb8YTAtmrZg2j338u03X/PCCy/w/fff89lnn5Gdnc3AgQN58803ERF27tzJlClTSElJwW63s3DhQmbMmMG4ceMYM2YMANdffz3XXHMNl112WUD/boEWzBpDRa6axuNHMxIAdgdc+RYRYQ7m13qRFz/9jRW7K9VdoQLkl19+4dprr8VutxMXF8fQoUNZuXIlffr0Yc6cOcyYMYMNGzZQu3Zt2rRpw65du5g6dSpffvklsbGxVodfKhH5APgVaC8iySJyi4hMEZEpvlOWALuAncBbwB0WhRo027Zt47bbbmP9+vXExsby+uuvF7k/MzOT/v37s27dOoYMGcJbb70FwODBg1m+fDlr1qxh/PjxPPvsswWPWbVqFZ988gn/+te/uPXWW3n33XcB2L59O7m5uSUmBYAOHTqwdOlS1qxZw1//+lf+8pe/ADB79mx279zO6iX/ZO2Xc7n2vK7k7F7JNeOu4O8P3cmaJf/k67kvEnFiG56T+zAZx4jJO06mPRZ7WASR0TFE165LZmYm3bom8ttvvzF48GDuuusuVq5cycaNG8nOzubzzz8HvP/077zzTtatW8eyZcto2rQpt956K3PmzAEgNTWV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fft2vv32W+x2O3Xr1mXevHncc889fPvtt3Tr1q3EpAD/2zNCRHj77bd59tlneeGFF3jiiSeoU6cOGzZ4k/HJkydJSUlh8uTJLF26lNatW3PixJn3gNm2bRtz5swp2MPiqaeeon79+rjdbkaMGMH69evp0KED11xzDfPnz6dPnz6kpaURFRVVsE/FSy+9dMZ9KvyhiaGw2nHIRU/T6eMpnO/6iqe/bMrfrky0OqpqZ9y4cSxatIjDhw8zfvx45s2bR0pKCqtWrSIsLIyEhIQiyxqXR2lrel133XX069ePL774gpEjR/L2228zfPhwVq1axZIlS3jwwQe58MILefTRRwPxq4WWQCd+Y+DELkxuBntd9WhcJ+K0pACBT/59+/alTZs2AFx77bX88ssvpyWG1q1bF1wl9+rViz179gCwceNGHn74YU6dOkVGRgYjR44seMxVV11VsFz2zTffzJgxY7jnnnt45513ypwoV9qeEd9++y0ffvhhwXn16tXjs88+Y8iQIQXn1K9f/4y/b3x8PP379y+4vWDBAmbPno3L5eLQoUNs3rwZEaFp06YFi/Tlb1xVkX0q/BF6jVtW6zYe4gfxcMQCvlq5kfXJp6yOqNoZP348H374IYsWLWLcuHGkpqbSuHFjwsLC+OGHH9i7d2+Fn3PIkCHMmzcP8F4J7tu3j/bt27Nr1y7atGnD3XffzWWXXcb69es5ePAg0dHR3HDDDdx33326amt55aRCbhop1MPuiKBhTOlby+cn//nz55+W/NeuXUtcXFy5k3/xWkVJtYyIiP/FYrfbC/aFnjhxIq+99hobNmzgscceK/KatWrVKvi5ZcuWxMXF8f333/Pbb78xatSoUuOZOnUqd911Fxs2bODNN98seE5jzGmxlXQMwOFw4PF4Cm6XFtfu3bt5/vnn+e6771i/fj2XXHJJwf4OJT1vdHQ0F1xwAZ988gkLFizguutO2/ssIDQxFCcCFz9PlCeT6VEf8+gnm8rchEOdrnPnzqSnp9O8eXOaNm3K9ddfT1JSEr1792bevHl06NChws95xx134Ha7SUxM5JprruHdd98lIiKC+fPn06VLF7p3787WrVu56aab2LBhA3379qV79+489dRTPPzww0H4LWsYjxtSk8mzRXDEE0uzelFlDksNZPJfsWIFu3fvxuPxMH/+fAYPHlzux6anp9O0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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEGCAYAAABhMDI9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABF3ElEQVR4nO3dd3iUZfbw8e+ZmVRC6ISegNIJvcMCgoooigoqVkDFxYLob3XFteGq79rXhiK64qKs0lwray/oIkLovUgNNbT0ZDIz9/vHTLJJSEKSmckzCedzXbmSeeaZmZPJPTnP3cUYg1JKKZXPZnUASimlQosmBqWUUkVoYlBKKVWEJgallFJFaGJQSilVhMPqACqqYcOGJiEhweowVA21atWqY8aYRla8tpZtFUwVKdvVLjEkJCSQlJRkdRiqhhKRvVa9tpZtFUwVKdvalKSUUqoITQxKKaWK0MSglFKqiGrXx6DKlpeXR3JyMjk5OVaHEtIiIyNp0aIFYWFhVodSIfr3VWcSiLKtiaGGSU5Opnbt2iQkJCAiVocTkowxHD9+nOTkZFq3bm11OBWif19VlkCVbW1KqmFycnJo0KCB/tMog4jQoEGDSl91i8g7InJURDaWcr+IyCsislNE1otIT78CLkT/vqos/pbtfJoYaiD9p3Fmfr5H7wIXlXH/KKCt7+s24A1/Xqw4/fuqsgSifAS1KUlELgJeBuzA28aYp4vdfz9wfaFYOgKNjDEnKvpay34/xpZD6dwyuHo1DajqxxizVEQSyjhlDDDXeNe0Xy4idUWkqTHmUNVEqALKlYPJOkm204Un1HcpsDmIadDU76cJWmIQETswE7gASAZWisinxpjN+ecYY54DnvOdfylwb2WSAsDHaw6wePUB+iTUo2uLun7HryovJiaGjIwMq8OwUnNgf6Hbyb5jpyUGEbkNb62CVq1aVUlwqgI8Hji+C3HnEhXqSQFwSjgQwokB6AvsNMbsAhCRD/FeSW0u5fxrgQ8q+2Izmq+k3+avuH9hDJ9OHUSEw17Zp1LKXyXV5Uv8t2KMmQ3MBujdu3c1+NcDe/bsYfTo0WzcWLSL5dZbb+X//u//6NSpk0WRBYbb5cKZkwmAw5lGmDuX3aYptsjaxDeoZXF0ZYsI0PMEs4+htKum04hINN4228Wl3H+biCSJSFJKSkqJLxadfYSxnq9pl/IVj39WWu5RVckYw/3330+XLl1ITExk/vz5ABw6dIghQ4bQvXt3unTpws8//4zb7WbixIkF5/7973+3OHq/JAMtC91uARy0KJYq8/bbbwckKbhcrgBEUzketxv30S1Epe0iKm0XYTnHOGVqkUUUzepE4Xa7LYutKgWzxlDuqybgUuC/pTUjleuqaugDsOsHnjv0LhesOIf3m8ZyQ//4SoRdczz+2SY2H0wL6HN2ahbLY5d2Lte5H330EWvXrmXdunUcO3aMPn36MGTIEP71r38xcuRIHnroIdxuN1lZWaxdu5YDBw4UXIWeOnUqoHFXsU+Bu3y15H5AajD6F6z8+7pcLiZMmMCaNWto164dc+fO5eKLL+b555+nd+/exMTEMG3aND7//HOioqL45JNPiIuL47PPPuPJJ5/E6XTSoEED5s2bR1xcHDNmzODgwYPs2bOHhg0bsn//fl599VW6d+8OwKBBg3jjjTfo2rXrabGsWLGCe+65h+zsbKKiopgzZw7t27fH7XbzwAMP8NVXXyEiTJ48malTp7Jy5UqmTZtGZmYmERERfPfddyxevJikpCSefuzPxOBi1KQ/M23aNIb8YTAtmrZg2j338u03X/PCCy/w/fff89lnn5Gdnc3AgQN58803ERF27tzJlClTSElJwW63s3DhQmbMmMG4ceMYM2YMANdffz3XXHMNl112WUD/boEWzBpDRa6axuNHMxIAdgdc+RYRYQ7m13qRFz/9jRW7K9VdoQLkl19+4dprr8VutxMXF8fQoUNZuXIlffr0Yc6cOcyYMYMNGzZQu3Zt2rRpw65du5g6dSpffvklsbGxVodfKhH5APgVaC8iySJyi4hMEZEpvlOWALuAncBbwB0WhRo027Zt47bbbmP9+vXExsby+uuvF7k/MzOT/v37s27dOoYMGcJbb70FwODBg1m+fDlr1qxh/PjxPPvsswWPWbVqFZ988gn/+te/uPXWW3n33XcB2L59O7m5uSUmBYAOHTqwdOlS1qxZw1//+lf+8pe/ADB79mx279zO6iX/ZO2Xc7n2vK7k7F7JNeOu4O8P3cmaJf/k67kvEnFiG56T+zAZx4jJO06mPRZ7WASR0TFE165LZmYm3bom8ttvvzF48GDuuusuVq5cycaNG8nOzubzzz8HvP/077zzTtatW8eyZcto2rQpt956K3PmzAEgNTWV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fft2vv32W+x2O3Xr1mXevHncc889fPvtt3Tr1q3EpAD/2zNCRHj77bd59tlneeGFF3jiiSeoU6cOGzZ4k/HJkydJSUlh8uTJLF26lNatW3PixJn3gNm2bRtz5swp2MPiqaeeon79+rjdbkaMGMH69evp0KED11xzDfPnz6dPnz6kpaURFRVVsE/FSy+9dMZ9KvyhiaGw2nHIRU/T6eMpnO/6iqe/bMrfrky0OqpqZ9y4cSxatIjDhw8zfvx45s2bR0pKCqtWrSIsLIyEhIQiyxqXR2lrel133XX069ePL774gpEjR/L2228zfPhwVq1axZIlS3jwwQe58MILefTRRwPxq4WWQCd+Y+DELkxuBntd9WhcJ+K0pACBT/59+/alTZs2AFx77bX88ssvpyWG1q1bF1wl9+rViz179gCwceNGHn74YU6dOkVGRgYjR44seMxVV11VsFz2zTffzJgxY7jnnnt45513ypwoV9qeEd9++y0ffvhhwXn16tXjs88+Y8iQIQXn1K9f/4y/b3x8PP379y+4vWDBAmbPno3L5eLQoUNs3rwZEaFp06YFi/Tlb1xVkX0q/BF6jVtW6zYe4gfxcMQCvlq5kfXJp6yOqNoZP348H374IYsWLWLcuHGkpqbSuHFjwsLC+OGHH9i7d2+Fn3PIkCHMmzcP8F4J7tu3j/bt27Nr1y7atGnD3XffzWWXXcb69es5ePAg0dHR3HDDDdx33326amt55aRCbhop1MPuiKBhTOlby+cn//nz55+W/NeuXUtcXFy5k3/xWkVJtYyIiP/FYrfbC/aFnjhxIq+99hobNmzgscceK/KatWrVKvi5ZcuWxMXF8f333/Pbb78xatSoUuOZOnUqd911Fxs2bODNN98seE5jzGmxlXQMwOFw4PF4Cm6XFtfu3bt5/vnn+e6771i/fj2XXHJJwf4OJT1vdHQ0F1xwAZ988gkLFizguutO2/ssIDQxFCcCFz9PlCeT6VEf8+gnm8rchEOdrnPnzqSnp9O8eXOaNm3K9ddfT1JSEr1792bevHl06NChws95xx134Ha7SUxM5JprruHdd98lIiKC+fPn06VLF7p3787WrVu56aab2LBhA3379qV79+489dRTPPzww0H4LWsYjxtSk8mzRXDEE0uzelFlDksNZPJfsWIFu3fvxuPxMH/+fAYPHlzux6anp9O0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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "utils.plot_history(history, ('loss', 'binary_accuracy'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train accuracy: 100.00%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = cnn_abstractor(X_train)\n",
    "yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "print('train accuracy: %.2f%%\\n' % (100*np.mean(yhat==y_train)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test accuracy: 100.00%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = cnn_abstractor(X_test)\n",
    "yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "100*np.mean(yhat==y_test)\n",
    "print('test accuracy: %.2f%%\\n' % (100*np.mean(yhat==y_test)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "out = cnn_abstractor.save_weights(\"larger_than_relation_weights\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"simplest_abstractor_cnn\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  104704    \n",
      "                                                                 \n",
      " cnn_embedder (TimeDistribut  multiple                 104704    \n",
      " ed)                                                             \n",
      "                                                                 \n",
      " flatten_3 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " query_projection (Dense)    multiple                  4160      \n",
      "                                                                 \n",
      " key_projection (Dense)      multiple                  4160      \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  672       \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 113,749\n",
      "Trainable params: 9,025\n",
      "Non-trainable params: 104,724\n",
      "_________________________________________________________________\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<tensorflow.python.checkpoint.checkpoint.CheckpointLoadStatus at 0x7f90a698b400>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model2 = SimplestAbstractorCNN(num_classes=2, sequence_len=2, symbol_dim=10, embedding_dim=64)\n",
    "model2.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "model2(X_train[:32])\n",
    "model2.summary()\n",
    "model2.load_weights(\"larger_than_relation_weights\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Overall accuracy: 100.00%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = model2(X)\n",
    "yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "print('Overall accuracy: %.2f%%\\n' % (100*np.mean(yhat==y)))"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "075427e9d7b4e88d8be5fc9c4269e9099fc3e822a226ecef7da6e611953d0392"
  },
  "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
