{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-15 15:34:45.416889: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 AVX512F AVX512_VNNI FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2023-05-15 15:34:45.628803: I tensorflow/core/util/util.cc:169] oneDNN custom operations are on. You may see slightly different numerical results due to floating-point round-off errors from different computation orders. To turn them off, set the environment variable `TF_ENABLE_ONEDNN_OPTS=0`.\n",
      "2023-05-15 15:34:45.673417: E tensorflow/stream_executor/cuda/cuda_blas.cc:2981] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "2023-05-15 15:34:46.424912: W tensorflow/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libnvinfer.so.7'; dlerror: libnvinfer.so.7: cannot open shared object file: No such file or directory; LD_LIBRARY_PATH: /gpfs/loomis/apps/avx/software/cuDNN/8.1.1.33-CUDA-11.2.2/lib:/gpfs/loomis/apps/avx/software/CUDAcore/11.2.2/nvvm/lib64:/gpfs/loomis/apps/avx/software/CUDAcore/11.2.2/extras/CUPTI/lib64:/gpfs/loomis/apps/avx/software/CUDAcore/11.2.2/lib:/vast/palmer/apps/avx.grace/software/Code-Server/4.7.0/lib:/gpfs/loomis/apps/avx/software/Perl/5.32.0-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/DB/18.1.40-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/libreadline/8.0-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/gettext/0.21-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/ncurses/6.2-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/libxml2/2.9.10-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/XZ/5.2.5-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/expat/2.2.9-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/cURL/7.72.0-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/zlib/1.2.11-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/GCCcore/10.2.0/lib64:/gpfs/loomis/apps/avx/software/GCCcore/10.2.0/lib\n",
      "2023-05-15 15:34:46.425073: W tensorflow/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libnvinfer_plugin.so.7'; dlerror: libnvinfer_plugin.so.7: cannot open shared object file: No such file or directory; LD_LIBRARY_PATH: /gpfs/loomis/apps/avx/software/cuDNN/8.1.1.33-CUDA-11.2.2/lib:/gpfs/loomis/apps/avx/software/CUDAcore/11.2.2/nvvm/lib64:/gpfs/loomis/apps/avx/software/CUDAcore/11.2.2/extras/CUPTI/lib64:/gpfs/loomis/apps/avx/software/CUDAcore/11.2.2/lib:/vast/palmer/apps/avx.grace/software/Code-Server/4.7.0/lib:/gpfs/loomis/apps/avx/software/Perl/5.32.0-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/DB/18.1.40-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/libreadline/8.0-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/gettext/0.21-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/ncurses/6.2-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/libxml2/2.9.10-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/XZ/5.2.5-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/expat/2.2.9-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/cURL/7.72.0-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/zlib/1.2.11-GCCcore-10.2.0/lib:/gpfs/loomis/apps/avx/software/GCCcore/10.2.0/lib64:/gpfs/loomis/apps/avx/software/GCCcore/10.2.0/lib\n",
      "2023-05-15 15:34:46.425085: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Cannot dlopen some TensorRT libraries. If you would like to use Nvidia GPU with TensorRT, please make sure the missing libraries mentioned above are installed properly.\n"
     ]
    }
   ],
   "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": 2,
   "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) / 255\n",
    "X_test = (255 - X_test) / 255\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": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x500 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x500 with 30 Axes>"
      ]
     },
     "metadata": {},
     "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": "markdown",
   "metadata": {},
   "source": [
    "## Abstractor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from simplest_abstractor import CnnEncoder\n",
    "from abstracters import SimpleAbstractor, RelationalAbstracter\n",
    "from abstractor import Abstractor\n",
    "from tensorflow.keras import layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"rmts_abstractor\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  104704    \n",
      "                                                                 \n",
      " abstractor_2 (Abstractor)   multiple                  8490      \n",
      "                                                                 \n",
      " flatten_5 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  1952      \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 115,179\n",
      "Trainable params: 10,475\n",
      "Non-trainable params: 104,704\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "embedding_dim = 64\n",
    "\n",
    "abstractor_kwargs = dict(\n",
    "        num_layers=1,\n",
    "        rel_dim=1,\n",
    "        symbol_dim=10,\n",
    "        proj_dim=64,\n",
    "        symmetric_rels=False,\n",
    "        encoder_kwargs=None,\n",
    "        rel_activation_type='softmax',\n",
    "        use_self_attn=False,\n",
    "        use_layer_norm=False,\n",
    "        dropout_rate=0.1,)\n",
    "\n",
    "cnn_encoder_kwargs = dict(ff_dim2=embedding_dim, normalize=True, name='cnn_encoder')\n",
    "\n",
    "class AbstractorRMTSModel(tf.keras.Model):\n",
    "    def __init__(self, embedding_dim, abstractor_kwargs, name=None):\n",
    "        super().__init__(name=name)\n",
    "        self.cnn_encoder = CnnEncoder(**cnn_encoder_kwargs)\n",
    "        # self.cnn_embedder = layers.TimeDistributed(cnn_encoder, name='cnn_embedder')\n",
    "        self.cnn_encoder.trainable = False\n",
    "        # self.abstractor = SimpleAbstractor(**abstractor_kwargs)\n",
    "        self.abstractor = Abstractor(**abstractor_kwargs)\n",
    "        self.flatten = layers.Flatten()\n",
    "        self.hidden_dense = layers.Dense(32, activation='relu', name='hidden_layer')\n",
    "        self.final_layer = layers.Dense(1, activation='sigmoid', name='final_layer')\n",
    "    \n",
    "    def call(self, inputs):\n",
    "        x = tf.map_fn(self.cnn_encoder, inputs)\n",
    "        x = self.abstractor(x)\n",
    "        x = self.flatten(x)\n",
    "        x = self.hidden_dense(x)\n",
    "        x = self.final_layer(x)\n",
    "\n",
    "        return x\n",
    "\n",
    "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",
    "abstractor_model = AbstractorRMTSModel(embedding_dim, abstractor_kwargs, name='rmts_abstractor')\n",
    "abstractor_model.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "abstractor_model(X_train[:32])\n",
    "abstractor_model.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/10\n",
      "279/279 [==============================] - 16s 53ms/step - loss: 0.6970 - binary_accuracy: 0.5010 - val_loss: 0.6931 - val_binary_accuracy: 0.5071\n",
      "Epoch 2/10\n",
      "279/279 [==============================] - 14s 50ms/step - loss: 0.5189 - binary_accuracy: 0.6820 - val_loss: 0.0753 - val_binary_accuracy: 0.9992\n",
      "Epoch 3/10\n",
      "279/279 [==============================] - 14s 50ms/step - loss: 0.0348 - binary_accuracy: 0.9975 - val_loss: 0.0112 - val_binary_accuracy: 1.0000\n",
      "Epoch 4/10\n",
      "279/279 [==============================] - 14s 51ms/step - loss: 0.0111 - binary_accuracy: 0.9992 - val_loss: 0.0048 - val_binary_accuracy: 1.0000\n",
      "Epoch 5/10\n",
      "279/279 [==============================] - 14s 51ms/step - loss: 0.0047 - binary_accuracy: 0.9999 - val_loss: 0.0024 - val_binary_accuracy: 1.0000\n",
      "Epoch 6/10\n",
      "279/279 [==============================] - 14s 51ms/step - loss: 0.0030 - binary_accuracy: 0.9999 - val_loss: 0.0014 - val_binary_accuracy: 1.0000\n",
      "Epoch 7/10\n",
      "279/279 [==============================] - 14s 51ms/step - loss: 0.0026 - binary_accuracy: 0.9997 - val_loss: 0.0013 - val_binary_accuracy: 1.0000\n",
      "Epoch 8/10\n",
      "279/279 [==============================] - 14s 51ms/step - loss: 0.0012 - binary_accuracy: 1.0000 - val_loss: 5.6505e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 9/10\n",
      "279/279 [==============================] - 14s 50ms/step - loss: 0.0010 - binary_accuracy: 1.0000 - val_loss: 4.3031e-04 - val_binary_accuracy: 1.0000\n",
      "Epoch 10/10\n",
      "279/279 [==============================] - 14s 51ms/step - loss: 8.9246e-04 - binary_accuracy: 1.0000 - val_loss: 3.7832e-04 - val_binary_accuracy: 1.0000\n"
     ]
    }
   ],
   "source": [
    "history = abstractor_model.fit(X_train, y_train, validation_data=(X_train, y_train), epochs=10, verbose=1, batch_size=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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J554Art378bu3bsRExODIUOGNPs8dyP7vwQpKSlISUlp8Gtr1qypdywkJATl5eVOjgqAn3HkJgwlKK6swl9ni9CvQ6jzvy95jV69eqG6uhq//PKLecSlsLAQR48eRc+ePc3nRUdHY8aMGZgxYwbmz5+Pd955B7NmzQJg3GRuypQpmDJlCoYMGYLHHnvMK5KbvXv34oYbbjB/bqqNmTx5MtasWVPvjVFsbCw2bdqEefPmYfny5WjXrh2WLl3qXsvADTUjHwrpb9tVemMyoVI6vsbk559/rvd5165d7do8dfv27UhMTLT4N+Kff/6x6rkqlQqTJ0/G6tWrodFocNddd1m9Cen27duRnp6OkSNHAgBycnIsCs/79euH06dP4+jRow2O3vTr1w/ff/99o21IIiIikJuba/68uLgYWVlZVsXV1M8jKCgIMTEx+P777y3+PuoKDw/H7bffjtWrV2P37t1N9olzZ7InNy1WzciNWtAjEBXYcbyAyQ1JqmvXrrjttttw//334+2330ZQUBCeeOIJtG/f3lx3NnfuXCQnJ6Nbt264ePEifvjhB3Pi85///Afx8fHo3bs3tFotvv76a4ukyJNdf/31Ta5Qa+iN0XXXXYf9+/c7MSonE6uN/1VIv8N6ld74s/RROj46nZOTg9TUVDz44IPYv38/3nzzTaungy4XFxeH999/H5s3b0ZsbCw++OAD7NmzB7GxsVY939QgFgB27txp0/f94IMPkJCQgOLiYjz22GMWoyLXXXcdhg4dijvvvBNLlixBXFwc/v77bwiCgJtvvhnz589H3759kZKSghkzZsDHxwc//vgjxo4di9atW+PGG2/EmjVrzCshn376aauSP2t+Hs888wxmzJiBNm3aIDk5GSUlJdi5c6f5DZHp5zJq1Cjo9XpMnjzZ6p+LO5F9KXiL5eNvnNsGECqUYufxhpeLEjli9erViI+Px6hRozBo0CCIoohNmzaZh+r1ej0efvhh9OzZEzfffDO6d++O9PR0AMai/Pnz56Nfv34YOnQolEolPvnkEzlfDjmTeeRG+uSmWsKRm0mTJqGiogJXX301Hn74YcyaNQsPPPCAXdeaMWMGxowZg/Hjx+Oaa65BYWFhoyP9Denatau5iLZubVtzVq1ahYsXL6J///6YOHEiZs+ejTZt2lics2HDBgwYMAB33303evXqhccff9xcV9StWzds2bIFv/32G66++moMGjQI//d//weVyjieMH/+fAwdOhSjRo3CyJEjcfvtt6NLl+YLna35eUyePBlpaWlIT09H7969MWrUKIv2EgAwfPhwREVFYcSIEWjXrp3VPxd3Iohe1sSluLgYISEhKCoqar7nzZJeQPEZ3Kp9Dn8ru+L3/yY1uSSSXKuyshJZWVnmjVepZWnq/49Nf4cthCtjbvBnd/EUUHEBCGoHBDXdLsMWeoOIv84WAQB6twvxqNpCURTRo0cPPPjggxbL+r1deXk52rVrh1WrVmHMmDFyh2NBqvsGR26aUrNiqnOAFrpqA/aevChzQETktQzOmZYy1dsoBcGjEpv8/HwsWbIEZ86c8di6ElsZDAacPXsWTz/9NEJCQnDrrbfKHZLTsOamKTVFxQPaiPiiFNhxvADXdm0tc1BE5JWcVFBsSm7UEkxJtSSRkZFo3bq1uUdNXU31dPnmm288cvUQYOyNFRsbiw4dOmDNmjXmaTJP5LmvTAo1RcV9wvTACbDuhojkIzqn5sZUTKySoJi4JWmq4uLgwYONfq19+/ZOiKZliImJ8ZrthJjcNKVmWqpLgHHzvD/PFuFSuQ6h/s7Z8oGIqFGmaSlB2uSm2kNHbpoSFxfX/Enk1rznt9keNSM3gfoidG0TCFEEdv9TKHNQROR1RJHTUkQ24G9zU2qSG5RfwOA4Y63NDk5NEZGriQYANdMJTpqWUnvYtBR5NyY3TakpKEZ5Ia6tSW5Yd0NELmcatYEACNLetjlyQ56Iv81Nqam5QcVFXNM5DEqFgJOF5ci54ILtH4iITOoWE9uwiaU1OHJDnojJTVP8a0dugnzVuKJDCABg1z8cvSEiF3JSMbFBFFFt4MgNeR7+NjelTs0NRNE8NbXjOIuKST4xMTFIS0uz6lxBEPDFF184NR5yAScVE5tWSgktqIGflL/fJ0+ehCAITS79Js/E5KYpppobvRbQlZmLincdL4DB4B29AoioBXBad+LaKSlB4umuliA6Ohq5ubno06eP3KGQizG5aYpPAKDUGD8uL0T/jq3gp1aisEyHI+dK5I2NiLyH0xr41UxJKTzznwKlUom2bds6vROvTqdz6vXlIIoiqqur5Q7Dbp75Gy0VQaidmqq4AB+VAtd0No7mcNVUCySKgK5MnoeVXT/ffvtttG/fHoaaOgeTW2+9FZMnT8Y///yD2267DZGRkQgMDMSAAQPw3XffSfYj+uOPP3DjjTfCz88P4eHheOCBB1BaWmr++tatW3H11VcjICAAoaGhGDx4ME6dOgUA+O2333DDDTcgKCgIwcHBiI+Px969eyWLjZqgrwaqKgC9TtLf26rKUghV5fAxVDj8uw3I8/udm5uL5ORk+Pn5ITY2Fp9++qn5a5dPS23duhWCIOD7779HQkIC/P39kZiYiCNHjpifY02MMTExeP755zFlyhSEhITg/vvvx4033oiZM2danFdYWAiNRoMffvih2dfx4YcfIiEhAUFBQWjbti0mTJiA/Px8i3P++usv3HLLLQgODkZQUBCGDBmCf/75x/z1VatWoXfv3tBoNIiKijLH09D03KVLlyAIArZu3Wrxs9m8eTMSEhKg0Wiwfft2q34eWq0Wjz/+OKKjo6HRaNC1a1esXLkSoigiLi4Oixcvtjj/zz//hEKhsIhdauxQ3Bz/MKDkLFBurLO5Nq41th45jx3HCzB9SGeZgyMLVeXAi+3k+d5PnjWO9DVj7NixmD17Nn788UcMGzYMAHDx4kVs3rwZX331FUpLSzFy5Eg8//zz8PX1xXvvvYfRo0fjyJEj6Nixo0MhlpeX4+abb8bAgQOxZ88e5OfnY/r06Zg5cybWrFmD6upq3H777bj//vvx8ccfQ6fT4ddffzVPV9xzzz3o378/MjIyoFQqcfDgQajVaodiIivpSoDVyZJfNqLm0SQrf7cBeX6/n376abz00kt444038MEHH+Duu+9Gnz590LNnz0afs2DBArz22muIiIjAjBkzMHXqVOzcuRMArI7x1VdfxdNPP42nnnoKAPDrr79i5syZeO2116DRGEf8165di3bt2uGGG25o9nXodDo899xz6N69O/Lz8zFv3jxMmTIFmzZtAgCcOXMGQ4cOxfXXX48ffvgBwcHB2Llzp3l0JSMjA6mpqXjppZeQnJyMoqIi82uyxeOPP47Fixejc+fOCA0NxenTp5v9eUyaNAm7d+/G0qVLccUVVyArKwsFBQUQBAFTp07F6tWr8eijj5q/x6pVqzBkyBB06dLF5visxeSmOeYVU8YdwU11N7+cuABdtQE+Kg5+kfXCwsJw880346OPPjLf/D/99FOEhYVh2LBhUCqVuOKKK8znP//88/j888/x5Zdf1ntXaKu1a9eioqIC77//PgICjP9YLVu2DKNHj8bLL78MtVqNoqIijBo1ynzTqfsPRHZ2Nh577DH06NEDANC1a1eH4iEbXDYS0lLJ8fs9duxYTJ8+HQDw3HPPITMzE2+++SbS09Mbfc4LL7yA6667DgDwxBNP4JZbbkFlZSV8fX1xxRVXWBXjjTfeaPEPdnR0NGbNmoX/+7//w7hx4wAAq1evxpQpU6yqZ5o6dar5486dO2Pp0qW4+uqrUVpaisDAQCxfvhwhISH45JNPzG8qunXrZhHnI488gjlz5piPDRgwoNnve7mFCxfipptuMn8eHh7e5M/j6NGj+N///ofMzEwMHz7cHL/Jfffdh//85z/49ddfcfXVV6OqqgoffvghXn31VZtjswWTm+bUaeQHAN0jgxAe4IPCMh0OZF/ENZ3DZQyOLKj9je8y5freVrrnnnvwwAMPID09HRqNBmvXrsVdd90FpVKJsrIyPPvss/j6669x9uxZVFdXo6KiAtnZ2Q6HePjwYVxxxRXmxAYABg8eDIPBgCNHjmDo0KGYMmUKRowYgZtuugnDhw/HuHHjEBUVBQBITU3F9OnT8cEHH2D48OEYO3asU995UR0KNXDfN0BIR8C/VfPnW+nE+TKU6aoR3cqv8T3zbPjdBlz/+z1o0KB6nze3Oqpfv37mj02/3/n5+ejYsaPVMSYkJFh8rtFocO+992LVqlUYN24cDh48iN9++83q1YoHDhzAM888g4MHD+LChQvmqb3s7Gz06tULBw8exJAhQxocLc3Pz8fZs2fNCaUjLn9dzf08Dh48CKVSaU4WLxcVFYVbbrkFq1atwtVXX42vv/4alZWVGDt2rMOxNoXDDs2pU3MDAAqFgER2K26ZBME4fC7Hw4aVJqNHj4bBYMDGjRuRk5OD7du349577wUAPPbYY9iwYQNeeOEFbN++HQcPHkTfvn0lKVgURbHRd5Cm46tXr8bu3buRmJiIdevWoVu3bvj5558BAM8884x5zv+HH35Ar1698PnnnzscF1lDD6j9AN8gSX9vdQpfiGp/qP2auK6Nq6jk+v2uq7mRkroJgulcUzJhbYx13ySYTJ8+HZmZmTh9+jRWrVqFYcOGoVOnTs3GW1ZWhqSkJAQGBuLDDz/Enj17zH9bpu/r5+fX6POb+hoAKGoKxuvuCF5VVdXguZe/ruZ+Hs19b8D4c/nkk09QUVGB1atXY/z48fD3ty1pthWTm+b4W47cAMC1ccaEZyc30SQ7+Pn5YcyYMVi7di0+/vhjdOvWDfHx8QCA7du3Y8qUKbjjjjvQt29ftG3bFidPnpTk+5re/ZWVlZmP7dy5EwqFwmJ4u3///pg/fz527dqFPn364KOPPjJ/rVu3bpg3bx62bNmCMWPGYPXq1ZLERs1wQp8bURRRZTAtBZfunwJX/36bku+6n5umTu3hSIx9+/ZFQkIC3nnnHXz00UcWU01N+fvvv1FQUICXXnoJQ4YMQY8ePeoVE/fr1w/bt29vMCkJCgpCTEwMvv/++wavHxFhrKzKzc01H7O2909zP4++ffvCYDBg27ZtjV5j5MiRCAgIQEZGBr755hurfy6OYHLTHHMjv9pExlR3czDnEkoqG85+iZpyzz33YOPGjVi1apX5XS0AxMXF4bPPPjMPaU+YMKHeyhNHvqevry8mT56MP//8Ez/++CNmzZqFiRMnIjIyEllZWZg/fz52796NU6dOYcuWLTh69Ch69uyJiooKzJw5E1u3bsWpU6ewc+dO7Nmzp8miTZKQKbmRsENxtUE0v5NXSbz1git/vz/99FOsWrUKR48exX//+19zYa+9HI1x+vTpeOmll6DX63HHHXdY9ZyOHTvCx8cHb775Jk6cOIEvv/wSzz33nMU5M2fORHFxMe666y7s3bsXx44dwwcffGBe6fXMM8/gtddew9KlS3Hs2DHs378fb775JgBjwjlw4EC89NJLOHToEH766SdzIbSjP4+YmBhMnjwZU6dOxRdffIGsrCxs3boV//vf/8znKJVKTJkyBfPnz0dcXFy9qURnYHLTnLpdimt0aOWPmHB/6A0ifjlxoZEnEjXuxhtvRFhYGI4cOYIJEyaYj7/++uto1aoVEhMTMXr0aIwYMQJXXXWVJN/T398fmzdvxoULFzBgwAD861//wrBhw7Bs2TLz1//++2/ceeed6NatGx544AHMnDkTDz74IJRKJQoLCzFp0iR069YN48aNQ3JyMp599llJYqMmiKJT+tyYuhOrlAooJG7g58rf72effRaffPIJ+vXrh/feew9r165Fr1697L6eozHefffdUKlUmDBhAnx9fa16TkREBNasWYNPP/0UvXr1wksvvVRv+XR4eDh++OEHlJaW4rrrrkN8fDzeeecd8xTb5MmTkZaWhvT0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Ds0mLX3Fgygal56qVCrxhRdeEI8dOyauXbtW9Pf3Fz/88EO5Q2vU5MmTxfbt25uXc3722Wdi69atxccff1zu0DyKu907POW+IYot/97hjvcNUXTfeweTm0YsX75c7NSpk+jj4yNeddVVLX5pJIAGH6tXr5Y7NJu09BuUyVdffSX26dNH1Gg0Yo8ePcQVK1bIHVKTiouLxTlz5ogdO3YUfX19xc6dO4sLFiwQtVqt3KF5HHe6d3jKfUMU3ePe4W73DVF033uHIIqiKM+YEREREZH0WHNDREREHoXJDREREXkUJjdERETkUZjcEBERkUdhckNEREQehckNEREReRQmN0RERORRmNwQERGRR2FyQ15j69atEAQBly5dkjsUInITvG+4JyY3RERE5FGY3BAREZFHYXJDLiOKIl555RV07twZfn5+uOKKK7B+/XoAtUO/GzduxBVXXAFfX19cc801+OOPPyyusWHDBvTu3RsajQYxMTF47bXXLL6u1Wrx+OOPIzo6GhqNBl27dsXKlSstztm3bx8SEhLg7++PxMREHDlyxLkvnIjsxvsG2UXefTvJmzz55JNijx49xG+//Vb8559/xNWrV4sajUbcunWr+OOPP4oAxJ49e4pbtmwRf//9d3HUqFFiTEyMqNPpRFEUxb1794oKhUJcuHCheOTIEXH16tWin5+fxQ7G48aNE6Ojo8XPPvtM/Oeff8TvvvtO/OSTT0RRFM3f45prrhG3bt0q/vXXX+KQIUPExMREOX4cRGQF3jfIHkxuyCVKS0tFX19fcdeuXRbHp02bJt59993mG4jphiKKolhYWCj6+fmJ69atE0VRFCdMmCDedNNNFs9/7LHHxF69eomiKIpHjhwRAYiZmZkNxmD6Ht9995352MaNG0UAYkVFhSSvk4ikw/sG2YvTUuQShw4dQmVlJW666SYEBgaaH++//z7++ecf83mDBg0yfxwWFobu3bvj8OHDAIDDhw9j8ODBFtcdPHgwjh07Br1ej4MHD0KpVOK6665rMpZ+/fqZP46KigIA5OfnO/waiUhavG+QvVRyB0DewWAwAAA2btyI9u3bW3xNo9FY3KguJwgCAOPcu+ljE1EUzR/7+flZFYtara53bVN8RNRy8L5B9uLIDblEr169oNFokJ2djbi4OItHdHS0+byff/7Z/PHFixdx9OhR9OjRw3yNHTt2WFx3165d6NatG5RKJfr27QuDwYBt27a55kURkVPxvkH24sgNuURQUBAeffRRzJs3DwaDAddeey2Ki4uxa9cuBAYGolOnTgCAhQsXIjw8HJGRkViwYAFat26N22+/HQDwyCOPYMCAAXjuuecwfvx47N69G8uWLUN6ejoAICYmBpMnT8bUqVOxdOlSXHHFFTh16hTy8/Mxbtw4uV46EdmJ9w2ym7wlP+RNDAaD+MYbb4jdu3cX1Wq1GBERIY4YMULctm2buWjvq6++Env37i36+PiIAwYMEA8ePGhxjfXr14u9evUS1Wq12LFjR/HVV1+1+HpFRYU4b948MSoqSvTx8RHj4uLEVatWiaJYWxh48eJF8/kHDhwQAYhZWVnOfvlEZAfeN8gegijWmXwkksnWrVtxww034OLFiwgNDZU7HCJyA7xvUGNYc0NEREQehckNEREReRROSxEREZFH4cgNEREReRQmN0RERORRmNwQERGRR2FyQ0RERB6FyQ0RERF5FCY3RERE5FGY3BAREZFHYXJDREREHuX/AcmB3GgiV3VJAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "utils.plot_history(history, ('loss', 'binary_accuracy'));"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train accuracy: 100.00%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = abstractor_model(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": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test accuracy: 100.00%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "out = abstractor_model(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": "markdown",
   "metadata": {},
   "source": [
    "## CorelNet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "from simplest_abstractor import CnnEncoder\n",
    "from multi_head_relation import MultiHeadRelation\n",
    "from tensorflow.keras import layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"rmts_abstractor\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  104704    \n",
      "                                                                 \n",
      " flatten_30 (Flatten)        multiple                  0         \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  1184      \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 105,921\n",
      "Trainable params: 1,217\n",
      "Non-trainable params: 104,704\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "embedding_dim = 64\n",
    "\n",
    "abstractor_kwargs = dict(\n",
    "        num_layers=1,\n",
    "        rel_dim=1,\n",
    "        symbol_dim=10,\n",
    "        proj_dim=64,\n",
    "        symmetric_rels=False,\n",
    "        encoder_kwargs=None,\n",
    "        rel_activation_type='softmax',\n",
    "        use_self_attn=False,\n",
    "        use_layer_norm=False,\n",
    "        dropout_rate=0.1,)\n",
    "\n",
    "cnn_encoder_kwargs = dict(ff_dim2=embedding_dim, normalize=True, name='cnn_encoder')\n",
    "\n",
    "class CorelNetRMTSModel(tf.keras.Model):\n",
    "    def __init__(self, embedding_dim, abstractor_kwargs, name=None):\n",
    "        super().__init__(name=name)\n",
    "        self.cnn_encoder = CnnEncoder(**cnn_encoder_kwargs)\n",
    "        # self.cnn_embedder = layers.TimeDistributed(cnn_encoder, name='cnn_embedder')\n",
    "        self.cnn_encoder.trainable = False\n",
    "        self.flatten = layers.Flatten()\n",
    "        self.hidden_dense = layers.Dense(32, activation='relu', name='hidden_layer')\n",
    "        self.final_layer = layers.Dense(1, activation='sigmoid', name='final_layer')\n",
    "    \n",
    "    def call(self, inputs):\n",
    "        x = tf.map_fn(self.cnn_encoder, inputs)\n",
    "        x = tf.matmul(x, x, transpose_b=True)\n",
    "        x = self.flatten(x)\n",
    "        x = self.hidden_dense(x)\n",
    "        x = self.final_layer(x)\n",
    "\n",
    "        return x\n",
    "\n",
    "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",
    "corelnet_model = CorelNetRMTSModel(embedding_dim, abstractor_kwargs, name='rmts_abstractor')\n",
    "corelnet_model.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "corelnet_model(X_train[:32])\n",
    "corelnet_model.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "TensorShape([8, 6, 64])"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = layers.TimeDistributed(corelnet_model.cnn_encoder)(X_train[1000:1008])\n",
    "x.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "TensorShape([8, 6, 64])"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = tf.map_fn(abstractor_model.cnn_encoder, X_train[1000:1008].astype('float32'))\n",
    "x.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "25348.71"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.dot(x[0, 0, :], x[0, 5, :])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<tf.Tensor: shape=(8, 6, 6), dtype=float32, numpy=\n",
       "array([[[25360.164, 25341.52 , 25348.709, 25381.666, 25381.666,\n",
       "         25348.709],\n",
       "        [25341.52 , 25322.963, 25330.127, 25363.   , 25363.   ,\n",
       "         25330.127],\n",
       "        [25348.709, 25330.127, 25337.307, 25370.195, 25370.195,\n",
       "         25337.307],\n",
       "        [25381.666, 25363.   , 25370.195, 25403.27 , 25403.27 ,\n",
       "         25370.195],\n",
       "        [25381.666, 25363.   , 25370.195, 25403.27 , 25403.27 ,\n",
       "         25370.195],\n",
       "        [25348.709, 25330.127, 25337.307, 25370.195, 25370.195,\n",
       "         25337.307]],\n",
       "\n",
       "       [[25310.43 , 25327.36 , 25347.115, 25321.506, 25321.506,\n",
       "         25347.115],\n",
       "        [25327.36 , 25344.404, 25364.098, 25338.445, 25338.445,\n",
       "         25364.098],\n",
       "        [25347.115, 25364.098, 25384.078, 25358.197, 25358.197,\n",
       "         25384.078],\n",
       "        [25321.506, 25338.445, 25358.197, 25332.637, 25332.637,\n",
       "         25358.197],\n",
       "        [25321.506, 25338.445, 25358.197, 25332.637, 25332.637,\n",
       "         25358.197],\n",
       "        [25347.115, 25364.098, 25384.078, 25358.197, 25358.197,\n",
       "         25384.078]],\n",
       "\n",
       "       [[25385.07 , 25354.545, 25350.182, 25367.965, 25367.965,\n",
       "         25350.182],\n",
       "        [25354.545, 25324.12 , 25319.744, 25337.512, 25337.512,\n",
       "         25319.744],\n",
       "        [25350.182, 25319.744, 25315.412, 25333.152, 25333.152,\n",
       "         25315.412],\n",
       "        [25367.965, 25337.512, 25333.152, 25350.967, 25350.967,\n",
       "         25333.152],\n",
       "        [25367.965, 25337.512, 25333.152, 25350.967, 25350.967,\n",
       "         25333.152],\n",
       "        [25350.182, 25319.744, 25315.412, 25333.152, 25333.152,\n",
       "         25315.412]],\n",
       "\n",
       "       [[25324.023, 25360.45 , 25324.809, 25377.639, 25377.639,\n",
       "         25324.809],\n",
       "        [25360.45 , 25397.057, 25361.244, 25414.236, 25414.236,\n",
       "         25361.244],\n",
       "        [25324.809, 25361.244, 25325.623, 25378.465, 25378.465,\n",
       "         25325.623],\n",
       "        [25377.639, 25414.236, 25378.465, 25431.59 , 25431.59 ,\n",
       "         25378.465],\n",
       "        [25377.639, 25414.236, 25378.465, 25431.59 , 25431.59 ,\n",
       "         25378.465],\n",
       "        [25324.809, 25361.244, 25325.623, 25378.465, 25378.465,\n",
       "         25325.623]],\n",
       "\n",
       "       [[25461.406, 25410.03 , 25425.045, 25392.6  , 25392.6  ,\n",
       "         25425.045],\n",
       "        [25410.03 , 25358.996, 25373.916, 25341.557, 25341.557,\n",
       "         25373.916],\n",
       "        [25425.045, 25373.916, 25388.893, 25356.475, 25356.475,\n",
       "         25388.893],\n",
       "        [25392.6  , 25341.557, 25356.475, 25324.17 , 25324.17 ,\n",
       "         25356.475],\n",
       "        [25392.6  , 25341.557, 25356.475, 25324.17 , 25324.17 ,\n",
       "         25356.475],\n",
       "        [25425.045, 25373.916, 25388.893, 25356.475, 25356.475,\n",
       "         25388.893]],\n",
       "\n",
       "       [[25333.35 , 25319.443, 25337.334, 25379.225, 25379.225,\n",
       "         25337.334],\n",
       "        [25319.443, 25305.62 , 25323.525, 25365.422, 25365.422,\n",
       "         25323.525],\n",
       "        [25337.334, 25323.525, 25341.512, 25383.428, 25383.428,\n",
       "         25341.512],\n",
       "        [25379.225, 25365.422, 25383.428, 25425.537, 25425.537,\n",
       "         25383.428],\n",
       "        [25379.225, 25365.422, 25383.428, 25425.537, 25425.537,\n",
       "         25383.428],\n",
       "        [25337.334, 25323.525, 25341.512, 25383.428, 25383.428,\n",
       "         25341.512]],\n",
       "\n",
       "       [[25390.193, 25358.152, 25378.914, 25358.88 , 25358.88 ,\n",
       "         25378.914],\n",
       "        [25358.152, 25326.24 , 25346.926, 25326.959, 25326.959,\n",
       "         25346.926],\n",
       "        [25378.914, 25346.926, 25367.764, 25347.676, 25347.676,\n",
       "         25367.764],\n",
       "        [25358.88 , 25326.959, 25347.676, 25327.7  , 25327.7  ,\n",
       "         25347.676],\n",
       "        [25358.88 , 25326.959, 25347.676, 25327.7  , 25327.7  ,\n",
       "         25347.676],\n",
       "        [25378.914, 25346.926, 25367.764, 25347.676, 25347.676,\n",
       "         25367.764]],\n",
       "\n",
       "       [[25398.074, 25363.41 , 25355.613, 25375.928, 25375.928,\n",
       "         25355.613],\n",
       "        [25363.41 , 25328.945, 25321.15 , 25341.373, 25341.373,\n",
       "         25321.15 ],\n",
       "        [25355.613, 25321.15 , 25313.385, 25333.586, 25333.586,\n",
       "         25313.385],\n",
       "        [25375.928, 25341.373, 25333.586, 25353.88 , 25353.88 ,\n",
       "         25333.586],\n",
       "        [25375.928, 25341.373, 25333.586, 25353.88 , 25353.88 ,\n",
       "         25333.586],\n",
       "        [25355.613, 25321.15 , 25313.385, 25333.586, 25333.586,\n",
       "         25313.385]]], dtype=float32)>"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tf.matmul(x, x, transpose_b=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x2b06fdd091c0>"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(X_train[1000:1008][0, 4, :])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.1340599"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.max(np.abs(x[0, -3, :] - x[0, 0, :]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/10\n",
      "279/279 [==============================] - 15s 49ms/step - loss: 2.1491 - binary_accuracy: 0.4949 - val_loss: 0.8594 - val_binary_accuracy: 0.5071\n",
      "Epoch 2/10\n",
      "279/279 [==============================] - 13s 47ms/step - loss: 0.7337 - binary_accuracy: 0.5006 - val_loss: 0.6948 - val_binary_accuracy: 0.5071\n",
      "Epoch 3/10\n",
      "279/279 [==============================] - 13s 48ms/step - loss: 0.7364 - binary_accuracy: 0.4974 - val_loss: 0.7358 - val_binary_accuracy: 0.4929\n",
      "Epoch 4/10\n",
      "279/279 [==============================] - 13s 47ms/step - loss: 0.7495 - binary_accuracy: 0.5075 - val_loss: 0.6942 - val_binary_accuracy: 0.4929\n",
      "Epoch 5/10\n",
      "279/279 [==============================] - 13s 47ms/step - loss: 0.7469 - binary_accuracy: 0.5037 - val_loss: 0.7157 - val_binary_accuracy: 0.4929\n",
      "Epoch 6/10\n",
      "279/279 [==============================] - 13s 47ms/step - loss: 0.7375 - binary_accuracy: 0.4990 - val_loss: 0.8578 - val_binary_accuracy: 0.4929\n",
      "Epoch 7/10\n",
      "279/279 [==============================] - 13s 48ms/step - loss: 0.7356 - binary_accuracy: 0.5035 - val_loss: 0.7074 - val_binary_accuracy: 0.5071\n",
      "Epoch 8/10\n",
      "279/279 [==============================] - 13s 47ms/step - loss: 0.7304 - binary_accuracy: 0.5098 - val_loss: 0.7095 - val_binary_accuracy: 0.4929\n",
      "Epoch 9/10\n",
      "279/279 [==============================] - 13s 48ms/step - loss: 0.7236 - binary_accuracy: 0.5064 - val_loss: 0.7083 - val_binary_accuracy: 0.4929\n",
      "Epoch 10/10\n",
      "279/279 [==============================] - 13s 48ms/step - loss: 0.7348 - binary_accuracy: 0.5003 - val_loss: 0.7322 - val_binary_accuracy: 0.4929\n"
     ]
    }
   ],
   "source": [
    "history = corelnet_model.fit(X_train, y_train, validation_data=(X_train, y_train), epochs=10, verbose=1, batch_size=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "utils.plot_history(history, ('loss', 'binary_accuracy'));"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": "markdown",
   "metadata": {},
   "source": [
    "## Transformer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "from simplest_abstractor import CnnEncoder\n",
    "# from abstracters import SimpleAbstractor, RelationalAbstracter\n",
    "# from abstractor import Abstractor\n",
    "from transformer_modules import Encoder\n",
    "from tensorflow.keras import layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"rmts_transformer\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  205120    \n",
      "                                                                 \n",
      " encoder (Encoder)           multiple                  99584     \n",
      "                                                                 \n",
      " flatten_8 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  24608     \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 329,345\n",
      "Trainable params: 124,225\n",
      "Non-trainable params: 205,120\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "embedding_dim = 128\n",
    "\n",
    "encoder_kwargs = dict(\n",
    "    num_layers=1, \n",
    "    num_heads=1, \n",
    "    dff=128,\n",
    "    dropout_rate=0.1)\n",
    "\n",
    "cnn_encoder_kwargs = dict(ff_dim2=embedding_dim, normalize=True, name='cnn_encoder')\n",
    "\n",
    "class TransformerRMTSModel(tf.keras.Model):\n",
    "    def __init__(self, embedding_dim, encoder_kwargs, name=None):\n",
    "        super().__init__(name=name)\n",
    "        self.cnn_encoder = CnnEncoder(**cnn_encoder_kwargs)\n",
    "        # self.cnn_embedder = layers.TimeDistributed(cnn_encoder, name='cnn_embedder')\n",
    "        self.cnn_encoder.trainable = False\n",
    "        self.encoder = Encoder(**encoder_kwargs)\n",
    "        self.flatten = layers.Flatten()\n",
    "        self.hidden_dense = layers.Dense(32, activation='relu', name='hidden_layer')\n",
    "        self.final_layer = layers.Dense(1, activation='sigmoid', name='final_layer')\n",
    "    \n",
    "    def call(self, inputs):\n",
    "        x = tf.map_fn(self.cnn_encoder, inputs)\n",
    "        x = self.encoder(x)\n",
    "        x = self.flatten(x)\n",
    "        x = self.hidden_dense(x)\n",
    "        x = self.final_layer(x)\n",
    "\n",
    "        return x\n",
    "\n",
    "loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True, name='binary_crossentropy')\n",
    "create_opt = lambda : tf.keras.optimizers.Adam()\n",
    "\n",
    "transformer_model = TransformerRMTSModel(embedding_dim, encoder_kwargs, name='rmts_transformer')\n",
    "transformer_model.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "transformer_model(X_train[:32])\n",
    "transformer_model.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/100\n",
      "279/279 [==============================] - 18s 56ms/step - loss: 0.7135 - binary_accuracy: 0.5044 - val_loss: 0.6943 - val_binary_accuracy: 0.4929\n",
      "Epoch 2/100\n",
      "279/279 [==============================] - 15s 53ms/step - loss: 0.6994 - binary_accuracy: 0.5028 - val_loss: 0.6960 - val_binary_accuracy: 0.5071\n",
      "Epoch 3/100\n",
      "279/279 [==============================] - 15s 53ms/step - loss: 0.6990 - binary_accuracy: 0.4990 - val_loss: 0.7054 - val_binary_accuracy: 0.4929\n",
      "Epoch 4/100\n",
      "279/279 [==============================] - 15s 54ms/step - loss: 0.6978 - binary_accuracy: 0.4980 - val_loss: 0.6945 - val_binary_accuracy: 0.4929\n",
      "Epoch 5/100\n",
      "279/279 [==============================] - 15s 54ms/step - loss: 0.6971 - binary_accuracy: 0.5010 - val_loss: 0.6932 - val_binary_accuracy: 0.4929\n",
      "Epoch 6/100\n",
      "279/279 [==============================] - 15s 54ms/step - loss: 0.6951 - binary_accuracy: 0.5025 - val_loss: 0.6935 - val_binary_accuracy: 0.5071\n",
      "Epoch 7/100\n",
      "279/279 [==============================] - 15s 53ms/step - loss: 0.6950 - binary_accuracy: 0.4965 - val_loss: 0.6931 - val_binary_accuracy: 0.5071\n",
      "Epoch 8/100\n",
      "279/279 [==============================] - 15s 53ms/step - loss: 0.6949 - binary_accuracy: 0.4927 - val_loss: 0.6931 - val_binary_accuracy: 0.5071\n",
      "Epoch 9/100\n",
      "279/279 [==============================] - 15s 54ms/step - loss: 0.6951 - binary_accuracy: 0.5001 - val_loss: 0.6939 - val_binary_accuracy: 0.4929\n",
      "Epoch 10/100\n",
      "279/279 [==============================] - 15s 54ms/step - loss: 0.6939 - binary_accuracy: 0.5038 - val_loss: 0.6931 - val_binary_accuracy: 0.5071\n",
      "Epoch 11/100\n",
      "279/279 [==============================] - 15s 54ms/step - loss: 0.6939 - binary_accuracy: 0.5068 - val_loss: 0.6934 - val_binary_accuracy: 0.4929\n",
      "Epoch 12/100\n",
      "167/279 [================>.............] - ETA: 3s - loss: 0.6933 - binary_accuracy: 0.5043"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[18], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m history \u001b[38;5;241m=\u001b[39m \u001b[43mtransformer_model\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfit\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX_train\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my_train\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mvalidation_data\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mX_train\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my_train\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mepochs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m100\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mverbose\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbatch_size\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m32\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/keras/utils/traceback_utils.py:65\u001b[0m, in \u001b[0;36mfilter_traceback.<locals>.error_handler\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     63\u001b[0m filtered_tb \u001b[39m=\u001b[39m \u001b[39mNone\u001b[39;00m\n\u001b[1;32m     64\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m---> 65\u001b[0m     \u001b[39mreturn\u001b[39;00m fn(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m     66\u001b[0m \u001b[39mexcept\u001b[39;00m \u001b[39mException\u001b[39;00m \u001b[39mas\u001b[39;00m e:\n\u001b[1;32m     67\u001b[0m     filtered_tb \u001b[39m=\u001b[39m _process_traceback_frames(e\u001b[39m.\u001b[39m__traceback__)\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/keras/engine/training.py:1564\u001b[0m, in \u001b[0;36mModel.fit\u001b[0;34m(self, x, y, batch_size, epochs, verbose, callbacks, validation_split, validation_data, shuffle, class_weight, sample_weight, initial_epoch, steps_per_epoch, validation_steps, validation_batch_size, validation_freq, max_queue_size, workers, use_multiprocessing)\u001b[0m\n\u001b[1;32m   1556\u001b[0m \u001b[39mwith\u001b[39;00m tf\u001b[39m.\u001b[39mprofiler\u001b[39m.\u001b[39mexperimental\u001b[39m.\u001b[39mTrace(\n\u001b[1;32m   1557\u001b[0m     \u001b[39m\"\u001b[39m\u001b[39mtrain\u001b[39m\u001b[39m\"\u001b[39m,\n\u001b[1;32m   1558\u001b[0m     epoch_num\u001b[39m=\u001b[39mepoch,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   1561\u001b[0m     _r\u001b[39m=\u001b[39m\u001b[39m1\u001b[39m,\n\u001b[1;32m   1562\u001b[0m ):\n\u001b[1;32m   1563\u001b[0m     callbacks\u001b[39m.\u001b[39mon_train_batch_begin(step)\n\u001b[0;32m-> 1564\u001b[0m     tmp_logs \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mtrain_function(iterator)\n\u001b[1;32m   1565\u001b[0m     \u001b[39mif\u001b[39;00m data_handler\u001b[39m.\u001b[39mshould_sync:\n\u001b[1;32m   1566\u001b[0m         context\u001b[39m.\u001b[39masync_wait()\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/util/traceback_utils.py:150\u001b[0m, in \u001b[0;36mfilter_traceback.<locals>.error_handler\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    148\u001b[0m filtered_tb \u001b[39m=\u001b[39m \u001b[39mNone\u001b[39;00m\n\u001b[1;32m    149\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m--> 150\u001b[0m   \u001b[39mreturn\u001b[39;00m fn(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m    151\u001b[0m \u001b[39mexcept\u001b[39;00m \u001b[39mException\u001b[39;00m \u001b[39mas\u001b[39;00m e:\n\u001b[1;32m    152\u001b[0m   filtered_tb \u001b[39m=\u001b[39m _process_traceback_frames(e\u001b[39m.\u001b[39m__traceback__)\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/eager/def_function.py:915\u001b[0m, in \u001b[0;36mFunction.__call__\u001b[0;34m(self, *args, **kwds)\u001b[0m\n\u001b[1;32m    912\u001b[0m compiler \u001b[39m=\u001b[39m \u001b[39m\"\u001b[39m\u001b[39mxla\u001b[39m\u001b[39m\"\u001b[39m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_jit_compile \u001b[39melse\u001b[39;00m \u001b[39m\"\u001b[39m\u001b[39mnonXla\u001b[39m\u001b[39m\"\u001b[39m\n\u001b[1;32m    914\u001b[0m \u001b[39mwith\u001b[39;00m OptionalXlaContext(\u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_jit_compile):\n\u001b[0;32m--> 915\u001b[0m   result \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_call(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwds)\n\u001b[1;32m    917\u001b[0m new_tracing_count \u001b[39m=\u001b[39m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mexperimental_get_tracing_count()\n\u001b[1;32m    918\u001b[0m without_tracing \u001b[39m=\u001b[39m (tracing_count \u001b[39m==\u001b[39m new_tracing_count)\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/eager/def_function.py:947\u001b[0m, in \u001b[0;36mFunction._call\u001b[0;34m(self, *args, **kwds)\u001b[0m\n\u001b[1;32m    944\u001b[0m   \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_lock\u001b[39m.\u001b[39mrelease()\n\u001b[1;32m    945\u001b[0m   \u001b[39m# In this case we have created variables on the first call, so we run the\u001b[39;00m\n\u001b[1;32m    946\u001b[0m   \u001b[39m# defunned version which is guaranteed to never create variables.\u001b[39;00m\n\u001b[0;32m--> 947\u001b[0m   \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_stateless_fn(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwds)  \u001b[39m# pylint: disable=not-callable\u001b[39;00m\n\u001b[1;32m    948\u001b[0m \u001b[39melif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_stateful_fn \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m    949\u001b[0m   \u001b[39m# Release the lock early so that multiple threads can perform the call\u001b[39;00m\n\u001b[1;32m    950\u001b[0m   \u001b[39m# in parallel.\u001b[39;00m\n\u001b[1;32m    951\u001b[0m   \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_lock\u001b[39m.\u001b[39mrelease()\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/eager/function.py:2495\u001b[0m, in \u001b[0;36mFunction.__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   2492\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Calls a graph function specialized to the inputs.\"\"\"\u001b[39;00m\n\u001b[1;32m   2493\u001b[0m \u001b[39mwith\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_lock:\n\u001b[1;32m   2494\u001b[0m   (graph_function,\n\u001b[0;32m-> 2495\u001b[0m    filtered_flat_args) \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_maybe_define_function(args, kwargs)\n\u001b[1;32m   2496\u001b[0m \u001b[39mreturn\u001b[39;00m graph_function\u001b[39m.\u001b[39m_call_flat(\n\u001b[1;32m   2497\u001b[0m     filtered_flat_args, captured_inputs\u001b[39m=\u001b[39mgraph_function\u001b[39m.\u001b[39mcaptured_inputs)\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/eager/function.py:2714\u001b[0m, in \u001b[0;36mFunction._maybe_define_function\u001b[0;34m(self, args, kwargs)\u001b[0m\n\u001b[1;32m   2690\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Gets a function for these inputs, defining it if necessary.\u001b[39;00m\n\u001b[1;32m   2691\u001b[0m \n\u001b[1;32m   2692\u001b[0m \u001b[39m`args` and `kwargs` can be None if this `Function` was created with an\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   2710\u001b[0m \u001b[39m    shape relaxation retracing.\u001b[39;00m\n\u001b[1;32m   2711\u001b[0m \u001b[39m\"\"\"\u001b[39;00m\n\u001b[1;32m   2712\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39minput_signature \u001b[39mis\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39mor\u001b[39;00m args \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39mor\u001b[39;00m kwargs \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m   2713\u001b[0m   args, kwargs, filtered_flat_args \u001b[39m=\u001b[39m (\n\u001b[0;32m-> 2714\u001b[0m       \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_function_spec\u001b[39m.\u001b[39;49mcanonicalize_function_inputs(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs))\n\u001b[1;32m   2715\u001b[0m \u001b[39melse\u001b[39;00m:\n\u001b[1;32m   2716\u001b[0m   filtered_flat_args \u001b[39m=\u001b[39m []\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/eager/function_spec.py:428\u001b[0m, in \u001b[0;36mFunctionSpec.canonicalize_function_inputs\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    426\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_input_signature \u001b[39mis\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m    427\u001b[0m   inputs, flat_inputs, filtered_flat_inputs \u001b[39m=\u001b[39m _convert_numpy_inputs(inputs)\n\u001b[0;32m--> 428\u001b[0m   kwargs, flat_kwargs, filtered_flat_kwargs \u001b[39m=\u001b[39m _convert_numpy_inputs(kwargs)\n\u001b[1;32m    429\u001b[0m   flat_inputs \u001b[39m+\u001b[39m\u001b[39m=\u001b[39m flat_kwargs\n\u001b[1;32m    430\u001b[0m   filtered_flat_inputs \u001b[39m+\u001b[39m\u001b[39m=\u001b[39m filtered_flat_kwargs\n",
      "File \u001b[0;32m/gpfs/gibbs/project/lafferty/ma2393/conda_envs/relml/lib/python3.8/site-packages/tensorflow/python/eager/function_spec.py:471\u001b[0m, in \u001b[0;36m_convert_numpy_inputs\u001b[0;34m(inputs)\u001b[0m\n\u001b[1;32m    469\u001b[0m need_packing \u001b[39m=\u001b[39m \u001b[39mFalse\u001b[39;00m\n\u001b[1;32m    470\u001b[0m filtered_flat_inputs \u001b[39m=\u001b[39m []\n\u001b[0;32m--> 471\u001b[0m \u001b[39mfor\u001b[39;00m index, value \u001b[39min\u001b[39;00m \u001b[39menumerate\u001b[39;49m(flat_inputs):\n\u001b[1;32m    472\u001b[0m   \u001b[39mif\u001b[39;00m \u001b[39misinstance\u001b[39m(value,\n\u001b[1;32m    473\u001b[0m                 (ops\u001b[39m.\u001b[39mTensor, resource_variable_ops\u001b[39m.\u001b[39mBaseResourceVariable)):\n\u001b[1;32m    474\u001b[0m     filtered_flat_inputs\u001b[39m.\u001b[39mappend(value)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "history = transformer_model.fit(X_train, y_train, validation_data=(X_train, y_train), epochs=100, verbose=1, batch_size=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "utils.plot_history(history, ('loss', 'binary_accuracy'));"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": "markdown",
   "metadata": {},
   "source": [
    "## Learning curve evaluation"
   ]
  },
  {
   "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)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.16 64-bit ('relml')",
   "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.16"
  },
  "vscode": {
   "interpreter": {
    "hash": "feb2622714ee4f3cfc5c273fa3fe6cf9410db521c7e03d7e619a7b4bef5cf3da"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
