{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2a1c8a85",
   "metadata": {},
   "source": [
    "# Demo: Systematic Compositional Generalization (depth 3)\n",
    "#### Reproducing train/test splits from \"On the generalization capacity of neural networks during generic multimodal reasoning\" (ICLR 2024)\n",
    "\n",
    "Note, that that this demo reproduces task inputs and targets that are converted to token IDs, rather than image pixels and natural language inputs.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2b7aaa17",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from gcog.models import rnn, transformer\n",
    "import gcog.task.config as config\n",
    "import gcog.task.dataset_generator as datagen # DATASET objects\n",
    "import gcog.task.task_generator as taskgen\n",
    "from torch.utils.data import DataLoader\n",
    "plt.rcParams['font.sans-serif'] = \"Arial\"\n",
    "%matplotlib inline\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b151253f",
   "metadata": {},
   "source": [
    "# Systematic compositional generalization split on task trees of depth 3 (CompTreeSubsets) (Fig. 4C)\n",
    "\n",
    "Specifically, all individual task operators are seen in the training set (e.g., EXIST -> GETLOCATION or SUMEVEN -> GETCOLOR); however, specific task operator combinations (e.g., EXIST -> GETCOLOR) are held out and limited to the test set\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3d508ae6",
   "metadata": {},
   "outputs": [],
   "source": [
    "#### Systematic generalization split\n",
    "dataset = 'comptreesubsets' # comptreesubsets ~ compositional tree structure (depth 3)\n",
    "taskdepth = 3 # number of nodes to include; depth 3 systematicity\n",
    "train_distractors = 5 # number of distractors to 'train' on\n",
    "test_distractors = 5 # number of distractors to 'test' on. (since this is not the distractor split, we can just choose the same number of distractors)\n",
    "ntrials = 5000 # number of randomly-sampled trials PER task operator\n",
    "location_sampling = True # when randomly sampling object features, randomly sample from all possible locations (i.e., red 'a' at location (1,1))\n",
    "nfeatures = 10 # number of object features to limit the model (i.e., only 10 colors and 10 shapes = 100 total color x shape combinations)\n",
    "\n",
    "train_dataset = datagen.CompTreeDatasetSubset(tree_depth=taskdepth,\n",
    "                                              n_distractors=train_distractors,\n",
    "                                              distractor_range=True,\n",
    "                                              location=location_sampling,\n",
    "                                              ntrials=ntrials,\n",
    "                                              subset=1, # 1 is train set (arbitrary choice)\n",
    "                                              nfeatures=nfeatures)\n",
    "\n",
    "test_dataset = datagen.CompTreeDatasetSubset(tree_depth=taskdepth,\n",
    "                                             n_distractors=test_distractors,\n",
    "                                             distractor_range=True,\n",
    "                                             location=location_sampling,\n",
    "                                             ntrials=ntrials,\n",
    "                                             subset=2, # 2 is test set\n",
    "                                             nfeatures=nfeatures)\n",
    "\n",
    "                                    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "20c0bb3f",
   "metadata": {},
   "source": [
    "#### Print dataset statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "48eac947",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of trials/samples: 40000\n"
     ]
    }
   ],
   "source": [
    "print('Number of trials/samples:', len(train_dataset)) # Number of task operators (8) * ntrials"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c001674",
   "metadata": {},
   "source": [
    "#### Initialize dataloader (and simulate forward inference)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6e210245",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Size of rule inputs: torch.Size([64, 5, 8])\n",
      "Size of stim inputs: torch.Size([64, 101, 3, 1])\n",
      "Size of target output: torch.Size([64])\n"
     ]
    }
   ],
   "source": [
    "## Demonstration with just the trainloader; identical format with testloader\n",
    "\n",
    "opsys_trainloader = DataLoader(train_dataset, batch_size=64, shuffle=True, num_workers=0)\n",
    "\n",
    "# Retrieve batch from dataloader \n",
    "# rule inputs are the task instruction input\n",
    "# stim_inputs are the binarized stimulus input\n",
    "# target_outputs are the output label (for classification task)\n",
    "# task_ordering: for now, disregard task_ordering; it's not necessary\n",
    "rule_inputs, stim_inputs, target_outputs, task_ordering = next(iter(opsys_trainloader)) \n",
    "\n",
    "# Rule and stim inputs have +1, to include the EOS token\n",
    "print('Size of rule inputs:', rule_inputs.shape) # batch_size x task tree length (rule sequence/tokens) x rule embedding \n",
    "print('Size of stim inputs:', stim_inputs.shape) # batch_size x image sequence/tokens (grid size is 10x10) x feature embedding x 1 image\n",
    "print('Size of target output:', target_outputs.shape) # batch_size, ranges from 1-138 (possible decision outputs/vocabulary)\n",
    "## Outputs can be:\n",
    "# Bool: True or False statement\n",
    "# Location tuple: 100 possible locations on a 10x10 grid\n",
    "# Shape identity: The identity of 26 possible shapes\n",
    "# Color identity: The identity of 10 possible colors\n",
    "# all together 138 possible output classifications\n",
    "\n",
    "# Initialize two models:\n",
    "# RNN\n",
    "model_rnn = rnn.RNN(num_hidden=512)\n",
    "outputs, hn = model_rnn(rule_inputs.float(),stim_inputs.float())\n",
    "\n",
    "# Perceiver\n",
    "model_perceiver = transformer.Perceiver(nhead=1,embedding_dim=256,num_hidden=512)\n",
    "outputs, hn = model_perceiver(rule_inputs.float(),stim_inputs.float())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "86cf2f5f",
   "metadata": {},
   "source": [
    "#### Visualize example trials from train and test datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4f4825bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current red g exist , then current orange h + current purple j sum is even , else current red i product is even ]\n",
      "Target output: True\n",
      "Instruction: [ if current purple a * current green h product is odd , then current green f product is even , else color of current b ]\n",
      "Target output: yellow\n"
     ]
    },
    {
     "data": {
      "image/png": "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Gxt/cV6eGSAiomwRGhqKpk2bonfv3ukKAQAYN26cUsEdFRUFR0dHAICPjw/i4uJyLOun5HI51q5dyxzMwRzMkSdzfMtv/SwGiIgoy127dg1NmzbF2LFjMWjQoAzn0dXVha6ubob3xcXFqfTDnDmYgzmYI7/k+BoWA0RElKVev36NRo0aYfny5WjdurWq4xAR0RewNyEiIspSv/32G6KiojB16lQ4OzvD2dkZEyZMUHUsIiLKAM8MEBFRlpoxYwZmzJih6hhERJQJPDNARERERKSmWAwQEREREakpFgNERERERGqKxQARERERkZpiMUBEREREpKZYDBARERERqSkWA0REREREaorFABERERGRmmIxQERERESkplgMEBERERGpKRYDRERERERqisUAEREREZGaYjFARERERKSmWAwQEREREakpFgNERERERGqKxQARERERkZpiMUBEREREpKZYDBARERERqSkWA0REREREaorFABERERGRmmIxQERERESkplgMEBERERGpKRYDRERERERqisUAEREREZGaYjFARERERKSmWAwQEVGWGzduHEqVKoXSpUtjwYIFqo5DRESfoaXqAERElL8cPHgQZ8+exY0bN5CYmIgyZcqgadOmKFmypKqjERHRJ1gMEBFRlmrSpAkaNGgALS0tPHv2DAqFAgYGBunmS0hIQEJCgnQ7KipK+lsul+dI1s9J3T5zMAdzMEdezCGEQHx8fKbmlQkhRDbnIcpzjI2N4evri+HDh6s6ClGeNXHiRCxYsADt2rXDunXrIJPJlO739fWFn59fuuX8/f2hr6+fUzGJiPKd2NhYdOrUCZGRkTA2Nv7ivCwGiDLAYoAoa8TGxqJ58+Zo164d+vTpo3RfRmcGHB0d4e/vj4EDByIuLi6n40rkcjnWrl0LHx8f5mAO5mCOPJcj9cxAZooBNhMiIqIsdevWLaSkpKBcuXLQ19dHq1at8M8//6SbT1dXF7q6uhmuIy4uTqUf5szBHMzBHKrIUdOwMcy1rHE0cjviRWw2JVPG3oSIiChL/fvvv+jXrx8SExORkJCAv/76C7Vr11Z1LCKiXEsTWtCT6aO4bnmUl9eAoaYJtGU6ObJtnhkgIqIs5eXlhStXrsDZ2Rmamppo164d2rVrp+pYRES5VgV9F3iYdMCxqF04+WEfulgMR1jCXfz1fnW2b5vF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9B83urq66S7uTxUXF6fSD3PmYA7mYI78kuNrWAxQvuLk5CRVw+vXr//ivDKZDH/99dcX50nblEhPTw+zZ8/G7NmzM5z30yrc29sb3t7eX81MlN8oFAoMGTIEbm5u0NfXx8qVK9OdFSAiotyBxQAREWWpatWqYciQIahevTqSk5PRpk0bdOzYUdWxiIgoAywGiIgoyw0dOhRDhw5VdQwiIvoKjjNARERERKSmWAwQEREREakpFgNERERERGqKxQARERERkZpiMUBEREREpKZYDBARERERqSkWA0REREREaorFABERERGRmmIxQERERESkplgMEBERERGpKRYDRERERERqisUAEREREZGaYjFARERERKSmWAxQnhQfH4958+bh3bt3qo7yXa5du6bqCEREREQsBijvef/+PTw8PDB58mRERkaqOs536dOnD7Zt26bqGERERKTmWAxQnvLs2TO4urri5s2bOHbsGJycnFQd6bvUrl0bHTp0wKJFi1QdhYiIiNSYlqoDEGXWv//+Cw8PDwDAmTNnUKpUKRUn+n5z586FhoYGhg4divDwcMyaNQsymUzVsYiIiEjNsBigPCEkJASenp6ws7PD4cOHYW9vr+pIP0RDQwNz586Fra0thg8fjvDwcKxZswba2tqqjkZERERqhM2EKNcLCAhAvXr1UKZMGZw6dSrPFwJpDRs2DP7+/tiyZQtatGiBmJgYVUciIiIiNcJigHK1P/74Ay1btkTjxo1x5MgRmJmZqTpSluvYsSMOHjyI06dPw93dHa9fv1Z1JCIiIlITLAYoVxJCYMaMGejVqxd69+6N7du3Q09PT9Wxsk39+vVx8uRJPH78GDVr1sSjR49UHYmIiIjUAIsBynUUCgUGDhyIiRMnYurUqVi+fDk0NTVVHSvbVaxYEefOnUNKSgpcXFw4FgERERFlOxYDlKvEx8ejffv2WLlyJVavXo1JkyapVS87RYsWxblz52Bvb4/atWvj+PHjqo5ERERE+RiLAco13r9/j0aNGuHAgQPYvXs3evXqpepIKmFlZYXg4GDUqFEDjRs3xvbt21UdiYiIiPIpFgOUKzx79gy1a9fGP//8g6CgIDRv3lzVkVTK0NAQ+/fvR9u2bdGhQwcsWbJE1ZGIiIgoH2IxQCr333//wcXFBe/fv8eZM2dQs2ZNVUfKFXR0dPDnn39ixIgR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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "trial_idx = np.random.randint(0,len(train_dataset))\n",
    "#### TRAINING SAMPLE\n",
    "# Randomly select a trial number\n",
    "# Extract the 'metatask' tree from dataset\n",
    "metatask_train = train_dataset.metatasks[trial_idx]\n",
    "\n",
    "# Generate stimuli\n",
    "objset = metatask_train.generate_objset(n_distractor=train_distractors)\n",
    "# Retrieve target label \n",
    "targets = metatask_train.get_target(objset)\n",
    "\n",
    "print('Instruction:', metatask_train)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.suptitle('Systematic generalization (CompTreeSubsets, depth 3) sample trial (training)')\n",
    "plt.subplot(121)\n",
    "metatask_train.task_graph.plot_graph()\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.subplot(122)\n",
    "plt.title('stimulus',fontsize=12,fontname='Arial')\n",
    "plt.imshow(np.asarray(img_array[:,:,:,0],dtype='int16'))\n",
    "plt.grid()\n",
    "plt.xticks(np.arange(0,200,20),np.arange(0,10),fontsize=8,fontname='Arial');\n",
    "plt.yticks(np.arange(0,200,20),np.arange(0,10),fontsize=8,fontname='Arial');\n",
    "\n",
    "\n",
    "#### TESTSET SAMPLE\n",
    "# Extract the 'metatask' tree from dataset\n",
    "metatask_test = test_dataset.metatasks[trial_idx]\n",
    "\n",
    "# Generate stimuli\n",
    "objset = metatask_test.generate_objset(n_distractor=test_distractors)\n",
    "# Retrieve target label \n",
    "targets = metatask_test.get_target(objset)\n",
    "\n",
    "print('Instruction:', metatask_test)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "plt.suptitle('Systematic generalization (CompTreeSubsets, depth 3) sample trial (test set)')\n",
    "plt.subplot(121)\n",
    "metatask_test.task_graph.plot_graph()\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.subplot(122)\n",
    "plt.title('stimulus',fontsize=12,fontname='Arial')\n",
    "plt.imshow(np.asarray(img_array[:,:,:,0],dtype='int16'))\n",
    "plt.grid()\n",
    "plt.xticks(np.arange(0,200,20),np.arange(0,10),fontsize=8,fontname='Arial');\n",
    "plt.yticks(np.arange(0,200,20),np.arange(0,10),fontsize=8,fontname='Arial');"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "compositional_cog",
   "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.9.18"
  },
  "vscode": {
   "interpreter": {
    "hash": "37a40440aafd5cefb3a0d26d91ee13b34d51e59133f87c8f7468e4d0155ce4d5"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
