{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2a1c8a85",
   "metadata": {},
   "source": [
    "# Demo: Systematic Compositional Generalization (depth 1)\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": 2,
   "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 individual operators (OpSys) (Fig. 4a)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3d508ae6",
   "metadata": {},
   "outputs": [],
   "source": [
    "#### Systematic generalization split\n",
    "dataset = 'opsys' # opsys ~ compositional structure\n",
    "taskdepth = 1 # number of nodes to include\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",
    "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.OperatorSystematicity(n_distractors=train_distractors,\n",
    "                                              distractor_range=True,\n",
    "                                              location=location_sampling,\n",
    "                                              subset=1, # subset 1 is the 'training set' (arbitrary choice)\n",
    "                                              nfeatures=nfeatures)\n",
    "\n",
    "# Test dataset samples from subset 2, which is a mutually exclusive set of operator x object feature combinations.\n",
    "test_dataset = datagen.OperatorSystematicity(n_distractors=test_distractors,\n",
    "                                             distractor_range=True,\n",
    "                                             location=location_sampling,\n",
    "                                             subset=2, # subset 2 is the 'training set' (arbitrary choice)\n",
    "                                             nfeatures=nfeatures)\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": 6,
   "id": "6e210245",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Size of rule inputs: torch.Size([64, 2, 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: current blue i sum is odd ?\n",
      "Target output: False\n",
      "Instruction: current red i sum is odd ?\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwMAAAGgCAYAAAD2NbtKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABSPUlEQVR4nO3dd3gU9cLF8bMpLAmkUQMkEAREQCAoIEWEgPSqdBAJEb2oFCmWYCGhiQ29CoqNctXYKCqISSCAglJUEBEUBYnSOwmQnvzeP7jZlyUhgDdkIfP9PA8Pu1PPTjabPTOzszZjjBEAAAAAy3FzdQAAAAAArkEZAAAAACyKMgAAAABYFGUAAAAAsCjKAAAAAGBRlAEAAADAoigDAAAAgEVRBgAAAACLogwAV9m1+L1+12ImK+LngKJ0LT7frsVMgNVQBmA5v/zyiwYMGKDAwECVKFFClSpVUv/+/bVly5ZCX9e0adP04osvFvpy/xfvvvuuJkyY4Lg/f/582Ww2JSYmui7UNSYkJETh4eGSpMTERNlsNs2fP79Q1/Htt9+qW7dujvtXaz0FycrK0q233qqVK1c6Dd+2bZvuvfdeBQUFyW63q2rVqho4cKA2btz4j9d1/PhxjRs3TjVq1JDdbleZMmXUrl07LVq06H99GHkMHjxYL7zwQqEv1xXOfy7+U+np6Ro3bpxiYmIuOa3NZlNUVNQVLf9y59m0aZNq166t9PR0SYX7+hgeHq6QkJCrPs/l2LFjh6pXr65Tp04V+rKBq4EyAEvZvn27mjdvrqNHj+rVV1/VihUr9OKLL+qvv/5S8+bNtWHDhkJd31NPPaWzZ88W6jL/V1OmTNHx48cd97t27ar169erUqVKLkx17apUqZLWr1+vrl27Fupy3377bW3fvv2qr6cgU6dOVZUqVXTnnXc6hr3//vu69dZbtXPnTk2dOlXx8fF69tlndfjwYbVs2VIzZ8684vWkpqaqVatWWrp0qR5//HHFxcVp3rx5CgwMVJ8+ffTKK68U4qOSnn/+eT377LP69ddfC3W516uDBw/q5ZdfVmZm5iWnXb9+vYYPH17oGdLS0jR06FA9++yzstvtkgr39fHpp5/WkiVLrvo8l6Nu3brq3r27xowZU+jLBq4GD1cHAIrSzJkzVaZMGcXGxsrT09MxvFevXrrppps0ZcoUffnlly5MWPTKly+v8uXLuzrGNctut6tZs2bFZj25Dh48qBkzZuibb75xDNuyZYsiIiI0ePBgvfPOO3J3d3eMGzx4sB555BFNmDBBDRo0cCoQl7Jw4UL9+uuv2rlzp2688UbH8J49eyolJUWTJk3SqFGjnNb3v6hSpYoGDBigJ554Qp9//nmhLNMqrtZz8PXXX5fNZtPdd999VZZfo0aNIpnnckVGRio4OFhjxozRLbfcctXWAxQKA1hIly5dTNWqVU16enqecZ9++qmZP3++McaYWbNmGUlm586dTtN8+OGHxmazmT179pjs7Gzz9NNPm5CQEFOiRAkTEhJiIiMjTUZGhjHGGElO/3Jt27bNdO3a1fj4+BgfHx/Tq1cvs3v3bsf41atXG0kmISHBtGnTxpQsWdIEBwebt99+2xw4cMDcddddplSpUiYoKMi8/PLLTvm2bt1q7rrrLlOuXDnj4eFhKleubEaNGmVSUlKMMcZUq1bNKdOePXvMvHnzHLdzxcfHm1atWplSpUqZwMBA88ADD5gTJ04UuG1feOEFU716dVOyZEnTokUL88UXXxhJZvXq1Vf82FeuXGnat29vvLy8TIUKFcyECRNMZmamY7rs7Gzz7LPPmho1apgSJUqYWrVqmVdffdUpT+vWrc3gwYNN7969jY+Pj+nSpYsxxpg9e/aYIUOGmEqVKhkPDw9Tvnx5M2TIEHPs2DHHvNWqVTNDhw51TC/JzJs3L99teP6/3Md69OhR89BDD5mqVasaT09PExAQYHr16uXYxkOHDnWab968eXnWY4wxv//+u+ndu7epWLGi8fb2Nm3atDHr1q1zjM+d55NPPjG9e/c2pUuXNv7+/ua+++4zp0+fLvDnNWHCBFOzZk2nYX369DEBAQHmzJkz+c6Tnp5uqlatalq1auW0rZ588kkzduxYExAQYAICAsw999zjtD2ff/55I8n89ttveZa5adMm88ILL5izZ8+aX375xUgyb775ptM0+/fvN25ubo7fz48++sg0aNDAlCxZ0pQrV84MHjzYHDhwwGmeb7/91thsNrNt27aLboOjR4+awYMHm4oVKxq73W4aNmxo/vOf/zhN8/XXX5sOHToYf39/4+npaUJCQsykSZNMdna2Meb/fwYLFy40PXv2NN7e3qZChQpmypQpJikpyURERBhfX19ToUIF89hjj5mcnByn+T788EPT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zs/F+Ph4IynPNrvnnntMpUqVnI6enS+/53Du0ak//vjDadrzX7Mu9zXlUmXgscceM/7+/nmGXzjfpEmTjCSzYsUKx7D09PR8nycvvfSSkeQ4IpTfG/uQkBCTlZXlGBYdHW0kOV4j/sk8VatWNd27d3fK8uyzz+b7GvHTTz8ZSWb58uUX3TbAtYAPEMNyJk+erAMHDigmJkb33XeffH199cEHH6h58+b697//7ZjuvvvuU2JiotauXStJeu+99+Tt7a3evXtLksLCwrRy5Uq1atVKM2fO1G+//aaRI0dqyJAhF113QkKCwsLC5O3traysLGVlZcnX11etWrXSihUrnKZt0aKF43ZgYKAk5/N5y5YtK0mOK1Z06NBBX3/9tby8vPT7779r2bJlmj59uo4cOaKMjIzL2japqan68ccfdddddzkN7927t37//XdVrlw5zzzr169Xamqq+vbt6zR84MCB//ixN2/e3Ol+UFCQ44OGq1atkjFG3bt3dywnKytLPXr0UFpamuPnJUnVq1dXqVKlHPdDQ0O1du1aVa9eXX/++afi4uL00ksv6ddff73sbXS+yMhIxcXFaeHChapWrZokqXLlylq1apVatWqlv//+W6tWrdKsWbP07bffXtE61qxZo27dusnPz88xzMPDQwMGDND333+vM2fOOIYXtL3y8+eff0o6t31ymf9e4vH8z9Lkx8PDw2l6SerevbtTzh49esjT09PpZ3H33Xdr7969io2N1fjx41W3bl2tWLFCAwYMUN++fR3LGzBggLy9vfX+++9LOncFml9//dVxRZ3WrVsrJSVF9evX15NPPqlvv/1WHTp00KRJk2Sz2ZyyhoSEaM+ePRd9LGFhYZo0aZL69eun+fPn6+jRo3rxxRd1++23S5KGDBmi5cuXKyMjQ9u3b9dnn32mqKgoZWVl5flZXur31WazKSAgIM8VZu655x6n+71791ZmZma+FzNISEiQzWZT165d8zz3Dx48qF9++eWijzU/Xl5eBZ43XxivKdK559uVXLWnfv36jtslSpRQbGys+vfvr4MHD+qbb77RW2+9pWXLlklSgTmaNGni9DmUoKAgSSrwd6OgeXbt2qW///77kq91uXIfc0HPQeBaQBmAJQUEBGjgwIF65513tHv3bm3evFl169bV448/7rjSTtu2bVW9enX95z//kSQtWLBA/fr1k7e3tyTp0Ucf1axZs5SSkqIJEyaoTp06ql+/vhISEi663uPHj+vjjz+Wp6en079ly5bpwIEDTtP6+vrmmT933fnJycnRE088oTJlyqh27dp66KGHtHnzZnl5eV32tbxPnDghY4wqVKhwWdNL0tGjRyUpzzy5b4hyXcljv/Bxurm5KScnx7EcSapXr57Tcpo2bSpJTsuqWLFinrwzZ85UxYoVVaNGDQ0dOlSrVq1SqVKlrvh65++//76ef/55vfrqq7rjjjucxn3wwQeqWrWqqlWrpr59+2rJkiUF/uzyc+LEiTzbUDq3XY0xSk5OdgwraHvlJykpSZKcilK5cuVUqlSpS15iNrdIVK1a1THswpLo5uamsmXL6uTJk07DPT091bFjR7344ov64YcftG/fPvXu3VsLFy50fHDf19dXffv21XvvvSfp3O9dzZo11apVK0nnis/y5ct1ww03ON64BwUFORX5XKVKlXI81vx89NFHGj9+vDZt2qRhw4apcuXK6tSpk+PNW2pqqoYPHy4/Pz/Vr19f48eP1549e+Tp6Znn+XKlv6+5Ltx2ub9HF2476dxz3xgjHx8fp+d+v379JCnP79GlVKhQIU+BOl9hvKZI555v5z/XLuXC39u4uDjVqVNHlStXVrdu3fSf//zHcUWignLk93shqcDfjYLmudzXuly5j7mg5yBwLaAMwDL279+vypUr6913380zrlGjRpo6darS09O1e/duSef25IWHh2vx4sXasmWLduzYoWHDhjnmcXNz08MPP6wff/xRhw4d0rx585SWlqbevXtfdG+Vv7+/Y8/uhf/i4+P/p8c3Y8YMzZw5U//+97916tQp/f3331q4cOEVXSnIz89PNpvN8UcvV3p6ur766iunS5Lmyt1zduTIEafhF94vrMfu7+8v6dwRgvyW1adPn4vOGxMTo/Hjx2vChAk6cuSIDh06pC+//NLpCjeXY9OmTbr//vv14IMPasSIEU7j1q1bp3vvvdexJ/z48eNKSEjIs/f+UsqUKaNDhw7lGX7w4EFJ/39k6J8oV66cJDntpbbZbOrevbtiY2Mvuuc0OztbS5YsUcuWLR3LkJTneZGdna1jx4453jS1aNHC6XcnV6VKlfTOO+9IOndt9lwRERHatWuXvv/+ey1cuDDPdfY7duyouLg4nTx5UkuXLtXNN9+sRx55JM/3IJw8edIp54X8/Pz03HPPKTExUb/99pueffZZrVu3Tg899JAkacyYMVq4cKE+/vhjnT59Wrt379Z77713yaMnV+LCbXf48GFJed9wSuee+6VLl873ef/99987HZ0oDIXxmiKde77902vu7969W7169VLDhg21a9cuJScna926derevfs/Wt7/4nJf63LlFrqCnoPAtYAyAMsIDAyUh4eHZs+erbS0tDzjd+7cqZIlS6pWrVqOYcOGDVNSUpLGjRunWrVqqWXLlo5xLVq0cFxHukKFCgoPD9fIkSOVlJTk2Gubu1cpV+vWrbVjxw6FhoaqcePGaty4sW699Va9/PLL//P1rtetW6d69eopIiLCccrG/v37tW3bNqc9YQVdvrF06dIKDQ3NcznG+Ph4denSRXv37s0zT2hoqPz8/LR48WKn4Rd+mVRhPfbWrVtLko4dO+ZYTuPGjXX8+HE99dRT+RaWXOvWrZOfn58ef/xxxxuaM2fOaN26dQXuLTzfgQMH1KtXL91222357o3+7rvvlJOTo+joaMebh+zsbMepULnrudRlNFu3bq1ly5Y57VXMzs7WRx99pCZNmjj2jP4Tuac0XfjznDhxos6ePasHH3ww3+0xceJE7dq1S08++aTT8NjYWKcC/PnnnysrK0vt2rWTdO50pE8//dRxVOF8O3fulOR8asgdd9yhWrVq6bHHHtOxY8d07733OsZNmDBBTZs2lTFG3t7e6tatm+OLqy58PHv37nU81gv99ddfCg4O1sKFCyVJtWvX1mOPPab27ds7lrNu3TqFhYWpV69ejr28P/74o44ePXrZz5dL+eKLL5zuL1y4UN7e3vle4rN169Y6c+aMjDFOz/1ffvlF0dHRysrKyncd//SSrZf7mnIp1apV0759+/Lsxb/w9TE/P/74o9LS0hQZGel0StNXX30lqeC9/IUtKChINWrUuORrXa7c59HFnoPAtYLvGYBluLu764033lCvXr3UuHFjjRw5UnXq1FFKSori4+M1a9YsTZ06VQEBAY55goOD1b59e8XFxWnatGlOy2vdurVefPFFVaxYUS1atND+/fv10ksvqXXr1o49Qf7+/vruu+/0zTffqFWrVnrmmWfUvHlzdevWTQ8++KBKliypN998U5999pnjTck/1bRpU02ZMkUzZsxQ8+bNtWvXLk2fPl3p6elOe3r9/f21ZcsWff31145Ta843efJk9ejRQ/3799ewYcN05MgRRUZGqlu3bgoNDc0zvY+Pjx577DE988wz8vb2Vps2bfT111/rjTfekPT/f/AL67HffPPNuueee3T//fcrMTFRjRs31s6dOzVx4kRVr169wL38TZs21RtvvKHx48ere/fuOnDggF544QUdOnTI6ed+MRkZGerZs6cyMzMVFRWlLVu2OL0ZCQoKcmzTkSNHKiIiQidPntSsWbO0detWSefOPfbx8ZG/v78OHz6sr776Kt/tOmnSJC1fvlxhYWGKjIyU3W7Xa6+9pt27dys2Nvayt1d+ateurapVq+rbb791+nxI/fr1NX/+fA0bNky7du3Sgw8+qJCQEB08eFDz5s1TfHy8nnvuOXXu3Nlpefv27VOPHj00evRo7d27V5GRkerYsaPatGkj6dw3za5evVpNmzbVmDFj1Lx5c7m7u+v777/Xiy++qM6dO6tTp05Oy4yIiFBkZKTat2+v4OBgx/A777xTM2fOVHh4uO655x5lZGTo+eefV5kyZdS2bVvHdMYYfffddxo9enS+26BatWoKCgrS6NGjlZycrBo1auiHH37Q8uXLFRkZKenc8+WTTz7RnDlzVKdOHW3dulVTp06VzWYrtC/L+vTTTxUYGKguXbpozZo1mj17tqZNm5bvaTVdunTRHXfcoZ49e+rpp59WnTp1tGnTJk2aNEkdO3a86B7o3DfyCQkJqlOnjm677bbLyna5rymX0qFDB82YMUPbt2/XzTff7Bh+4etjfm655RZ5eHjo8ccf1/jx45Wenq558+Y5Tisryi91tNlsmjx5sgYPHqwHH3xQd911l7Zu3arJkydLyltu1q1bJ29v74s+NuCaUfSfWQZc68cffzQDBgwwQUFBxm63G19fX9OmTRuzaNGifKd/7bXXjJubm9m7d6/T8MzMTMd1se12u6lQoYIZPny40/XVX3rpJePv72+8vb3NX3/95Vh/7uUBS5cubZo1a2Y+//xzxzy5V9Q5//r8F7uijc67GkdaWpp5+OGHTWBgoPHy8jK1a9c2kyZNMtHR0cZutzu+JyAmJsZUqFDB2O12s3bt2ny/Z+DLL780TZo0MXa73VSpUsU88sgjBV4eLycnx0yZMsVx7fNWrVqZl19+2UgyP/74o9O2v9LHbsy5KwOdf+nIzMxMM3nyZHPDDTcYT09PExQUZB588EFz/Pjxi86Tm/OZZ54xQUFBpmTJkqZGjRpm9OjR5q233jKSzPbt240xF7+a0IXXbL/wX+7PYvbs2eaGG24wdrvdVK1a1QwdOtRxhZ0vv/zSGHPuOxduuukm4+npaZ599tl8f8ZbtmwxnTt3NqVLlzY+Pj6mXbt2jivdXJjtfBdeJSU/48aNM3Xq1Ml33Pbt283w4cNNSEiIsdvtJigoyAwcONBxCcjzVatWzQwcONA89NBDpnTp0qZixYpm7NixTtehN+bcFXZGjx5tateubby9vY2Xl5dp0KCBef755/P93o9t27YZSY7LS54vJibG3HLLLY7t0rlzZ/Pzzz87TbNhwwann2l+Dh48aMLDw03lypVNiRIlTI0aNcy0adMcVw86fvy4GTRokClbtqwpXbq0qV+/vvn3v/9tHnjgAVOpUiWTlZV1Wb+b52+rC59X06ZNM+3btzclS5Y0N954o3njjTcuOo8x567eNXbsWMfvWvXq1U1kZKTT1ZXyM27cOFOqVCnj7+9v0tPTL/oc+SevKfk91vNlZmaaChUqmOeee85p+IWvj7lXE7rQp59+aurVq2dKlixpKleubO6++27z9ddfG5vNZmbPnm2Myf/KQOdvN2PyXjntn8xjzLkrXuV+50GjRo3Mu+++ayTl+RvSqVMn069fv4tuF+BaYTPmCj81B1hMly5d5O7urqVLl7o6yjUpKytLMTExCgsLc9qDO3v2bI0ePVrHjx93nOePa8f+/ftVs2ZNxcfH/097LkNCQtSmTRvNnz+/8MJJev755/X8889r//79/+iUqGHDhunkyZP67LPPCjVXYUlMTFT16tU1b968PJ+JKI5eeuklzZkzR7///nuBH1q+1n344Ye65ZZbVLt2bcewL7/8Ut26ddPWrVvVoEEDSed+vjVr1tT333+vRo0auSoucFk4TQi4iClTpmjnzp366quv9PXXX7s6zjXLw8NDzz33nF555RU99dRTKleunLZu3aqnn35a9957L0XgGlWlShU98sgjmjFjxjV1GsOCBQv0yy+/aPbs2Y7To67U33//rcWLF2vdunVXISH+iYceekizZ8/WwoUL81ya83ry/vvv68knn9TUqVMVHBysP/74Q88884zatGnjKALSuTLbt29figCuD64+NAFcqxo3bmz8/PzM888/7+oo17w///zT9O/f31SoUMGUKFHC1KxZ00RHR1/0W2ZxbUhPTzcNGzY0sbGx/3gZ+Z1a8b/I/fbqQYMG5Xv60OUYMGCAmT59eqFluhoK+jK74urbb781NWvWNGlpaa6O8o8dO3bMDB8+3FSpUsWUKFHCBAcHm7FjxzqdRrl9+3YTHBzsdMoocC3jNCEAAADAori0KAAAKLbY5wkUjDIAAACKpR07djh9P4x07hKhUVFRRbL+kJAQS3xAHNc3PkAMAACKpU8++UTr1693GrZ+/XrHFwICoAwAAAALye/bnQEr4zQhAABw3dq8ebPatWsnPz8/+fj46M4779TGjRsVFRWl6OhoSc6nBp1/e82aNbLZbFq1apXCwsLk5eWlqlWr6p133tHBgwd19913q3Tp0goODtYrr7ziWGfufGvWrHHK0qZNG8c3b18oMTFRNpstz3dyhIeHKyQkxHH/zz//VM+ePVW2bFl5e3urefPm+uqrr/6HLQQUjDIAAACuS8nJyerUqZPKlSunhQsX6qOPPtLZs2fVsWNHDRs2TPfdd5+kc6cGDR8+/KLLGTBggLp3766lS5fqxhtv1IgRIxQWFqb69etr0aJFuvXWWzV27Fht2rTpqj6enJwcdevWTWfOnNF7772nzz//XGXLllWPHj20a9euq7puWBenCQEAgOvSjh07dPToUY0ePdrxQeGbbrpJb775ptzc3ByfDbjUqUEREREaN26cJKl06dJq3ry5mjZt6jiy0LhxY33++ef67rvv1LRp06v2eI4cOaJff/1VTz75pLp06SJJjhxpaWlXbb2wNsoAAAC4Lt18880qX768unfvrv79+6tLly5q166dnn/++StaTosWLRy3AwMDJTkXiLJly0qSTp069b+HLkDFihVVt25d3X///VqxYoU6d+6sjh07aubMmVd1vbA2ThMCAADXpdKlS2vt2rXq2rWrPvroI/Xo0UPly5fXv/71ryvak+7r65tnmLe3d2FGvSw2m00rVqxQeHi4YmNjNWDAAFWoUEH9+/fXiRMnijwPrIEjAwAA4LpVu3Ztvffee8rOztamTZv03nvv6Y033tANN9xw1dZps9kkSdnZ2U7Dz5w5o9KlS1/xPOerXLmyXn/9dc2ePVtbt27VwoULNWPGDJUpU0ZvvPFGYT0EwIEjAwAA4Lq0cOFClS9fXocOHZK7u7uaN2+u119/Xf7+/tq7d6/c3d2vynpzjyTs3bvXMezkyZPasWPHFc2TmZnp9KHk9evXq2LFivr+++9ls9kUGhqqqVOnqn79+k7zAYWJIwMAAOC61LJlS2VnZ6tXr1564okn5Ovrq48//lhJSUnq3bu3fvnlF0nShx9+qGbNmql69eqFst4GDRooODhY0dHR8vPzk7u7u5599lmVKlXqovMEBASoRYsWeu2111SrVi2VK1dOr776qlJTUx3zNWrUSN7e3hoyZIiioqIUGBiolStX6qefftKYMWMKJTtwIY4MAACA61KlSpUUFxcnPz8/3Xffferatas2b96sRYsWKSwsTL1791aTJk00dOhQvfDCC4W2Xnd3dy1atEiVK1fWwIEDNWrUKPXv31+9e/cucL758+erSZMmuv/++zV06FCFhobqkUcecYwvWbKk4uPjVa9ePY0ZM0YdO3bUZ599pjfffFPh4eGFlh84n80YY1wdAgAAAEDR48gAAAAAYFGUAQAAAMCiKAMAAACARVEGAAAAAIuiDAAACl1MTIzq1q2rWrVqadasWa6OAwC4CK4mBAAoVPv371eLFi20efNmlSxZUi1atND777+v+vXrFzhfTk6ODhw4IB8fH8e3tQIArpwxRqdPn1blypXl5lbwvn++dAwAUKhWrlypdu3aqWzZspKkPn36aOHChXnKQHp6utLT0x339+/fr7p16xZpVgAozvbu3augoKACp6EMAAAK1YEDB1S5cmXH/UqVKmnTpk15pnv22WcVHR2dZ/g777wjb2/vq5oRAIqzlJQUDR8+XD4+PpecljIAAChUOTk5Tqf5GGPyPUwdGRmpcePGOe4nJycrODhY3t7eGjlypFJTU4skb368vLw0d+5cRUREkIMc5CDHdZcj91MAl3PKJWUAAFCogoKCtHbtWsf9Q4cOOR0pyGW322W32/NdRmpqqkv/mJODHOQgR3HJcSlcTQgAUKjuvPNOrVy5UkeOHNHZs2f16aefqlOnTq6OBQDIB0cGAACFqkqVKpo+fbrCwsKUmZmp4cOHq2nTpq6OBQDIB2UAAFDoBg0apEGDBrk6BgDgEjhNCAAAALAoygAAAABgUZQBAAAAwKIoAwAAAIBFUQYAAAAAi6IMAAAAABZFGQAAAAAsijIAAAAAWBRlAAAAALAoygAAAABgUZQBAAAAwKIo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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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pMJkKei9Yfbs2cbV1dW2xwIorTiBGE5p8uTJOnLkiOLj43XffffJ19dX77zzjpo3b65//etftunuu+8+HThwQJs2bZIkvf322/Ly8lLv3r0lSREREVq7dq1atmypWbNm6ZdfftGoUaM0ePDgyy573bp1ioiIkJeXlzIzM5WZmSlfX1+1bNlSa9assZu2RYsWtttBQUGS7I/nLVeunCTp7NmzkqT27dvriy++kKenp3799VetXLlS06dP1/Hjx5Wenl6odZOSkqLvv/9evXr1shveu3dv/frrrwoODs4zz5YtW5SSkqJ77rnHbnhkZOQ/fu7Nmze3ux8SEmI70XD9+vUyxqhbt262x8nMzFT37t2Vmppq+31JUvXq1VW2bFnb/fDwcG3atEnVq1fX77//roSEBL344ov6+eefC72OLhYTE6OEhAQtXbpU1apVkyQFBwdr/fr1atmypf766y+tX79ec+bM0VdffXVVy9i4caO6du0qPz8/2zA3Nzf1799f3377rc6fP28bXtD6ys/vv/8uKWf95DL/f3nEi8+lyY+bm5vd9JLUrVs3u5zdu3eXu7u73e/i7rvv1sGDB7Vq1So9+uijqlevntasWaP+/fvrnnvusT1e//795eXlpcWLF0vKuQLNzz//bLuiTqtWrZScnKwGDRroySef1FdffaX27dtr0qRJslgsdlnDwsL0xx9/XPa5REREaNKkSerbt68WLlyoEydO6IUXXtAdd9whSRo8eLA+++wzpaena8+ePfrwww8VGxurzMzMPL/LK/29WiwWBQQE2P5ecw0aNMjufu/evZWRkZHvxQzWrVsni8WiLl265HntHz16VD/++ONln2t+PD09VbNmzcuOL4r3FCnn9RYWFnbF6QrzHhEREaFff/1Vt956q6ZOnaodO3ZowIABGjt2bKHzVKpUSfXq1dPw4cMVFRWl9957T8YYzZo1SzfddFOhsxQkLCxMWVlZOnjwYKFzAY5AGYDTCggIUGRkpN566y3t379f27dvV7169TRhwgTbVSjatGmj6tWr6z//+Y8kadGiRerbt6+8vLwkSY899pjmzJmj5ORkjR8/XnXr1lWDBg20bt26yy731KlTeu+99+Tu7m73s3LlSh05csRuWl9f3zzz5y47P9nZ2XriiScUGBioOnXq6MEHH9T27dvl6elZ6Otgnz59WsYYVaxYsVDTS9KJEyckKc88uR+Icl3Nc7/0ebq4uCg7O9v2OJJUv359u8dp2rSpJNk9VqVKlfLknTVrlipVqqSaNWtqyJAhWr9+vcqWLXvV1wpfvHixnnvuOb388su688477ca98847qlq1qqpVq6Z77rlHK1asKPB3l5/Tp0/nWYdSzno1xigpKck2rKD1lZ/ExERJsitK5cuXV9myZa94idncIlG1alXbsEtLoouLi8qVK6czZ87YDXd3d1eHDh30wgsv6LvvvtOhQ4fUu3dvLV261Hbivq+vr+655x69/fbbknL+7m644Qa1bNlSUk7x+eyzz1SjRg3bB/eQkBC7Ip+rbNmytueanyVLlujRRx/Vtm3bNHToUAUHB6tjx462ApGSkqJhw4bJz89PDRo00KOPPqo//vhD7u7ueV4vV/v3muvSdZf7d3TpupNyXvvGGPn4+Ni99vv27StJef6OrqRixYp5CtTFiuI9Rcp5vV38WrucwrxH9OvXT/Hx8fL29lZsbKxuueUW1ahRQ0uWLCl0HovFojVr1igqKkqrVq1S//79VbFiRfXr10+nT58udJaC5D7fgl5/QGlAGYBTOXz4sIKDg/Xvf/87z7ibb75ZU6dOVVpamvbv3y8p5x9GVFSUli9frh07duinn37S0KFDbfO4uLjooYce0vfff69jx45pwYIFSk1NVe/evS+71czf39+2ZffSn9WrV/9Pz2/mzJmaNWuW/vWvf+ns2bP666+/tHTp0qu6UpCfn58sFovtA36utLQ0ff755/leri8kJESSdPz4cbvhl94vqufu7+8vKWcPQX6P1adPn8vOGx8fr0cffVTjx4/X8ePHdezYMX366ad2V7gpjG3btmn48OEaOXKkRowYYTdu8+bNuvfee21bwk+dOqV169bl2Xp/JYGBgTp27Fie4UePHpX03z1D/0T58uUlyW4rtcViUbdu3bRq1arL7lXIysrSihUrdPvtt9seQ1Ke10VWVpZOnjxp+2DbokULu7+dXJUrV9Zbb70lSfrpp59sw6Ojo7Vv3z59++23Wrp0aZ7r7Hfo0EEJCQk6c+aMPvnkE9100016+OGH83wPwpkzZ+xyXsrPz0/PPvusDhw4oF9++UUzZszQ5s2b9eCDD0qSxo4dq6VLl+q9997TuXPntH//fr399ttX3HtyNS5dd3///bekvOVa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YXdSMhzL09NTixcv1sSJE5WWluboOMXmrbfeUnBwsB544AFHRwEKhcOEAAAAACfFngEAAHDdYpsnUDDKAAAAuC799NNPdt8NI+V8uV5sbGyJLD8sLMwpTg7HtY0TiAEAwHXp/fff15YtW+yGbdmyxfZlgAAoAwAAwInk983OgDPjMCEAAHDN2r59u9q2bSs/Pz/5+Pjorrvu0tatWxUbG6u4uDhJ9ocGXXx748aNslgsWr9+vSIiIuTp6amqVavqrbfe0tGjR3X33XfL29tboaGhmj17tm2ZufNt3LjRLkvr1q1t37p9qQMHDshiseT5Po6oqCiFhYXZ7v/+++/q0aOHypUrJy8vLzVv3lyff/75/7CGgIJRBgAAwDUpKSlJHTt2VPny5bV06VItWbJEFy5cUIcOHTR06FDdd999knIODRo2bNhlH6d///7q1q2bPvnkE9WuXVsjRoxQRESEGjRooGXLlunWW2/VI488om3bthXr88nOzlbXrl11/vx5vf322/roo49Urlw5de/eXfv27SvWZcN5cZgQAAC4Jv300086ceKExowZYztR+MYbb9Trr78uFxcX27kBVzo0KDo6WuPGjZMkeXt7q3nz5mratKltz0Ljxo310Ucf6euvv1bTpk2L7fkcP35cP//8s5588kl17txZkmw5UlNTi225cG6UAQAAcE266aabVKFCBXXr1k39+vVT586d1bZtWz333HNX9TgtWrSw3Q4KCpJkXyDKlSsnSTp79uz/HroAlSpVUr169TR8+HCtWbNGnTp1UocOHTRr1qxiXS6cG4cJAQCAa5K3t7c2bdqkLl26aMmSJerevbsqVKigBx544Kq2pPv6+uYZ5uXlVZRRC8VisWjNmjWKiorSqlWr1L9/f1WsWFH9+vXT6dOnSzwPnAN7BgAAwDWrTp06evvtt5WVlaVt27bp7bff1muvvaYaNWoU2zItFoskKSsry274+fPn5e3tfdXzXCw4OFivvvqq5s6dq127dmnp0qWaOXOmAgMD9dprrxXVUwBs2DMAAACuSUuXLlWFChV07Ngxubq6qnnz5nr11Vfl7++vgwcPytXVtViWm7sn4eDBg7ZhZ86c0U8//XRV82RkZNidlLxlyxZVqlRJ3377rSwWi8LDwzV16lQ1aNDAbj6gKLFnAAAAXJNuv/12ZWVlqWfPnnriiSfk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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 (OpSys) 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 (OpSys) 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
}
