{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Relational Match to Sample with asymmetric 'size' relation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Set Up"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-15 21:12:58.587568: 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 21:12:58.792215: 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 21:12:58.836519: 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 21:12:59.614350: 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 21:12:59.614546: 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 21:12:59.614561: 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\n",
    "\n",
    "from tqdm import tqdm, trange\n",
    "import wandb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "dat = np.load('imgs_size/RMTS_size_pretrain.npz')\n",
    "X = dat['x']\n",
    "y = dat['y']\n",
    "X = X\n",
    "X = np.expand_dims(X, axis=4)\n",
    "\n",
    "from sklearn.model_selection import train_test_split\n",
    "test_size = 0.35\n",
    "val_size = 0.15\n",
    "X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=test_size)\n",
    "X_train, X_val, y_train, y_val = train_test_split(X_train, y_train, test_size=val_size/(1-test_size))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((100, 2, 32, 32, 1),\n",
       " (100,),\n",
       " (30, 2, 32, 32, 1),\n",
       " (30,),\n",
       " (70, 2, 32, 32, 1),\n",
       " (70,))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.shape, y_train.shape, X_val.shape, y_val.shape, X_test.shape, y_test.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x500 with 10 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, y, to_show=5)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CNN Encoder (for all models)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "class CnnEncoder(tf.keras.Model):\n",
    "    def __init__(self, ff_dim1=64, ff_dim2=64, normalize=True, name='cnn_encoder'):\n",
    "        super().__init__(name=name)\n",
    "\n",
    "        self.conv_layer1 = layers.Conv2D(32, (3, 3), activation='relu', name='%s/conv_layer1' % name)\n",
    "        self.pool_layer1 = layers.MaxPooling2D((3, 3))\n",
    "        self.conv_layer2 = layers.Conv2D(32, (3, 3), activation='relu', name='%s/conv_layer2' % name)\n",
    "        self.pool_layer2 = layers.MaxPooling2D((3, 3))\n",
    "        self.flatten = layers.Flatten()\n",
    "        #self.dense1 = layers.Dense(ff_dim1, activation='relu')\n",
    "        self.dense2 = layers.Dense(ff_dim2, activation='tanh', name='%s/dense_layer' % name)\n",
    "        if normalize:\n",
    "            self.normalize = layers.LayerNormalization(center=False, scale=False, epsilon=1e-6)\n",
    "        else:\n",
    "            self.normalize = False\n",
    "\n",
    "    def call(self, inputs):\n",
    "        source = inputs\n",
    "        x = self.conv_layer1(source)\n",
    "        x = self.pool_layer1(x)\n",
    "        x = self.conv_layer2(x)\n",
    "        x = self.pool_layer2(x)\n",
    "        x = self.flatten(x)\n",
    "        #x = self.dense1(x)\n",
    "        x = self.dense2(x)\n",
    "        if self.normalize:\n",
    "            outputs = self.normalize(x)\n",
    "        else:\n",
    "            outputs = x\n",
    "        return outputs\n",
    "    \n",
    "    def print_summary(self, input_shape):\n",
    "        inputs = layers.Input(input_shape)\n",
    "        outputs = self.call(inputs)\n",
    "        print(tf.keras.Model(inputs, outputs).summary())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Abstractor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from abstracters import SimpleAbstractor, RelationalAbstracter\n",
    "from abstractor import Abstractor\n",
    "from tensorflow.keras import layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-15 21:18:25.688965: 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 21:18:26.393483: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1616] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 22296 MB memory:  -> device: 0, name: NVIDIA GeForce RTX 3090, pci bus id: 0000:1c:00.0, compute capability: 8.6\n",
      "2023-05-15 21:18:27.570535: I tensorflow/stream_executor/cuda/cuda_dnn.cc:384] Loaded cuDNN version 8101\n",
      "2023-05-15 21:18:28.585684: W tensorflow/stream_executor/gpu/asm_compiler.cc:80] Couldn't get ptxas version string: INTERNAL: Running ptxas --version returned 32512\n",
      "2023-05-15 21:18:28.652976: W tensorflow/stream_executor/gpu/redzone_allocator.cc:314] INTERNAL: ptxas exited with non-zero error code 32512, output: \n",
      "Relying on driver to perform ptx compilation. \n",
      "Modify $PATH to customize ptxas location.\n",
      "This message will be only logged once.\n",
      "2023-05-15 21:18:29.448211: I tensorflow/stream_executor/cuda/cuda_blas.cc:1614] TensorFloat-32 will be used for the matrix multiplication. This will only be logged once.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"rmts_abstractor\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  17824     \n",
      "                                                                 \n",
      " abstractor (Abstractor)     multiple                  8450      \n",
      "                                                                 \n",
      " flatten_1 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  672       \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 26,979\n",
      "Trainable params: 9,155\n",
      "Non-trainable params: 17,824\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=False, name='cnn_encoder')\n",
    "\n",
    "rmtsabstractor_kwargs = dict(cnn_encoder_kwargs=cnn_encoder_kwargs, abstractor_kwargs=abstractor_kwargs)\n",
    "\n",
    "class AbstractorRMTSModel(tf.keras.Model):\n",
    "    def __init__(self, cnn_encoder_kwargs, 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",
    "# create_opt = lambda : tf.keras.optimizers.Adam()\n",
    "\n",
    "abstractor_model = AbstractorRMTSModel(**rmtsabstractor_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": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/20\n",
      "1/1 [==============================] - 2s 2s/step - loss: 0.7536 - binary_accuracy: 0.5000 - val_loss: 0.7473 - val_binary_accuracy: 0.5000\n",
      "Epoch 2/20\n",
      "1/1 [==============================] - 0s 53ms/step - loss: 0.7249 - binary_accuracy: 0.5000 - val_loss: 0.7382 - val_binary_accuracy: 0.5000\n",
      "Epoch 3/20\n",
      "1/1 [==============================] - 0s 60ms/step - loss: 0.7594 - binary_accuracy: 0.5000 - val_loss: 0.7294 - val_binary_accuracy: 0.5000\n",
      "Epoch 4/20\n",
      "1/1 [==============================] - 0s 60ms/step - loss: 0.6994 - binary_accuracy: 0.5000 - val_loss: 0.7212 - val_binary_accuracy: 0.5000\n",
      "Epoch 5/20\n",
      "1/1 [==============================] - 0s 60ms/step - loss: 0.7176 - binary_accuracy: 0.5000 - val_loss: 0.7139 - val_binary_accuracy: 0.5000\n",
      "Epoch 6/20\n",
      "1/1 [==============================] - 0s 55ms/step - loss: 0.7473 - binary_accuracy: 0.5000 - val_loss: 0.7070 - val_binary_accuracy: 0.5000\n",
      "Epoch 7/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.7064 - binary_accuracy: 0.5000 - val_loss: 0.6999 - val_binary_accuracy: 0.5000\n",
      "Epoch 8/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.7135 - binary_accuracy: 0.5000 - val_loss: 0.6928 - val_binary_accuracy: 0.5000\n",
      "Epoch 9/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.7028 - binary_accuracy: 0.5000 - val_loss: 0.6862 - val_binary_accuracy: 0.5000\n",
      "Epoch 10/20\n",
      "1/1 [==============================] - 0s 56ms/step - loss: 0.6707 - binary_accuracy: 0.6000 - val_loss: 0.6796 - val_binary_accuracy: 0.5000\n",
      "Epoch 11/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.6891 - binary_accuracy: 0.5000 - val_loss: 0.6731 - val_binary_accuracy: 0.5000\n",
      "Epoch 12/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.6873 - binary_accuracy: 0.5000 - val_loss: 0.6664 - val_binary_accuracy: 0.5000\n",
      "Epoch 13/20\n",
      "1/1 [==============================] - 0s 58ms/step - loss: 0.6804 - binary_accuracy: 0.4000 - val_loss: 0.6597 - val_binary_accuracy: 0.7000\n",
      "Epoch 14/20\n",
      "1/1 [==============================] - 0s 58ms/step - loss: 0.6386 - binary_accuracy: 0.8000 - val_loss: 0.6526 - val_binary_accuracy: 0.7000\n",
      "Epoch 15/20\n",
      "1/1 [==============================] - 0s 62ms/step - loss: 0.6450 - binary_accuracy: 0.8000 - val_loss: 0.6451 - val_binary_accuracy: 0.7000\n",
      "Epoch 16/20\n",
      "1/1 [==============================] - 0s 61ms/step - loss: 0.6562 - binary_accuracy: 0.8000 - val_loss: 0.6371 - val_binary_accuracy: 1.0000\n",
      "Epoch 17/20\n",
      "1/1 [==============================] - 0s 58ms/step - loss: 0.6246 - binary_accuracy: 0.8000 - val_loss: 0.6301 - val_binary_accuracy: 1.0000\n",
      "Epoch 18/20\n",
      "1/1 [==============================] - 0s 60ms/step - loss: 0.6337 - binary_accuracy: 0.9000 - val_loss: 0.6225 - val_binary_accuracy: 1.0000\n",
      "Epoch 19/20\n",
      "1/1 [==============================] - 0s 59ms/step - loss: 0.6227 - binary_accuracy: 0.9000 - val_loss: 0.6143 - val_binary_accuracy: 1.0000\n",
      "Epoch 20/20\n",
      "1/1 [==============================] - 0s 58ms/step - loss: 0.6445 - binary_accuracy: 0.7000 - val_loss: 0.6058 - val_binary_accuracy: 1.0000\n"
     ]
    }
   ],
   "source": [
    "train_size = 10\n",
    "X_train_, y_train_ = X_train[:train_size], y_train[:train_size]\n",
    "history = abstractor_model.fit(X_train_, y_train_, validation_data=(X_train_, y_train_),\n",
    "    verbose=1, epochs=20, batch_size=64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/4 [==============================] - 0s 18ms/step - loss: 0.6272 - binary_accuracy: 0.9000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.6271562576293945, 0.8999999761581421]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abstractor_model.evaluate(X_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3/3 [==============================] - 0s 14ms/step - loss: 0.6387 - binary_accuracy: 0.8286\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.6387030482292175, 0.8285714387893677]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abstractor_model.evaluate(X_test, y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CorelNet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "from multi_head_relation import MultiHeadRelation\n",
    "from tensorflow.keras import layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"rmts_corelnet\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  17824     \n",
      "                                                                 \n",
      " flatten_3 (Flatten)         multiple                  0         \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  160       \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  33        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 18,017\n",
      "Trainable params: 193\n",
      "Non-trainable params: 17,824\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "embedding_dim = 64\n",
    "cnn_encoder_kwargs = dict(ff_dim2=embedding_dim, normalize=False, name='cnn_encoder')\n",
    "rmtscorelnet_kwargs = dict(cnn_encoder_kwargs=cnn_encoder_kwargs)\n",
    "\n",
    "class CorelNetRMTSModel(tf.keras.Model):\n",
    "    def __init__(self, cnn_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.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(**rmtscorelnet_kwargs, name='rmts_corelnet')\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": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/20\n",
      "1/1 [==============================] - 1s 1s/step - loss: 0.6902 - binary_accuracy: 0.5000 - val_loss: 0.6889 - val_binary_accuracy: 0.5000\n",
      "Epoch 2/20\n",
      "1/1 [==============================] - 0s 55ms/step - loss: 0.6889 - binary_accuracy: 0.5000 - val_loss: 0.6877 - val_binary_accuracy: 0.5000\n",
      "Epoch 3/20\n",
      "1/1 [==============================] - 0s 55ms/step - loss: 0.6877 - binary_accuracy: 0.5000 - val_loss: 0.6867 - val_binary_accuracy: 0.5000\n",
      "Epoch 4/20\n",
      "1/1 [==============================] - 0s 56ms/step - loss: 0.6867 - binary_accuracy: 0.5000 - val_loss: 0.6859 - val_binary_accuracy: 0.5000\n",
      "Epoch 5/20\n",
      "1/1 [==============================] - 0s 58ms/step - loss: 0.6859 - binary_accuracy: 0.5000 - val_loss: 0.6852 - val_binary_accuracy: 0.5000\n",
      "Epoch 6/20\n",
      "1/1 [==============================] - 0s 54ms/step - loss: 0.6852 - binary_accuracy: 0.5000 - val_loss: 0.6847 - val_binary_accuracy: 0.6000\n",
      "Epoch 7/20\n",
      "1/1 [==============================] - 0s 54ms/step - loss: 0.6847 - binary_accuracy: 0.6000 - val_loss: 0.6842 - val_binary_accuracy: 0.6000\n",
      "Epoch 8/20\n",
      "1/1 [==============================] - 0s 59ms/step - loss: 0.6842 - binary_accuracy: 0.6000 - val_loss: 0.6838 - val_binary_accuracy: 0.6000\n",
      "Epoch 9/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.6838 - binary_accuracy: 0.6000 - val_loss: 0.6835 - val_binary_accuracy: 0.6000\n",
      "Epoch 10/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.6835 - binary_accuracy: 0.6000 - val_loss: 0.6831 - val_binary_accuracy: 0.7000\n",
      "Epoch 11/20\n",
      "1/1 [==============================] - 0s 56ms/step - loss: 0.6831 - binary_accuracy: 0.7000 - val_loss: 0.6828 - val_binary_accuracy: 0.7000\n",
      "Epoch 12/20\n",
      "1/1 [==============================] - 0s 56ms/step - loss: 0.6828 - binary_accuracy: 0.7000 - val_loss: 0.6824 - val_binary_accuracy: 0.7000\n",
      "Epoch 13/20\n",
      "1/1 [==============================] - 0s 59ms/step - loss: 0.6824 - binary_accuracy: 0.7000 - val_loss: 0.6820 - val_binary_accuracy: 0.7000\n",
      "Epoch 14/20\n",
      "1/1 [==============================] - 0s 55ms/step - loss: 0.6820 - binary_accuracy: 0.7000 - val_loss: 0.6816 - val_binary_accuracy: 0.7000\n",
      "Epoch 15/20\n",
      "1/1 [==============================] - 0s 54ms/step - loss: 0.6816 - binary_accuracy: 0.7000 - val_loss: 0.6812 - val_binary_accuracy: 0.7000\n",
      "Epoch 16/20\n",
      "1/1 [==============================] - 0s 57ms/step - loss: 0.6812 - binary_accuracy: 0.7000 - val_loss: 0.6807 - val_binary_accuracy: 0.7000\n",
      "Epoch 17/20\n",
      "1/1 [==============================] - 0s 56ms/step - loss: 0.6807 - binary_accuracy: 0.7000 - val_loss: 0.6803 - val_binary_accuracy: 0.7000\n",
      "Epoch 18/20\n",
      "1/1 [==============================] - 0s 61ms/step - loss: 0.6803 - binary_accuracy: 0.7000 - val_loss: 0.6799 - val_binary_accuracy: 0.7000\n",
      "Epoch 19/20\n",
      "1/1 [==============================] - 0s 60ms/step - loss: 0.6799 - binary_accuracy: 0.7000 - val_loss: 0.6797 - val_binary_accuracy: 0.7000\n",
      "Epoch 20/20\n",
      "1/1 [==============================] - 0s 58ms/step - loss: 0.6797 - binary_accuracy: 0.7000 - val_loss: 0.6795 - val_binary_accuracy: 0.7000\n"
     ]
    }
   ],
   "source": [
    "train_size = 10\n",
    "X_train_, y_train_ = X_train[:train_size], y_train[:train_size]\n",
    "history = corelnet_model.fit(X_train_, y_train_, validation_data=(X_train_, y_train_),\n",
    "    verbose=1, epochs=20, batch_size=64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/4 [==============================] - 0s 15ms/step - loss: 0.6986 - binary_accuracy: 0.5500\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.698609471321106, 0.550000011920929]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corelnet_model.evaluate(X_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3/3 [==============================] - 0s 16ms/step - loss: 0.6984 - binary_accuracy: 0.5429\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.6983519196510315, 0.5428571701049805]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corelnet_model.evaluate(X_test, y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Transformer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformer_modules import Encoder\n",
    "from tensorflow.keras import layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"rmts_transformer\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " cnn_encoder (CnnEncoder)    multiple                  17824     \n",
      "                                                                 \n",
      " encoder (Encoder)           multiple                  74944     \n",
      "                                                                 \n",
      " flatten_11 (Flatten)        multiple                  0         \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  8256      \n",
      "                                                                 \n",
      " hidden_layer (Dense)        multiple                  4160      \n",
      "                                                                 \n",
      " final_layer (Dense)         multiple                  65        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 105,249\n",
      "Trainable params: 105,249\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "\n",
    "embedding_dim = 64\n",
    "encoder_kwargs = dict(\n",
    "    num_layers=1, \n",
    "    num_heads=4,\n",
    "    dff=64,\n",
    "    dropout_rate=0.1)\n",
    "\n",
    "cnn_encoder_kwargs = dict(ff_dim2=embedding_dim, normalize=False, name='cnn_encoder')\n",
    "rmtstransformer_kwargs = dict(cnn_encoder_kwargs=cnn_encoder_kwargs, encoder_kwargs=encoder_kwargs)\n",
    "\n",
    "class TransformerRMTSModel(tf.keras.Model):\n",
    "    def __init__(self, cnn_encoder_kwargs, encoder_kwargs, name=None):\n",
    "        super().__init__(name=name)\n",
    "        self.cnn_encoder = CnnEncoder(**cnn_encoder_kwargs)\n",
    "        # self.cnn_embedder = layers.TimeDistributed(self.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_dense1 = layers.Dense(64, activation='relu', name='hidden_layer')\n",
    "        self.hidden_dense2 = layers.Dense(64, 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 = self.cnn_embedder(inputs)\n",
    "        x = tf.map_fn(self.cnn_encoder, inputs)\n",
    "        x = self.encoder(x)\n",
    "        x = self.flatten(x)\n",
    "        x = self.hidden_dense1(x)\n",
    "        x = self.hidden_dense2(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.01)\n",
    "# create_opt = lambda : tf.keras.optimizers.SGD(learning_rate=0.01)\n",
    "\n",
    "transformer_model = TransformerRMTSModel(**rmtstransformer_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": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/40\n",
      "1/1 [==============================] - 2s 2s/step - loss: 0.7347 - binary_accuracy: 0.5000 - val_loss: 0.6877 - val_binary_accuracy: 0.5000\n",
      "Epoch 2/40\n",
      "1/1 [==============================] - 0s 68ms/step - loss: 0.6989 - binary_accuracy: 0.5000 - val_loss: 0.7725 - val_binary_accuracy: 0.5000\n",
      "Epoch 3/40\n",
      "1/1 [==============================] - 0s 70ms/step - loss: 0.7798 - binary_accuracy: 0.5000 - val_loss: 1.2982 - val_binary_accuracy: 0.5000\n",
      "Epoch 4/40\n",
      "1/1 [==============================] - 0s 65ms/step - loss: 1.3030 - binary_accuracy: 0.5000 - val_loss: 0.7465 - val_binary_accuracy: 0.5000\n",
      "Epoch 5/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.7471 - binary_accuracy: 0.5000 - val_loss: 0.7116 - val_binary_accuracy: 0.5000\n",
      "Epoch 6/40\n",
      "1/1 [==============================] - 0s 64ms/step - loss: 0.7107 - binary_accuracy: 0.5000 - val_loss: 0.7256 - val_binary_accuracy: 0.5000\n",
      "Epoch 7/40\n",
      "1/1 [==============================] - 0s 67ms/step - loss: 0.7149 - binary_accuracy: 0.5000 - val_loss: 0.7040 - val_binary_accuracy: 0.5000\n",
      "Epoch 8/40\n",
      "1/1 [==============================] - 0s 66ms/step - loss: 0.7019 - binary_accuracy: 0.5000 - val_loss: 0.6935 - val_binary_accuracy: 0.5000\n",
      "Epoch 9/40\n",
      "1/1 [==============================] - 0s 67ms/step - loss: 0.6961 - binary_accuracy: 0.5000 - val_loss: 0.7092 - val_binary_accuracy: 0.5000\n",
      "Epoch 10/40\n",
      "1/1 [==============================] - 0s 70ms/step - loss: 0.6934 - binary_accuracy: 0.5000 - val_loss: 0.6911 - val_binary_accuracy: 0.5000\n",
      "Epoch 11/40\n",
      "1/1 [==============================] - 0s 69ms/step - loss: 0.6973 - binary_accuracy: 0.4000 - val_loss: 0.7059 - val_binary_accuracy: 0.5000\n",
      "Epoch 12/40\n",
      "1/1 [==============================] - 0s 70ms/step - loss: 0.7203 - binary_accuracy: 0.5000 - val_loss: 0.6945 - val_binary_accuracy: 0.5000\n",
      "Epoch 13/40\n",
      "1/1 [==============================] - 0s 68ms/step - loss: 0.6904 - binary_accuracy: 0.5000 - val_loss: 0.7048 - val_binary_accuracy: 0.5000\n",
      "Epoch 14/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.7008 - binary_accuracy: 0.5000 - val_loss: 0.6989 - val_binary_accuracy: 0.5000\n",
      "Epoch 15/40\n",
      "1/1 [==============================] - 0s 68ms/step - loss: 0.6994 - binary_accuracy: 0.5000 - val_loss: 0.7025 - val_binary_accuracy: 0.5000\n",
      "Epoch 16/40\n",
      "1/1 [==============================] - 0s 73ms/step - loss: 0.7039 - binary_accuracy: 0.5000 - val_loss: 0.6944 - val_binary_accuracy: 0.5000\n",
      "Epoch 17/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.6987 - binary_accuracy: 0.4000 - val_loss: 0.7040 - val_binary_accuracy: 0.5000\n",
      "Epoch 18/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.7033 - binary_accuracy: 0.5000 - val_loss: 0.6941 - val_binary_accuracy: 0.5000\n",
      "Epoch 19/40\n",
      "1/1 [==============================] - 0s 68ms/step - loss: 0.6978 - binary_accuracy: 0.5000 - val_loss: 0.7029 - val_binary_accuracy: 0.5000\n",
      "Epoch 20/40\n",
      "1/1 [==============================] - 0s 73ms/step - loss: 0.6769 - binary_accuracy: 0.5000 - val_loss: 0.6923 - val_binary_accuracy: 0.5000\n",
      "Epoch 21/40\n",
      "1/1 [==============================] - 0s 67ms/step - loss: 0.6947 - binary_accuracy: 0.7000 - val_loss: 0.6934 - val_binary_accuracy: 0.5000\n",
      "Epoch 22/40\n",
      "1/1 [==============================] - 0s 67ms/step - loss: 0.6900 - binary_accuracy: 0.6000 - val_loss: 0.6918 - val_binary_accuracy: 0.5000\n",
      "Epoch 23/40\n",
      "1/1 [==============================] - 0s 67ms/step - loss: 0.7222 - binary_accuracy: 0.5000 - val_loss: 0.6939 - val_binary_accuracy: 0.5000\n",
      "Epoch 24/40\n",
      "1/1 [==============================] - 0s 67ms/step - loss: 0.7486 - binary_accuracy: 0.3000 - val_loss: 0.6894 - val_binary_accuracy: 0.5000\n",
      "Epoch 25/40\n",
      "1/1 [==============================] - 0s 70ms/step - loss: 0.7688 - binary_accuracy: 0.3000 - val_loss: 0.6911 - val_binary_accuracy: 0.5000\n",
      "Epoch 26/40\n",
      "1/1 [==============================] - 0s 68ms/step - loss: 0.6949 - binary_accuracy: 0.5000 - val_loss: 0.7189 - val_binary_accuracy: 0.5000\n",
      "Epoch 27/40\n",
      "1/1 [==============================] - 0s 68ms/step - loss: 0.7230 - binary_accuracy: 0.5000 - val_loss: 0.6935 - val_binary_accuracy: 0.5000\n",
      "Epoch 28/40\n",
      "1/1 [==============================] - 0s 70ms/step - loss: 0.6738 - binary_accuracy: 0.5000 - val_loss: 0.7001 - val_binary_accuracy: 0.5000\n",
      "Epoch 29/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.7219 - binary_accuracy: 0.5000 - val_loss: 0.7299 - val_binary_accuracy: 0.5000\n",
      "Epoch 30/40\n",
      "1/1 [==============================] - 0s 65ms/step - loss: 0.7334 - binary_accuracy: 0.5000 - val_loss: 0.6894 - val_binary_accuracy: 0.6000\n",
      "Epoch 31/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.6834 - binary_accuracy: 0.4000 - val_loss: 0.7113 - val_binary_accuracy: 0.5000\n",
      "Epoch 32/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.6982 - binary_accuracy: 0.5000 - val_loss: 0.6861 - val_binary_accuracy: 0.7000\n",
      "Epoch 33/40\n",
      "1/1 [==============================] - 0s 72ms/step - loss: 0.6942 - binary_accuracy: 0.5000 - val_loss: 0.6934 - val_binary_accuracy: 0.5000\n",
      "Epoch 34/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.7109 - binary_accuracy: 0.5000 - val_loss: 0.6848 - val_binary_accuracy: 0.5000\n",
      "Epoch 35/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.6906 - binary_accuracy: 0.6000 - val_loss: 0.6998 - val_binary_accuracy: 0.5000\n",
      "Epoch 36/40\n",
      "1/1 [==============================] - 0s 66ms/step - loss: 0.6657 - binary_accuracy: 0.6000 - val_loss: 0.6943 - val_binary_accuracy: 0.5000\n",
      "Epoch 37/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.6840 - binary_accuracy: 0.6000 - val_loss: 0.6922 - val_binary_accuracy: 0.5000\n",
      "Epoch 38/40\n",
      "1/1 [==============================] - 0s 75ms/step - loss: 0.7066 - binary_accuracy: 0.5000 - val_loss: 0.6640 - val_binary_accuracy: 0.5000\n",
      "Epoch 39/40\n",
      "1/1 [==============================] - 0s 73ms/step - loss: 0.7355 - binary_accuracy: 0.5000 - val_loss: 0.6321 - val_binary_accuracy: 0.7000\n",
      "Epoch 40/40\n",
      "1/1 [==============================] - 0s 71ms/step - loss: 0.6439 - binary_accuracy: 0.7000 - val_loss: 0.6141 - val_binary_accuracy: 0.7000\n"
     ]
    }
   ],
   "source": [
    "train_size = 10\n",
    "X_train_, y_train_ = X_train[:train_size], y_train[:train_size]\n",
    "history = transformer_model.fit(X_train_, y_train_, validation_data=(X_train_, y_train_),\n",
    "    verbose=1, epochs=40, batch_size=64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/4 [==============================] - 0s 20ms/step - loss: 0.6508 - binary_accuracy: 0.6200\n"
     ]
    }
   ],
   "source": [
    "transformer_model.evaluate(X_train, y_train);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3/3 [==============================] - 0s 15ms/step - loss: 0.6761 - binary_accuracy: 0.5143\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.6760765314102173, 0.5142857432365417]"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "transformer_model.evaluate(X_test, y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Learning curve evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_callbacks(use_wandb=False, patience=10):\n",
    "    callbacks = []\n",
    "    callbacks.append(tf.keras.callbacks.EarlyStopping(monitor='val_loss', \n",
    "        patience=patience, min_delta=1e-2, baseline=0.6, mode='auto',\n",
    "        restore_best_weights=True, verbose=False))\n",
    "    if use_wandb: callbacks.append(wandb.keras.WandbMetricsLogger(log_freq='epoch'))\n",
    "    return callbacks\n",
    "\n",
    "def evaluate_model(model, X_test, y_test):\n",
    "    eval_dict = model.evaluate(X_test, y_test, return_dict=True, verbose=False)\n",
    "    return eval_dict\n",
    "\n",
    "def log_to_wandb(evaluation_dict):\n",
    "    wandb.log(evaluation_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "start_trial = 0\n",
    "wandb_project_name = 'abstractor_size_rmts'\n",
    "\n",
    "fit_kwargs = {'epochs': 100, 'batch_size': 64}\n",
    "\n",
    "def evaluate_learning_curves(\n",
    "    create_model, group_name, \n",
    "    X_train, y_train, X_val, y_val, X_test, y_test,\n",
    "    train_sizes, num_trials, use_wandb=False):\n",
    "\n",
    "    eval_dicts =[]\n",
    "\n",
    "    for train_size in tqdm(train_sizes, desc='train size'):\n",
    "\n",
    "        for trial in trange(start_trial, start_trial + num_trials, desc='trial', leave=False):\n",
    "\n",
    "            if use_wandb:\n",
    "                run = wandb.init(project=wandb_project_name, group=group_name, name=f'train size = {train_size}; trial = {trial}',\n",
    "                    config={'train size': train_size, 'trial': trial, 'group': group_name})\n",
    "            model = create_model()\n",
    "\n",
    "            sample_idx = np.random.choice(len(X_train), train_size, replace=False)\n",
    "            X_train_ = X_train[sample_idx]\n",
    "            y_train_ = y_train[sample_idx]\n",
    "            \n",
    "            history = model.fit(X_train, y_train, validation_data=(X_val, y_val), verbose=0,\n",
    "                callbacks=create_callbacks(use_wandb=use_wandb), **fit_kwargs)\n",
    "\n",
    "            eval_dict = evaluate_model(model, X_test, y_test)\n",
    "            \n",
    "            if use_wandb:\n",
    "                log_to_wandb(eval_dict)\n",
    "                wandb.finish(quiet=True)\n",
    "            \n",
    "            eval_dict.update({'group': group_name, 'train_size': train_size, 'trial': trial})\n",
    "            eval_dicts.append(eval_dict)\n",
    "\n",
    "            del model\n",
    "    \n",
    "    return eval_dicts\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_abstractor():\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(**rmtsabstractor_kwargs, name='rmts_abstractor')\n",
    "    abstractor_model.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "    abstractor_model(X_train[:32])\n",
    "\n",
    "    return abstractor_model\n",
    "\n",
    "def create_corelnet():\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(**rmtscorelnet_kwargs, name='rmts_corelnet')\n",
    "    corelnet_model.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "    corelnet_model(X_train[:32])\n",
    "    return corelnet_model\n",
    "\n",
    "def create_transformer():\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",
    "    transformer_model = TransformerRMTSModel(**rmtstransformer_kwargs, name='rmts_transformer')\n",
    "    transformer_model.compile(loss='binary_crossentropy', optimizer=create_opt(), metrics=['binary_accuracy'])\n",
    "    transformer_model(X_train[:32])\n",
    "    return transformer_model\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Failed to detect the name of this notebook, you can set it manually with the WANDB_NOTEBOOK_NAME environment variable to enable code saving.\n",
      "\u001b[34m\u001b[1mwandb\u001b[0m: Currently logged in as: \u001b[33mawni00\u001b[0m. Use \u001b[1m`wandb login --relogin`\u001b[0m to force relogin\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "wandb.login()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating abstractor\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "train size: 100%|██████████| 5/5 [00:24<00:00,  4.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating corelnet\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "train size: 100%|██████████| 5/5 [00:13<00:00,  2.67s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating transformer\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "train size: 100%|██████████| 5/5 [00:39<00:00,  7.85s/it]\n"
     ]
    }
   ],
   "source": [
    "num_trials = 1\n",
    "train_sizes = [5, 10, 20, 30, 40]\n",
    "\n",
    "print('evaluating abstractor')\n",
    "\n",
    "abstractor_eval_dicts = evaluate_learning_curves(\n",
    "    create_abstractor, 'abstractor', \n",
    "    X_train, y_train, X_val, y_val, X_test, y_test,\n",
    "    train_sizes, num_trials, use_wandb=False)\n",
    "\n",
    "print('evaluating corelnet')\n",
    "\n",
    "corelnet_eval_dicts = evaluate_learning_curves(\n",
    "    create_corelnet, 'corelnet', \n",
    "    X_train, y_train, X_val, y_val, X_test, y_test,\n",
    "    train_sizes, num_trials, use_wandb=False)\n",
    "\n",
    "print('evaluating transformer')\n",
    "\n",
    "transformer_eval_dicts = evaluate_learning_curves(\n",
    "    create_transformer, 'transformer', \n",
    "    X_train, y_train, X_val, y_val, X_test, y_test,\n",
    "    train_sizes, num_trials, use_wandb=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>loss</th>\n",
       "      <th>binary_accuracy</th>\n",
       "      <th>group</th>\n",
       "      <th>train_size</th>\n",
       "      <th>trial</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.022509</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>abstractor</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.619966</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>abstractor</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.613458</td>\n",
       "      <td>0.914286</td>\n",
       "      <td>abstractor</td>\n",
       "      <td>20</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.027017</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>abstractor</td>\n",
       "      <td>30</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.611699</td>\n",
       "      <td>0.671429</td>\n",
       "      <td>abstractor</td>\n",
       "      <td>40</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.712416</td>\n",
       "      <td>0.471429</td>\n",
       "      <td>corelnet</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.688291</td>\n",
       "      <td>0.814286</td>\n",
       "      <td>corelnet</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.703540</td>\n",
       "      <td>0.471429</td>\n",
       "      <td>corelnet</td>\n",
       "      <td>20</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.753636</td>\n",
       "      <td>0.471429</td>\n",
       "      <td>corelnet</td>\n",
       "      <td>30</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.634969</td>\n",
       "      <td>0.828571</td>\n",
       "      <td>corelnet</td>\n",
       "      <td>40</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.000941</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>transformer</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.008980</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>transformer</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.008932</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>transformer</td>\n",
       "      <td>20</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.003858</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>transformer</td>\n",
       "      <td>30</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.004558</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>transformer</td>\n",
       "      <td>40</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       loss  binary_accuracy        group  train_size  trial\n",
       "0  0.022509         1.000000   abstractor           5      0\n",
       "1  0.619966         1.000000   abstractor          10      0\n",
       "2  0.613458         0.914286   abstractor          20      0\n",
       "3  0.027017         1.000000   abstractor          30      0\n",
       "4  0.611699         0.671429   abstractor          40      0\n",
       "0  0.712416         0.471429     corelnet           5      0\n",
       "1  0.688291         0.814286     corelnet          10      0\n",
       "2  0.703540         0.471429     corelnet          20      0\n",
       "3  0.753636         0.471429     corelnet          30      0\n",
       "4  0.634969         0.828571     corelnet          40      0\n",
       "0  0.000941         1.000000  transformer           5      0\n",
       "1  0.008980         1.000000  transformer          10      0\n",
       "2  0.008932         1.000000  transformer          20      0\n",
       "3  0.003858         1.000000  transformer          30      0\n",
       "4  0.004558         1.000000  transformer          40      0"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "dfs = [pd.DataFrame(eval_dict) for eval_dict in (abstractor_eval_dicts, corelnet_eval_dicts, transformer_eval_dicts)]\n",
    "pd.concat(dfs)"
   ]
  }
 ],
 "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
}
