{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2a1c8a85",
   "metadata": {},
   "source": [
    "# Demo: Dataset with NLP and image pixel representations\n",
    "\n",
    "Note, that that this demo reproduces task inputs and targets that are converted to  image pixels and natural language inputs. We did not evaluate any models using this dataset format in the paper.\n",
    "\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",
    "#### Pixel Word dataloader\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": "27665b8e",
   "metadata": {},
   "source": [
    "# Distractor generalization split (Fig. 3)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 3,
   "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": 11,
   "id": "6ff4276b",
   "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",
    "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:', len(rule_inputs)) # batch_size x string\n",
    "print('Size of stim inputs:', stim_inputs.shape) # batch_size x width pixel x height pixel x rgb 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"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bb1a72b3",
   "metadata": {},
   "source": [
    "#### Visualize example trials from train and test datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "358ba17b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: loc of current white g ?\n",
      "Target output: (4, 3)\n",
      "Instruction: loc of current brown c ?\n",
      "Target output: (4, 3)\n"
     ]
    },
    {
     "data": {
      "image/png": "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tuyqboMk06xZM+f1jIwM4+vra6pWreosysYYc8stt5iePXu6zFejRg2Xaf7v//7PSDLfffedMcb1NbJnzx5js9nM5MmTXfI8//zzxtvb25w4cSLf23rpcz/nObZmzRqX6S5+PL755htz++23m19++cVlmh49epiaNWvmOU9eZsyYYSSZ06dP57suY/54HP/973+7TBcVFWX+7//+z2XY4sWLjSTz5ZdfutyeHG3btjU+Pj4uj93bb79tJJmvvvrqT8/TunVrU79+fef/MGOMWbBgQa771xhjzpw5YySZGTNm5HvfAMgfxwwAN5C8zsjRtm1bjRkzRvXq1VNkZKTuuusuderUSV27dr3i8urVq+dyPWfXjcTERP3888/66aefnLvDpKenS5I2btyoFi1aqGLFis75KlWqpP379+e5jvPnz+u///2v/vGPf8jT09M53N/fX927d8+1b/OlmS4VHx+vEiVKqFevXs5hHh4eioyMdO4+sGfPHv32228aPXq0MjMzndO1bdtWfn5+WrNmjbp16+Yc3qJFC+flnH2bc3YnWrdunSpWrKjGjRu7LKtHjx56+umndfr0aQUEBOSZfeDAgRo4cKBSU1O1d+9e/fzzz9q+fbsyMzOd92dBpaenq0+fPsrOztbixYtVsmRJSVKnTp3UqVMnZWRk6KefftJPP/2knTt36tixYwoKCirQsvfs2aOjR4/m2tWievXqatGihdavX+8y/OL7y263q1y5cpc9aLZ9+/aaOXOmDh06pB49euiuu+5yOXj2am5Dy5YtnZe9vLxUtmxZNWnSRF5ef7ydBQUF6cyZMy7zDRgwwGWavn37avjw4dq4caPCw8Ndpo2Pj5cxRj169HB5zCMiIjR+/Hht3LjR5flXEJd7Xjds2FAbN25Udna2fv31V/3888/67rvvtHv3bpf1X8mvv/4qf39/+fv7/6lM8+fPlySdOHFCP//8s/bs2aOPP/5Yki77fA0PD5efn5/z+qWvoaudJy0tTV9++aVeeOEFl/95d999twYOHJhrWWXKlJG/vz9nFQL+JI4ZAG4Ahw4dksPhyPPDXYsWLfTJJ5+oWrVqeuWVV3T77bcrODhYr7322hWXW6FCBZfre/fuVceOHRUQEKBWrVrppZdecn4IMP87W8fJkydVvnz5Amc/c+aMjDEu5SFHxYoVc31ouzTTpY4fP66goCB5eLj++7p4+Tn7Wf/tb39TiRIlXP6SkpJ0+PBhl3l9fHycl3OWm7NP/8mTJ3X06NFcy3n66aclyXlsRl7ZU1JSNHjwYJUpU0b16tXTU089pX379qlEiRJXffaTxx9/XNu3b9fSpUtd7v/s7Gw999xzCgwMVK1atfS3v/1N27dvl8PhKPA6Tp06JUkFfowuvr+kC/dZfsdASNLUqVM1fvx47du3T3/7298UFhamli1b6ptvvrnq23DxB8j88uSlcuXKLtdz7sPTp0/nmjbn+RMeHu7ymDdt2lSScj1/CuJKz+spU6aoQoUKql69ugYNGqT4+Hj5+vpe1fMkMTFRvr6+fzrTV199paZNm6pcuXLq0KGD3njjDefr4XI58no+SLrsc+Jy85w6dUpZWVm5/s/klL+8+Pr6KjExMd/1AcgfWwaA61xWVpY2bNigVq1auXyzfrHOnTurc+fOSk5OVnx8vF577TU9+eSTat68uZo1a1ag9WRnZ6tbt24qWbKktm7dqltvvVVeXl764Ycf9O677zqn8/f3d56//GLx8fEKCwtTtWrVXIb7+/vLZrPp6NGjueY5cuRIvm/u+QkODtaJEyeUnZ3tUgiOHTvmsk5J+uc//5nnueNzvskvCH9/f9WoUUNxcXF5jq9atWq+8w4bNkyLFi3SwoULdeeddzo/qF1NmZKk1157TbNnz9Z7772X6yw0kydP1pQpUzRz5kz17dtXZcqUkSTnB9eCCAwMlKRCe4wuZbfbNWbMGI0ZM0YHDhzQsmXL9OKLLyoqKkq7d+8ulNtwJZceiPv7779LyvuxyHn+xMfHq3Tp0rnGh4aGFlouSYqLi9NTTz2lyZMnKyYmxnmWp8jISG3btq3Ayylbtmyu4lZQSUlJ6tKli+rXr6/vvvtOderUkYeHhz755BMtXrz4Ty3zzypfvrxKlizp8pqWLvyPOnHiRJ7znD59+i8/TwGrYssAcJ2bOXOmDh8+rMceeyzP8SNHjlTTpk1ljJGPj4+6d+/u/NGjnDPB5FciLnbixAnt2bNHDz74oG677TbnLhWffvqppD++5WvdurU2b97s8kZ94sQJde3a1blLwcUf0n19fdWkSRMtXLjQ5cfTEhMTtXz5ct1+++0Fvi+kC7v6ZGZmatmyZS7DlyxZ4rxcu3ZtlS9fXvv27VOTJk2cf8HBwXruueec30gXdH0HDx5U+fLlXZa1du1avfzyyy67nlxq06ZNat++vXr16uUsAl9//bWOHz9+2W9NL7ZmzRo99dRTGj16tPr165fnOsLDwxUTE+P8EH3o0CHt2rXLZR2Xew7UqlVLFStWdO4mkuPXX3/V5s2br/oxulhKSopq1qzp3AUtNDRUjz/+uAYMGOB8fhb0NvwVOc/NHIsWLZLNZlP79u1zTdu2bVtJF57XFz/mJ0+e1PPPP3/ZM/xcusWqIDZt2qQyZcro2WefdRaBc+fOadOmTVd1+6tUqaLz58/n2tpRkNf/jz/+qJMnT2rYsGEKDw933o5LX/9FwdPTU61atXJ5TUsXHsO8dps6deqUkpOTVaVKlaKKCBQrbBkArhNJSUnasmWLpD++AVu1apVmzZql++67T3369Mlzvo4dO2rKlCmKjo7Wfffdp/T0dL388ssKDAzUHXfcIenCN52bN29WfHx8vuc3L1++vMLCwjR9+nQFBwcrICBAq1at0tSpUyX9sf/v8OHD9fbbb6tz584aM2aMvL29NXHiRFWqVEn333+/c31ffvmlPv/8c7Vu3VqTJk1S586d1aVLFz3xxBNKT0/XpEmTlJaWphdeeOGq7qc2bdrozjvvVExMjCZOnKgqVarorbfe0o4dO5z7F3t6emrChAl65JFH5OnpqR49eujMmTN68cUX9dtvv6lx48YFXt8DDzyg6dOn684779To0aMVGhqqNWvW6KWXXtITTzyhEiVK5Dtv06ZN9f7772vmzJmqU6eOduzYofHjx8tmsxXoh6n27t2rfv366bbbbtPdd9+trVu3uuyuUbduXTVt2lQvvviiJk+erBYtWuiXX37RxIkTlZaW5rIOf39/ffPNN/rss89yfePu4eGhSZMm6YEHHlD//v01aNAgnThxQmPHjlVgYKBGjBhR4PvrUg6HQ40bN1ZsbKxKliyp+vXra8+ePZo3b57uvvtu5/1UkNvwV2zbtk333XefBg4cqJ07d+of//iHHn744VxbsiTplltu0X333aeHHnpICQkJatKkifbs2aPRo0eratWqqlmzZr7rufS5XxBNmzbVm2++qaeeeko9evTQ4cOH9c9//lNHjx69qq1YnTp1kiR98cUX6t69u0um/B77HLVq1ZKfn58mTJggLy8vlShRQosWLdJbb70l6fL7/18LsbGxateune65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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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CD93nrEqi19//RWBgYF46aWXbIVAfn4+fv3113t6/TVq1EBBQUGRsx13vvfdunXD6dOnUa9ePbvX9+2332LhwoWQy+UO+b1y6dIlREVFYeXKlQCsn7MXX3wRvXv3tj1HWbIAJe/XwuepUaNGmfcTEf2NxQBROZKbm4ukpCQkJSXh999/x7p16zBx4kRMmTIFY8eOxbBhw4pdr1evXjh48CBiY2Oxbds2bNy4EZMnT0ZISAgeeOABANZvAs+cOYMdO3YU2y0CsH5DGh0djfnz52PVqlXYsWMHXnrpJUyfPh3A333on3vuOXh7e6Nv375YuXIlNmzYgMGDB6Nq1ar473//a9ve77//jl9++QVCCLz11ls4e/Ys+vXrh3Xr1mHlypV44IEHoNfrMXPmzHvaT127dkXv3r0RFxeHL774Aps3b8aIESNw9OhR2zUVcrkcc+bMwYIFCzB58mRs27YNP/74I/r06YNDhw6hVatWZd7eo48+iho1aqB3795YunQpdu7cienTp2PGjBm2YSBL0rZtW2zZsgULFizA7t278fHHH6N///6QJKlMN6Y6f/48HnnkEbRp0wYPP/ww9u3bZ/uMJCUlITc3F23btsWxY8cwd+5c7N69G19//TW6du0KvV5vt42goCAcPnwYu3fvLjKkpkwmw1tvvYXt27dj1KhR2LRpE5YtW4bevXsjJCQEU6dOLfP+upNarUarVq0QHx+PTz75BLt378aXX36JJUuW4OGHH7btp7K8hn9j//79GDt2LLZs2YJ3330XM2bMwIQJE4qcyQKAJk2aYOzYsXjiiSfw7rvvYufOnViwYAFGjx6NtLQ01KtXr8Tt3PnZL4u2bdsiJycHzz//PHbt2oWEhAR06dIFKSkp9/T6+/TpAwD47bffimS6/b2fOnUqLBYLevXqhR9++AGJiYmYMGECPvroIzRo0ACAY36v1KhRA5GRkZg8eTIWLVqE3bt34/3338fPP/9se+/LkqW0/frrr7+iZs2apb4nRFQK91y3TER36tatmwBg+5HJZCI8PFx0795dfPvtt7bROwrdOTpIQkKCaNmypfDz8xP+/v6if//+4tixY7blO3bsENWrVxdeXl5i+fLltpF7Cof3K3TkyBHRrVs34efnJ0JDQ0WXLl3E5s2bRYMGDcSIESNs7f78808xaNAg4efnJ0JCQsSwYcPE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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('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
}
