{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2a1c8a85",
   "metadata": {},
   "source": [
    "# Demo: Distractor Generalization\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": "27665b8e",
   "metadata": {},
   "source": [
    "# Distractor generalization split (Fig. 3)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "807dd7f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "#### Distractor generalization split\n",
    "dataset = 'comptree' # comptree ~ compositional tree structure\n",
    "taskdepth = 1 # number of nodes to include; distractor generalization in the paper only uses single task operators\n",
    "train_distractors = 5 # number of distractors to 'train' on\n",
    "test_distractors = 40 # number of distractors to 'test' on; in the paper, we also include additional test splits for 10, 20, 30 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.CompTreeDataset(tree_depth=taskdepth,\n",
    "                                        n_distractors=train_distractors,\n",
    "                                        distractor_range=True, # true: include trials with distractors ranging from 1 through train_distractors (randomly sampled)\n",
    "                                        location=location_sampling,\n",
    "                                        ntrials=ntrials,\n",
    "                                        nfeatures=nfeatures)\n",
    "\n",
    "test_dataset = datagen.CompTreeDataset(tree_depth=taskdepth,\n",
    "                                        n_distractors=test_distractors,\n",
    "                                        distractor_range=False, # false: only include trials with test_distractors\n",
    "                                        location=location_sampling,\n",
    "                                        ntrials=ntrials,\n",
    "                                        nfeatures=nfeatures)\n",
    "                                    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "abdc0273",
   "metadata": {},
   "source": [
    "#### Print dataset statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "5c45014c",
   "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": "5008b7b3",
   "metadata": {},
   "source": [
    "#### Initialize dataloader (and simulate forward inference)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6ff4276b",
   "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",
    "distractor_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(distractor_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": "bb1a72b3",
   "metadata": {},
   "source": [
    "#### Visualize example trials from train and test datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "358ba17b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: current green h product is even ?\n",
      "Target output: False\n",
      "Instruction: current red e product is even ?\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "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3z6FhYU5bWvlypV6/vnnnYaenOurr75S+/btddtttzmKwHfffacjR46c91PTs61YsUKPPvqoxowZo379+hW5j+joaMXFxTneRP/xxx/atm2b0z7O9xqoU6eOwsPDHcNECvz+++9av379Rf+MzpaRkaHatWs7hqBVr15dw4cPV//+/R2vz5I+hr+j4LVZYP78+bLZbGrfvn2hZdu2bSvpzOv67J95SkqKnn766fNe4efcI1Yl8dVXXykwMFBPPvmkowicOnVKX3311UU9/ho1auj06dOFjnaU5Pf/l19+UUpKikaOHKno6GjH4zj39788uLu764YbbnD6nZbO/AyLGjZ17Ngxpaenq0aNGuUVEbiicGQAuESkpaVpw4YNkv73CVhSUpLefPNNDRgwQL169SpyvY4dO2rq1KkaPHiwBgwYoOzsbD3//PMKCQnRzTffLOnMJ53r16/X6tWri72+eVhYmKKiojRt2jRFREQoODhYSUlJevnllyX9b/zvI488ojlz5qhz584aO3asfHx8NGnSJFWpUkV33323Y3/ffPONvvzyS7Vp00bPPfecOnfurC5duujBBx9Udna2nnvuOWVlZWncuHEX9TzddNNNuuWWWxQXF6dJkyapRo0aeuedd/TDDz84xhe7u7tr4sSJuu++++Tu7q6YmBidOHFCzz77rPbv36+mTZuWeH9DhgzRtGnTdMstt2jMmDGqXr26VqxYoSlTpujBBx+Up6dnseu2aNFC//nPfzRjxgzVq1dPP/zwgyZMmCCbzVaiL6batWuX+vXrp+bNm6tPnz7auHGj03CN+vXrq0WLFnr22Wc1efJktWrVSr/99psmTZqkrKwsp30EBQXp+++/1xdffFHoE3c3Nzc999xzGjJkiO68804NGjRIR48eVXx8vEJCQjRq1KgSP1/nstvtatq0qRISEuTl5aVGjRppx44dmj17tvr06eN4nkryGP6OTZs2acCAARo4cKC2bt2qZ555RsOGDSt0JEuSGjRooAEDBujee+9VcnKymjVrph07dmjMmDG66qqrVLt27WL3c+5rvyRatGihN954Q48++qhiYmJ04MABvfDCCzp06NBFHcXq1KmTJOnrr79Wjx49nDIV97MvUKdOHQUEBGjixIny8PCQp6en5s+fr3feeUfS+cf/l4WEhAS1a9dOd9xxh+655x7t2bPHcZ7JuYXrq6++knTmCCmAv8BVZy4D+J+2bdsaSY5/bm5uJjw83LRr18689957TlfUMKbw1UESExPNddddZ/z9/U2FChVM165dzdatWx3zV69ebapXr268vLzM+++/77hyz5o1a5y2u2XLFtO2bVvj7+9vQkNDTZs2bcyyZctM3bp1zR133OFYbvv27SYmJsb4+/ubkJAQ06tXL7Nr1y7H/H/9618mKCjI+Pr6Oi5JumbNGtOmTRtjt9tNUFCQ6dmzp+NKLgXzi8pUlGPHjpnBgweboKAg4+fnZ+666y4zfPhwU6FCBaflPvzwQ9O0aVPj7e1tQkNDTc+ePZ2el3OvclJA51yx5M8//zRxcXEmLCzMeHt7mzp16pjnn3/e6SpB565jjDEpKSkmNjbWhIaGGn9/f9OwYUPzyiuvmGHDhpkqVaqY3Nzc815NqOB2cf/WrFljMjMzzfDhw014eLix2+2mTp06Zty4cSYhIcF4e3ubY8eOGWPOvEYK8q9bt67IqxbNnz/fNG3a1Hh5eZmKFSuaAQMGmL179zrmF3elowtd5SYtLc089NBDjtdgRESEeeyxx0x6eroxxpT4MRT1HBe173OvniXJPPLII6Zv377GbrebyMhI8+yzzzpd3ercdXJycsz48eNNzZo1jaenp4mIiDD/+Mc/TEpKSrGP05jCr/3iXmNn587PzzfPPPOMiYiIMD4+Pubqq682Dz30kONKVj/99FOJnmdjjLnuuuvMP/7xD6dpJfnZG3Pmd7BZs2bGbrebsLAw07lzZ/PVV1+ZChUqmMcff9wYU/SVgc69Etq5v8t/ZR1jjFm4cKFp2LCh8fLyMrVr1zYffvihkWT+9a9/Oa17//33mxYtWpz3eQFQPJsxfIc3gMvHnj17tH79et16662y2+2O6XfccYd27dqlzZs3uzAdLkU2m03jxo1z+rKqK9WCBQsUFxenAwcOXNTJxJeaTz/9VBEREbruuusc03766Sc1aNBAixYtUs+ePSWdGU5VtWpVvfvuuxd9hScAZ3DOAIDLipubmwYPHqzBgwdr+fLlWr16tR577DEtWLBAI0eOdHU8wKV69eql6OhoTZ8+3dVR/pakpCTdcssteuedd7Ru3TrNmzdPffv2Vd26dR3DoSRp+vTpatCggW699VYXpgUub5wzAOCyEhkZqc8//1zjx49X3759lZOTo/r16+v9999X//79XR0PcCmbzaa5c+eqbdu2Gjx4sOOE5MvNiy++KLvdrgkTJujAgQMKCQlR165d9dxzz8nHx0fSmcsMv/LKK/riiy+K/A4WACXDMCEAAADAohgmBAAArlh85gmcH2UAAABckX7++WfdcMMNTtNsNlu5nUweFRWlwYMHl8u+gL+KcwYAAMAV6T//+Y/Wr1/vNG39+vWKiIhwUSLg0kMZAAAAltGyZUtXRwAuKQwTAgAAl63NmzerQ4cOCgwMVIUKFdSxY0dt3LhR8fHxSkhIkOQ8NOjs22vXrpXNZtPq1avVvn172e12Va9eXW+//bYOHjyoXr16yd/fX5GRkY5vYz97vbVr1zpladeundq1a1dkzuTkZNlsNs2ePdtp+uDBgxUVFeW4//vvv+vWW29VaGiofH191apVK33++ed/4xkCzo8yAAAALktpaWnq0qWLKlasqPnz5+uDDz7Q6dOn1blzZw0ZMkT33HOPpDNDg4YOHVrsdu68807FxMRo8eLFql27tu6//361b99eDRs21IIFC9S0aVM98sgj2rRpU5k+nvz8fPXo0UOnTp3S3LlztWjRIoWGhqpnz5767bffynTfsC6GCQEAgMvSzz//rCNHjuihhx5ynChct25dvfnmm3Jzc3OcG3ChoUFxcXEaNWqUJMnf31+tWrVSixYtHEcWmjVrpkWLFumbb75RixYtyuzxHD58WNu3b9fYsWPVrVs3SXLkyMzMLLP9wtooAwAA4LLUoEEDVapUSTExMerXr5+6deumDh066Pnnn7+o7bRu3dpxOzw8XJJzgQgNDZUknThx4u+HPo/KlSurfv36uvfee7VixQp17dpVnTt31tSpU8t0v7A2hgkBAIDLkr+/v9atW6fu3bvrgw8+UM+ePVWpUiXdd999F/VJekBAQKFpvr6+pRm1RGw2m1asWKHBgwdr2bJluvPOOxUWFqZ+/frp2LFj5Z4H1sCRAQAAcNmqU6eO5s6dq7y8PG3atElz587VG2+8oZo1a5bZPm02myQpLy/PafqpU6fk7+9/0eucrWrVqpo+fbpef/11/fDDD5o/f74mT56skJAQvfHGG6X1EAAHjgwAAIDL0vz581WpUiUdOnRI7u7uatWqlaZPn66goCDt27dP7u7uZbLfgiMJ+/btc0w7fvy4fv7554taJycnx+mk5PXr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8fGSpNzcXD3zzDOKjIxUQECAbrrpJv3www+aM2eOJk2apHXr1ikoKEiSdPLkSY0YMUKRkZEKCwvTnXfeqT///FOSdPfddys2NtZpP/369dPw4cMlSbt27VJMTIwqVqyoGjVqaOzYscrOznZkvPHGGzVy5EhVqlRJYWFhGjp0qHJyckrzaQcAAKAM4NKxYMECbdu2TTt27NDOnTsdb5xXrVqlKVOmaO/evWrdurV69+6tXbt26fvvv9e+fftUt25ddejQQWlpaUpJSVH37t3Vp08fnThxQs8//7w++eSTEmeYMGGCEhMTlZSUpOPHj6tdu3bq0aOHBgwYoDFjxqhNmzY6ceKEJCkuLk47d+7Ud999p99//10BAQG6/fbbZYzRvffeq08++URpaWmSpBMnTujTTz/VPffco9OnT6tDhw5q0KCB9u/fr6+++korV67UuHHjHDm+/vprhYWF6cCBA1q6dKk++OADLViwoNSeawAAAIkygEvISy+9pEqVKik8PFzjx4/XRx99pKysLNWsWVM333yz/P39tXfvXn3xxReOowh2u11TpkxRTk6OPvvsMy1ZskR+fn564okn5OnpqRtuuEFxcXElzjBnzhw98cQTql+/vtzd3fX000/ro48+KjQ86PDhw5o/f75effVVhYWFyd/fXy+//LL++9//avPmzWrTpo2qV6+ujz76SJI0b9481a1bV9ddd52WLl2q7OxsTZo0ST4+PoqMjNSzzz6r119/3bF9u92uMWPGyNPTU82bN1fjxo3166+/ls4TDQAA8P88XB0AKFCrVi3H7erVqysrK0vHjh1T1apVHdMLhuHUrFnTMc3d3V3Vq1dXcnKy8vPzFRkZKZvN5ph/9dVX6/vvvy9RhoMHD6pGjRqO+15eXmrZsmWh5ZKTkyVJ119/vdN0Dw8P7d69W02bNtXQoUP17rvv6p577tHs2bM1dOhQx7qHDx9WcHCwYz1jjLKzs3X48GFJUlhYmNNj8PT0VH5+fokeAwAAQElxZACXjD/++MNxe/fu3fL19VXFihWd3hQXjPfftWuXY1peXp727NmjKlWqKDIyUnv27HF647x//37HbXd3d8fY/AJHjx513I6MjNTevXsd93NycvTII4/o4MGDTutERERIkn755RedOHHC8e+7775Tjx49JEmDBg3Sxo0btXLlSm3dutVxDkFERISuueYap/X279+vH3/8UZUqVbq4Jw0AAOBvoAzgkvHUU08pLS1NBw4c0DPPPKO7775bnp6eTstUqVJF3bp100MPPaRDhw4pIyNDTz75pPLy8hQTE6OYmBjl5+crPj5e2dnZ+u677/TWW2851q9Xr54OHTqkNWvWyBij9957T9u3b3fMHzJkiF544QX9+uuvys3N1aRJk7Rw4UJVrFhRPj4+SktLkzFGVatWVffu3TVy5EilpKQoJydHEydOVPPmzR3nFFSqVEkxMTEaOnSoevfu7TgS0KNHD508eVIvvPCCsrKydOLECd19993q16+fU/EBAAAoa5QBXDKuueYaNWjQQA0bNlSrVq300ksvFbnc3LlzVbNmTV133XWqXLmytm7dqtWrVyskJERBQUFKSkrSqlWrFBwcrHvuuUd9+vRxrNusWTM9/fTTGjRokEJCQrRq1Sqn+U888YTuuusude7cWaGhoVq3bp0+//xzeXp6KiYmRikpKQoMDNSJEyc0d+5cBQUFqUmTJqpYsaKWLl2qpKQkhYeHO7Z37733as+ePbrnnnsc0wICArRy5UqtWbNGERERqlmzptzc3PTpp5+WwbMKAABQPM4ZwCVj+PDheuGFF5ymFVzy82whISFOn/afq3Hjxvr666+LnT9+/HiNHz++yHkeHh4aN26c05V9CkRHR2vPnj1O0958881i9yNJnTp1KvK7CerVq6fPPvusyHUGDx6swYMHO01bu3btefcDAADwV3BkAABQ6vr376/atWurSZMmatKkiRYuXOjqSACAInBkAABQ6r799ltt3LhRISEhro4CADgPygBcLioqqsihNAAuT8eOHdORI0fUv39/HTx4UL1799YzzzxT6AT5rKwsZWVlOe4XfEmfdOa7NlypYP/kIAc5yHE55jDGKDMzs0TL2gzvwmBxO3fudPqOAwB/z88//6x//vOfev311xUQEKCePXsqNja20BcAxsfHKyEhodD6iYmJ8vX1La+4AHDFSU9PV2xsrFJTUxUQEHDeZSkDsLTXX39d8+fP15o1a1wd5aLFx8dr7dq1nFyMS94nn3yid999Vx9//LHT9KKODERGRioxMVEjRoxQRkZGeUd1sNvtmjlzpuLi4shBDnKQ47LLUXBkoCRlgGFCsLQjR44wRAkoZd9++60OHDignj17SjrzxYAeHoX/3Hh7e8vb27vIbWRkZLj0jzk5yEEOclwpOS6EqwmhzG3evFnt2rVThQoVVLVqVT3zzDMyxmjt2rWFxhCffVnN+Ph4derUSc2bN1dISIi+/PJLRUVF6f7771d4eLiuvfZa5efna/PmzWrfvr2Cg4NVq1YtvfTSS443+PHx8erTp48GDBigoKAgRUREaPTo0ZKkOXPmaNKkSVq3bp2CgoKKzJ6cnKwuXbooICBAdevW1UsvveTIvHbtWkVGRio2NlZBQUGaMmWKjDF69dVXVadOHQUFBalNmzb67rvvHNs7efKkRowYocjISIWFhenOO+/Un3/+6diXzWbTO++8o6ioKAUGBuqWW25x+gblc506dUr33nuvqlSpoooVK2rs2LF/6WcElKa8vDyNHDlSqampysnJ0YwZM3T77be7OhYAoAiUAZSpY8eO6ZZbblH79u119OhRrVu3TrNmzdK///3vEq2/atUqTZkyRXv37lXr1q0lSRs3btQvv/yiNWvW6NChQ7r55pvVp08fHT58WIsWLdL06dOdtv/xxx+rU6dOSklJ0b///W9NmTJFGzZs0KBBgzRmzBi1adPG8a3BZ8vLy1P37t1VtWpVHTx4UElJSXr33Xedltm/f7/q1aunI0eO6IEHHtD06dP1r3/9Sx999JGOHDmiIUOGqGPHjo43/HFxcdq5c6e+++47/f777woICNDtt9/udHRiyZIl2rJli3799Vf9+eefmjBhQrHPz+bNm9W2bVsdOHBAH330kZ577jmtX7++RM8tUFauv/56jRw5Ui1btlT9+vXVtGlT9e/f39WxAABFoAygTC1evFh2u13PPPOMvL29dfXVV2vlypXq3r17idavWbOmbr75Zvn7+zuGGfTp00dBQUEKCgrSe++9p3r16mn48OHy9PRU/fr19fjjj2vatGmObdSuXVt333233N3d1a1bN1WpUkW//vrrBfe9YcMG/frrr3rttdfk5+enGjVqaOLEiYWWi4uLk6enpypUqKDXX39dY8aMUaNGjeTp6am4uDjVq1dP7733ng4fPqz58+fr1VdfVVhYmPz9/fXyyy/rv//9rzZv3uzY3pNPPqmgoCBVrlxZMTEx580aHR2tAQMGyGazqX379goPD9euXbtK9NwCZenhhx/W9u3btXPnTk2ePNnVcQAAxeCcAZSpgwcPKjIy0mk4UJ06dSRJ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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwMAAAGgCAYAAAD2NbtKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB5XUlEQVR4nO3dd3xUVf7G8c+dSTKZJKRSAiSA9CKCUkSQJooogoqKiroiKrorgqKuCv4UsHd3LYtlLYtiAysovYhIUZGiAgISeoAkpJBMJlPO74/ISEhou8kMZJ63r7ycuffMnCeTGzLfueecaxljDCIiIiIiEnZsoQ4gIiIiIiKhoWJARERERCRMqRgQEREREQlTKgZERERERMKUigERERERkTClYkBEREREJEypGBARERERCVMqBkREREREwpSKAZEwEuxrDOqahice/UyC40R8nasqUzC/1xPxdRU52akYEDlB9OrVC8uyAl82m40aNWrQoUMHXnzxRXw+X5n2jRo1YujQocf8/F988QXXX399Jac+vEcffZRnnnkmaP2dzDIyMrAsi7fffhuAt99+G8uyyMjIqNR+/v3vf3P33XcH7ldVPyerXr160atXr//5eY712D/e3+HjeUxGRgYNGjRg7969QPmffWUJ5r8rh76us2fP5vTTT8fj8QSlf5HqSsWAyAnk9NNPZ8mSJSxZsoRFixYxefJkOnfuzB133MGQIUPKfCr26aef8n//93/H/NzPPfccW7durYrYFXrggQcoLCwMWn/VSf/+/VmyZAl169at1Od9+OGHyc7OrvJ+wt2xHvvH+zt8rIwxDBs2jDvuuINatWoB5X/2lSWY/64c+rqed955pKen88gjjwSlf5HqKiLUAUTkT/Hx8XTp0qXMtgEDBtC8eXNGjx7NwIEDueaaa4DSwkGqp1q1agXexFWHfqRiVfU7/Omnn7Jy5Uq++uqrKnn+E8kDDzxAjx49uPXWW1XUivyXdGZA5CQwcuRI6tWrx8SJEwPbDh0u8OGHH9KuXTucTie1atXi2muvZdeuXUDp8IeFCxeycOFCLMtiwYIFLFiwAMuyePXVV2nYsCF16tRh1qxZALzxxht07NiR2NhYnE4n7du356OPPiqTadOmTVxxxRUkJyeTlJTEhRdeyC+//AKAZVkAjB8/PnAb4IcffqBfv36kpKQQHx/PgAEDAo8BjpjpUAUFBdxyyy3Url2buLg4rrrqKl544YUy/QF8/vnndOzYkejoaFJTUxk1alSZTxfHjRtH06ZNmT59OqeddhoOh4PmzZvzzjvvlHmenJwcbrnlFurUqUN0dDRdunRh7ty5ZdpYlsX48ePp1KkTCQkJgU8sv/nmG84//3ySkpKIiorilFNOYdy4cfj9/gq/t4OH7xwYQnS4rwNWr17NoEGDqFWrFpGRkdSvX5+RI0ficrmA0uNly5YtvPPOO4HnrmiY0OzZs+nevTsJCQmkpKQwZMgQtm3bViZbREQEy5Yt46yzziI6OpoGDRrw1FNPVfi9HFBcXMxtt91GWloaDoeDli1b8uyzz5Zpc7Tv4cBrPHHiRIYOHUpCQgLJycmBNvfccw+1atUiJSWFm266ieLi4jKPe+mll7j++uuJi4ujTp065Z77UH6/nyeeeIKmTZsGjosXX3zxiN9nRcf+gWNswoQJpKSk0KRJE7Kzs8v9DmdkZPCXv/yFevXqERkZSe3atfnLX/5y3J/oP/7441x22WVER0cDFf/sAbZu3crVV19NcnIyMTEx9OnTh59++qnMcx3vvysVycrK4tprryU1NZXo6Gjat2/PpEmTyrQ5WpbD/ZvSuXNnGjRowPPPP39cr5GIHMSIyAmhZ8+epmfPnofdf91115nIyEjj8XiMMcY0bNjQXH/99cYYY7799ltjt9vN+PHjzfz5882kSZNMampq4Pl++eUXc/rpp5vTTz/dLFmyxOTl5Zn58+cbwCQnJ5uPP/7YTJo0yeTn55uXXnrJ2Gw2M2HCBDN//nwzZcoU06lTJxMREWG2bNlijDFm586dJjk52bRp08a8//77Zvr06ebMM880derUMXv37jVLliwxgLnxxhvNkiVLjDHGzJs3z0RGRppzzz3XfPbZZ+bDDz807dq1M/Hx8Wbt2rXGGHPYTBU555xzTGJionnllVfMtGnTzIUXXmgcDoc5+J+19957zwDmmmuuMV9//bX517/+ZZKSkkyfPn2M3+83xhjz0EMPmZiYGNOoUSPzxhtvmNmzZ5u+ffsaIJDL5XKZdu3amTp16pjXX3/dTJ8+3Vx22WUmIiLCzJ07N9AfYCIiIswTTzxhpk+fblavXm1WrlxpIiIizNVXX21mzpxpZsyYYa655hoDmPfee88YY8zmzZsNYN566y1jjDFvvfWWAczmzZtNcXGxWbJkSZmvV1991ViWZW666abAzyM+Pt707dvXTJs2zcyePdvccccdBjCPPvqoMcaYFStWmNTUVHPhhReaJUuWmOLi4jL9GGPMpEmTDGCuvPJKM336dPPOO++YRo0amfr165vdu3cHslmWZRo0aGBeeOEFM3fuXDNkyBADmBkzZhz2+B0+fLhp1KiRef/99838+fPN3//+9zLf87F8Dwde4/j4eHPLLbeYuXPnmlGjRhnAtGjRwgwePNjMmDHDjBkzxgDmqaeeKvO4xMRE069fPzN9+nTzzDPPmOjoaDNo0KBAm0N/B4cPH24iIyPNQw89ZGbOnGnGjBkT+N04nIqO/YceeshERESYdu3amVmzZpnJkycbY8r+DhcWFpqGDRuajh07mk8++cTMmzfPTJgwwdjtdnPzzTcHnv/gx1Rk3bp1BjAzZ84MbKvoZ793715Tv35906xZM/Pee++Zzz77zPTq1cvExcWZX3/91Rjz3/27UpG+ffua9u3bm08//dTMnTvXDB061ABm/vz5xhhzTFkqel0PGDt2rKlbt+5hXxMROTIVAyIniKMVA/fcc48BTGZmpjGm7JuCxx9/3MTFxRmXyxVo/9VXX5lx48YF3vQe+vwH3niPHTu2TD+jR482f//738ts+/HHHw0QeBNz9913G6fTaXbt2hVos3PnTtOgQQPzxRdfGGNK33w99NBDgf2dO3c2LVu2NF6vN7Bt3759JiUlxQwePPiImQ41d+5cA5ipU6cGtvl8PtO6detAMeD3+01aWprp169fmcfOmTPHAGbatGnGmNI3aoCZM2dOoM2WLVsMYJ555hljjDGvvfaaAczSpUsDbfx+v+nRo4fp2LFjYBtgunXrVqa///znP+aCCy4wPp+vTNaEhAQzfPhwY8yRi4FD7dmzxzRs2NCcffbZxu12G2OMmTlzpunRo0e5N2Nt27Y1ffv2Ddw/9I3kwf34fD6Tmppqzj333DLPsXHjRhMVFRU4Jg485o033gi0KS4uNtHR0WbEiBHl8h7QokWLQPFywIQJE8yXX355XN8DYM4888zAfY/HY2JjY80pp5wSKJSNMebUU081F198cZnHNWvWrEyb559/3gDm559/NsaU/R1Zv369sSzLPPHEE2XyPPDAAyY6OtpkZWUd9ns99Ng/cIzNnj27TLuDfx4//fSTOfvss83GjRvLtBkwYIBp3rx5hY+pyCuvvGIAs2/fvsP2ZYwxY8aMMdHR0SYjIyOwze12m8aNG5vLL7/cGPPf/btSEYfDYR555JHAfZ/PZ+666y6zaNGiY85iTPnX9YDPPvvMAIHCQUSOj+YMiJxkDh0GA9CzZ0/Gjh1L27ZtGTx4MBdeeCF9+/blggsuOOrztW3btsz9A0M38vLy2LBhA7/99ltgOExJSQkAixYt4qyzziI1NTXwuLp167Jly5YK+ygsLOT777/nwQcfxG63B7YnJiZy0UUXlRvbfGimQ82bN4/IyEguueSSwDabzcbgwYMZN24cAOvXr2f79u2MGTMGr9cbaNezZ0/i4+OZPXs2/fv3D2w/66yzArfT0tICuQHmzp1LamoqHTp0KPNcAwYM4J577mHfvn0kJSVVmP26667juuuuo7i4mE2bNrFhwwZWrFiB1+sNvJ7HqqSkhEGDBuH3+5k6dSpRUVEA9O3bl759++LxePjtt9/47bffWL16NXv27CElJeWYnnv9+vVkZmby+OOPl9nepEkTzjrrLObPn19m+8Gvl8PhoFatWkecNNu7d28mTpzIjh07GDBgABdeeGGZybPH8z107do1cDsiIoKaNWvSsWNHIiL+/JOWkpJCbm5umcddffXVZdpcdtll3HnnnSxatIg2bdqUaTtv3jyMMQwYMKDMz3zgwIE88sgjLFq0qMzxdyyOdFy3b9+eRYsW4ff7+f3339mwYQM///wza9euLdP/0fz+++8kJiaSmJh4xHZz586lffv21K9fP/D8NpuNCy64gHfffRf43/5dOVjv3r156KGHWLVqFRdeeCEXXHBBmVWBjiXLkTRq1AiAzZs306pVq+PKJiKaMyBy0tixYwdOp7PCN3dnnXUWX331FY0bN+aZZ57h7LPPJi0tjX/84x9Hfd46deqUub9p0ybOPfdckpKS6NatG08++WTgTav5YzWj7OxsateufczZc3NzMcaUKR4OSE1NLfem7dBMh9q7dy8pKSnYbGX/CTv4+Q+Ms/7b3/5GZGRkma/8/Hx27txZ5rExMTGB2wee98CY/uzsbDIzM8s9zz333AMQGENdUXaXy8VNN91EQkICbdu25a677mLz5s1ERkYe95rpt912GytWrODzzz8v8/r7/X7uu+8+kpOTadGiBX/7299YsWIFTqfzmPvIyckBOOaf0cGvF5S+ZoebAwHwwgsv8Mgjj7B582b+9re/0ahRI7p27RoYF34830N8fHy55z80T0Xq1atX5v6B13Dfvn3l2h44ftq0aVPmZ965c2eAcsfPsTjacf3cc89Rp04dmjRpwvXXX8+8efOIjY09ruMkLy+P2NjYo7bLzs5m6dKl5Y7pl19+mby8PIqKiv6nf1cO9sEHH3DXXXexfPlybrjhBurVq0e/fv3YvHnzMWc5kgPfb15e3nHlEpFSOjMgchLw+XwsWLCAbt26lflk/WDnn38+559/PkVFRcybN49//OMf3HHHHXTp0oUzzzzzmPrx+/3079+fqKgoli1bxumnn05ERAS//vprmU/oEhMTA+uXH2zevHk0atSIxo0bl9memJiIZVlkZmaWe8yuXbuoWbPmMeU7IC0tjaysLPx+f5mCYM+ePWX6BHj66acrXDv+wCf5xyIxMZFmzZoxefLkCvefcsoph33sqFGjmDJlCh9++CHnnXde4I3L8RRTAP/4xz944403+OCDD8qtQvPEE0/w3HPPMXHiRC677DISEhIAAm9cj0VycjJApf2MDuVwOBg7dixjx45l69atfPnllzz88MMMGTKEtWvXVsr3cDSHTsTdvXs3UPHP4sDxM2/ePGrUqFFuf4MGDSotF8DkyZO56667eOKJJxg2bFhglafBgwezfPnyY36emjVrlivcKpKYmEjPnj0Pez0Eh8MBVM6/KwkJCTz55JM8+eSTrF+/ns8//5wJEybwt7/9ja+//vqYsxzOgWLufz1GRcKVzgyInAQmTpzIzp07+etf/1rh/rvvvpvOnTtjjCEmJoaLLroo8If1wEowhysiDpaVlcX69eu58cYb6dSpU2BIxddffw38+Ul59+7dWbJkSZk331lZWVxwwQV88cUXAGXepMfGxtKxY0c+/PDDMhdPy8vLY9q0aZx99tnH/FpA6fAFr9fLl19+WWb7p59+GrjdsmVLateuzebNm+nYsWPgKy0tjfvuu6/cqilH62/btm3Url27zHPNmTOHp556qszQk0N9++239O7dm0suuSRQCPz444/s3bv3iJ+kH2z27NncddddjBkzhiuvvLLCPtq0acOwYcMCb6J37NjBmjVryvRxpGOgRYsWpKam8t5775XZ/vvvv7NkyZLj/hkdzOVy0bx588AQtAYNGnDbbbdx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oUEH316wYAGWZTFv3jx69+6N0+mkQYMGvPHGG+zatYtBgwYRFxdHeno6L7zwQqDPA49bsGBBmSy9evWiV69eFebMyMjAsizefvvtMtuHDh1Ko0aNAvd///13Lr74YlJSUoiJieGss87i66+//h9eIZEjUzEgIiIiJ6X8/Hz69etHzZo1mTJlCh988AGFhYWcf/753HDDDdx4441A6dCgm2666bDPc9VVVzFgwAC+/PJLmjdvzq233krv3r1p27YtU6dOpUOHDtx5550sX768Sr8fv9/PRRddxP79+5k0aRKff/45KSkpDBw4kI0bN1Zp3xK+NExIRERETkq//vore/fuZeTIkYGJwi1btuTVV1/FZrMF5gYcbWjQsGHDGD16NABxcXGcddZZdO7cOXBmoWPHjnz++ed89913dO7cucq+nz179rB27VrGjh3LhRdeCBDIUVxcXGX9SnhTMSAiIiInpVNPPZVatWoxYMAArrzySi688EL69OnDU089dVzP07Vr18Dt1NRUoGwBkZKSAkBubu7/HvoI6tSpQ+vWrbn55puZPXs2F1xwAeeffz7PPfdclfYr4U3DhEREROSkFBcXx6JFi+jfvz8ffPABAwcOpFatWtxyyy3H9Ul6fHx8uW0xMTGVGfWYWJbF7NmzGTp0KDNmzOCqq66idu3aXHnlleTk5AQ9j4QHnRkQERGRk1aLFi2YNGkSPp+P5cuXM2nSJP71r3/RuHHjKuvTsiwAfD5fme379+8nLi7uuB9zsHr16vHKK6/w8ssvs2rVKqZMmcITTzxBcnIy//rXvyrrWxAJ0JkBEREROSlNmTKFWrVqkZmZid1u56yzzuKVV14hMTGRbdu2Ybfbq6TfA2cStm3bFti2b98+fv311+N6jMfjKTMpecmSJdSpU4fvv/8ey7Jo3749jzzyCG3bti3zOJHKpDMDIiIiclLq1q0bPp+PSy65hPvuu4/4+Hg+/PBD8vLyuOyyy/j5558BeP/99+nSpQunnHJKpfR72mmnkZ6ezvjx40lISMBut/P4448TGxt72MckJSXRtWtXXnzxRZo1a0bNmjX55z//icvlCjzu9NNPJyYmhuuuu45x48aRmprKnDlzWLlyJaNGjaqU7CKH0pkBEREROSnVrVuXmTNnkpCQwI033kj//v1ZsWIFU6dOpXfv3lx22WV06tSJ66+/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1NYyehcmclgbNmwoc/0DETm6X3/9lf/7v//j5ZdfJj4+noEDBzJkyJByFwAcN24c48ePL/f4yZMnExMTE6y4IiLVTlFREUOGDCEvL4/4+PgjtlUxIHIYL7/8MlOmTGH+/PlV1odlWcyfP59evXpVWR8iofbZZ5/xn//8h08++aTM9orODKSnpzN58mRGjBiBy+UKdtQAp9PJm2++ybBhw5RDOZRDOU66HAfODBxLMaBhQiKHsXfvXg1fEvkv/PDDD+zcuZOBAwcCpRcGjIgo/+fG4XDgcDgqfA6XyxXSP+bKoRzKoRzVJcfRaDUhCakVK1bQq1cvatSoQb169XjwwQcxxrBgwYJy44sPXnJz3Lhx9O3bl06dOpGcnMw333xDo0aNuPXWW0lNTeX000/H7/ezYsUKevfuTVJSEs2aNeP5558PvMEfN24cl19+Oddeey2JiYmkpaVx//33A/DOO+/w2GOPsWjRIhITEyvMblkWI0eOpGbNmgwYMACAOXPm0LlzZxITE2nTpg3vvfdeoL3H42H06NHUrFmTWrVqlVtG9VC7d+/m2muvJTU1lXr16nHrrbdSEIIrE4ocL5/Px6hRo8jLy8Pj8TBx4kQuvfTSUMeSILMTQbQVgw17qKOIyBGoGJCQycnJ4bzzzqN3795kZWWxaNEi3nrrLV577bVjevzcuXN58skn2bp1K127dgVg2bJlrFu3jvnz55OZmck555zD5Zdfzp49e/j888955ZVXyjz/J598Qt++fcnOzua1117jySefZOnSpVx//fWMGTOG7t27B64oXJFNmzaxdetWJk2axKpVqxg4cCD33Xcf2dnZvP7669xxxx3MnDkTgIcffphp06axfPlyMjIyWLNmzWGf1+/3c/HFF2Oz2diwYQNr1qxhx44dDB8+/JheG5FQOvPMMxk1ahRdunShdevWdOjQgauvvjrUsSTI2sV05c7UZ2jqODXUUUTkCFQMSMh8+eWXOJ1OHnzwQRwOB02aNGHOnDn079//mB7fuHFjzjnnHOLi4gJDEC6//HISExNJTEzk3XffpVWrVtx2221ERkbSunVr7rnnHl566aXAczRv3py//OUv2O12LrzwQurWrctvv/12zN/DkCFDiImJITExkVdffZWLL76YQYMGYbfb6dq1KzfffHOgv0mTJnHPPffQuHFjYmNj+ec//1nu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OY6ZEREROQFs377dNGjQwGRlZZn9+/eb0047zaxevTroOZYuXWratWtnIiMjzebNm4PevzHGLFu2zJx66qlm//79xu/3m2uvvdY899xzQc8xffp00717d+PxeExhYaFp1KiRWbduXdBzHDBnzhxTs2ZNc/3114csgzHGNG3a1GRnZ4es/02bNpl69eqZbdu2GY/HY7p3726mTZsWsjwHrF+/3jRq1Mhs37496H0XFRWZ5ORks3v3buPxeEznzp3N7Nmzg55jzpw5pk2bNiY3N9d4vV5z0UUXmalTpwY9x/HQmQERETkhzJkzhz59+pCSkkJsbCyXX345U6ZMCXqOiRMn8uKLL1KvXr2g931AUlISL730ErGxsViWRbt27di6dWvQc1x44YXMnTuXiIgI9u7di8/nIzY2Nug5AHJychg7dixjxowJSf8H59i7dy9XX301p512GuPHj8cEeZX2Tz/9lCuvvJK0tDQiIiL44IMP6NKlS1AzVOS2225j/Pjx1K9fP+h9e71evF4vLpcrcNvpdAY9x4oVK7jgggtISEjAbrdzwQUX8Pnnnwc9x/FQMSAiIieEnTt3lnkDXrduXXbt2hX0HG+99Rbdu3cPer8Ha9asGT179gRgz549vPTSSwwcODAkWSIjI3nggQdo1aoV55xzTkje6AHccsstPProoyQlJYWk/wMyMzPp06cP77zzDkuXLmXRokW89dZbQc2wceNG/H4/l1xyCe3ateOVV14hOTk5qBkOtXDhQnbv3h2yIUI1atTgkUceoWXLltSvX5+GDRvStWvXoOc444wzmDlzJjk5ORQXF/PFF1+E5N+x46FiQERETgh+vx/LsgL3jTHYbOH9ZyojI4PevXtz880307t375DleOSRR8jKymL79u28/vrrQe//jTfeID09nT59+gS970O1bt2aqVOnkpqaSkxMDCNGjGDatGlBzeD1epkxYwavvfYaS5cuZdmyZbzzzjtBzXCof/3rX4wePbrM73AwrVmzhrfeeostW7awc+dOLMvimWeeCXqOPn36MHToUHr16kW/fv04++yziYqKCnqO4xHe/8qKiMgJIy0trcwnaJmZmSEdqhNqK1eupFu3btx6662MHTs2JBl++eUX1qxZA0BMTAyXXnopq1evDnqODz/8kFmzZtG+fXsefPBBvvjiC0aOHBn0HAA//PADX3zxReC+z+cjIiIiqBlSU1Pp06cPtWvXxul0cumll7J8+fKgZjhYSUkJc+fO5bLLLgtZhhkzZtC7d29q166Nw+HghhtuYMGCBUHPUVBQwKBBg1i9ejULFiwgMjKSxo0bBz3H8VAxICIiJ4Rzzz2XOXPmsGfPHgoLC/n444/p169fqGOFxN69e+nXrx8vvvgit99+e8hyrF27lltvvZWSkhLcbjeffPIJPXr0CHqO2bNn8/PPP7Ny5UomTJjAwIED+ec//xn0HFD65n/UqFHk5eXh8XiYOHEil156aVAzXHTRRcyaNYt9+/bh8/mYOXMmZ5xxRlAzHGzNmjU0a9aMGjVqhCxDu3btmDlzJvn5+Rhj+PLLL+nQoUPQc2RkZDBw4EA8Hg/79u3j3//+N4MHDw56juMR3FJWRETkMOrXr89jjz1G79698Xg83HTTTXTu3DnUsULihRdeID8/nwkTJjBhwgQA+vfvH/RlCi+//HJWrFhB+/btsdvtDB48+IR/Y1PVzjzzTEaNGkWXLl3wer1cdtllXH311UHPcP/999O9e3c8Hg99+vThhhtuCGqGg23atIkGDRqErH+Avn37ct1119GxY0ccDgcdO3bkvvvuC3qOtm3bcvXVV9OuXTu8Xi+jR4/m7LPPDnqO42GZYE+BFxERERGRE4KGCYmIiIiIhCkVAyIiIiIiYUrFgIiIiIhImFIxICIiIiISplQMiIiIiIiEKRUDIiIiIiJhSsWAiIiIiEiYUjEgIiIiIhKmVAyIiIiIiIQpFQMiIiIiImHq/wFEvW9xP5dIygAAAABJRU5ErkJggg==",
      "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('Distractor generalization 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('Distractor generalization 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
}
