{
 "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": 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_pixelwords 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": 2,
   "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",
    "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.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": 3,
   "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 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6e210245",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Size of rule inputs: 64\n",
      "Size of stim inputs: torch.Size([64, 64, 64, 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:', len(rule_inputs)) # batch_size x string\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"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "86cf2f5f",
   "metadata": {},
   "source": [
    "#### Visualize example trials from train and test datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4f4825bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: current red e product is even ?\n",
      "Target output: False\n",
      "Instruction: current orange g product is even ?\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "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ZNq1a2d8fX1NeHi4y7xz12/ua9EYY9LS0syTTz5pwsPDTbFixUzt2rXN3LlzL/gcc5eT+1OxYkVjzNnX4J133mkGDRpkAgMDzc0332wyMzONJDNmzBjn9Jd6TzHG5JnmfA6Hw5QvX96MHz/eZZrz3x/HjBljqlSpYuLj403JkiVN5cqVzZEjR8yZM2fMM888Y6pWrWqKFStmSpQoYe666y6zadMm5/z69u3rfG6562306NFmxIgRJiQkxPj4+JiWLVu6vKf/k2mMMWbWrFmmRo0axm63mzp16pjly5cbT09Pl79dY4y5++67zf3333/B9QJcKygDsJTXX3/dSDL16tUz06ZNM7/++qvzn/O5jh07Znx8fMyoUaNchrdu3dpER0cbY4yZOHGiCQ4ONjNmzDArV640kydPNp6ens5/iuvWrTOSzIABA8y6deuMMcZs377dlChRwjRo0MDMnz/ffPzxx6ZOnTomNDTU/P3338aY/34gLlOmjHnppZfMsmXLTIsWLYynp6epXr26GT16tFmyZIm59957jSTz/fffG2OM2b9/vwkICDAtW7Y0CxcuNMuWLTOPP/64kWQmTJhgjDFm48aNJjQ01LRp08asW7fOpKen5ykDixcvNh4eHqZjx45m4cKFZs6cOSY0NNTceeedF1yv8fHxxsPDwzz99NMmMTHRDBs2zPj6+rp8QL6S5162bFkzduxYk5SUZIYNG2YkmTfffNO5vIceesh4e3ubMWPGmMTERPPss88aDw8PM3bsWOc4zZo1M15eXqZHjx4mKSnJJCYmmtOnT5uKFSua+vXrm08//dR8/fXXZuzYscbT09M8+OCDzmkvVgY2btxo1q1b5/xZunSpKVmypKlbt645ffq0ycnJMQ0bNjRVq1Y1CQkJZsWKFebll182/v7+5u677zbGGLNjxw7Tpk0bExoaatatW2cOHTqUZzlbt241JUqUMDfffLP5+OOPzWeffWaio6ONt7e3WblypUu24OBg88QTT5jly5ebiRMnGpvNZp555pkL/r6MMaZcuXImNjbWeT87O9sEBASYLl26XHS6oUOHGpvN5vywX7FiRRMUFGQaNGhgPvvsM/P222+bkiVLmvr16zs/1P7888/OD5JxcXFm3bp1ztJ8vltvvdXcfvvtLsMmTZpk/P39zalTp8yaNWuMp6eniY+PNytWrHC+Pps1a+YyTU5OjgkPD3d5judr2bKliYqKMgsWLDBJSUmmX79+Lq/Zn376yfkaSkxMNEuWLDG9evUyksyHH35ojPnv7yAwMNCMGjXKJCUlme7duxtJpnr16ubRRx81iYmJZuDAgc7idu50QUFBplevXuarr74yI0eONB4eHmb48OHOjOe+FnNyckzr1q1NiRIlzNSpU82SJUvMv/71LyPJzJ49O9/nmJ6ebj799FMjyYwaNcps3LjRGHP2g7CXl5dp0aKFSUpKMgsWLDDGuH6wv5z3lPOnyc+SJUvybFzJ7/1xzJgxxsvLy9StW9csXbrUJCQkGGPOltQyZcqY9957z6xcudK8/fbbpmzZsqZ69erO9+/8PtgHBgaatm3bmsWLF5sPPvjAlCpVyjRq1Mg5zj+ZZvbs2UaSGThwoFmyZIkZO3as8ff3z1PkjTHmnXfeMd7e3pcs5oC7UQZgOc8995zx8fFxbpHK3bL43XffuYzXo0cPExkZ6fxns3//fuPp6encctiqVStz1113uUzz2muvuWxZPP+fZM+ePU1ISIg5ceKEc1hKSooJDAw0I0aMMMb89wPx008/7Rwn9x9nnz59nMOOHDliJDn3DiQmJpo77rjDZd7GGFO7dm3TsmVL5/3ztzSeXwbq169vbr75Zpd5zJs3z1SrVs3s27cvz/o8deqU8fX1NY899pjL8NwPKbkfrK7kuZ9fwipVqmTatWtnjDlbKmw2m5k0aZLLOKNGjTI+Pj7OD6nNmjUzdrvdZSv3pk2bzO2332527NjhMm379u3NDTfckO86ym+Lfa7s7GzTrl07U6ZMGZOcnGyMObsVOzo62nzzzTcu4z722GOmWLFizvvnfxA5fzldu3Y1pUqVMsePH3eOk5mZaapXr24aNmzoMk3v3r1dlhUdHW1uuummPHlz/frrr0aS8wOgMWe3kksyTz755AWnM+bsa1yS80NlxYoVTXBwsEvOBQsWGElm4cKFzmHz5883ZcuWdf7d+fr6mlatWuXZqv3WW28ZSS57jGrUqGFiYmKMMcY8//zzxt/f36SlpTkfX7x4sYmLi8tT7Dt27OhcV/mx2+0uW6uzs7PNE088YVavXm2MMeb9998399xzj8uW+uzsbBMYGGgeeughY8x/fwfdunVzjnPgwAEjyWUPSk5OjgkICDBDhw51me78kj106FDj7e1tjh07ZoxxfS0uXbrUSMqzznr37m3KlSvnsvfsXPm9hnP3Tv3xxx8u4577nnW57ymXKgNPPfWUCQoKyjP8/OnGjBljJJlly5Y5hzkcjnxfJy+99JKR5NwjlN8H+8jISJOVleUcFh8fbyQ53yP+yTQVKlQw7du3d8ny/PPP5/se8dNPPxlJZvHixRdcN8C1gC8Qw3LGjh2r/fv3KyEhQQMGDFBAQIA+/PBDNW7cWP/+97+d4w0YMEDJyclavXq1JGnOnDny8/NT586dJUnR0dFavny5mjZtqqlTp+q3337T4MGD1adPnwsuOykpSdHR0fLz81NWVpaysrIUEBCgpk2batmyZS7jNmnSxHk7NDRUkuvxvKVKlZIk5xkrWrZsqVWrVsnX11e///67Fi5cqIkTJ+rQoUPKyMi4rHWTlpamDRs2qFOnTi7DO3furN9//11hYWF5plm3bp3S0tJ0//33uwzv0aPHP37ujRs3drkfHh7u/KLh119/LWOM2rdv75xPVlaWOnTooPT0dOfvS5IqVaqk4sWLO+9HRUVp9erVqlSpkv78808lJibqpZde0rZt2y57HZ0rNjZWiYmJmjdvnipWrChJCgsL09dff62mTZtq9+7d+vrrrzVt2jStXbv2ipaxcuVKtWvXToGBgc5hXl5e6t69u3744QedOnXKOfxi6ys/f/75p6Sz6yeX+f9TPJ77XZr8eHl5uYwvSe3bt3fJ2aFDB3l7e7v8Lu677z7t2bNHS5Ys0RNPPKGaNWtq2bJl6t69u+6//37n/Lp37y4/Pz998MEHks6egWbbtm3OM+o0a9ZMZ86cUe3atTVy5EitXbtWLVu21JgxY2Sz2VyyRkZGateuXRd8LtHR0RozZoy6du2qWbNm6fDhw3rxxRd1++23S5L69OmjxYsXKyMjQ1u3btVnn32muLg4ZWVl5fldXurv1WazKTg4OM8ZZnr37u1yv3PnzsrMzMz3ZAZJSUmy2Wxq27Ztntf+gQMH9Msvv1zwuebH19f3osfNF8R7inT29XYlZ+2pXbu283axYsW0ZMkSdevWTQcOHNA333yjt99+WwsXLpSki+Zo0KCBy/dQwsPDJemifxsXm2bHjh3avXv3Jd/rcuU+54u9BoFrAWUAlhQcHKwePXro3Xff1c6dO7Vx40bVrFlTTz/9tPNMO3feeacqVaqk999/X5I0e/Zsde3aVX5+fpKkJ598UtOmTdOZM2c0YsQI1ahRQ7Vr11ZSUtIFl5uSkqL//Oc/8vb2dvlZuHCh9u/f7zJuQEBAnulzl52fnJwcPfPMMypZsqSqV6+uRx55RBs3bpSvr+9ln8v76NGjMsYoJCTkssaXpMOHD0tSnmlyPxDlupLnfv7z9PDwUE5OjnM+klSrVi2X+TRs2FCSXOZVtmzZPHmnTp2qsmXLqkqVKurbt6++/vprFS9e/IrPd/7BBx9oypQpevXVV3XHHXe4PPbhhx+qQoUKqlixou6//34tWLDgor+7/Bw9ejTPOpTOrldjjFJTU53DLra+8nPixAlJcilKpUuXVvHixS95itncIlGhQgXnsPNLooeHh0qVKqVjx465DPf29larVq304osv6scff9TevXvVuXNnzZs3z/nF/YCAAN1///2aM2eOpLN/d1WrVlXTpk0lnS0+ixcvVuXKlZ0f3MPDw12KfK7ixYs7n2t+5s6dqyeeeELr169X//79FRYWptatWzs/vKWlpWngwIEKDAxU7dq19cQTT2jXrl3y9vbO83q50r/XXOevu9y/o/PXnXT2tW+MUYkSJVxe+127dpWkPH9HlxISEpKnQJ2rIN5TpLOvt3Nfa5dy/t9tYmKiatSoobCwMLVr107vv/++84xEF8uR39+FpIv+bVxsmst9r8uV+5wv9hoErgWUAVjGvn37FBYWpvfeey/PYzfffLPGjx8vh8OhnTt3Sjq7Ja9fv3769NNPtWnTJv3666/q37+/cxoPDw89+uij2rBhgw4ePKiZM2cqPT1dnTt3vuDWqqCgIOeW3fN/li5d+j89v0mTJmnq1Kn697//rePHj2v37t2aN2/eFZ0pKDAwUDabzflPL5fD4dBXX33lckrSXLlbzg4dOuQy/Pz7BfXcg4KCJJ3dQ5DfvLp06XLBaRMSEvTEE09oxIgROnTokA4ePKhFixa5nOHmcqxfv14PPvigHn74YQ0aNMjlsTVr1uiBBx5wbglPSUlRUlJSnq33l1KyZEkdPHgwz/ADBw5I+u+eoX+idOnSkuSyldpms6l9+/ZasmTJBbecZmdna8GCBbrtttuc85CU53WRnZ2tI0eOOD80NWnSxOVvJ1e5cuX07rvvSjp7bvZcMTEx2rFjh3744QfNmzcvz3n2W7VqpcTERB07dkxffvmlbrrpJj3++ON5roNw7Ngxl5znCwwM1OTJk5WcnKzffvtNzz//vNasWaNHHnlEkjR06FDNmzdP//nPf3Ty5Ent3LlTc+bMueTekytx/rr7+++/JeX9wCmdfe37+/vn+7r/4YcfXPZOFISCeE+Rzr7e/uk593fu3KmOHTuqbt262rFjh1JTU7VmzRq1b9/+H83vf3G573W5cgvdxV6DwLWAMgDLCA0NlZeXl6ZPn6709PQ8j2/fvl0+Pj6qVq2ac1j//v114sQJDR8+XNWqVdNtt93mfKxJkybO80iHhISoX79+Gjx4sE6cOOHcapu7VSlXs2bN9OuvvyoqKkr169dX/fr1dcstt+jll1/+n893vWbNGtWqVUsxMTHOQzb27dunLVu2uGwJu9jpG/39/RUVFZXndIxLly5VmzZttGfPnjzTREVFKTAwUJ9++qnL8PMvJlVQz71Zs2aSpCNHjjjnU79+faWkpGjUqFH5FpZca9asUWBgoJ5++mnnB5pTp05pzZo1F91aeK79+/erY8eOuvXWW/PdGv3tt98qJydH8fHxzg8P2dnZzkOhcpdzqdNoNmvWTAsXLnTZqpidna25c+eqQYMGzi2j/0TuIU3n/z6fffZZnT59Wg8//HC+6+PZZ5/Vjh07NHLkSJfhS5YscSnAn3/+ubKystSiRQtJZw9H+uSTT5x7Fc61fft2Sa6Hhtxxxx2qVq2annrqKR05ckQPPPCA87ERI0aoYcOGMsbIz89P7dq1c1646vzns2fPHudzPd9ff/2liIgIzZs3T5JUvXp1PfXUU7r77rud81mzZo2io6PVsWNH51beDRs26PDhw5f9ermUL774wuX+vHnz5Ofnl+8pPps1a6ZTp07JGOPy2v/ll18UHx+vrKysfJfxT0/ZernvKZdSsWJF7d27N89W/PPfH/OzYcMGpaenKzY21uWQpq+++krSxbfyF7Tw8HBVqVLlku91uXJfRxd6DQLXCq4zAMvw9PTUG2+8oY4dO6p+/foaPHiwatSooTNnzmjp0qWaNm2axo8fr+DgYOc0ERERuvvuu5WYmKgJEya4zK9Zs2Z68cUXVbZsWTVp0kT79u3TSy+9pGbNmjm3BAUFBenbb7/VN998o6ZNm2r06NFq3Lix2rVrp4cfflg+Pj5666239Nlnnzk/lPxTDRs21Lhx4zRp0iQ1btxYO3bs0MSJE+VwOFy29AYFBWnTpk1atWqV89Cac40dO1YdOnRQt27d1L9/fx06dEixsbFq166doqKi8oxfokQJPfXUUxo9erT8/PzUvHlzrVq1Sm+88Yak//7DL6jnftNNN6l379568MEHlZycrPr162v79u169tlnValSpYtu5W/YsKHeeOMNPfHEE2rfvr3279+vF154QQcPHnT5vV9IRkaG7r33XmVmZiouLk6bNm1y+TASHh7uXKeDBw9WTEyMjh07pmnTpmnz5s2Szh57XKJECQUFBenvv//WV199le96HTNmjBYvXqzo6GjFxsbKbrfrtdde086dO7VkyZLLXl/5qV69uipUqKC1a9e6fD+kdu3amjVrlvr3768dO3bo4YcfVmRkpA4cOKCZM2dq6dKlmjx5su655x6X+e3du1cdOnTQkCFDtGfPHsXGxqpVq1Zq3ry5pLNXml2xYoUaNmyooUOHqnHjxvL09NQPP/ygF198Uffcc49at27tMs+YmBjFxsbq7rvvVkREhHP4XXfdpalTp6pfv37q3bu3MjIyNGXKFJUsWVJ33nmnczxjjL799lsNGTIk33VQsWJFhYeHa8iQIUpNTVWVKlX0448/avHixYqNjZV09vXy8ccf680331SNGjW0efNmjR8/XjabrcAulvXJJ58oNDRUbdq00cqVKzV9+nRNmDAh38Nq2rRpozvuuEP33nuvnnvuOdWoUUPr16/XmDFj1KpVqwtugc79IJ+UlKQaNWro1ltvvaxsl/ueciktW7bUpEmTtHXrVt10003O4ee/P+anXr168vLy0tNPP60nnnhCDodDM2fOdB5WVpgXdbTZbBo7dqx69eqlhx9+WJ06ddLmzZs1duxYSXnLzZo1a+Tn53fB5wZcMwr/O8uAe23YsMF0797dhIeHG7vdbgICAkzz5s3N/Pnz8x3/tddeMx4eHmbPnj0uwzMzM53nxbbb7SYkJMQMHDjQ5fzqL730kgkKCjJ+fn7mr7/+ci4/9/SA/v7+plGjRubzzz93TpN7Rp1zz89/oTPa6JyzcaSnp5tHH33UhIaGGl9fX1O9enUzZswYEx8fb+x2u/M6AQkJCSYkJMTY7XazevXqfK8zsGjRItOgQQNjt9tN+fLlzeOPP37R0+Pl5OSYcePGOc993rRpU/Pyyy8bSWbDhg0u6/5Kn7sxZ88MdO6pIzMz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9ddfV1BQkPbs2SNPT8+rstzcPQl79uxxDjt27Jh+/fXXK5omMzPT5UvJ69atU9myZfXDDz/IZrMpKipK48ePV+3atV2mAwoSewYAAMB16bbbblN2drY6duyoZ555RgEBAfrPf/6jEydOqHPnzvrll18kSR999JEaNWqkSpUqFchy69Spo4iICMXHxyswMFCenp56/vnnVbx48QtOExwcrCZNmui1115TtWrVVLp0ab366qtKS0tzTnfzzTfLz89Pffr0UVxcnEJDQ7V8+XL99NNPGjp0aIFkB87HngEAAHBdKleunBITExUYGKgBAwaobdu22rhxo+bPn6/o6Gh17txZDRo0UN++ffXCCy8U2HI9PT01f/58hYWFqUePHnrsscfUrVs3de7c+aLTzZo1Sw0aNNCDDz6ovn37KioqSo8//rjzcR8fHy1dulS1atXS0KFD1apVK3322Wd666231K9fvwLLD5zLZowx7g4BAAAAoPCxZwAAAACwKMoAAAAAYFGUAQAAAMCiKAMAAACARVEGAAAFLiEhQTVr1lS1atU0bdo0d8cBAFwAZxMCABSoffv2qUmTJtq4caN8fHzUpEkTffDBB6pdu/ZFp8vJydH+/ftVokQJ59VaAQBXzhijkydPKiwsTB4eF9/2z0XHAAAFavny5WrRooVKlSolSerSpYvmzZuXpww4HA45HA7n/X379qlmzZqFmhUAirI9e/YoPDz8ouNQBgAABWr//v0KCwtz3i9XrpzWr1+fZ7znn39e8fHxeYa/++678vPzu6oZAaAoO3PmjAYOHKgSJUpcclzKAACgQOXk5Lgc5mOMyXc3dWxsrIYPH+68n5qaqoiICPn5+Wnw4MFKS0srlLz58fX11YwZMxQTE0MOcpCDHNddjtxvAVzOIZeUAQBAgQoPD9fq1aud9w8ePOiypyCX3W6X3W7Pdx5paWlu/WdODnKQgxxFJcelcDYhAECBuuuuu7R8+XIdOnRIp0+f1ieffKLWrVu7OxYAIB/sGQAAFKjy5ctr4sSJio6OVmZmpgYOHKiGDRu6OxYAIB+UAQBAgevZs6d69uzp7hgAgEvgMCEAAADAoigDAAAAgEVRBgAAAACLogwAAAAAFkUZAAAAACyKMgAAAABYFGUAAAAAsCjKAAAAAGBRlAEAAADAoigDAAAAgEVRBgAAAACLogwAAAAA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57y9a9cu+fn5qXTp0i4finOP99+5c6dzWHZ2tv766y+VK1dOERER+uuvv1w+OO/du9d529PT03lsfq4jR444b0dERGj37t3O+5mZmRo2bJgOHDjgMk14eLgk6bffftPx48edPxs2bFC7du0kSX379tX333+v5cuX6+eff3Z+hyA8PFxVq1Z1mW7v3r365ZdfVKZMmStbaQAAAP8DygCuGc8884xSU1O1f/9+jR49Wg888IC8vb1dxilXrpzatGmjIUOG6ODBg0pLS9PTTz+t7OxstW/fXu3bt1dOTo7i4uKUkZGhDRs26J133nFOX6NGDR08eFArVqyQMUYffPCBtm3b5ny8f//+euGFF/T7778rKytLEydO1IIFC1S6dGn5+PgoNTVVxhiFhYWpbdu2Gjp0qFJSUpSZmakJEyaoQYMGzu8UlClTRu3bt9fAgQPVuXNn556Adu3a6eTJk3rhhRfkcDh0/PhxPfDAA+rWrZtL8QEAALjaKAO4ZlStWlU33XSTateurcaNG+vll1/Od7w5c+aocuXKqlevnsqWLauff/5ZX3/9tUqWLKmgoCAlJiYqKSlJwcHBGjBggLp06eKctn79+ho1apT69u2rkiVLKikpyeXxp556Sr169VKrVq1UqlQprV69Wl999ZW8vb3Vvn17paSkKDAwUMePH9ecOXMUFBSkqKgolS5dWosWLVJiYqJCQ0Od83vwwQf1119/acCAAc5hAQEBWr58uVasWKHw8HBVrlxZHh4e+uKLL67CWgUAALgwvjOAa8ajjz6qF154wWVY7ik/z1WyZEmXrf3nq1u3rtauXXvBx8eOHauxY8fm+5iXl5fGjBnjcmafXLVq1dJff/3lMuytt9664HIkqWXLlvlem6BGjRpavHhxvtP069dP/fr1cxm2cuXKiy4HAADgn2DPAACgwPXo0UM33HCDoqKiFBUVpQULFrg7EgAgH+wZAAAUuB9//FHff/+9SpYs6e4oAICLoAzA7SIjI/M9lAbA9eno0aM6fPiwevTooQMHDqhz584aPXp0ni/IOxwOORwO5/3ci/RJZ6+14U65yycHOchBjusxhzFG6enplzWuzfApDLigP/74w+X6BwAu7ddff9Vzzz2n6dOnKyAgQB06dFDPnj3zXAAwLi5O8fHxeaZPSEiQn59fYcUFgCLnzJkz6tmzp06cOKGA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T91zzz36/PPPCz3HlaAMAACuCfv373f5AF6uXDkdOHCg0HPMnDlTTZs2LfTlnqtatWpq1qyZJOnQoUOaNm2aOnTo4JYs3t7eGjVqlGrUqKE777zTLR/0JOlf//qXJkyYoODgYLcsP9fBgwfVokULzZ49W999951Wr16tmTNnFmqGHTt2KCcnRx07dlTdunX1+uuvq2TJkoWa4XyrVq3S33//7bZDhEqUKKHx48frxhtvVPny5VWxYkU1adKk0HPUq1dPiYmJOnr0qNLT0/XFF1+45X3sSlAGAADXhJycHNlsNud9Y4w8PKz9byo5OVnR0dF68MEHFR0d7bYc48eP15EjR7R371698847hb78d999VxEREWrRokWhL/t8NWvW1Pz58xUaGio/Pz8NHjxYCxcuLNQMWVlZWrJkid5++2199913+v777zV79uxCzXC+N954Q8OHD3f5Gy5MW7Zs0cyZM/XXX39p//79stlsevHFFws9R4sWLdSvXz81b95crVu31u23365ixYoVeo4rYe13WQDANSM8PNxlC9rBgwfdeqiOu/3000+67bbbNGjQII0cOdItGbZu3aotW7ZIkvz8/NSpUyf9/PPPhZ7jP//5j5YuXaqoqCiNHj1aX3zxhYYMGVLoOSTpxx9/1BdffOG8n52dLS8vr0LNEBoaqhYtWigkJES+vr7q1KmT1q9fX6gZzpWRkaGkpCR17tzZbRmWLFmi6OhohYSEyG63q3///lq5cmWh5zh58qTuu+8+/fzzz1q5cqW8vb1VuXLlQs9xJSgDAIBrwl133aXly5fr0KFDOn36tD755BO1bt3a3bHc4vDhw2rdurVee+01PfbYY27LsW3bNg0aNEgZGRlyOBz69NNPdccddxR6jmXLlumXX37RTz/9pLFjx6pDhw569dVXCz2HdPbD/9ChQ3XixAllZmbqzTffVKdOnQo1Q7t27bR06VIdO3ZM2dnZSkxMVL169Qo1w7m2bNmiatWqqUSJEm7LULduXSUmJio1NVXGGH355Ze65ZZbCj1HcnKyOnTooMzMTB07dkzvvfeeunbtWug5rkThVlkAAC6gfPnymjhxoqKjo5WZmamBAweqYcOG7o7lFq+88opSU1M1duxYjR07VpLUtm3bQj9NYZcuXbRx40ZFRUXJ09NTXbt2veY/2Fxtt956q4YOHapGjRopKytLnTt3Vo8ePQo9Q2xsrJo2barMzEy1aNFC/fv3L9QM59q5c6cqVKjgtuVLUsuWLdWnTx/Vr19fdrtd9evX1zPPPFPoOWrXrq0ePXqobt26ysrK0vDhw3X77bcXeo4rYTOF/RV4AAAAANcEDhMCAAAALIoyAAAAAFgUZQAAAACwKMoAAAAAYFGUAQAAAMCiKAMAAACARVEGAAAAAIuiDAAAAAAWRRkAAAAALIoyAAAAAFjU/wELXsNVM5IoWQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwMAAAGgCAYAAAD2NbtKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABYhUlEQVR4nO3de3jO9ePH8de9g3ubnTHDxhBCyxSKEiPnQ0SOCUNRoqQcY4RQqa+QDl+HaJ2IChkWpVIqkiIi50MYNuy8vX9/7Lc7tw3Td3az+/m4Lte1+3N83Z/d7t2v+3OyGGOMAAAAADgdF0cHAAAAAOAYlAEAAADASVEGAAAAACdFGQAAAACcFGUAAAAAcFKUAQAAAMBJUQYAAAAAJ0UZAAAAAJwUZQAoBDfivf1uxEzOiN8DCtON+Hq7XpkK87neiNsVyC/KAJzSb7/9pm7duik4OFjFihVTmTJl1LVrV23durXA1zV58mS9/PLLBb7c/8V///tfDR8+3PZ4wYIFslgs2r9/v+NC3WDCwsLUp08fSdL+/ftlsVi0YMGCAl3Ht99+q7Zt29oeX6/1XElGRobuvPNOrVu3zm749u3b9cgjjygkJERWq1Xly5dX9+7d9cMPP/zrdcXHx2vYsGGqXLmyrFarAgMD1bRpUy1duvR/fRq59OzZUy+99FKBL9cRLn4t/lupqakaNmyYYmJirjqtxWJRdHT0NS0/v/Ns3rxZ1apVU2pqqqTr9/546Xvc9ZLXdn377bft/l8DNzrKAJzO77//rvr16+vkyZOaOXOm1q5dq5dfflkHDhxQ/fr19f333xfo+saOHasLFy4U6DL/Vy+88ILi4+Ntj9u0aaNNmzapTJkyDkx14ypTpow2bdqkNm3aFOhy3377bf3+++/XfT1XMmnSJJUrV07333+/bdjixYt15513ateuXZo0aZLWrFmjF198UX///bfuuecezZgx45rXk5ycrIYNG+rzzz/XiBEjFBsbq/nz5ys4OFidO3fWa6+9VoDPSpo+fbpefPFF7dy5s0CXe7M6duyYXn31VaWnp1912k2bNql///4FniElJUW9e/fWiy++KKvVKun6vT9e+h53veS1Xfv166cjR45o/vz51339QEFwc3QAoLDNmDFDgYGBWr16tdzd3W3DO3TooFtvvVUvvPCCVq5c6cCEha9UqVIqVaqUo2PcsKxWq+6+++4is54cx44d09SpU/X111/bhm3dulVRUVHq2bOn3nnnHbm6utrG9ezZU0899ZSGDx+u22+/3a5AXM2SJUu0c+dO7dq1S1WrVrUNf+CBB5SUlKTx48frySeftFvf/6JcuXLq1q2bRo4cqU8//bRAluksrtdrcM6cObJYLHrwwQevy/JvFC4uLho1apSGDBmi7t27y8PDw9GRgCszgJNp3bq1KV++vElNTc017uOPPzYLFiwwxhgza9YsI8ns2rXLbpr333/fWCwWs2/fPpOZmWmef/55ExYWZooVK2bCwsLMqFGjTFpamjHGGEl2/3Js377dtGnTxvj4+BgfHx/ToUMHs3fvXtv49evXG0kmLi7ONG7c2Hh4eJjQ0FDz9ttvm6NHj5qOHTua4sWLm5CQEPPqq6/a5du2bZvp2LGjKVmypHFzczNly5Y1Tz75pElKSjLGGFOhQgW7TPv27TPz58+3/ZxjzZo1pmHDhqZ48eImODjYPProo+b06dNX3LYvvfSSqVixovHw8DANGjQwn332mZFk1q9ff83Pfd26daZZs2bG09PTBAUFmeHDh5v09HTbdJmZmebFF180lStXNsWKFTNVqlQxM2fOtMvTqFEj07NnT9OpUyfj4+NjWrdubYwxZt++faZXr16mTJkyxs3NzZQqVcr06tXLnDp1yjZvhQoVTO/evW3TSzLz58/Pcxte/C/nuZ48edI8/vjjpnz58sbd3d0EBASYDh062LZx79697eabP39+rvUYY8zu3btNp06dTOnSpY2Xl5dp3Lix+eabb2zjc+b56KOPTKdOnYy3t7fx9/c3/fr1M+fOnbvi72v48OHmlltusRvWuXNnExAQYM6fP5/nPKmpqaZ8+fKmYcOGdttqzJgx5umnnzYBAQEmICDAPPzww3bbc/r06UaS+eOPP3Itc/Pmzeall14yFy5cML/99puRZN588027aY4cOWJcXFxs/z8/+OADc/vttxsPDw9TsmRJ07NnT3P06FG7eb799ltjsVjM9u3bL7sNTp48aXr27GlKly5trFarqVWrlnn33Xftpvnqq69M8+bNjb+/v3F3dzdhYWFm/PjxJjMz0xjzz+9gyZIl5oEHHjBeXl4mKCjIvPDCCyYhIcFERUUZX19fExQUZJ577jmTlZVlN9/7779v2rZtazw9PU1ISIjdsnO2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XOm94bXXXjOurq62PRbAjYoTiOGUJk6cqKNHjyomJkb9+vWTr6+v3nvvPdWvX1//+c9/bNP169dP+/fv18aNGyVJixYtkpeXlzp16iRJioyM1Lp169SwYUPNmDFDf/zxhwYPHqxevXpddt1xcXGKjIyUl5eXMjIylJGRIV9fXzVs2FBr1661m7ZBgwa2n4ODgyXZH89bokQJSdLZs2clSc2bN9dXX30lT09P7d69WytWrNCUKVN04sQJpaWl5WvbJCcn6+eff1bHjh3thnfq1Em7d+9W2bJlc82zadMmJScn66GHHrIb3r1793/93OvXr2/3OCQkxHai4ZdffiljjNq1a2dbTkZGhtq3b6+UlBTb70uSKlasqOLFi9seR0REaOPGjapYsaL++usvxcbG6pVXXtHOnTvzvY0uNmrUKMXGxmrJkiWqUKGCJKls2bL68ssv1bBhQx08eFBffvmlZs2apW+//faa1rFhwwa1bdtWfn5+tmFubm7q1q2bfvzxR50/f942/ErbKy9//fWXpOztk8P8/+URLz6XJi9ubm5200tSu3bt7HK2b99e7u7udr+LBx98UIcOHdLq1av1zDPPqEaNGlq7dq26deumhx56yLa8bt26ycvLS4sXL5aUfQWanTt32q6o06hRIyUlJSk8PFxjxozRt99+q+bNm2v8+PGyWCx2WcPCwrRv377LPpfIyEiNHz9eXbp00YIFC3Ty5Em9/PLLuvfeeyVJvXr10qpVq5SWlqbff/9dy5cvV3R0tDIyMnL9Lq/2/9VisSggIMD2/zXHww8/bPe4U6dOSk9Pz/NiBnFxcbJYLGrTpk2u1/6xY8f022+/Xfa55sXT01OVK1e+7PiCeE+Rsl9vYWFhV50uP+8RkZGR2r17t+68805NmjRJW7duVY8ePTR06NB85yldurRq1KihAQMGqE+fPvrwww9ljNGMGTN022235TvLlYSFhSkzM1OHDh3Kdy7AESgDcFoBAQHq3r273nnnHe3du1dbtmxRjRo1NGLECNtVKJo0aaKKFSvq3XfflSQtXLhQXbp0kZeXlyTp2Wef1axZs5SUlKThw4erevXqCg8PV1xc3GXXGx8frw8//FDu7u52/1asWKGjR4/aTevr65tr/px15yUrK0sjR45UYGCgqlWrpscff1xbtmyRp6dnvq+Dffr0aRljFBQUlK/p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R0erefPmqlu3rgIDA/X1118rLCxMAwcOVHBwsGrXrq2srCxt2bJFkZGRCggIUJUqVfTqq6/aPuBHR0erc+fOevjhh+Xv76+QkBCNGjVKkrRw4UJNmTJFGzdulL+/f57ZDxw4oK5duyooKEjBwcHq2bOn7e7DGzZsUGhoqHr06CF/f39NmzZNiYmJGjBggKpUqaLixYurXLlymjJlim15YWFhevHFF1W7dm15e3urdu3adnsltm7dqnvvvVc+Pj6KiIjQ5MmTbXdZlqR169apXr168vf3V82aNfXee+9ddrsnJydr0KBBCgwMVGhoqJ5//nlVrFiRy5Ki0GVmZmro0KFKSEhQenq65s6dq44dOzo6FgAgD5QBFKjTp0+rWbNmioyM1KlTp7Rx40bNnz9fb731Vr7mj4uL07Rp03Tw4EE1aNBAkvTDDz/ojz/+0Pr163X8+HE1adJEnTt31okTJ/Tpp59qzpw5dsv/5JNP1Lx5c8XHx+utt97StGnT9P3336t3794aPXq0GjZsaLtL8MXS09PVrFkzubq66s8//9Qff/whY4zatWunjIwMSdLhw4dVvXp1nTx5Uo8//rhGjhypffv26ccff9T58+c1c+ZMjRkzRnv27LEtd968efr444914sQJ1apVS4MGDZKUfUhEy5Yt1aRJE506dUqLFi2yex7btm1T+/btNXLkSMXHx+vtt9/WU089pdjY2Dy33dNPP60ff/xR27Zt086dO3XgwAHt378/X9sdKEh33XWXhg4dqrvvvls1atTQnXfeqe7duzs6FgAgD5QBFKjPP/9cnp6eGjdunKxWqypXrqx169apTZs2+Zq/UqVKatKkiby9vW2HFXTu3Fn+/v7y9/fX4sWLVb16dT3xxBNyd3dXjRo19Oyzz2rWrFm2ZVStWlWPPPKIXF1d1bp1a5UpU0a7d+++6ro3btyov/76S3PnzpWfn5/8/f315ptv6pdfftFPP/1kmy4qKkru7u7y8fFRdHS0PvroI/n6+urw4cPy8PCQJB09etQ2fb9+/XTLLbfIy8tLPXv2tGX5/PPP5ebmpujoaFmtVoWHh2vEiBG2+d5880098MADevDBB+Xq6qoGDRpowIABds81R3p6uhYtWqTJkycrNDRU3t7emj17tlxdXfO13YGC9tRTT2nnzp36888/NXXqVEfHAQBcBucMoEAdO3ZMoaGhdocDVatWTZLsvi2/nLJly15x2P79+/Xzzz/bHeaTlZVl96E3ODjYbn53d3dlZWVddd1///23SpYsaXeijY+Pj0qUKKH9+/fblntxnhMnTmjo0KHasmWLKlasqDp16tgy5ZXH3d3ddkjToUOHVL58ebm4/NPJK1WqZPdcv/zyS7vnmpmZqcqVK+fKHh8fr6SkJLtDjHx8fFSyZMmrPm8AAOC82DOAAhUaGqpDhw7ZnaT76aefatGiRbYP7GlpabZxp06dspv/0nMKLh0WEhKiJk2a6OzZs7Z/+/bt09atW//n7GFhYTp16pTdtc4TEhJ06tQplSlTJs88Dz30kOrUqaOTJ09qy5YtevHFF/O9vgoVKujgwYN22+rAgQO2n0NCQtSnTx+757p7926tWrUq17KCgoLk6elpN/+FCxdybV8AAICLUQZQoNq0aaP09HRNmTJFaWlp2rt3r5566iklJyfrlltukZubm95//31J2SfHfvnll9e0/J49e2rTpk167733lJGRoWPHjqlt27YaNmxYvub38PBQYmJinlcUqlu3rmrWrKmBAwcqISFBCQkJGjRokG655Rbdc889eS4vISFBnp6ecnV11cmTJ/Xkk09Ksi88l9O+fXtlZWXZttWuXbv00ksv2cb369dPMTExWrNmjbKysvTnn3/qvvvu08svv5xrWS4uLurXr5/Gjx+vo0ePKikpSU8//bQyMzPztV0AAIBzogygQPn7+ys2NlZxcXEKDg5W48aN9dhjj+nRRx9VmTJl9J///EcvvPCCfH19NWvWLPXt2/eall+hQgWtXr1ab775poKCglSrVi1Vr15dCxYsyNf87dq1U3x8vPz8/HKdROzm5qYVK1YoIyNDVatWVYUKFZSWlqa1a9fmeVlESZo/f74+/PBD+fr66s4771RISIhq166t7du3XzVL8eLF9dlnn+nTTz9VQECAunXrpubNm6tYsWKSsk/CfP/99zV69GgFBASoUaNGat++/WWPv546dapuvfVWVa9eXVWrVlVoaKhcXFxsywMAALgU5wygwEVERFz2G//HH39cjz/+eJ7joqOjcw3L62o49evX19dff/2vllGzZk27Q2kuFRoaqo8++ijPcY0bN861R6FFixbauXPnZZd3af6LlxEfH6+0tDRt3rzZNv7111/Xtm3bbI/btGmT75Ov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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
}
