{
 "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",
    "import utils\n",
    "import imageio"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8910, 6, 32, 32, 1) (8910,) (990, 6, 32, 32, 1) (990,)\n",
      "(200, 2, 32, 32, 1) (200,)\n"
     ]
    }
   ],
   "source": [
    "dat = np.load('imgs_size/RMTS_size_m0.npz')\n",
    "\n",
    "X_train = dat['train_x']\n",
    "y_train = dat['train_y']\n",
    "X_test = dat['test_x']\n",
    "y_test = dat['test_y']\n",
    "X_train = 255 - X_train \n",
    "X_test = 255 - X_test\n",
    "\n",
    "X_full = np.expand_dims(X_train, axis=-1)\n",
    "y_full = y_train\n",
    "X_train = X_full\n",
    "X_test = np.expand_dims(X_test, axis=-1)\n",
    "print(X_full.shape, y_full.shape, X_test.shape, y_test.shape)\n",
    "\n",
    "dat = np.load('imgs_size/RMTS_size_pretrain.npz')\n",
    "X_pair = dat['x']\n",
    "y_pair = dat['y']\n",
    "X_pair = 255 - X_pair\n",
    "X_pair = np.expand_dims(X_pair, axis=-1)\n",
    "print(X_pair.shape, y_pair.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 144x360 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x360 with 30 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def display_sample(X, y, to_show=10):\n",
    "    seq_len = int(X.shape[1]/2)\n",
    "    fig, axarr = plt.subplots(to_show, 2*seq_len, figsize=(2*seq_len, 5))\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[ind,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[ind], loc='right')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "display_sample(X_pair, y_pair, to_show=5)\n",
    "display_sample(X_train, y_train, to_show=5)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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_5 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " query_projection (Dense)    multiple                  4160      \n",
      "                                                                 \n",
      " key_projection (Dense)      multiple                  4160      \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  1952      \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 115,069\n",
      "Trainable params: 10,305\n",
      "Non-trainable params: 104,764\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "from simplest_abstractor import SimplestAbstractorCNN\n",
    "create_opt = lambda : tf.keras.optimizers.Adam(learning_rate=0.001)\n",
    "\n",
    "cnn_abstractor = SimplestAbstractorCNN(num_classes=2, sequence_len=6, symbol_dim=10, embedding_dim=64)\n",
    "cnn_abstractor.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "cnn_abstractor(X_full[:32])\n",
    "cnn_abstractor.summary()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/10\n",
      "279/279 [==============================] - 12s 44ms/step - loss: 0.6928 - binary_accuracy: 0.5112 - val_loss: 0.6930 - val_binary_accuracy: 0.5128\n",
      "Epoch 2/10\n",
      "279/279 [==============================] - 11s 41ms/step - loss: 0.6935 - binary_accuracy: 0.5081 - val_loss: 0.6922 - val_binary_accuracy: 0.5230\n",
      "Epoch 3/10\n",
      "279/279 [==============================] - 13s 45ms/step - loss: 0.3467 - binary_accuracy: 0.8022 - val_loss: 0.0221 - val_binary_accuracy: 0.9997\n",
      "Epoch 4/10\n",
      "279/279 [==============================] - 12s 45ms/step - loss: 0.0115 - binary_accuracy: 0.9999 - val_loss: 0.0060 - val_binary_accuracy: 1.0000\n",
      "Epoch 5/10\n",
      "279/279 [==============================] - 13s 46ms/step - loss: 0.0044 - binary_accuracy: 1.0000 - val_loss: 0.0031 - val_binary_accuracy: 1.0000\n",
      "Epoch 6/10\n",
      "279/279 [==============================] - 13s 45ms/step - loss: 0.0025 - binary_accuracy: 1.0000 - val_loss: 0.0020 - val_binary_accuracy: 1.0000\n",
      "Epoch 7/10\n",
      "279/279 [==============================] - 12s 42ms/step - loss: 0.0016 - binary_accuracy: 1.0000 - val_loss: 0.0013 - val_binary_accuracy: 1.0000\n",
      "Epoch 8/10\n",
      "279/279 [==============================] - 13s 47ms/step - loss: 0.0012 - binary_accuracy: 1.0000 - val_loss: 9.7722e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 9/10\n",
      "279/279 [==============================] - 10s 36ms/step - loss: 8.6623e-04 - binary_accuracy: 1.0000 - val_loss: 7.3859e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 10/10\n",
      "279/279 [==============================] - 9s 32ms/step - loss: 6.6420e-04 - binary_accuracy: 1.0000 - val_loss: 5.7725e-04 - val_binary_accuracy: 1.0000\n"
     ]
    }
   ],
   "source": [
    "history = cnn_abstractor.fit(X_train, y_train, validation_data=(X_train, y_train), epochs=10, verbose=1, batch_size=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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A+D444/nzTff5L333mPRokX8+te/Dh3zzjvv8PTTT/M///M/XHrppTz44IMAbNmyhaampogiADBlyhRWrVrFe++9x89//nN+9KMfAbBs2TK2b9/Oe++9x/vvv895551Hc3MzCxcu5M4772TdunW8+OKL5ObmdvpnqK+vZ+rUqbz11lscf/zxXHXVVaxevZoNGzbQ0NDAs88+Czg3+SuvvJJ169bx+uuvM3z4cC699FKWL18OQHV1Na+//jqnn356DH/8xNI/x19JoClrCLn1+6j2tlDoGVirTaMR65N7vHCCZjoye/ZsVq1axXPPPccFF1zA9ddfz4UXXsi6det44YUXuPvuu3n00Ud54IEHEmxxbKjquV3sV+DKeNsR9+/X1wquyG6Q0aNHc9xxxwFw/vnn87vf/S60T1XJzMri9K99DYCjjjqKf/7TCeQoKysLuQebm5vbLHo644wzQjflBQsWcMstt3DbbbfxwAMPcPHFF0c1s7q6mosuuoiPPvoIEaGlxZnbePHFF7n88stDbqaioiLWr1/P8OHDmTlzJkBMDxxut5t58+aFPr/yyiv8+te/xuv1UlVVxaGHHsqJJ57Irl27OOusswBndS/ACSecwJVXXsmePXt48sknmTdvXr90e9mIIIDmFlFELR9XpHW0S58ye/ZsHnnkEXw+H+Xl5axatYpZs2bx6aefMnToUBYvXsy3vvUt3n33XSoqKvD7/cybN49bbrmFd999N9nmG8ERQQTaT+qGf27x+cnIyMST5RzrdrtpbXXmG5YsWcJVV13F+vXr+cMf/tBm4VNeXl7ovcfj4atf/SpPP/00jz76KN/4Roc4kxA/+clP+PKXv8yGDRt45plnQudU1Q52RtoGkJGRgT8s1DXcrpycnNC8QGNjI9/5znd4/PHHWb9+PYsXL6axsTHqQw/ABRdcwIoVK1i+fDmXXHJJ1HbJxIQgQGbBUIqkho/3mBD0FWeddRaHHXYYhx9+OHPmzOHXv/41BxxwAK+++irTp0/niCOO4IknnuCaa65h165dnHjiiUyfPp2LL76Y//t//2+yzTc6EYIdO3bwxhtvAPCXv/yF448/PrSvocW5oeZmdhxNVFdXM3Kks670T3/6U6eXv/TSS7n66quZOXMmRUVFUduFnzPoTgI4+eSTuffee0MiVFVVxZQpU9i9ezerV68GoLa2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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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A+D444/nzTff5L333mPRokX8+te/Dh3zzjvv8PTTT/M///M/XHrppTz44IMAbNmyhaampogiADBlyhRWrVrFe++9x89//nN+9KMfAbBs2TK2b9/Oe++9x/vvv895551Hc3MzCxcu5M4772TdunW8+OKL5ObmdvpnqK+vZ+rUqbz11lscf/zxXHXVVaxevZoNGzbQ0NDAs88+Czg3+SuvvJJ169bx+uuvM3z4cC699FKWL18OQHV1Na+//jqnn356DH/8xNI/x19JoClrCLn1+6j2tlDoGVirTaMR65N7vHCCZjoye/ZsVq1axXPPPccFF1zA9ddfz4UXXsi6det44YUXuPvuu3n00Ud54IEHEmxxbKjquV3sV+DKeNsR9+/X1wquyG6Q0aNHc9xxxwFw/vnn87vf/S60T1XJzMri9K99DYCjjjqKf/7TCeQoKysLuQebm5vbLHo644wzQjflBQsWcMstt3DbbbfxwAMPcPHFF0c1s7q6mosuuoiPPvoIEaGlxZnbePHFF7n88stDbqaioiLWr1/P8OHDmTlzJkBMDxxut5t58+aFPr/yyiv8+te/xuv1UlVVxaGHHsqJJ57Irl27OOusswBndS/ACSecwJVXXsmePXt48sknmTdvXr90e9mIIIDmFlFELR9XpHW0S58ye/ZsHnnkEXw+H+Xl5axatYpZs2bx6aefMnToUBYvXsy3vvUt3n33XSoqKvD7/cybN49bbrmFd999N9nmG8ERQQTaT+qGf27x+cnIyMST5RzrdrtpbXXmG5YsWcJVV13F+vXr+cMf/tBm4VNeXl7ovcfj4atf/SpPP/00jz76KN/4Roc4kxA/+clP+PKXv8yGDRt45plnQudU1Q52RtoGkJGRgT8s1DXcrpycnNC8QGNjI9/5znd4/PHHWb9+PYsXL6axsTHqQw/ABRdcwIoVK1i+fDmXXHJJ1HbJxIQgQGbBUIqkho/3mBD0FWeddRaHHXYYhx9+OHPmzOHXv/41BxxwAK+++irTp0/niCOO4IknnuCaa65h165dnHjiiUyfPp2LL76Y//t//2+yzTc6EYIdO3bwxhtvAPCXv/yF448/PrSvocW5oeZmdhxNVFdXM3Kks670T3/6U6eXv/TSS7n66quZOXMmRUVFUduFnzPoTgI4+eSTuffee0MiVFVVxZQpU9i9ezerV68GoLa2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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'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": 16,
   "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",
    "print('test accuracy: %.2f%%\\n' % (100*np.mean(yhat==y_test)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "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_9 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " query_projection (Dense)    multiple                  4160      \n",
      "                                                                 \n",
      " key_projection (Dense)      multiple                  4160      \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  1952      \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 115,069\n",
      "Trainable params: 10,305\n",
      "Non-trainable params: 104,764\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "pretrained_abstractor = SimplestAbstractorCNN(num_classes=2, sequence_len=6, symbol_dim=10, embedding_dim=64)\n",
    "pretrained_abstractor.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "pretrained_abstractor(X_train[:32])\n",
    "pretrained_abstractor.summary()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pretrained test accuracy: 48.28%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = pretrained_abstractor(X_test)\n",
    "yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "print('pretrained test accuracy: %.2f%%\\n' % (100*np.mean(yhat==y_test)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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_11 (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": [
    "pretrained_relation = SimplestAbstractorCNN(num_classes=2, sequence_len=2, symbol_dim=10, embedding_dim=64)\n",
    "pretrained_relation.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "pretrained_relation(X_pair[:32])\n",
    "pretrained_relation.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "relation accuracy: 100.00%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "pretrained_relation.load_weights(\"larger_than_relation_weights\")\n",
    "out = pretrained_relation(X_pair)\n",
    "yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "print('relation accuracy: %.2f%%\\n' % (100*np.mean(yhat==y_pair)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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_13 (Flatten)        multiple                  0         \n",
      "                                                                 \n",
      " query_projection (Dense)    multiple                  4160      \n",
      "                                                                 \n",
      " key_projection (Dense)      multiple                  4160      \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  1952      \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 115,069\n",
      "Trainable params: 10,305\n",
      "Non-trainable params: 104,764\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "pretrained_abstractor = SimplestAbstractorCNN(num_classes=2, sequence_len=6, symbol_dim=10, embedding_dim=64)\n",
    "pretrained_abstractor.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "pretrained_abstractor(X_train[:32])\n",
    "pretrained_abstractor.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load pretrained relational cross attention\n",
    "pretrained_abstractor.cnn_encoder.set_weights(pretrained_relation.cnn_encoder.get_weights())\n",
    "pretrained_abstractor.cnn_embedder.set_weights(pretrained_relation.cnn_embedder.get_weights())\n",
    "pretrained_abstractor.query_projection.set_weights(pretrained_relation.query_projection.get_weights())\n",
    "pretrained_abstractor.key_projection.set_weights(pretrained_relation.key_projection.get_weights())\n",
    "\n",
    "\n",
    "# load pretrained symbolic processing rule\n",
    "if (True):\n",
    "    pretrained_abstractor.hidden_layer.set_weights(cnn_abstractor.hidden_layer.get_weights())\n",
    "    pretrained_abstractor.final_layer.set_weights(cnn_abstractor.final_layer.get_weights())\n",
    "    pretrained_abstractor.symbols = cnn_abstractor.symbols"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/30\n",
      "5/5 [==============================] - 3s 170ms/step - loss: 0.0059 - binary_accuracy: 1.0000 - val_loss: 0.0042 - val_binary_accuracy: 1.0000\n",
      "Epoch 2/30\n",
      "5/5 [==============================] - 0s 65ms/step - loss: 0.0040 - binary_accuracy: 1.0000 - val_loss: 0.0033 - val_binary_accuracy: 1.0000\n",
      "Epoch 3/30\n",
      "5/5 [==============================] - 0s 62ms/step - loss: 0.0031 - binary_accuracy: 1.0000 - val_loss: 0.0028 - val_binary_accuracy: 1.0000\n",
      "Epoch 4/30\n",
      "5/5 [==============================] - 0s 64ms/step - loss: 0.0027 - binary_accuracy: 1.0000 - val_loss: 0.0024 - val_binary_accuracy: 1.0000\n",
      "Epoch 5/30\n",
      "5/5 [==============================] - 0s 69ms/step - loss: 0.0023 - binary_accuracy: 1.0000 - val_loss: 0.0021 - val_binary_accuracy: 1.0000\n",
      "Epoch 6/30\n",
      "5/5 [==============================] - 0s 84ms/step - loss: 0.0021 - binary_accuracy: 1.0000 - val_loss: 0.0019 - val_binary_accuracy: 1.0000\n",
      "Epoch 7/30\n",
      "5/5 [==============================] - 0s 69ms/step - loss: 0.0018 - binary_accuracy: 1.0000 - val_loss: 0.0017 - val_binary_accuracy: 1.0000\n",
      "Epoch 8/30\n",
      "5/5 [==============================] - 0s 69ms/step - loss: 0.0017 - binary_accuracy: 1.0000 - val_loss: 0.0015 - val_binary_accuracy: 1.0000\n",
      "Epoch 9/30\n",
      "5/5 [==============================] - 0s 71ms/step - loss: 0.0015 - binary_accuracy: 1.0000 - val_loss: 0.0014 - val_binary_accuracy: 1.0000\n",
      "Epoch 10/30\n",
      "5/5 [==============================] - 0s 89ms/step - loss: 0.0014 - binary_accuracy: 1.0000 - val_loss: 0.0013 - val_binary_accuracy: 1.0000\n",
      "Epoch 11/30\n",
      "5/5 [==============================] - 0s 65ms/step - loss: 0.0013 - binary_accuracy: 1.0000 - val_loss: 0.0012 - val_binary_accuracy: 1.0000\n",
      "Epoch 12/30\n",
      "5/5 [==============================] - 0s 117ms/step - loss: 0.0012 - binary_accuracy: 1.0000 - val_loss: 0.0012 - val_binary_accuracy: 1.0000\n",
      "Epoch 13/30\n",
      "5/5 [==============================] - 0s 63ms/step - loss: 0.0012 - binary_accuracy: 1.0000 - val_loss: 0.0011 - val_binary_accuracy: 1.0000\n",
      "Epoch 14/30\n",
      "5/5 [==============================] - 0s 71ms/step - loss: 0.0011 - binary_accuracy: 1.0000 - val_loss: 0.0010 - val_binary_accuracy: 1.0000\n",
      "Epoch 15/30\n",
      "5/5 [==============================] - 0s 75ms/step - loss: 0.0010 - binary_accuracy: 1.0000 - val_loss: 9.9162e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 16/30\n",
      "5/5 [==============================] - 0s 71ms/step - loss: 9.8967e-04 - binary_accuracy: 1.0000 - val_loss: 9.3917e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 17/30\n",
      "5/5 [==============================] - 0s 77ms/step - loss: 9.3410e-04 - binary_accuracy: 1.0000 - val_loss: 8.9472e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 18/30\n",
      "5/5 [==============================] - 0s 82ms/step - loss: 8.8647e-04 - binary_accuracy: 1.0000 - val_loss: 8.5464e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 19/30\n",
      "5/5 [==============================] - 0s 83ms/step - loss: 8.4494e-04 - binary_accuracy: 1.0000 - val_loss: 8.1926e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 20/30\n",
      "5/5 [==============================] - 0s 76ms/step - loss: 8.0795e-04 - binary_accuracy: 1.0000 - val_loss: 7.8328e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 21/30\n",
      "5/5 [==============================] - 0s 70ms/step - loss: 7.7547e-04 - binary_accuracy: 1.0000 - val_loss: 7.5216e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 22/30\n",
      "5/5 [==============================] - 0s 72ms/step - loss: 7.4603e-04 - binary_accuracy: 1.0000 - val_loss: 7.2116e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 23/30\n",
      "5/5 [==============================] - 0s 62ms/step - loss: 7.1357e-04 - binary_accuracy: 1.0000 - val_loss: 6.9158e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 24/30\n",
      "5/5 [==============================] - 0s 63ms/step - loss: 6.8569e-04 - binary_accuracy: 1.0000 - val_loss: 6.6611e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 25/30\n",
      "5/5 [==============================] - 0s 70ms/step - loss: 6.6265e-04 - binary_accuracy: 1.0000 - val_loss: 6.4018e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 26/30\n",
      "5/5 [==============================] - 0s 68ms/step - loss: 6.3567e-04 - binary_accuracy: 1.0000 - val_loss: 6.1658e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 27/30\n",
      "5/5 [==============================] - 0s 77ms/step - loss: 6.1425e-04 - binary_accuracy: 1.0000 - val_loss: 5.9408e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 28/30\n",
      "5/5 [==============================] - 0s 92ms/step - loss: 5.8541e-04 - binary_accuracy: 1.0000 - val_loss: 5.7397e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 29/30\n",
      "5/5 [==============================] - 0s 71ms/step - loss: 5.6688e-04 - binary_accuracy: 1.0000 - val_loss: 5.5438e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 30/30\n",
      "5/5 [==============================] - 0s 72ms/step - loss: 5.5030e-04 - binary_accuracy: 1.0000 - val_loss: 5.3514e-04 - val_binary_accuracy: 1.0000\n"
     ]
    }
   ],
   "source": [
    "num_tr = 150\n",
    "history = pretrained_abstractor.fit(X_train[:num_tr], y_train[:num_tr], validation_data=(X_train[:num_tr], y_train[:num_tr]), epochs=30, verbose=1, batch_size=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pretrained test accuracy: 99.90%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = pretrained_abstractor(X_test)\n",
    "yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "print('pretrained test accuracy: %.2f%%\\n' % (100*np.mean(yhat==y_test)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "def initialize_pretrained_abstractor(pretrained_relation=None):\n",
    "\n",
    "    pretrained_abstractor = SimplestAbstractorCNN(num_classes=2, sequence_len=6, symbol_dim=10, embedding_dim=64)\n",
    "    pretrained_abstractor.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "    pretrained_abstractor(X_full[:32])\n",
    "\n",
    "    # load pretrained relational cross attention\n",
    "    if (pretrained_relation != None):\n",
    "        pretrained_abstractor.cnn_encoder.set_weights(pretrained_relation.cnn_encoder.get_weights())\n",
    "        pretrained_abstractor.cnn_embedder.set_weights(pretrained_relation.cnn_embedder.get_weights())\n",
    "        pretrained_abstractor.query_projection.set_weights(pretrained_relation.query_projection.get_weights())\n",
    "        pretrained_abstractor.key_projection.set_weights(pretrained_relation.key_projection.get_weights())\n",
    "\n",
    "    return pretrained_abstractor "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_callbacks(patience=7):\n",
    "    callbacks = []\n",
    "    callbacks.append(tf.keras.callbacks.EarlyStopping(monitor='val_loss', \n",
    "        patience=patience, min_delta=0, start_from_epoch=30, mode='auto', restore_best_weights=True, verbose=True))\n",
    "    return callbacks\n",
    "\n",
    "def train_abstractor_models(train_sizes, num_trials, num_epochs, relation=None):\n",
    "    from tqdm import tqdm\n",
    "    from sklearn.model_selection import train_test_split\n",
    "    accs = list()\n",
    "    n_val = 100\n",
    "    for n in tqdm(train_sizes):\n",
    "        trial_accs = []\n",
    "        for trial in np.arange(num_trials):\n",
    "            model = initialize_pretrained_abstractor(pretrained_relation=relation)\n",
    "            X_train, X_val, y_train, y_val = train_test_split(X_full, y_full, train_size=n, test_size=n_val)\n",
    "            model.fit(X_train, y_train, validation_data=(X_val, y_val), callbacks=create_callbacks(), epochs=num_epochs, verbose=0)\n",
    "            out = model(X_test)\n",
    "            yhat = np.array([int(o) for o in np.round(np.squeeze(out.numpy()))])\n",
    "            acc = 100*np.mean(yhat==y_test)\n",
    "            trial_accs.append(acc)\n",
    "        accs.append(trial_accs)\n",
    "    return accs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_epochs = 200\n",
    "num_trials = 10\n",
    "\n",
    "pretrained_n = [5, 10, 50, 100, 150, 200, 250, 300]\n",
    "pretrained_accs = train_abstractor_models(pretrained_n, num_trials=num_trials, num_epochs=num_epochs,   relation=pretrained_relation)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_epochs = 200\n",
    "num_trials = 50\n",
    "de_novo_n = [50, 250, 500, 750, 1000, 1250, 1500, 1750, 2000]\n",
    "de_novo_accs = train_abstractor_models(de_novo_n, num_trials=num_trials, num_epochs=num_epochs, relation=None)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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N16v4X6lmmqUev8hpZ7+glK/rlDqR7OUujtJe/xktlJ/uEipf/y7UgfWKzXUGx4vgxFpr127do37WXd3d1gcenp61OzZs9XevXvVwoULvcvfeecddfbZZ6srr7xSnXbaaepLX/qScjqdqrOzU910002quLhYlZSUqJ/97GfqqaeeUvHx8aqwsFCVlpaq/v5+NXfuXHXvvfeqlStXqscff1z9/ve/V+Xl5Wrx4sXq6quvVn19fUoppZqbm9WVV16pFi9erBYvXqzeffdddf3116uYmBhVWlqqvv3tbyuXy6W+/e1ve4/5t7/9zeu4du1adeONN45yV0qpO+64Q1ksFlVaWqo+/elPq9raWrVo0SL15S9/WS1ZskTV1dWpW2+9VS1btkwVFRWpu+66y7vtmjVr1AcffKCUUio+Pl7927/9m1q8eLGqqKhQzc3NSimlWltb1dVXX63Ky8tVeXm52rBhg1JKqba2NnX++eerJUuWqFtuuUXNmTNH1dbWHnfe//jHP6oFCxao1atXqy9+8Yvqq1/9asD9+vLwww+rq666Sl144YXq1FNPVd/5zne8nz322GOqpKREFRcXq+9+97tKKaV+85vfjFrn4YcfVl/72tdUd3e3+ulPf6qKi4tVcXGx+vnPf+73O+Lve0qANBfhrj56EbgJuM/9/ILP8sdE5GfAbGABsFkvCWXEKUg/foesuhdg773QdRD629wfCCTlwPxzYN7ZsOBCyDg1rHfbhjxfGMvr3r/vZNfhbu/7UO+u/VE0O4m7P1kccJ3nn3+eiy66iMLCQtLS0ti6dStlZWUAbN68mV27djF37lwuuuginn32WTIzM2lsbPTexXd1dZGSksKDDz54XEkhJibGWyXX3t7Ov/7rvwLwgx/8gD/84Q/cdtttfP3rX2fNmjU899xzOJ1Oent7ue+++6ipqWHbtm0APPPMM2zbto3q6mra2to444wzWL16tdexpqbmuDvx++67jwcffNC7j7q6Ovbu3cvDDz/Mb37zGwB+8pOfkJaWhtPp5Nxzz2X79u0sXrx41H76+vo488wz+clPfsJ3v/td/ud//ocf/OAHfOMb3+Cb3/wmq1at4tChQ1x44YXs3r2be++9l1WrVnHXXXfx8ssv8/vf//64c97U1MTdd9/Nli1bSE5O5pxzzmHp0qUA4+53LNu2bePDDz/Ebrez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J8BDDz3kTQ0yFfT6js3IksK04XTA/jfg3V9A/fsQPwuWfxPO/LKWUtrExGBccsklYS1hORyOcaeNrKysJCEhgbPOOiuk7crLyyecE2A6mWovn7F/56233jodWroxI0sK6enpU9+JUlD1B20wWv37kFMKl/0Czv72pAPCtHjpgOkVOkaocvjlL39JUVERixcv5oYbbgDgscce897Z3nzzzXz961/nrLPOYv78+Tz99NOAlr/nK1/5CsXFxVx22WVccskl3s98Wbt2LbfffjtnnXUWJSUlbN6sJTa+5557uOWWW7jgggv47Gc/y5EjR7jmmms444wzOOOMM3j33Xepq6vjoYce4uc//zlLlizh/fff5+abb+Zb3/oW55xzDnfccQebN2/mrLPOYunSpZx11lneSacqKyu9Se7uuecePv/5z7N27Vrmz5/PL3/5S6/fX//6V5YvX86SJUv40pe+5B01/fDDD1NYWMiaNWt49913/Z4737/hS1/6kt+/YSx///vfqaioYOnSpZx33nm0tLQc93f+85//HFWa27ZtG2eeeSaLFy/mqquu8o7SX7t2LXfccQfLly+nsLCQf/7zn8cdT6/v2IwsKRQXT0Pysrp/wj9+DI5BKL4a1nwXMqc24cq0eOmA6RUEr96pTYLkJhYFE8wwNyHZp8PFk6/que+++6itrcVut9PV1QUc3zjZ1NTEhg0b2LNnD5dffjnXXnstzz77LHV1dezYsYPW1lZOO+00Pv/5z/s9Rl9fH++99x7r16/n85//vDcl95YtW9iwYQOxsbF8+tOf9ptO+tZbbyUhIYFvf/vbKKV49NFH2bdvH2+99RZWq5Xu7m7Wr19PVFQUb731Fv/2b//GM88cP+/Wnj17eOedd+jp6WHhwoV8+ctf5qOPPuKJJ57g3XffJTo6mq985Ss8+uijnH/++eOmvR6L52+IiYnhM5/5zIQpsVetWsX777+PiPC///u/3H///fz0pz8d9XcCvP32295tPvvZz/KrX/2KNWvWcNddd3Hvvffy3//934BWQtm8eTOvvPIK9957L2+99dao402UdG+yzMigsH79+qmlR2j7CPa8os1UVnw1XPIAxE/9rnXKXjpheoWO0+kkyqrvv9d4mTo9yz15g6688kquvPJKAO90kh6uvPJKLBYLRUVFtLS0AFqq6+uuuw6LxUJ2djbn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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_comparison(pretrained_n, pretrained_accs, scratch_n, scratch_accs):\n",
    "    import scipy.stats\n",
    "    scratch_accuracy = np.mean(scratch_accs, axis=1)\n",
    "    scratch_acc_sem = scipy.stats.sem(scratch_accs, axis=1)\n",
    "    pretrained_accuracy = np.mean(pretrained_accs, axis=1)\n",
    "    pretrained_acc_sem = scipy.stats.sem(pretrained_accs, axis=1)\n",
    "    fig, ax = plt.subplots(figsize=(6,4))\n",
    "    ax.plot(scratch_n, scratch_accuracy, label='Abstractor trained de novo')\n",
    "    ax.fill_between(scratch_n, scratch_accuracy - scratch_acc_sem,\n",
    "        scratch_accuracy + scratch_acc_sem, alpha=0.5)\n",
    "    ax.plot(pretrained_n, pretrained_accuracy, label='Using pretrained relation')\n",
    "    ax.fill_between(pretrained_n, pretrained_accuracy - pretrained_acc_sem,\n",
    "        pretrained_accuracy + pretrained_acc_sem, alpha=0.5)\n",
    "    ax.set_xlabel('Training Set Size')\n",
    "    ax.legend()\n",
    "    ax.set_ylabel('RMTS Classification Accuracy')\n",
    "    ax.grid(linestyle='dashed')\n",
    "    fig.savefig('rmts_accuracies.pdf')\n",
    "    plt.show()\n",
    "\n",
    "plot_comparison(pretrained_n, pretrained_accs, de_novo_n, de_novo_accs)\n",
    "\n",
    "\n"
   ]
  }
 ],
 "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
}
