{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "be9f019c-3c74-4fe5-ae8a-b96e796321b4",
   "metadata": {},
   "source": [
    "# Demo of the underlying task framework\n",
    "\n",
    "Note, this is not for producing training/test data, but rather to understand the underlying mechanics of task (and to visualize the task)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4896be9a-39f4-4a1d-a2d2-7589db43f86a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from importlib import reload\n",
    "import gcog.task.stim_generator as stim\n",
    "import gcog.task.task_generator as taskgen\n",
    "import gcog.task.config as config\n",
    "import networkx as nx\n",
    "from networkx.drawing.nx_agraph import graphviz_layout\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\") # runtime warning from graphviz\n",
    "%matplotlib inline\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ea7b66a",
   "metadata": {},
   "source": [
    "# Print the list of operators included in the task\n",
    "\n",
    "Note, global properties of tasks are included in `gcog.task.config.py`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "945f3c03",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All task operations: ['exist', 'go', 'getcolor', 'getshape', 'sumeven', 'producteven', 'productodd', 'sumodd']\n",
      "All colors: ['red', 'green', 'blue', 'yellow', 'purple', 'orange', 'white', 'pink', 'cyan', 'brown']\n",
      "All shapes: ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']\n"
     ]
    }
   ],
   "source": [
    "print('All task operations:', config.ALL_TASK_OPS)\n",
    "print('All colors:', config.ALL_COLORS)\n",
    "print('All shapes:', config.ALL_SHAPES)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "be0b41f4-412f-4991-b373-8207c89a6e6a",
   "metadata": {},
   "source": [
    "# 1. A single operator (controlled by min_depth parameter)\n",
    "* The way to implement this task is by traversing the task graph (or tree) from top-to-bottom.\n",
    "* The if-then clause is interpreted as: If the statement above the if-then clause is true, then traverse down the left-hand side. If it's false, traverse down the right-hand side."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4903598b-10c0-4343-a8f7-9d5fc291682f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "whens = config.ALL_TIME\n",
    "task_graph = taskgen.TaskGraph(whens=whens,\n",
    "                               starting_operators=['exist'],# config.STARTING_OPS,\n",
    "                               ending_operators=config.ENDING_OPS,\n",
    "                               min_depth=1)\n",
    "plt.figure(figsize=(2,2))\n",
    "task_graph.plot_graph()\n",
    "plt.tight_layout()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fbd6de5e-55de-49d6-a6c8-fa2e2fb91c3e",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2de747a5-62ea-4fdc-86e7-eefd39e7c9bb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: current green k exist ?\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 1 # This is a variable that changes the number of 'distractor objects' in the image\n",
    "\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2f501811-7637-4976-9cac-e9dc6edefa6f",
   "metadata": {
    "tags": []
   },
   "source": [
    "## Generate an image that satifies this task graph, but add more distractors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b5b52c1e-7d7c-41fa-b660-c76b203bbf2f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: current green k exist ?\n",
      "Target output: False\n"
     ]
    },
    {
     "data": {
      "image/png": "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WCYAnD9/HmlpaXj33XexY8cObN26Ffn5+YpkFxUVweFw4L777kNycjLefPNNhIaGKpLd6JtvvkFZWZliUwKBgYF46aWXcMsttyAqKgq9evXCiBEjFMkeOHAgNmzYgMrKStTX12PdunWKdoqzhJerw+GAJElNj2VZvurFDjxNcXExUlNT8dhjjyE1NVWx3JdeegkXL15ESUkJ3n77bUUy33nnHcTExCAtLU2RvMvFx8dj1apViIiIgF6vR2ZmJj7//HNFsm02G9avX4+///3v2LFjB3bu3Il3331XkexGS5cuxbx585r9XxPp4MGDyM/Px88//4zS0lJIkoS//e1vimSnpaVh5syZuP322zFu3DiMGjUKvr6+imS3h/CWi46ObvZT5fz584r/iu4qhYWFGDlyJGbPno2FCxcqkvnjjz/i4MGDAAC9Xo9JkybhwIEDimR//PHH2LhxI1JSUvDnP/8Z69atw1NPPaVI9u7du7Fu3bqmx3a7HRqNItclQkREBNLS0tC9e3fodDpMmjQJu3btUiQbACwWCzZv3oz7779fscz169cjNTUV3bt3h1arxaxZs7BlyxZFsmtqajB58mQcOHAAW7ZsgY+PD3r37q1IdruIntQtKSmRe/XqJZeVlcm1tbVyYmKivHPnTtGxLfTq1UvRN7QuXLggh4eHKz7R/s9//lMeMWKEbDab5fr6evmOO+6QP/74Y0XHIMuynJ+fr+gbWjt27JBjY2Plqqoq2WKxyGPHjpULCgoUy7755pvlyspK2WazyRMnTpTffvttRbJlWZZ3794tDx8+XLE8WZblDRs2yAkJCXJ1dbXscDjkxx9/XH7++ecVyT5w4ICcmJgoWywWubKyUo6Li5O3bt2qSHZ7CP/RHhUVhZdffhmpqamwWq149NFHMWTIENGxLvfaa6/BYDDgxRdfxIsvvggAmDBhgvDDRh544AHs3bsXKSkpUKvVmDJlCqZMmSI0szMYOnQo5syZg2HDhsFms+H+++/HtGnTFMvOysrC6NGjYbVakZaWhlmzZimSDQAnTpxAz549FcsDgDvvvBMzZszAoEGDoNVqMWjQICxYsECR7MTEREybNg3Jycmw2WyYN28eRo0apUh2e/DaAkREAnjPO0tERApiuRIRCcByJSISgOVKRCQAy5WISACWKxGRACxXIiIBWK5ERAKwXImIBGC5EhEJwHIlIhLg/wPYhFVrWEt25AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 20\n",
    "\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e5a53758-f4d7-4952-86be-bb044fcb5f2e",
   "metadata": {
    "tags": []
   },
   "source": [
    "# 2. 1 if-then clauses (controlled by min_depth parameter)\n",
    "* The way to implement this task is by traversing the task graph (or tree) from top-to-bottom.\n",
    "* The if-then clause is interpreted as: If the statement above the if-then clause is true, then traverse down the left-hand side. If it's false, traverse down the right-hand side."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8c325aed-26b3-4629-8404-058312c0d4c2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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UVEh3333nZiZmcnBgwflt99+E0tLS2VyVF9fXzE3N5eff/5ZRETeeecdJaw8PDzE29tbUlNT5dq1a3fspr5Vo4xN15w88cQTWLt2rf5zdBCRQdq0aRPMzc0RExMDMzMzdOjQAYmJiRg+fLhe+3t5eSEgIACWlpbKQKMhISGwsbGBjY0N1q5dCx8fH0yePBmmpqbo2rUrXn/9dSxZskQ5RqdOnRAaGgpjY2MMGzYMLi4uOHXqlN7nMHfuXHh4eMDKygqLFy/Gzp07kZOTo6wfN24cTE1N0bp1a3z99deIjo5Gnz59YGJign/+858YMWIEVqxYgf79+8PCwgK//fYbLl26hD/++AOhoaFITEwEAGzcuBHPPvusctzx48fD29sbrVq10rtZi6N211FTmsWWiBqOIY/afdOtr6cAQHZ2do315Ofn67zucnP/o0ePwsjICCNGjMDWrVtx4cIFDBw4EE8//TSio6ORl5eHI0eO6DR/1fS6T214ZUREVANDHrX7pupXQWfOnAGgO5VE9Xo8PT2Rlpams39aWpryuss//vEPbN26FYmJiRg6dCgCAgJw+vRpLF++HP7+/rC1ta1XrQwjIqIaGPKo3TfFxsYiJycHly5dwmuvvYZnn332tnclb4qMjMSiRYuQkpKCqqoq/PDDD9i4caMyvURgYCCysrLw008/YejQoWjdujV8fX3x3nvv6dyiu1cMIyKiGhjyqN03PfXUU+jXrx86duyINm3a3PV9xRkzZmDy5MkYNWoUrK2tsWDBAnz77bfw8/MDAJiZmeHpp5+GqakpunfvDgB48sknUVpain/84x91OfUaaeRusUpERNQIeGVERESqYxgREZHqGEZERKQ6hhEREamOYURERKpjGBERkeoYRkREpDqGERERqY5hREREqmMYERGR6hhGRESkOoYRERGpjmFERESq+3+WVNilRRSceQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "task_graph = taskgen.TaskGraph(starting_operators=config.STARTING_OPS,\n",
    "                               ending_operators=config.ENDING_OPS,\n",
    "                               min_depth=3)\n",
    "plt.figure\n",
    "\n",
    "plt.figure(figsize=(4,2.5))\n",
    "task_graph.plot_graph()\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5986bac2-2705-4b87-84d9-ce7cc202c9e4",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "ca2d83f3-e302-406f-bdec-50cf889f98a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current purple m * current cyan n product is even , then shape of current blue object , else current cyan x * current brown a product is odd ]\n",
      "Target output: False\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 3\n",
    "\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "12d66dcb-01cb-453a-94d7-912c917f8dc6",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph, but add more distractors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "556b75a7-7266-4b92-94a1-f167a1ed770a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current purple m * current cyan n product is even , then shape of current blue object , else current cyan x * current brown a product is odd ]\n",
      "Target output: a\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVcAAAFwCAYAAAAMmDiWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABAJUlEQVR4nO3dd3hUZfr/8feZkslMeuiBQKRDKFGQJogYC4hiwQWJohDrb0VRrIiFqNiX9auIsLoUdWPFgrqC4IpgAaSjQJCeBNJJncnU8/sDiQQCJDBnSuZ+XZeXyZmTue/DTD555pTnKKqqqgghhPAqnb8bEEKIxkjCVQghNCDhKoQQGpBwFUIIDUi4CiGEBiRchRBCAxKuQgihAQlXIYTQgISr8Bu5fkU0ZhKuwi+2bdvGBRdcUGuZoihMnz7dJ/WTkpKYMGGCT2qJ0GTwdwMiNH300Uf88ssvtZb98ssvtGnTxk8dCeFdEq4iYAwYMMDfLQjhNbJbQGhmw4YNpKamEhMTQ1RUFJdccglr1qxh+vTpZGRkALV3BRz79YoVK1AUhf/9738MGzYMs9lM27Ztefvttzl06BDXXXcdkZGRJCYm8uqrr9bUPPpzK1asqNXLRRddxEUXXVRnn/v27UNRFBYsWFBr+YQJE0hKSqr5fs+ePVx99dU0adIEi8XCwIED+eabb87iX0g0ZhKuQhPl5eUMHz6cpk2b8sknn/DBBx9QVVXF5ZdfzsSJE7n11luBI7sCbrvttpM+zw033MBVV13Fl19+SefOnbnrrrsYNmwYPXv2ZNGiRfTp04f777+ftWvXaro9Ho+HK6+8ksrKSt59912++OILmjRpwqhRo9i1a5emtUVwkt0CQhPbtm2jsLCQe++9t+bAVdeuXZk7dy46na5m3+rpdgWkp6czZcoUACIjIxk4cCD9+vWrGfn27duXL774gp9//pl+/fpptj0FBQVs376dadOmccUVVwDU9FFdXa1ZXRG8JFyFJnr06EGzZs246qqrGDt2LFdccQWpqam89NJLDXqeQYMG1XzdsmVLoHYgN2nSBIDS0tKzb/oUWrRoQffu3bn99ttZtmwZI0aM4PLLL2fmzJma1hXBS3YLCE1ERkayatUqRo4cyQcffMCoUaNo1qwZd955Z4NGetHR0Scss1gs3my1XhRFYdmyZUyYMIElS5Zwww030Lx5c8aOHUtJSYnP+xGBT0auQjNdunTh3Xffxe12s3btWt59913efPNN2rdvr1lNRVEAcLvdtZZXVlYSGRnZ4J85VkJCArNnz+aNN95g8+bNfPLJJ7zwwgvEx8fz5ptvemsTRCMhI1ehiU8++YRmzZqRl5eHXq9n4MCBzJ49m9jYWLKzs9Hr9ZrUPTrSzc7Orll2+PBhtm3b1qCfcTqdtQ6S/fLLL7Ro0YJff/0VRVFISUnh2WefpWfPnrV+ToijZOQqNHHBBRfgdru55pprePTRR4mOjubDDz+krKyM0aNH89tvvwHw/vvvM2DAAM455xyv1O3VqxeJiYlkZGQQExODXq/n+eefJyIi4qQ/ExcXx6BBg3j99dfp1KkTTZs25bXXXsNms9X83LnnnovFYmH8+PFMnz6dli1bsnz5cjZt2sTkyZO90rtoXGTkKjTRqlUrli5dSkxMDLfeeisjR45kw4YNLFq0iGHDhjF69GjOP/98brnlFl5++WWv1dXr9SxatIiEhATGjRvHPffcw9ixYxk9evQpf27BggWcf/753H777dxyyy2kpKRw33331TweHh7Ot99+S3JyMpMnT+byyy/n888/Z+7cuXIZraiTInd/FUII75ORqxBCaEDCVQghNCDhKoQQGpBwFUIIDTQoXDMzM+nevTudOnVi1qxZWvUkhBBBr95nC+Tm5jJo0CA2bNhAeHg4gwYN4r333qNnz55a9yiEEEGn3hcRLF++nNTU1JqJMq6//no++eSTeoWrx+Ph4MGDREVF1VxqKIQQwUhVVSoqKkhISECnO/mH/3qH68GDB0lISKj5vlWrViedQ9Nut2O322u+z83NpXv37vUtJYQQAS87O/uUtyWqd7h6PJ5ao05VVU+a2s8//3zNfJvHevvtt/0yo5EQQniL1WrltttuIyoq6pTr1Ttc27Rpw6pVq2q+z8vLqzWSPdbUqVNrJjiGI7PSJyYmYrFYmDRpEjabrb5lz5rZbGbevHmkp6f7tK7UDq3aobjNoVr76GGq0+3irHe4XnLJJTz11FMUFBQQERHBxx9/zNtvv13nuiaTCZPJVOdjNpvN5y+CP+tK7dCqHYrbHMq1T6Xe4dq6dWuee+45hg0bhtPp5LbbbtP0thpCCKEpRaH5lVdiiIkBVaVo6VIcRUVee/oGTTmYlpZGWlqa14oLIYRfKAq6sDA6TJ1KZOfOqMC6K6/EUVICHo9XSsgVWkKIkNNi1Cj6L1/Oziee4JchQ1h94YW0+/vfSX79da/VkMmyhRAhxxgXR0TXrlTn5FCVlQWAdc8eVJfLazUkXIUQAvhj+nSvPl/QhGuzZs149913MZvNVFRUcNNNN2l+O+WQNPw+SOhy4vKf34cdK33ejhDe0mrsWFrffDMAppYtUfR6esyZg9tqBWDHgw9SuX271+oFdLhaLBZSUlJQFIWYmBiMRiM6nY6wsDD69evHzp072bdvn7/bbFwUBZQ6dsU3aQOtu8HBLFC9s8NfCJ9SFJQ/b4x59BxVRac7skyDG7IEdLgmJSWxYsUKDAYDOTk5dOvWjaqqKmJjY8nKyuK9997jgQce8Hebjcs3/6x7+ZUPwcBx8NpYcFh925MQXnDogw849MEHALSZMIGuL7/M1jvuqNnn6m0BHa5H/7q8+eabLF68mOrqaj93FIKimsIVU47sKpBJd4Sot4AN18TERNq0acP27dv5/vvvWbp0ac1jbrebrKwsnE4n3bp1Y9euXTidTj9224jEtgJj+F/fRzWFJolgigK3w399CRFkAjZcZ86cSefOnenfv3+tGbYAKioqGDZsGPfeey9r1qyhd+/e7N2710+dNjKjHoVz+vz1fXE2zJkAIyZD1wv91pYQwSZgw1Wv16PT6XC5XNQ1n7fb7QbAaDTKHLHe0Lw9DBwLu1bDb9/9tdxeeWTEKndgF6JBAjZci4uLiY+Pp02bNrhcLtxuN3l5eaiqiqIotGrVCr1eT3Z2Ni4vnvgbsmJawHmjYMEk2Lve390IEfQCNlwnTZpEcnIymzZtwmAwkJuby7nnnovVaiU6OpqffvqJRYsWkZKSEpAz4gghQlvAhqvdbufAgQM8//zz6HQ6FEVh2rRpwJH5FN966y3WrFmD1SqnBXlF0QFYPufI/tYO55/4eJtk3/ckRBAL2HAFKCoq4sUXXwQgISGBNWvWYLFYKCsro1+/fhR5cXqwkHc4F1YthHEvQVJK3etUlgCy71UEP4/Dgau0FPXPYzdaCOhwPVZeXl7N1VqqqlJSUuLvlhqnTzNAb6z7MdUDDtkFI4Jf3qJFFC5dilPDS+iDJlw9Hg/FxcX+bqPxs1f5uwMhNOex2/Ecd4qnt8l8rkIIoQEJVyGE0ICEqxBCaEDCVQghNCDhKoQQGpBwFUIIDTQ4XCsqKujZs6fcAUAIIU6hQeG6Zs0ahgwZQpZGM3cLIURj0aBwnTNnDq+//joJCQla9SOEEI1Cg67Qmj9/fr3Ws9vttSa4Li8vr/nabDY3pORZO1rP13WldmjVDsVtDtXaqqrW65ZTilrXTNSncfTGgUlJSXU+Pn36dDIyMk5YnpmZicViaWg5IYQIGFarlbS0NMrKyoiOjj7peprMLTB16lSmTJlS8315eTmJiYkApKen+3T+VbPZzLx583xeV2qHVu1Q3OZQrV3f8agm4WoymTCZTHU+ZrPZ/DK5tb/qSu3Qqh2K2xzKtU9FznMVQggNnNHIVc5xFUKIU5ORqxBCaEDCVQghNCDhKoQQGpBwFUIIDUi4CiGEBiRchRBCAxKuQgihAQlXIYTQgISrEEJoQMJVCCE0IOEqhBAakHAVQggNSLgKIYQGJFyFEEIDEq5CCKEBCVchhNCAhKsQQmhAwlUIITQg4SqEEBqQcBVCCA1IuAohhAYkXIUQQgMNCteZM2eSnJxMz549SU9Px+FwaNWXEEIEtXqH69q1a5k/fz5r165ly5YtOJ1O3njjDS17E0KIoGWo74pxcXHMmjWLiIgIAHr37s2BAwc0a0wIIYJZvcO1U6dOdOrUCYCCggJmzZrF/Pnz61zXbrdjt9trvi8vL6/52mw2n2mvZ+RoPV/XldqhVTsUtzlUa6uqSnV19WnXU1RVVRvyxPv27WPkyJGkpaUxbdq0OteZPn06GRkZJyzPzMzEYrE0pJwQQgQUq9VKWloaZWVlREdHn3S9BoXrpk2bGDlyJI8++ij33HPPSdera+SamJhIZmYmkyZNwmaz1bfkWTObzcybN4/09HSf1pXaoVU7FLc5VGsfHbmeLlzrvVugsLCQ4cOHM3v2bK677rpTrmsymTCZTHU+ZrPZfP4i+LOu1A6t2qG4zaFc+1TqfbbAq6++Snl5OU8//TQpKSmkpKScdLeAEEKEunqPXGfMmMGMGTO07EUIIRoNuUJLCCE0IOEqhBAaqPduASFE42Vs2hRTixYAOEtLsefmYunYEY/DQbVcLHRGZOQqhKD1uHEMXLmSgStX0uGRR0Cvp9f8+XR9/nl/txa0ZOQqRIhqce21NL30UgCqc3L4fdIkAMJatKDHrFmYExOpzsnxZ4tBTUauQoSomHPPJWHsWOIvvBC31crB99/n4Pvv4ygqImHcOIyxsf5uMajJyFWIEOYsK2PtpZfiKCz0dyuNjoxchQgxhthYOj31FK6qKnY/9xzOkhJUl6vm8fL169n55JPY8/L82GXwk3AVIsQYoqNpe9dduK1Wst9+G88x84AAVG7fzr433sBRXOynDhsHCVchhNCA7HMVIsS4ysvZ/8Yb6C0WkiZPBqBs3ToO//QTAJHdu9P0sssIa9oUm5zjesZk5CpEiHGVlrLr2WfRhYXR4ZFH6PDIIzS99FJ0ZjM6s5mYvn3p8PDDhDVr5u9Wg5qEqxAhat9rr/FTv3781K8frrIyLli7lgvWriW6d29+HjiQql27/N1iUJPdAkKEKFdZGa6yMgDKt26lZMUKAMrWr8eWk4PqdPqxu+An4SqEoHj5coqXLz/yjaKgGI2oHg94PP5tLIhJuAohamk+ciQdHn2UPzIyqNyxw9/tBC0JVyFCVETXrljatz9hufmcc7Du3Uvljh1UZ2f7obPGQcJViBCVkJZGUh03Gj343ntsHj/eDx01LhKuQoSonH//m6IlS05Ybs/P90M3jY+EqxAhyrZ/P7b9+/3dRqMl57kKIYQGJFyFEEIDDQrXqVOn0q1bN7p3787MmTO16kkIIYJevfe5/ve//+Wnn35i69atOBwOkpOTGTlyJF26dNGyPyGECEr1DtcrrriCSy+9FIPBQG5uLm63m4iIiDrXtdvt2I+ZI7K8vLzma7PZfBbtNtzRer6uK7VDq3YobnOo1lZVlerq6tOup6iqqjbkiR9//HFmzpzJmDFjmD9/PoqinLDO9OnTycjIOGF5ZmYmFoulIeWEECKgWK1W0tLSKCsrIzo6+qTrNThcjz75qFGjGDNmDHfccccJj9c1ck1MTCQzM5NJkyZhs9kaWvKMmc1m5s2bR3p6uk/rSu3Qqh2K2xyqtY+OXE8XrvXeLfD777/j8Xjo2bMnFouFa6+9li1bttS5rslkwmQy1fmYzWbz+Yvgz7pSO7Rqh+I2h3LtU6n32QLbt2/nrrvuwuFwYLfb+fTTT7nwwgu17E0IIYJWvUeu119/PRs2bCAlJQW9Xs+YMWMYM2aMlr0JIUTQatDlr8899xzPPfecVr0IIUSjIVdoCSGEBiRchRBCAzIrlgh5ljAdfc6J5PhTtl1ulV/3VOJ0N/hsxYAWYdQxsms0W/Oq2V545GT4bs3DSWl15GT8PSV21mRb/dlioyDhKkJefKSBuy5pif64dK2ye/g9dw9lVrefOtNGkwgDs69py4zv88gqOhKuwztHk3FJKwDe3Vgi4eoFEq4i5OWXOZn24X44buRqMui4f0Rr1u2p4KuNh/3TnIb+PqAp1/eIBWDZHxUMmbsTgBKry49dNR4SriLkOd0q+4rstZa1ig2jZYyBdk1N7Ck4/XXkwSghOoymEQZ+3FfF7hI7mw8F3on4wUzCVYg6XNQtmmv6NvF3G5pSVZUKu4ebP9rHYVvj2vURCCRcRchrFmXkjtSW6I7ZLfB7jpWXv8rl7sta+a8xjc1bV8wHWw5TYZdg1YKEqwhprWKNtIk3EW5U0B1zQKu4wsn2g1ZcjexMgWPtLrHz8/4qf7fRaEm4ipB24wXNaRkbxiPv78Xtqf1YhElOAxdnTt49IuQpQMMn3hTi1GTkKkJaSaULk1FHQlwYnuMC1hymQ6c7cTJ4IepDwlWEtAUr80lsYuL5sUno6whSvXy2E2dIwlWENI8KRRVO3llVcMLlr0ftP+4c2GBXYnXx0H9zWZ8rV2FpScJVhLwqu4dlv5X6uw2fqXR4mL++2N9tNHryoUcIITQg4SqEEBqQcBVCCA1IuAohhAYkXIUQQgMSrkIIoYEzCtcHH3yQCRMmeLkVIYRoPBocrt999x0LFy7UohchhGg0GhSuJSUlTJs2jccee0yrfoQQolFo0BVad955JzNmzCA7O/uU69ntduz2vy4ZLC8vr/nabDY3sMWzc7Ser+tK7dCqHYrbHKq1VVWluvr0t/5RVLV+k629/fbbbNu2jZkzZ7JgwQJWrFjBggUL6lx3+vTpZGRknLA8MzMTi8VSn3JCCBGQrFYraWlplJWVER0dfdL16h2ul156KYcOHcJgMFBSUkJlZSU33XQTr7322gnr1jVyTUxMJDMzk0mTJmGz+e5GaGazmXnz5pGenu7TulI7tGqH4jaHau2jI9fThWu9dwssW7as5uujI9e6ghXAZDJhMpnqfMxms9X7H8LU3EyHv/fg0Jf7OLy+sL6tnnVdb5PaoVM7FLc5lGufSsCe5xre0kJEUhTGqDDMrSOwJEWdcF95LShAclIS57RqvDemE0Jo74zCdcKECSfd3+otSendaHdzF7Y88jOWtlEkP3U+ujC9pjUBjAYDH0yfztPp6ZrXEkI0XgE7n+vBL/ZiSYyk0+TeWPdXsHvu73icntP/oBfodDqUk82cLIQQ9RCwuwXKfy+hdEsRkR1jqM63UrI6nxNuciSEEAEqYEeuANUHrWy8ZxXq8fc8FkKIABfQ4WqMM9FmdHuKfjxExY5Sv/XROTGRO0eNAiCnsJBXP/oIGUNrRwfcHdGBZvojZ5y8VbUXPQrpEUm8Zz3ATlelfxsUoh4CO1yjjCRclYQ1u9Ln4WoKC6NZbCwAXRITGXvxxQBs37+fzGXLKK2sxO50+rSnxi5eMaJTFPQoXBregnb6IxecfFddgFnRc6sliZX2IglXERQCOlz9aUT//vz+zjsA/LR1K8k33wxA8jnnsHn+fO7+5z9Z9MMP/myxUbEoej5tMpAW+nDcqNxYspa9rioA3orrw3nGWP82KEQDSbieRJjRiNFgYME33/Dj1q2UVR35RbfZ7cRGRmI0yD+dNylAlM7IfreVZdX55LhtlKsuAMIVHRE6+fcWwUXesSfhdLmw2e3MXbyYDTt31ix3ezxU2mwY9HosJhNWe+O6p70/GFGwKHpsqpu1jhL+UflHrcerVQ821Y1Z0f48ZyG8JWBPxfK3JWvW0GviRLbu2VNr+fZ9++g1YQJDevXivy+/TJiMYM/azZZ2fNZkEHce3sArFTtPePz/lW7k3tJN1HMaDCECgiTDSdjsdg4WFZ2w3Ol2c7C4mPCwMFrExcnFBl4QoTPQXGei2GOv2RVwrBKPgxKPww+dCXHmZOQq/M6jqrhQ0Ss6DCgYjptEQs+RMwiECCYychV+9x/rAVbYC3kjNoU4XRgu1UP64fXsd1sBeC22N+cb4/zcpRANI+Eq/O6w6sTqcrPTVUmcYsQDDAyLJ1mNRgEqPC6y3TZa630/270QZ0rCtQ6qqp72Ciz1z/+Ed9jx8HDZVgAMKCxrOoTOhkhU4JriXzAqCp/ED/Bvk0I0gITrcZxuNzc+8wxVp5l895mFC4k0m3G4TjwAI86OC5W7SzdiVvSoQJargl7GGH+3JUSDBFS4RrSPBgWqdpeffmWNqKrK5l27Trve7txcH3QTura5KvzdghBnJaDOFmh/R3c63Jns7zaEEOKsBdTIdd+CHVjaRtH9yb4AuCqdbJ+xnqq9/hvJCiHEmQiocK3YUYrH4aHVlUkoCnhcHkrWFcok2YIq1c02VwUVdVxkIEQgCqhwBajaU86myav+WiC5KoAtzjIuL1qFTJsugkXAhSsggSrqJMEqgklAHdASQojGosHhOm7cODp37kxKSgopKSl89tlnWvQlhBBBrcG7BdatW8eaNWuIj4/Xoh8hhGgUGjRyLSkpobCwkHHjxtGrVy8yMjJkjk0hhKhDg0aueXl5pKam8sYbbxAdHc2oUaOYP38+6enptdaz2+3Yj5mhv7z8r/NUzWbfTr5xtJ6v60rt0KoditscqrVVVaW6uvq06ynqWQw9P//8c9555x0+/fTTWsunT59ORkbGCetnZmZisVjOtJwQQvid1WolLS2NsrIyoqOjT7peg0au69at4+DBg4waNQoAt9uNoY7bnEydOpUpU6bUfF9eXk5iYiIA6enp2E4zKYo3mc1m5s2b5/O6QVdbp0NnMuGx28Fzdic9BdV2B3ldqe372vUdjzYoXN1uN5MnT2bo0KFYLBbmzJlzwi4BAJPJhMlkqvM5bDabz18Ef9YNltpxgwfT48032XLrrZStXevT2lqQ95nU9rcGHdDq378/kydPZsCAAXTv3p0+ffowbtw4rXoTPtLsiiuITkmhZMUKYvv2pdnw4f5uyWfihw6l+ZVXgtwLzSda6cK5wdyG5rq6B1+NSYNPxbrvvvu47777NGhF+IVOR/uHHsJRUMDGtDT6LFqE3mymcOlSCIEzQRJvv52IDh0o/OYbVLfb3+00el2NUfwjphdjStZQ4Gjct6UPzMtfhe94PGxJTyf2/PMZuGoVe155hfING0IiWIXQkoSrwLZ3L4boaGx791K1Ywe2ffv83ZIQQU/CVQBQsXkzm2680d9tCNFoyMQtxzHoYN717Zh6UYtTrvfI0BbMv74dRp33DoRE6eL4f82e4TzLhTXLzrMM5Z7mL3BP8xdIjRrttVrHi+nbl75ff01U796a1QgGxiZNOG/RIvp+/TXnfvghhhi5d5c4MzJyPY5OUeiTYOZ0mdmlqYm+bSynXa8hjIqR9qbuFLpyOewqBKCJoQU65cjfQEXR7m+hMTaWuEGDMIZgmOjMZmL790d1uzFER6MzGlH0enRhYcT06YN11y5sBw74u00RZCRcA9DgyJEMjhwJwHcVi/i//If93FHjZm7Xjr5ffw2A/eBBfjr/fNxWK4aYGC5Yt45DH37Izscf93OXIthIuAYgRVGo9lj5uORNcpy7/d1Oo6f8eY5r9ttvU/DNN7iPmRdDObKCfxoTQU32uQagcvdhDjr38ZttDXlO+TiqNY/dTuWOHZSsWkXxd9/Bn+e7qm43VX/8gep0EtGlC4rR6OdORTCRcA1AK8o/5/X8R6lWrf5uJSRY9+5l9dCh5C9eXGu5u7KSdVddhaOwkP7ffUd4QoKfOhTBSMI1AKmoeOSOUb6jqqguV50XTqhuN6gqisEguwdEg8g+1+OoKuRVuqh2emgdfeRjoN3loch65KOiUafQPNKAOUz+LjUWitGIqXXrI0HqdmPPzz/yRlAUTC1aoOj12A8ePBLAQtSThOtxnB6Vq9/ZzdXdY9l4b1cAfthTyd8y9wLQrXk4397aEbNRx4FShz9bFV5iad+eC375BRWwHzrEL0OG4LHZMERF0e/bb8lfvJifL7gATz0mSBbiKAnXOlS7VDYdsvLSD/kA6HUK0y9pBYDHo/LKynxG94gj0iSj18bAUVTEgX/968g8topC+wcfrHksZ+FCytatwxOAU9qJwCbhehJZhXayCgsAGJIUyfvjkgDYmmfjivm7aRcXxrkJFrw5vYkHFZunEqfq+xGxx+XCVVqKx+n0eW1/cldVYdu7l33//Ceq242pZUv6/+9/6M1mXOXlrB42DGdJib/bbDRcqkqZ6sTl1d+cwCThWg+rD1TR+/+2A+DygApMXXIQo17B4fbem6TMXcSLeffgUH3/8fPwTz/xY9++uI6531ko2P7ggyh6fc10g/aCAn4ZPPjIwStVxXn4sJ87bFxWO4oZXPgD5Z7G/0dcwrUenB6VYmvtuT4rHd4/mq+iUuXxT7ipTifO4mK/1PYnd0VF7QUej4xUNeREpcQTGscqZKehEEJoQMJVCCE0IOEqhBAakHAVQggNSLgKIYQGJFyFEEIDDQrXL7/8kr59+9KtWzcmT56sVU9CCBH06h2ue/bs4a677uLzzz9n69atbNy4ka//nL1dCCFEbfW+iOCzzz5j7NixtGnTBoAPPvgAk8mkWWNCCBHM6h2uu3btwmQycc0117B3716uuuoqnnnmmTrXtdvt2I+5VUb5MZdUms3ms2i34Y7W83VdqR1atUNxm0O1tqqqVNdjhjRFVeuYIbgOt99+O6tWrWLlypVERUUxatQobrzxRiZMmHDCutOnTycjI+OE5ZmZmVgslvqUE0KIgGS1WklLS6OsrIzo6OiTrlfvkWvLli1JTU2lefPmAFx77bWsXbu2znCdOnUqU6ZMqfm+vLycxMREANLT07H5cPo2s9nMvHnzfF5XaodW7VDc5lCtXc/xaP3D9corr+Smm27i8OHDREdHs3TpUq666qo61zWZTCfdH2uz2Xz+IvizrtQOrdqhuM2hXPtU6n22QP/+/Zk6dSpDhgyhe/futG7dmokTJ2rZmwgRlw81MfOJKGKifH+Pqkt6xHLd+U3k9ljC6xp0nmt6ejq//fYbWVlZzJ49G71er1VfIoT06WnktnEWIiy+T7iUdhFc0DkayVbhbXKFlhBCaEDCVQghNBCw4aozm9FHRJxyHcVoRB8VJfeTb+QizAoWs29eYwUwG3WYw3SEGwP21yN46RT0FgPo/no9dWE69BYDeosBxdB4fpcD9t3T7eWXOffDD1FOsV+39Y03Muinnwj/86ox0Ti9PyuWd1+N9UmtGIuel9KSeHV8e56/oR2R4XJcwZtiesTTZ85QorvG1iw75/bu9JkzlD5zhtJsaGv/NedlAXsPrdK1a3EePkzirbdSvHIlVTt21DymhIWRMHYsYc2bk//ll7irqvzYqdBKh3Z6RgwzsX2Xi5xD7tP/wBmKDNczvFccHhX0Oli/txJFAY8KF3aNZk9BNTsOBt6pPsFIZ9RhjDPRdEgCEe2PnIDvqnBS9FMeAKam4bS4tA0F3+eiuoL7DrEBG66577xDRJcuDPj+ezyPPYZ1925UpxP0eozR0XSYOpVDH3/MzmnT/N2q8CKdDgx/DhbP62Hk5ceiGTa2mNUbtbtbaFyEgQlDW+D2qBRVOHnwP3uxu1QiTDpeHd+eVVnlEq5epCgKCVcloaoqqksl65WNFP8Zrh3+XzKtRraj6Mc83C6Xnzs9OwEbrgDWPXv4ZfBg2t55J32/+IL1111H4q230mrMGDbdeCO2Awf83aLwsr+NDOfpB6IA+Gmdg16XFZKt4aj1WB+vKeLHrHIcQT5iChZVeyvIenED9mLf30reFwI6XFWnE+uePVRs24Y+MpLmV12FITqa8i1bqNq168TbIougZdArXH1pOOf2MNKxnZ4lP9jZst3FH/u0D1ar3c2m/VXsPGSjoPyvEbLLrfLrnkrsTg8DOkaxcX8ldqcE79lSVZWyrcWUbzuMLbf2Lr3KXWXoTHri+zenak851gOVfury7AV0uB6Vu3AhxcuXM2jNGvbOnMm2e++Fel7fK4JDuAlmPXNkH5zTBQ/NqGD7H775WFhc6eK1pQfxHPeWsrtU/vW/PEamxDHpslZMeW8vBU7tdk+EkuwPdlG2pfiE5fnLcihZV0ifuUPJ/XQv1gN/+KE77wjYswWOdc6UKSS//jobRo9GbzbT5/PPMcTG+rst4UW2argq/TD9ry5m6N+Kef6RKJ5/NMrfbQlxxgJ65Kq3WIg5/3yMcXE4Skoo37QJS8eORPXsSdygQVRlZWHdvdvfbQovcHtUNm1zcjDfg14HBcUeIiwKlwwO49fNTsoq5JNKYxLZMQblz3Ndq/aV4yx1AGBuE4G5TSTlv5dQnWf1Z4tnLaBHruFt23LeokVU7drF1ttuw2O3c/A//2HrnXeS/H//R5v0dH+3KDTg9sDtj5Sx4hcH374XT/fOAT0GEA2kKApJE7uS/Ew/kp/pR0yPJjWPJVyVRMe/9yDrpU0Ursj1Y5dnL2Dfte0feYSIjh3ZOHYsldu313rMXVXF5okTie3Xj3M/+IDfJ0/GkZ/vp06FVlb96mD4zSXcPs7CtZd7ePg5OYDZGKiqyr4FO6jac+QOJfH9mtPisiPzPZduLmLHSxtx231zhoiWAnbkaoiMRDEYKF6xAvvBg7UeU10uDv/4I7bsbIxxcSi6gN0MUQ+HCtxs/M3J8ceKCoo8fLvSgeqB6EhtLovMK3OQXWw/5TplNjd7C6txuWXXhLdU/lFG6cYiSjcW4a52Y4gyYogyUp1npfy3Ek44uhiEAnbkuvPJJ498cYqzAvI+/pi8Tz6RMweC3PyPbCz42HbSl/G2R8o0q/3ej4UowKneQT9mlfNTVvkp1xFnbv/CLPa/k3Xkm0b0jxyw4VrvwJRgbRRO9TJq/RLX5+nlXaaxRvgPLJ+nhRBCAxKuQgihAQlXIYTPWLMr2fOvbdgONv6Z7AJ3n6sQotGxF9g49OU+f7fhEzJyFUIIDUi4CiGEBuodrnPmzCElJaXmv7i4OMaPH69lb0IIEbTqHa533XUXmzZtYtOmTXz00UfExsbywgsvaNmbEEIErTPaLXD33XeTkZFB69aN52ZiQgjhTQ0+W+CHH34gPz//lLsE7HY7dvtf12uXl5fXfG02mxta8qwcrefrulI7tGqH4jaHam1VVamuPv2taRRVbdjFhTfccAPDhw9nwoQJJ11n+vTpZGRknLA8MzMTi8XSkHJCCBFQrFYraWlplJWVER0dfdL1GhSuDoeD1q1bs2fPHqKiTj5LfF0j18TERDIzM5k0aRI2m+/upGk2m5k3bx7p6ek+rRustQf1CcOgh5VrHT6v7Q3+qh2K2xyqtY+OXE8Xrg3aLbB161Y6dep0ymAFMJlMmEymOh+z2Ww+fxH8WTfYak/9u5kIs8Kg68rOesKUYNruYK8rtQPv1ucNOqC1e/du2rZtq1Uvtcy4/XYWPvYYepmr1ScGnGfk50+bsPATG6/Oq+LHRU24+IIwf7clRNBq0Mh1zJgxjBkzRqteaumcmEjH1q1RFG0mSRa1eTxQbVcx6MGjKlTbVTzBPxm8EH4jcwsIANZucnLxuBKWZ8YTYVEYdG2xTJUrxFmQcBW1PP5yBXq9zEEuxNkKynDV6XR0SUyktLKSQ8XF3n1yRcHSsSMem43qnBwA9BERmJOSAPBUV/v0dt7NYmNpGR8PwOGKCnIKC+nUpg0Ol4v9eXler1dQ7EF2c/tAgL3PhPcF5a9RtMXC0n/8g/v+9jevP7diMHDuf/5Dp6eeqlkWc/75DFy5koErV9LzrbfAh/uBx19+OWvnzmXt3Lk8fvPN6HU6Mp98kn/8/e+a1JvzXAwLZ8b6chNDUqC9z4T3Bd3I9boLL+Syfv2YPm8em7X4y64ooNMR268fybNnA+AqLeX3SZMAcJSUaP6Z+W8XXcTl/fsDkJ2fzx0vvwxAyyZNeOvhh2nbogXZBQWa1NbpkJGrL5zmfaaPjCT5jTfImT+fsl9/9Wen4gwFRbjGR0cT9eclbr07dqRvly489q9/UXLMZbXeZm7XjoS2bXHk51P8ww8cfP99zWod77wuXbjx0kvJLSxk7uLFvPvttwBMGDGCGbff7rM+hPZO9j6L6t2bri++SPH330u4BqmgCNenJkxgwogRADz37rsMvvtuqh1nfgVRvakqmydOpGz9eu1rHaesspILJ02ioLTU57WFj/nxfSa0E9AfAFvEx/P8HXcwuFcv7E4nM959l/9t2OCTYC3fsoWdTzyBdfduVF8EORAXFcWzt91Gpc3G9PnzKamowOX+62TTX7dv59G5c71/EE/4zcneZ/aDB9n5xBNEdO7MOfffj6LX+7FLcSYCOlxjIyO58bLLaNWkCbmFhWQuW8Zve/f6pHbVH3+w/403cGi0b7Mu0RYL94weja26mjlffHHCH5Hf9+3j/z7+mKKyMp/1JLR1sveZo7CQ/W+8gaVdO1qPH49iCIoPmeIYAf2K7crNJfW++3C53bSMj2fVrFn886OPeG3RIn+3JoQQpxTQ4ep2uzn850djt8fDwiVLiI6IYNJ11/Hvr7/GdszMW41BWVUVr378MZbwcB644QbgyK6AlZs3A9DjnHMYMWAAzWJiNDnHVQjhPQG9W+BY5VVVTJ8/H0VRePCGG2gaE4OxkX1UKq2s5Kl58wgzGHj85pt5/OabubxfPywmExaTiX7dujFt/Hiax8X5u1UhxGkETbge9donnzDioYf4bMYMHho3zt/taOIfH31ErwkT6DVhAqWVlWxZsIAtCxZwbqdOpKSns/PPK3qEEIErYId+/9uwgd/27sXj8dRaXlZVhcPlYsWmTfyRne39wm43+YsXU63Fc9dTWWUlZZWVAGzZvZvv/jxF59cdO8guKMDpcvmtN+El9Xyflfz0E9W5uahumaIs2ARsuL75+ecnfcxmt/PgG29oUld1u9n19NOaPPeZWLp2LUvXrgVAAYxGIx6PB/dxf3TOxJ8XCSG/t75X3/dZ7sKFPuhGaCHodguEslGDB/Pz7Nk88e9/88CsWWf9fCMvNrH+66Z07SDnUArhbQE7cg1l3dq1o2Mdty1vn5DAnoMH2bZvHwe8cP5tRZXK3gNuBvYJo3P7IyPhP/a6qKhUZcpBIc6ShGsAunn4cKbUcceHBd98w5hjZlE6Wz+sdrBqrYNfv2zKuclH3gqpaSV8/7NvrkgTojGTcA1Acxcv5utffjlheX5JiddreTxw+yOlRFiO7CHausPp9RpChCIJ1wC079Ah9h065LN6G36Tsw+E8DY5oCWEEBqQcBVCCA00KFzff/99kpOTSU5O5sEHH9SqJyGECHr1DlebzcakSZP4/vvv2bx5M6tWrWL58uVa9iaEEEGr3ge0XC4XLpcLm81W87X5z1uvHM9ut2M/Zsaq8mNux3Kyn9HK0Xq+riu1Q6t2KG5zqNZWVZXq6urTrqeoav1PF3/99dd5+OGHsVgsDB06lEWLFqHUcYfK6dOnk5GRccLyzMxMLBZLfcsJIUTAsVqtpKWlUVZWRnR09EnXq3e4bt26lVtuuYUlS5YQExNDWloaAwYM4KGHHjph3bpGromJiWRmZjJp0iRsNtsZbNKZMZvNzJs3j/T0dJ/WldqhVTsUtzlUax8duZ4uXOu9W2DJkiUMGzaM5s2bAzBx4kTefPPNOsPVZDJhMpnqfB6bzebzF8GfdaV2aNUOxW0O5dqnUu8DWr1792bp0qWUl5ejqipffvklffr00bI3ITSnC9ejt8i1NOHh4cTFxREXFye77ryk3uF62WWXMX78ePr27UuvXr1wOBw8+uijWvYmhOY6/L8edH/qfNCdeOwglNx2221kZWWRlZXFc8895+92GoUG/cl+5JFHeOSRR7TqRQifM1gMGCKN/m7Db8LDw5k4cSLx8fG8++67AFRVVTF58mT+85//UFRU5OcOg5dcoSVECLNYLDzzzDNYLBYeeOABHnjgAXbt2sWzzz5LixYt/N1eUJNwFULU8tlnn9GrVy/++OMPf7cS1GRPvgAgRh9PZ1NvdlRvwoObbuF9UIBq1cZvtjWo/HXGXoLxHFobkwDId+VywLHTP00HMZ0OrrrERHTk6cc3FVUeFi+z44U7+wAQERHB1VdfjV6vJzIyEpPJRI8ePRg/fjwAu3bt4pc6prz0hoSEBFJTU1m2bBl5J7k9vNls5uqrr2bbtm1s2bLFa7Ut7aKwtIuiZHUeHkfd/5jG2DBiz21G2ZZiHMWnv1DgVCRcBXAkMG9sMoXZBY/jUO2kNbkPBYVCVy7bbetxcWSeVwWF3pZBXBY9FoAfK/9LtuOPWuErTs+ghxcejaZTUt232FGUI/+pKuza7+ab7wuxe2kO86ZNmzJ37tyaK5t0Oh0jRoxg+PDhAMyfP1+zcO3VqxcLFy7kkksuOWm4xsbGMnfuXF555RWvhmt8v+a0ub4DG7aVHAnO49+yClgSI+l8f2+2PbNOwlV4j6IojIm/m1znXmbmTUFFJVofx+QWL/Jdxaf8Ub2FW5tOI6t6E6/k3QdA5/De3N/iFeYXvcBhd6F/NyCIOF1w3R2HCa/7dHC6djTw3quxPPFKBZ9/a8fhxTnMDx06xODBg9HpdMTExPD555/z2Wef8dprrwFQXFzsvWIBJH9ZNmVbiul8f29KNxeT89GuWo93mtwLnVHPpvt+pDrPetb1JFxFLc2MCVR5yslx7gbAobYmIaw9kbpo9OhpHXYOWdUbyXXuAeAcUzdah7XHoITuEfczoaqwfVfdk5T37WXEaFBYssLOz+udbPvDu5OZOxwONm/eDEB8fDwul4v8/Hw2btzo1Tp1KSoqYsmSJXTo0AGbzXbCCLl79+5069aN77//nl27dp3kWc6Ms9SB2+rCUVyNIcJA7HnNKN9Wgj5cT2SHGFQP2AttVO0pP/2T1YOEq6ilAVNNCI0880AkzZroOf+qokZ3o8h169ZxxRVXsHz5ctLT0xk0aFCt99zdd9/NNddcQ9euXamoqPB6fY/Dw86Zm2k5vC3dn+zLxntWYUmMpOvU89jy0C9U7DjstVoSrqKGqqp8UTqPXfatNctK3UW8WfAE3c19GRN/NwuKXiTfmVPz+FbbagpduVwZezO5jr18W/6hP1pvFM7rYeClx6L5YLGNTdtcjS5YA0nJ2nyq86y0TeuEq9zBb9PWYD3g3TCXU7FELTmO3WQ7/vo45lTt7LJvJUwJp62pM3vs2yhx59c8XuYuZlf1byQYz6GVsZ0/Wm4Ukjsb6NHFSIRF4bcsF+u2NO4bRW7fvp39+/fTv39/4uPjCQ8Pp1+/flitVjZs2IDb7da0vupWcVe70Rl1oFNwV7tRPd79aybhKoSfKQq8/VIMN15jZtC1xaze2LiDFeCee+7h1Vdf5ccffyQ1NZW2bduycuVK9uzZw6hRo7Baz/6A0qk0GdiSns8PYP87WZRuLKL3K4OISIryag3ZLSCEHw3qY+S+WyOY/5GN7btCa1eAqqooilIzJ/TR/2u5318x6mh/R3dclU6yXt6IvbAaV5WLHS9uoPnFbYg7rxkHMr1z8YSEqxB+ck6inv7nhjF6RDgff11NQZGbLu1PPO/V6YK92e5GF7w2m42srCwiIyNp06YNO3fupLS0VLN6higjpqZmItpFUbqpiOKfj5xn67a5KP4pj6aDWmKMCcPcJgJ7UTWe6rPbNSHhKoQfhBnhy3lxdGlvQFHgP6/FnjQ89+x3kzLCexcRBIqtW7fSu3dv3nnnHXr27Em/fv3qdfuUM9Xy8ra0Ht2eTZN/xF504vyvWf/YTEyPeM6ddSHbn13H4XVnd962hKsAIM95gE8Ov0mBK7fOxzdaV3LAsROXeuJvuAc3S8oyqfR45/xAX8pbcgB9hAFfDwtdbnhuViUx0ac/7FFe4cHl3VNda1RVVfHwww+zbds2bQqcgqqqOJ1OFEXBYDDgdDrxeOsa3zoc3liIs8KBs8wBdZXxqNhyKtnzr21YD1SedT0JVwHAYXchP1b+96SP77b/zm7773U+pqKy3vqDVq1p6vB6/1xV5vFA5hfajdLqy263M2/ePL/UNhqNNG3alOrqagoKCjQ/x7pqdzlVu089AHCU2Mn7736v1JOzBYQQftG7d2+2b9/Ot99+y/Dhw3FpNTz3Exm5CiF8pmPHjjWzb6mqyj/+8Q82bdqk+alX/iDhKoTwmaSkJCZPngwcuRT20ksvbbSXXEu4CiF8ZuXKlXTt2hU4MoFMYw1WkHAVQviQw+E46TyujY0c0BJCCA00KFxfeOEFunTpQq9evZgxY4ZWPQkhRNCrd7h+9913vPfee6xdu5aNGzeyevVqPv30Uy17E0KIoFXvcN2wYQMjRowgJiYGvV7PiBEj+OKLL7TsTQghgla9D2idd9553H///UydOhWLxcLixYtPeqma3W7HbrfXfF9e/tdVEUdviuYrR+v5uq7UDq3aobjNoVpbVdV6zYGgqA04F2LmzJksWLCA+Ph4LrnkElavXs1XX311wnrTp08nIyPjhOWZmZlYLJb6lhNCiIBjtVpJS0ujrKyM6Ojok65X73CtqKiguLiYpKQkAF588UVyc3Nr7hh5rLpGromJiWRmZjJp0iRsthNnpNGK2Wxm3rx5pKen+7Su1A6t2qG4zaFa++jI9XThWu/dAvv27ePGG29k/fr1VFZW8u9///ukEz6YTCZMprrvGWyz2Xz+IvizrtQOrdqhuM2hXPtU6h2uPXv2ZNy4cfTu3RuXy8WUKVMYPHiwlr0JIUTQatAVWlOnTmXq1Kla9SKEEI2GXKElhBAakHAVQggNSLgKIYQGAnZWrFvHmmnWRMdLc6o42W11LhoQxpWpJp6fXUnx4cY7dVkoMOgUrju/CRbTiX/vv950mMJypx+6EuLMBWy4jkwNp9M5el6ZW1XnvcQAzu1h5O6bI5j9rpXiw2d3G1zhPyaDQrTFQL8OUcRYat9aWgU27KvCandTZdfu5nVCeFvAhqsIHZf2jOPKc+N4+rNsSquOu4+SAg9c0RqHS+XFL3P806AQZ0DCVfidUa9gDtNjc3iwOk4cnf68sxyP7PURQUbCVfidy6Nid3owGRTCjcoJj/9vWxmN+G4gopGScBV+t2xrKb/uruD+K1oTYz5xn+vLX+Wyp+D0sxAJEUgkXIXfVTs9FFWqbN5fRUQdZwt0a20mLsLA+r2VfuhOiDMTsOHqdqu43WA0gqKAqoLrmBMCDAbQy1m6jcKR11cl8+fCOh9/5vq2uDxIuIqgErDhel9GOcmdDKxd3BS9XiGv0M3ICSXYqiEqUuGbhfF0TNKf/olEwEtNjiU1OYYXFudQZpNT6kTjELDhmpvnQae42PaHC50ObNUqV10SXjOa3ZfjJjJCISZShq/BrsLmIq/MSa+2EThcJx65OlBsp8wqoSuCS8CGK0D2IQ9j7y4FoHVLHTv+14wIi8LhMpWuwwq56VozMx6OkiPJQW7N7ko2H6jin+PbEx9R+y2pAk9+fICdeYE3X6cQpxLQ4XqswmIPqeNK0OnB5YLD5R4++NLGT+sdHMyXUU2ws7tUXvoyB4P+xFOxsosdfuhIiLMTNOHqcMLazbWvLz9U4OFQgVwS2RioKuwttJ9+RSGChOywFEIIDUi4CiGEBiRchRBCAxKuQgihAQlXIYTQgISrEEJoQMJVCCE0IOEqhBAa8Em4qn9en2q1Wmu+9hVVVf1SV2qHVu1Q3OZQrn20/qkoqg86y8nJITExUesyQgjhM9nZ2bRp0+akj/skXD0eD1lZWXTv3p3s7Gyio6O1LlmjvLycxMREn9eV2qFVOxS3OVRrq6pKRUUFCQkJ6HQn//Dvk7kFdDodrVu3BiA6OtrnL4I/60rt0KoditscirVjYmJOu44c0BJCCA1IuAohhAZ8Fq4mk4mnnnoKk8nkq5J+rSu1Q6t2KG5zKNeuD58c0BJCiFAjuwWEEEIDEq5CCKEBCVchhNCAT8I1MzOT7t2706lTJ2bNmuWLkrVUVFTQs2dP9u3b59O6M2fOJDk5mZ49e5Keno7D4Zsb7U2dOpVu3brRvXt3Zs6c6ZOax3vwwQeZMGGCT2uOGzeOzp07k5KSQkpKCp999pnPan/55Zf07duXbt26MXnyZJ/VnTNnTs32pqSkEBcXx/jx431S+/333yc5OZnk5GQefPBBn9Q86oUXXqBLly706tWLGTNm+LR2vakay8nJUdu2basWFRWplZWVaq9evdQtW7ZoXbbG6tWr1d69e6tGo1Hdu3evz+quWbNG7dGjh1pZWal6PB71pptuUmfOnKl53a+//lodMmSI6nQ61aqqKjUpKUndsWOH5nWPtXz5crVp06bqLbfc4tO6HTt2VIuLi31aU1VVdffu3WpCQoKanZ2tOp1OdciQIepXX33l8z6ysrLUpKQkNScnR/NaVqtVjY+PV/Pz81Wn06n269dPXbZsmeZ1VfXI+ys5OVktLS1VXS6XeuWVV6qLFi3ySe2G0Hzkunz5clJTU2nSpAkRERFcf/31fPLJJ1qXrTFnzhxef/11EhISfFYTIC4ujlmzZhEREYGiKPTu3ZsDBw5oXveKK67gu+++w2AwUFhYiNvtJiIiQvO6R5WUlDBt2jQee+wxn9U8WrewsJBx48bRq1cvMjIyfDahx2effcbYsWNp06YNBoOBDz74gAEDBvik9rHuvvtuMjIyaq6G1JLL5cLlcmGz2Wq+NpvNmtcF2LBhAyNGjCAmJga9Xs+IESP44osvfFK7ITQP14MHD9YKtlatWnHo0CGty9aYP38+Q4YM8Vm9ozp16sTQoUMBKCgoYNasWYwaNcontY1GI48//jjdunXj4osv9skv21F33nknM2bMIC4uzmc1AfLy8khNTWXhwoWsXr2aVatWMX/+fJ/U3rVrFx6Ph2uuuYbevXsze/Zs4uPjfVL7qB9++IH8/Hyf7RKIiori2WefpWvXrrRu3Zp27doxaNAgn9Q+77zzWLp0KSUlJVRXV7N48WKfZkp9aR6uHo8HRVFqvldV9ZSTHTQ2+/btY9iwYdx+++0MGzbMZ3WfffZZioqKyMnJ4a233vJJzbfffpvExERSU1N9Uu9Y3bt3Z9GiRbRs2RKLxcKkSZP46quvfFLb5XKxZMkS/vWvf7F69WrWrFnDwoULfVL7qDfffJMpU6bU+l3T0tatW5k/fz779+/n4MGDKIrCK6+84pPaqampTJgwgYsuuojhw4czePBgwsLCfFK7ITRPuTZt2tT6q5KXl+fzj+j+smnTJi644ALuuusupk2b5pOav//+O1u3bgXAYrFw7bXXsmXLFp/U/vDDD/n2229JSUnhySefZPHixdx7770+qb1u3ToWL15c873b7cZg8Mm8RLRs2ZLU1FSaN2+O2Wzm2muvZe3atT6pDeBwOPjuu+8YPXq0z2ouWbKEYcOG0bx5c0wmExMnTmTFihU+qV1RUcF1113Hli1bWLFiBUajkfbt2/ukdoNovVM3JydHbdeunZqfn69WVlaqPXv2VNesWaN12RO0a9fOpwe0CgoK1BYtWvh8R/vHH3+sDho0SLXb7Wp1dbV68cUXqx9++KFPe1BVVZ0/f75PD2itXr1aTUpKUktLS1WHw6FecsklamZmps9qd+zYUS0pKVFdLpc6atQo9a233vJJbVVV1XXr1qkDBw70WT1VVdWlS5eqycnJallZmerxeNQ77rhDfeKJJ3xSe8uWLWrPnj1Vh8OhlpSUqJ06dVJXrVrlk9oNofmf9tatW/Pcc88xbNgwnE4nt912G/369dO6rN+9+uqrlJeX8/TTT/P0008DMHLkSM1PG7n++uvZsGEDKSkp6PV6xowZw5gxYzStGQj69+/P5MmTGTBgAC6Xi9GjRzNu3Dif1Z46dSpDhgzB6XSSmprKxIkTfVIbYPfu3bRt29Zn9QAuu+wyxo8fT9++fTGZTPTt25dHH33UJ7V79uzJuHHj6N27Ny6XiylTpjB48GCf1G4ImVtACCE0EDpHloQQwockXIUQQgMSrkIIoQEJVyGE0ICEqxBCaEDCVQghNCDhKoQQGpBwFUIIDUi4CiGEBiRchRBCAxKuQgihgf8Pyhp8ZsaJd2cAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors=30\n",
    "\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "46077b6a-e07f-4514-8741-2fb71c83c00f",
   "metadata": {
    "tags": []
   },
   "source": [
    "# 3. Two if-then clauses (controlled by min_depth parameter)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "0599a160-5193-4728-9b9a-75e4279090d2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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gwoLC9OgQYN06tQpnT17VgMGDFDTpk2VnZ191eerX7++atWqpb59+yo9PV3p6el66aWXFBoaqoiICElS+/btNX78eFWvXl1+fn564okntHbtWm3atKnAlwoAwK1GoARw29jtdi1dulTLly9XQECAIiMj9eKLL6pPnz4KDAzUhx9+qFGjRsnb21sTJkxQjx49rmv7ISEhWrJkiaZMmSJ/f3/VrVtXNWvW1PTp0wu0ftu2bZWSkiIfH598v5gjXTjtvXnz5jy1ubq6atGiRTpy5IhCQ0MVGBioPXv26L///a9KlSp11ee7uF52draqV6+ukJAQZWZm6r///a/jGtHWrVsrIyNDzZs3l3Thm95BQUF67LHH8pwqBwBn4taLAHAdTpw4oYoVK2rv3r266667nF0OABQKXEMJAAVw/vx57dmzRx9++KFatWpFmASASxAoAaAAzp8/r4YNGyo4OFiLFi1ydjkAUKhwyhsAAACW8KUcAAAAWEKgBAAAgCUESgAAAFhCoAQAAIAlBEoAAABYQqAEAACAJQRKAAAAWEKgBAAAgCUESgD4E2+99ZbeeustZ5cBAIUat14EgD+xfft2Z5cAAIUeI5QAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsMTV2QUAQGF0/vx5GWOUk5MjSTp37pxsNpvc3d2dXBkAFD42Y4xxdhEAUJjMnz9fTz311BXTbTabvv32W7Vr1+72FwUAhRinvAHgMnfffbdsNttV5wEA8iJQAsBlatSooc6dO8vV9X9XBbm6uqpz586qUaOGEysDgMKJU94AkI9du3apZs2auniItNls+uOPPwiUAJAPRigBIB8XRyltNptsNhujkwDwJxihBICr2LVrl+OayZ07dxIoAeAqCJQA8CciIyMlSatWrXJqHQBQmBEoAQAAYAnXUAIAAMASAiUAAAAsIVACAADAEgIlAAAALCFQAgAAwBICJQAAACwhUAIAAMASAiUAAAAsIVACAADA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KSkp6tOnjwIDA+Xn56c2bdrkOa33448/qn79+ipTpowiIiK0f/9+x7zp06ercuXKeZ7/0pHB7OxsDR8+XMHBwfL29tajjz6qrVu3asaMGRozZozWrl0ru90uSZbqkKR//etfqlq1qjw9PRUdHa0zZ87c3DcWt0xR3WdPnjypV155RcHBwfL399ezzz6ro0ePSpK6deum5557Ls/zdOrUSf369ZMk7d27V23btpWfn59CQkL01ltvKTMz01HjI488or/+9a8qX768/P391atXL2VlZd3Mtx0o9giUwE0wb948bd++Xbt27VJcXJzjg2z58uUaN26cDh48qIYNG+rpp5/W3r17tXnzZh06dEh33323mjZtqoyMDKWkpKh169aKiopSWlqa3nvvPX333XcFruGdd97RF198oaVLlyo1NVWRkZFq06aNunbtqqFDh6pRo0ZKS0uTJEt1rFixQq+88oo+/fRTpaWlqUGDBvr1119v4ruJ26Go7bMvvPCC4uLitHHjRu3bt0/e3t5q3769jDHq3bu3vvvuO2VkZEiS0tLStGDBAvXs2VOnT59W06ZNVbt2bR0+fFjr1q1TbGysRowY4ahj/fr18vf3V2Jior7//nvNnTtX8+bNu2nvNXBHMABu2P79+40ks2nTJse0pUuXGnd3dzNkyBATGhrqmL53714jyezYscMxLTs72wQEBJg5c+aY6dOnm7vuusvk5uY65vfv3980btzYGGPMtGnTTEhISJ7nb9y4sRkxYoQxxpjKlSubKVOmOOadP3/ebNiwwWRlZZkRI0Y4tmO1ju7du5vnnnsuTx3h4eGOOlC4FcV99ujRo0aS2blzp2PZ06dPG1dXV/Pbb78ZY4ypUaOG+de//mWMMeaTTz4x9erVM8YY8+WXX5rAwMA8NS5dutR4eXk5avTw8Mgzv2HDhubtt98u2BsKwBhjDCOUwE0QFhbmeFypUiWdP39eJ06cUMWKFR3TL56eq1q1qmOai4uLKlWqpPj4eCUkJCg4OFg2m80xv1q1agWuISkpSSEhIY6fS5YsqQYNGsjV1TXPclbrSEhIUKVKlfJs89JtoWgoSvtsfHy8JOmhhx6S3W6X3W5XxYoV5erq6jjF3qtXL82cOVPShdPYvXr1cqx77Ngx+fr6Otbt2LGjMjMzdezYMUmSv79/ntfg5uam3NzcAr8OAJzyBm6KhIQEx+P9+/erdOnS8vPzy/MhdfFasr179zqm5eTk6MCBAwoMDFRwcLAOHDiQ54Ps8OHDjscuLi6O674uSk5OdjwODg7WwYMHHT9nZWVpwIABSkpKyrOO1TqCg4O1b9++PNu8dD6KhqK0zwYFBUmSdu7cqbS0NMd/GzduVJs2bSRJ0dHR+vnnnxUbG6tt27Y5rqkMCgpSaGhonvUOHz6s33//XeXLl7++Nw3AVREogZtgyJAhysjIUGJiooYPH65u3brJzc0tzzKBgYFq1aqVXn31VR05ckRnz57VG2+8oZycHLVt21Zt27ZVbm6uYmJilJmZqY0bN+rTTz91rF+zZk0dOXJEK1eulDFGs2bN0h9//OGY36NHD73//vvavXu3srOzNWbMGH377bfy8/NTqVKllJGRIWOM5TpeeOEFfffdd1q0aJGys7M1Y8YM/fzzz7f+TcZNVZT22YoVK6p169b661//qpSUFGVlZWn06NGqX7++4xrL8uXLq23bturVq5eefvpp+fr6SpLatGmjkydP6v3339f58+eVlpambt26qVOnTnnCMwBrCJTATRAaGqratWurTp06evjhhzV+/Ph8l/v8889VtWpV3XfffapQoYK2bdumFStWqGzZsrLb7Vq6dKmWL18uX19f9ezZU1FRUY51H3jgAf3tb39TdHS0ypYtq+XLl+eZ//rrr6tLly564oknVK5cOa1du1aLFy+Wm5ub2rZtq5SUFPn4+CgtLc1SHREREZo5c6YGDhwoHx8fffPNN2rWrNmte3NxSxTFfdZut6tevXry8/PT999/r6VLlyogIMCxvd69e+vAgQPq2bOnY5q3t7diY2O1cuVKBQUFqWrVqipRooQWLFhwC95V4M5lM4ZGX8CNio+PV5UqVbR///4r2qMAhRH7LIBbgRFKAAAAWEKgBAAAgCWc8gYAAIAljFACRdSlt78DCiP2UeDOQaAEiqCJEyeqT58+zi7jT116z2bceYrCPgrg5iFQAkXQ8ePHxdUqKMzYR4E7C4ESuIpNmzYpMjJSXl5eqlixooYPHy5jjFatWnVFQ+Tu3bure/fukqSYmBg1b95c9evXV9myZbVmzRpVrlxZffv2VUBAgMLDw5Wbm6tNmzbpsccek6+vr8LCwjR+/HjHB3BMTIyioqLUtWtX2e12BQUF6c0335QkzZgxQ2PGjNHatWtlt9vzrX3fvn1q27atfHx85O/vr5dfflnnz59X37591bx58zzLvvLKK+rWrZskaeHChWrYsKH8/f1VunRpNW7c2HHacvr06XrkkUf017/+VeXLl5e/v7969eqlrKysq76He/bsUfPmzeXr66uqVavqm2++ue7fA66uKO+jBw4cUKdOneTv76+AgAB16dLFcYecVatWKTg4WM8995zsdrvGjRunjIwM9e7dW2FhYSpTpozuuusujRkzxrG9ypUra+zYsQoPD5enp6fCw8O1cuVKx/zNmzfrkUcekZeXl+rVq6fRo0fnaZsUGxurBx98UHa7XbVq1dLs2bOv+r4nJiaqU6dOqlKlikqXLq2qVavq3//+d4F/b0Cx5IwbiAOFXUpKiilbtqyJiYkx586dM3v27DFBQUFm8uTJZuXKlebyfzrR0dEmOjraGGPMiBEjTIkSJczy5cvNyZMnTVZWlgkJCTH16tUzqampJjU11SQkJBgfHx8zYcIEk5mZaXbs2GFCQ0PN5MmTHduw2WxmxowZJjs723z//ffGZrOZDRs2OOY3btw439qzsrJMaGio6d27tzl58qQ5evSoqVevnhkyZIj5+eefTYkSJUxCQoIxxpjz58+bcuXKmRUrVphDhw4Zd3d3s2DBAmOMMcnJyaZRo0ama9euxhhjpk2bZiSZd955x2RmZppffvnFlClTxsyZMyffOho3bmzKly9vNm7caHJycszIkSONp6enyczMtPS7wQVFeR/NzMw0YWFhpnPnziYtLc2kpqaazp07m/vvv99kZWU56h85cqTJzMw0GRkZ5qWXXjJNmzY1qampJjc313zzzTdGkomLizPGGBMSEmJCQ0NNXFycOX36tImOjjY1atQwxhiTnp5u/P39zbBhw8y5c+fMtm3bTKVKlUxISIgxxpgtW7YYDw8PM2/ePJOdnW3Wr19v/Pz8zJIlS/Ktv2XLlqZr167m9OnTJjs723zwwQfGw8PDnDx50sqvFCjSGKEE8rFw4UJ5eHho+PDhcnd3V7Vq1RQbG6vWrVsXaP2qVauqSZMm8vT0lKurqyQpKipKdrtddrtds2bNUs2aNdWvXz+5ubnpnnvu0eDBgzVhwgTHNqpXr65u3brJxcVFrVq1UmBgoHbv3n3N516/fr3i4+P1z3/+U56envL399e3336rXr166cEHH1TNmjX1xRdfSJIWLVokb29vRUZGyt/fXzt27FDbtm118uRJHTp0SH5+fnnu+ezh4aGhQ4fKzc1N9evXV926df+0pk6dOum+++5TiRIl1KlTJ506dUpHjx4t0HuIP1eU99G1a9dq3759mjx5snx8fGS32zVlyhRt2bJFv/32m2O5F154QW5ubvLy8lJMTIy++uoreXt76/DhwypVqpSkC6OFF/Xs2VOhoaEqXbq0unTp4qhl4cKFcnV1VUxMjNzd3VWnTh298cYbjvWmTJmidu3aqUOHDnJxcVHDhg3Vu3fvPK/1Up9++qk++eQTlSxZUgcPHpSXl5fOnj2rEydOFOi9B4ojV2cXABRGSUlJCg4OznPasEaNGpIunMa9looVK/7ptPj4eG3cuDHP6cDc3Fy5uLg4fr70lnKS5Obmptzc3ALV7ufnp9KlSzumXXpqr0ePHpo5c6Zee+01TZ8+Xd27d5fNZpObm5vmzJmjyZMny2azqU6dOsrIyHCEDUny9/fP855cq6Zy5co5HpcsWVKSlJ2dfc3XgGsryvvo0aNH5efnJ29vb8c0Ly8vlStXTvHx8Y7tXlrPsWPH9Ne//lWbNm1SlSpV9MADDzhqyq8eNzc3x+n5Q4cOqVKlSipR4n9jKFWrVs3zWlesWJHntebk5KhatWr51r9v3z4NHjxYu3fvVvXq1RUWFnZFLcCdhhFKIB/BwcE6dOhQni8VzJ8/X59//rnjAzUzM9MxLzk5Oc/6l1+/dvm0oKAgNWnSRGlpaY7/9u/fr82bN9+U2pOTk3XmzBnHtLVr1+qf//ynJOn555/XH3/8oQ0bNmjZsmWO6+q++uorffzxx1q1apUOHTqkH374QeHh4Zbrwa1RlPfRypUrKzk5WRkZGY5p6enpSk5OVmBgYL71dOzYUQ888ICOHz+uTZs2aezYsQV+vpCQEB08eDDPe3XgwAHH46CgIHXv3j3Pa929e7d++OGHK7aVlZWlNm3a6Pnnn1dKSop++ukn9e/fv8C1AMUVgRLIR+vWrZWVlaUxY8YoMzNTe/fuVf/+/XX27FmFhobK1dVVc+bMkXThYv4VK1Zc1/a7dOmiDRs2aPbs2crOzlZSUpLatGmjgQMHFmj9UqVKKSMjI99v0T744IOqXr26XnvtNZ05c0ZHjx7VwIEDdezYMUkXRhlbt26tfv36qVGjRqpUqZKkCx/oLi4u8vDwkDFGS5Ys0cyZM/OEEhQeRXkfrV+/vmrVqqW+ffsqPT1d6enpeumllxQaGqqIiIh8t5eeni4PDw+5uLjo+PHj+stf/iJJBdo/n3zySeXm5jreq127dun99993zO/Zs6e++OILLVu2TLm5uYqLi9Ojjz6qv//971dsKzMzU2fOnFHp0qVls9l08OBBvf766wWuBSiuCJRAPux2u5YuXarly5crICBAkZGRevHFF9WnTx8FBgbqww8/1KhRo+Tt7a0JEyaoR48e17X9kJAQLVmyRFOmTJG/v7/q1q2rmjVravr06QVav23btkpJSZGPj4/S0tLyzHNzc9OiRYuUkJCgSpUqqW7dunr00Uc1cuRIxzI9evTQ5s2b9cILLzimRUdH6/HHH1etWrVUvnx5vfPOO+rfv7927drFB2UhVJT3UVdXVy1atEjZ2dmqXr26QkJClJmZqf/+9795LrG41LRp0/Tll1/K29tb999/v4KCghQeHq7t27dfs5YyZcpowYIFmj9/vnx9ffXss8+qefPmjsswHnroIc2ZM0dDhw6Vr6+vGjdurCeffFLvvvtuvtuaNm2aRo4cKS8vLz322GNq1qyZKlSoUKBagOKKWy8Cd6Bt27apcePGSkpKcny5ASiuUlJStHPnzjyjnx9//LHmzp2r9evXO7EyoPhghBK4g5w8eVK///673nrrLfXo0YMwiTtCdna2mjRposWLF0u68CWcTz75RG3atHFyZUDxwQglcAf5v//7Pz344IOqV6+eFi5cKF9fX2eXBNwW8+fP17Bhw7R//37Z7XZ1795dI0aMuOopdgDXh0AJAAAASzjlDQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJRAEff5559r8+bNzi4DuCGbN2/WrFmznF0GAIsIlEAR984772jOnDnOLgO4IXPmzNGoUaOcXQYAiwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJAAAASwiUAAAAsIRACQAAAEsIlAAAALCEQAkAAABLCJQAAACwhEAJ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GzfONGjQIM8yU6ZMMbVr13Zs4/IDQcWKFc2MGTMc8692QEtNTTVubm5m7969ZuvWraZq1aqmXbt25oMPPjC5ubkmMDDQsR9LMt98802eGqpVq2aM+fNAea36LxcVFWWGDRtmjDEmPDzcDBgwwNSpU8cYY8wbb7xhevToke96uH5F+dh5MVCuW7fOMa1ly5aO0aGLOnfubF555RVz7tw54+7ubpYtW+aYt2XLlusKlO+8884V+/LgwYNvOFB++umnxsvLyyxcuPCG1kfRPv4ac+HfzHfffef4edeuXUaSSUhIcNR/8Q8sYy6Mlk+cODHPNjp27GhefPFFk5OTYypUqGCWL19uTpw4YTw9Pc2LL75o/vKXvxhjjHnooYccdYWEhJixY8c6trFs2TJjs9nyrfHPjhM3Q947ljvZ5TdWl6R77723wOtfehP4/KbFx8drxYoVstvtjmk5OTl5broeEBDgeOzm5iZJee6neTUPP/yw5s2bp48++kjvvfeeSpcurVdffVVvvfWWSpS4+qWqUVFRatKkiaZMmXLN58CtlZSUpODg4Dz3fq1Ro4akC99QvZaC7H8bN27Ms//l5ubKxcXF8fOl+590YR8syP5nt9sVGRmpxYsX6/Tp02rWrJlq1qyppUuXKiIiQrm5uXrkkUccy5crV87xuGTJksrOzr7mcxSk/ku1b99e48ePV79+/bR3714tWbJEH330kY4ePar58+fr73//+zWfEwVTlI+dV3u+VatWadKkSY5p2dnZatq0qVJSUnT+/HlVqlTJMe/SOgri0KFDV3zZpmrVqvrll1+uazuStGnTJr388stavny5GjVqdN3r44KifPy9qEqVKo7HF/fPS+8xfmk9R48eVdWqVa9Yf+vWrSpRooSefPJJLV68WMnJyYqIiFDLli315ptv6siRI9q8ebPatm2bb91ubm5XvdbT6nHiWgpVoAwODtb27dvzTJs2bZr8/f2veVN2SXl2xPymBQUFqXv37po8ebJjWlJS0k250PbgwYOqUKGCli5dqszMTMXGxqpDhw6677771Lp163zXSUlJ0datWzVnzhzLzw/rgoODdejQIRljHPvN/PnzlZGR4fjwyczMVMmSJSVd2P/8/Pwc6xdk/2vSpImWLFnimJaSkqKTJ0/elPqfeuop/fDDD8rMzFTfvn11zz336K233tK8efPUrl27P/3DpiCut/7WrVvrhRde0Jw5c9S4cWP5+/vrgQce0OTJk5WQkKDHH3/cUj34n6J87Lza83Xr1k1DhgxxTDt48KA8PDzk4+OjUqVKad++fY7Acb1fhAkJCdHChQvzTDtw4MAN1b1y5UqFh4cTJi0q6sdfSUpMTHQEtH379kmSKleurB07dlxRT+XKlbV379486+/du1eBgYGSLhzPX3/9daWnp6t58+Zq0qSJ9uzZoylTpigyMlK+vr7XXd+fHSeullOuR6H6lvezzz6rTZs2aebMmcrJydHGjRs1cOBAubm5qWbNmjpy5IhWrlwpY4xmzZqlP/7447q237NnT33xxRdatmyZcnNzFRcXp0cffbTAIyWlSpVSenp6vvN+/fVXtWjRQlu3blXJkiVVoUIFScqzw1/O19dXx48fdxwU4VytW7dWVlaWxowZo8zMTO3du1f9+/fX2bNnFRoaKldXV0f4j42N1YoVK65r+126dNGGDRs0e/ZsZWdnKykpSW3atNHAgQMLtH6pUqWUkZFx1Q/xp556SqtXr9ZPP/2kJk2a6O6771a5cuU0ceJEdejQ4bpqvfQ5L+7z11u/j4+PGjdurNGjR6t58+aSpObNm+u9995T69at5e7ufkM14UpF+diZnz59+uijjz7Sr7/+Kkn67bffdP/992vOnDkqWbKkunXrpmHDhunw4cNKT0/X66+/fl2v5/nnn9eWLVsc79fPP/+sqVOnXtc2LnrppZe0bNmyG1oX/1PUj7+SNGLECCUmJio1NVWDBg1Shw4dVL58+XyX7dWrl959911t2rRJOTk5+vrrr7VgwQJ1795dktS0aVMdOnRI3377rZo3by4vLy81aNBA77333g0fz//sOHEzFKpAWa1aNf3www+aOHGiypYtq2effVb/+Mc/1Lx5cz3wwAP629/+pujoaJUtW1bLly9XVFTUdW3/oYce0pw5czR06FD5+vqqcePGevLJJ/Xuu+8WaP1OnTpp/fr1eU61XPT0009r0KBBevLJJ1WmTBl17NhR//znP/XQQw9ddXuHDx9W5cqVuS95IWG327V06VItX75cAQEBioyM1Isvvqg+ffooMDBQH374oUaNGiVvb29NmDBBPXr0uK7th4SEaMmSJZoyZYr8/f1Vt25d1axZU9OnTy/Q+m3btlVKSop8fHyUlpZ2xfyKFSuqVq1aql27tuO0TvPmzVWyZEk1adLkumq9qGfPnho6dKi6du16Q/W3b99eycnJjkD5xBNP6MyZMzd8QET+ivKxMz9RUVEaM2aMevToIW9vb0VFRWnAgAH6y1/+Ikn68MMP9eCDD6pOnToKCwv70+NsfoKCgjRv3jyNGzdOPj4+eu2119SiRQvH6Nf1+Oc//6mGDRte93rIq6gffyWpRYsWeuihhxQWFqYKFSros88+u+r2Bg4cqH79+qlTp07y8fHRmDFjNHfuXDVu3FiS5O7urpYtW8rNzU21a9eWdOH4ee7cOT311FPX89Id/uw4cTNwpxwAwB3l0KFDSk5OVnh4uGPaoEGDdOTIEc2ePduJlQFFV6EaoQQA4FZLTk7WI488oo0bN0qStm3bplmzZqlNmzZOrgwouhihBADccf71r39p3LhxSkpKUkBAgF555RX179/f2WUBRRaBEgAAAJZwyhsAAACWECgBAABgCYESAAAAlhAoAQAAYAmBEgAAAJYQKAEAAGAJgRIAAACWECgBAABgCYESAAAAlhAoAQAAYAmBEgAAAJYQKAEAAGAJgRIAAACWECgBAABgCYESAAAAlhAoAQAAYAmBEgAAAJYQKAEAAGAJgRIAAACWECgBAABgCYESAAAAlhAoAQAAYAmBEgAAAJYQKAEAAGAJgRIAAACWECgBAABgCYESAAAAlhAoAQAAYAmBEgAAAJYQKAEAAGAJgRIAAACWECgBAABgCYESAAAAlhAoAQAAYAmBEgAAAJYQKAEAAGAJgRIAAACW/D9gqtaMbrJGmAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "task_graph = taskgen.TaskGraph(starting_operators=config.STARTING_OPS,\n",
    "                               ending_operators=config.ENDING_OPS,\n",
    "                               min_depth=5)\n",
    "task_graph.plot_graph()\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "823e9179-c93d-4d88-8522-40bcf4ba6a78",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "89a5dbd3-ee0f-4825-946c-4f484b78fccc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current brown g + current yellow l sum is even , then [ if current cyan h product is odd , then color of current s , else current white w sum is odd ] , else [ if current orange a product is even , then current red g exist , else current brown c product is odd ] ]\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "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YSGysrIarOd0OuF0On33rVar77bRaLzGkQNTn6d0LrPVla3GbVZrthACDofjiutpxDXsen7wwQd4++23sWHDhgaP5+bmIi8vr9H6FosFJpPpauOIiILOZrMhIyMDVVVVMJvNza4X0J7r/v37UVpaikmTJgEAPB4P9PrGPyInJwfz58/33bdarYiNjQUAZGVlwW63BxJ7TYxGIwoKChTPZba6stW4zWrN9nd/NKBy9Xg8mDt3Lm677TaYTCasWLGi0SEBADAYDDAYDE3+DLvdrvgvIZi5zFZXthq3Wc3ZlxNQuQ4fPhxz587FiBEj4Ha7MXXqVKSnp8uajYgoZAV8Kta8efMwb948CaMQEbUdvEKLiEgClisRkQQsVyIiCViuREQSsFyJiCRguRIRScByJSKSgOVKRCQBy5WISAKWKxGRBCxXIiIJWK5ERBKwXImIJGC5EhFJwHIlIpKA5UpEJAHLlYhIApYrEZEELFciIglYrkREErBciYgkYLkSEUkQULlu2bIFQ4cOxYABAzB37lxZMxERhTy/y/X48eOYM2cOPvjgAxw+fBhfffUVPvzwQ5mzERGFLL2/K27cuBHTp09Hr169AABr1qyBwWCQNhgRUSjzu1yPHj0Kg8GAe++9FydOnMA999yD5557rsl1nU4nnE6n777VavXdNhqN1zBu4OrzlM5ltrqy1bjNas0WQsDhcFxxPY0QQvjzAx988EHs3r0bf//73xEZGYlJkybht7/9LTIzMxutm5ubi7y8vEaPWywWmEwmf+KIiFolm82GjIwMVFVVwWw2N7ue33uuPXr0QGpqKrp16wYAmDx5Mvbt29dkuebk5GD+/Pm++1arFbGxsQCArKws2O12f2OvmdFoREFBgeK5zFZXthq3Wa3Zfu6P+l+ud999N+6//36cP38eZrMZ27dvxz333NPkugaDodnjsXa7XfFfQjBzma2ubDVus5qzL8fvswWGDx+OnJwcjB49GgkJCYiJicGsWbNkzkZEFLL83nMFLr6kz8rKkjULEVGbwSu0iIgkYLkSEUnAciUikoDlSkQkAcuViEgClisRkQQsVyIiCViuREQSsFyJiCRguRIRScByJSKSgOVKRCQBy5WISAKWKxGRBCxXIiIJWK5ERBKwXImIJGC5EhFJwHIlIpKA5UpEJAHLlYhIApYrEZEEfpfrihUrkJyc7PvTsWNHzJgxQ+ZsREQhy+9ynTNnDg4ePIiDBw/ivffeQ4cOHfDiiy/KnI2IKGRd1WGBRx55BHl5eYiJiWnpeYiI2gR9oE/47LPPUFZWdtlDAk6nE06n03ffarX6bhuNxkAjr0l9ntK5zFZXthq3Wa3ZQgg4HI4rrqcRQohAfvB9992HcePGITMzs9l1cnNzkZeX1+hxi8UCk8kUSBwRUatis9mQkZGBqqoqmM3mZtcLqFzr6uoQExOD48ePIzIystn1mtpzjY2NhcViQXZ2Nux2u7+R18xoNKKgoABZWVmK5jJbXdlq3Ga1ZtfvuV6pXAM6LHD48GHEx8dftlgBwGAwwGAwNLnMbrcr/ksIZi6z1ZWtxm1Wc/blBPSG1rFjx9C7d29ZsxARSROdno6bNm1CWOfOiuQFtOealpaGtLQ0WbMQEUljiI5G1E03QRserkger9AiIpKA5UpEJEHA57kSEbUVpuuvh/anN99tx4/D24JvjLFciUiVNHo9Br/9Ntr37w8IgX3jx6Pqyy9b7OezXIlINbQGA/q/8AI8NhsgBErefPPibQA9pk5Fp1tvxYk//7lFsliuRKQa2rAw9Lj3Xrirq1FXXo4T//3fsB0/DgAYlpkJr8vVYuXKN7SISHXObNyIz0eNgu3ECWkZLFciUg2v04ljf/wjzmzYAK/DAVxy9f/Jv/wF5z79FP2eew4R/ftfcxbLlYhUw+tyoaSwEJW7djVadmb9elzYuxd9srNhjIu75iyWKxGRBCxXIiIJWK5ERBKwXImIJGC5EpEqVH/zDU6vWeO7aKApzrIylL7zDhwlJdecx4sIiEgVKrZvR8X27Zddx3b0KL599NEWyeOeKxGRBCxXIiIJWK5ERBKwXImIJGC5EhFJwHIlIpKA5UpEJEFA5fruu+8iMTERiYmJWLBggayZiIhCnt/larfbkZ2djb/97W/4+uuvsXv3buzcuVPmbEREIcvvK7TcbjfcbjfsdrvvttFobHJdp9MJp9Ppu2+1Wn23m3uOLPV5SucyW13ZatxmtWYLIeBwOK64nkaISz6K+wpeffVVPPHEEzCZTLjtttuwfv16aDSaRuvl5uYiLy+v0eMWiwUmk8nfOCKiVsdmsyEjIwNVVVUwm83Nrud3uR4+fBgzZ87Etm3bEBUVhYyMDIwYMQK/+93vGq3b1J5rbGwsLBYLsrOzYW/B7wa/EqPRiIKCAmRlZSmay2x1Zatxm9WaXb/neqVy9fuwwLZt25CSkoJu3boBAGbNmoXly5c3Wa4GgwEGg6HJn2O32xX/JQQzl9nqylbjNqs5+3L8fkNr8ODB2L59O6xWK4QQ2LJlC2666SaZswWNOVKDCFPjwx1ERP7yu1zvuusuzJgxA0OHDsWgQYNQV1eHhQsXypwtKMLCgI9Xd0L+75vf3SciupKAPs/1ySefxJNPPilrllZBA6BjBy3M7bnnSkRXj1doERFJwHIlIpKA5UqkMhEREcjIyEBCQkKDx3U6HaZMmYKRI0c2es5dd92FsWPHKjVim8ByJVKZLl264I033sCECRMaPB4eHo78/Hw88MADjZ6zaNEiPP3000qN2CawXImIJGC5EqmM3W7Hxx9/jPDwcKSmpiIsLAx9+/bFmDFjsGfPHly4cAFjx45F+/bt0a1bN4wfPx4//PAD9uzZE+zRQwrLlUhlzp49i8mTJ6NDhw5Yu3YtIiMj8Zvf/AZr1qzBE088gSNHjmDr1q3o27cvhg8fjg8//BBvv/12k1djUvNYrkREErBciYgkYLkSEUkQ0OWvRNR2rF69GgcPHsQrr7yC48eP4/7770dFRQU+/fRTZGRk4LHHHkNtbS3S0tLw3XffBXvckMM9VyKVOnz4MLZt24Zx48YhPDwcGzduhM1mQ1FRETZs2IBhw4ahb9++WLduHSoqKoI9bshhuRIRScDDAr/g9gB5f65GeaU32KMQSVdbW+s7/epSXq8XixcvRnV1dZAmC30s11/wegHLpit/+RhRW+B0OlFQUNDocSEE3nvvvSBM1HbwsAARkQQsVyIiCViuREQSsFyJiCRguRIRScByJSKSIKByffHFF9G/f38MGjQIixcvljUTEVHI87tcP/nkE7zzzjvYt28fvvrqK+zZswcbNmyQORsRUcjyu1wPHDiA8ePHIyoqCjqdDuPHj8emTZtkzkZEFLL8vkLrxhtvxOOPP46cnByYTCZs3rwZXm/Tl4g6nU44nU7ffavV6rttNBqvYdzA1ecpnctsdWWrcZvVmi2EgMNx5as4NUII4e8Pzc/Px6pVq9CpUyff9+1s3bq10Xq5ubnIy8tr9LjFYoHJZPI3joio1bHZbMjIyEBVVRXMZnOz6/ldrtXV1Th37hzi4uIAAH/4wx9w6tQpvPLKK43WbWrPNTY2FhaLBdnZ2bDb7QFuztUzGo0oKChAVlaWornMVle2GrdZrdn1e65XKle/DwsUFRXht7/9Lf75z3+ipqYGb775ZpMf+AAABoMBBoOhyWV2u13xX0Iwc5mtrmw1brOasy/H73JNSkpCeno6Bg8eDLfbjfnz5+PWW2+VORsRUcgK6CMHc3JykJOTI2sWIqI2g1doERFJwHIlIpKA5UpEJAG/5oWadduAKPTt+vNZH7Y6LzZ+eQ4uj9+nRhNdUbfUXmj/Hz+f0uS2uVG89iiEK7S/x47lSg1EGLTQaTUAgIG9TEjuE+FbZrV7sOtIFapsbjjdLFi6eroIPbT6iy+cOwzujA43dvUtc1XVoWxHMVwX6uB1eoI14jVjuVIDj9zZEwNiLl5F9+auMhR+VuZbFmXSIW9ab3x08Dw2H6gM1ojUBvSbn4yoxE4AgGMrvsGx17/1LQuLMmDQH0aidEsRTq0/HqwRrxnLlRowhGnhcHmx60gVfqxwwFb380szrwB2HL6AY2X8dly6Nrp2OngcHpTtLEbtCSs8te6fF3oFznx0EjU/XAjafC2B5UoAAK0GCNdr4PEInD5fh7V7Khqt43B5seHLc0GYjtoMrQbacC2E2wt7aQ1OvvNDo1U8dg+K1x4NwnAti+VKAIABMSZk39UTb+4qww+nW9+lhNQ2RA3shH7zk3Fs+Tewfnc+2ONIxVOxCAAQptOgU4QejjovrPbQfROBWjdtmBbhnQ3w2N1wW+uCPY5ULFcCAAgBeLyARgPotBf/aJpYT6e9uA7R1RACEB4BjVYDje7in6b+ojX3eChhuRIA4F+nbfid5QRSB3bASxl98VJGXwy+5DQsADAbdXj+N31w58AOwRmSQp71SCW+yv47uo+NxZClv8KQpb9Cx0tOwwIAvTkcg/40Cj3G9wnSlC2Dx1wJAOB0CZw6X4eSc078dJorYjqGw6D/+d/fcL0GZ6pcPGxAV83r8MBeUgvbyRpofvqLZuzVHlqDzreONlwHx2kbXFXO5n5MSGC5UgPr9v18NsC8cdH4f6MjfffP17rx+OoTsIf4lTMUfMXv/tt3u/8TQ9B39gDf/bpKJw7M2QVPiP8jznKlZq3dU44PD/58sYDHCzjdLFZqWT++8wNKN5/w3RduAU8IX5lVj+VKzTp9wQXAFewxqI1zlNbCURrsKVoe39AiIpKA5UpEJAHLlYhIApYrEZEELFciIglYrkREErBciYgkYLkSEUmgSLkKcfH7lmw2m++2UoQQQclltrqy1bjNas6uz78cjVBgspKSEsTGxsqOISJSTHFxMXr16tXsckXK1ev14vvvv0dCQgKKi4thNpuv/KQWYrVaERsbq3gus9WVrcZtVmu2EALV1dWIjo6GVtv8i39FPltAq9UiJiYGAGA2mxX/JQQzl9nqylbjNqsxOyoq6orr8A0tIiIJWK5ERBIoVq4GgwHPPPMMDAaDUpFBzWW2urLVuM1qzvaHIm9oERGpDQ8LEBFJwHIlIpKA5UpEJIEi5WqxWJCQkID4+HgsXbpUicgGqqurkZSUhKKiIkVz8/PzkZiYiKSkJGRlZaGurk6R3JycHAwYMAAJCQnIz89XJPOXFixYgMzMTEUz09PT0a9fPyQnJyM5ORkbN25ULHvLli0YOnQoBgwYgLlz5yqWu2LFCt/2Jicno2PHjpgxY4Yi2e+++y4SExORmJiIBQsWKJJZ78UXX0T//v0xaNAgLF68WNFsvwnJSkpKRO/evUVFRYWoqakRgwYNEocOHZId67Nnzx4xePBgERYWJk6cOKFY7t69e8XAgQNFTU2N8Hq94v777xf5+fnScz/88EMxevRo4XK5RG1trYiLixP/+te/pOdeaufOnaJLly5i5syZiuZef/314ty5c4pmCiHEsWPHRHR0tCguLhYul0uMHj1abN26VfE5vv/+exEXFydKSkqkZ9lsNtGpUydRVlYmXC6XGDZsmNixY4f0XCEu/v1KTEwUFy5cEG63W9x9991i/fr1imQHQvqe686dO5GamorOnTsjIiIC06ZNw7p162TH+qxYsQKvvvoqoqOjFcsEgI4dO2Lp0qWIiIiARqPB4MGDcfLkSem5EyZMwCeffAK9Xo/y8nJ4PB5ERERIz61XWVmJRYsW4amnnlIssz63vLwc6enpGDRoEPLy8hT7QI+NGzdi+vTp6NWrF/R6PdasWYMRI0Yokn2pRx55BHl5eb6rIWVyu91wu92w2+2+20ajUXouABw4cADjx49HVFQUdDodxo8fj02bNimSHQjp5VpaWtqg2Hr27InTp0/LjvUpLCzE6NGjFcurFx8fj9tuuw0AcPbsWSxduhSTJk1SJDssLAxPP/00BgwYgDvuuEOR/9nqPfzww1i8eDE6duyoWCYAnDlzBqmpqXjrrbewZ88e7N69G4WFhYpkHz16FF6vF/feey8GDx6MZcuWoVOnTopk1/vss89QVlam2CGByMhIPP/887jhhhsQExODPn36YNSoUYpk33jjjdi+fTsqKyvhcDiwefNmRTvFX9LL1ev1QqPR+O4LIS77YQdtTVFREVJSUvDggw8iJSVFsdznn38eFRUVKCkpwRtvvKFI5sqVKxEbG4vU1FRF8i6VkJCA9evXo0ePHjCZTMjOzsbWrVsVyXa73di2bRv+8pe/YM+ePdi7dy/eeustRbLrLV++HPPnz2/w/5pMhw8fRmFhIX788UeUlpZCo9HgT3/6kyLZqampyMzMxO23345x48bh1ltvRXh4uCLZgZDecr169Wrwr8qZM2cUf4keLAcPHsQtt9yCOXPmYNGiRYpkfvvttzh8+DAAwGQyYfLkyTh06JAi2WvXrsXHH3+M5ORk/Nd//Rc2b96Mxx57TJHs/fv3Y/Pmzb77Ho8Her0in0uEHj16IDU1Fd26dYPRaMTkyZOxb98+RbIBoK6uDp988gmmTp2qWOa2bduQkpKCbt26wWAwYNasWdi1a5ci2dXV1ZgyZQoOHTqEXbt2ISwsDNddd50i2QGRfVC3pKRE9OnTR5SVlYmamhqRlJQk9u7dKzu2kT59+ij6htbZs2dF9+7dFT/Q/v7774tRo0YJp9MpHA6HuOOOO8TatWsVnUEIIQoLCxV9Q2vPnj0iLi5OXLhwQdTV1YkxY8YIi8WiWPb1118vKisrhdvtFpMmTRJvvPGGItlCCLF//34xcuRIxfKEEGL79u0iMTFRVFVVCa/XKx566CHx+9//XpHsQ4cOiaSkJFFXVycqKytFfHy82L17tyLZgZD+T3tMTAyWLFmClJQUuFwuzJ49G8OGDZMdG3Qvv/wyrFYrnn32WTz77LMAgIkTJ0o/bWTatGk4cOAAkpOTodPpkJaWhrS0NKmZrcHw4cMxd+5cjBgxAm63G1OnTkV6erpi2Tk5ORg9ejRcLhdSU1Mxa9YsRbIB4NixY+jdu7dieQBw1113YcaMGRg6dCgMBgOGDh2KhQsXKpKdlJSE9PR0DB48GG63G/Pnz8ett96qSHYg+NkCREQSqOedJSIiBbFciYgkYLkSEUnAciUikoDlSkQkAcuViEgClisRkQQsVyIiCViuREQSsFyJiCRguRIRSfD/ASW/G8zt9WWuAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 3\n",
    "\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "105f8455-0282-44c4-9cbb-594b2ea68bcb",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph, but add more distractors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "38934b55-00a1-4ead-9791-529a1271bc22",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current brown g + current yellow l sum is even , then [ if current cyan h product is odd , then color of current s , else current white w sum is odd ] , else [ if current orange a product is even , then current red g exist , else current brown c product is odd ] ]\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVcAAAFwCAYAAAAMmDiWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABMvElEQVR4nO3deVxU9f7H8deZGRhm2AQEFUXNJRdEKc1MMzNtMctb2bW0+qVUVyvL8rZoy03b63a93bK9tJWsm5WWpVldyyz3fd8VFJB1WGafOb8/RlECFJQzAzOf5+PRIzjnwPt7GPj4ne/5nu9RVFVVEUII0aB0gW6AEEIEIymuQgihASmuQgihASmuQgihASmuQgihASmuQgihASmuQgihASmuQgihASmuImDk/hURzKS4ioDYunUrAwYMqLJNURSmTZvml/z27dszduxYv2SJ0GQIdANEaPr888/5448/qmz7448/aNOmTYBaJETDkuIqGo1+/foFuglCNBgZFhCaWbt2LUOGDCE2Npbo6GiGDh3KihUrmDZtGtOnTweqDgWc+PGSJUtQFIWff/6ZwYMHYzKZaNu2Le+++y45OTlcd911REVFkZKSwssvv1yZeezrlixZUqUtF198MRdffHGN7dy/fz+KovD+++9X2T527Fjat29f+fnevXv5y1/+QkJCAmazmQsuuIDvv//+DH5CIphJcRWaKC0t5YorrqB58+Z88cUXzJkzh4qKCi6//HLGjRvHbbfdBviGAm6//fZav8+NN97I1VdfzTfffMPZZ5/NhAkTGDx4MGlpacydO5fevXtz//33s3LlSk3Px+v1ctVVV1FeXs5HH33EvHnzSEhIYMSIEezevVvTbNE0ybCA0MTWrVvJz8/n3nvvrbxw1bVrV9566y10Ol3l2OqphgIyMjKYPHkyAFFRUVxwwQX07du3sufbp08f5s2bx++//07fvn01O58jR46wbds2Hn30Ua688kqAynbY7XbNckXTJcVVaKJHjx4kJiZy9dVXc8MNN3DllVcyZMgQXnzxxXp9n/79+1d+3LJlS6BqQU5ISACgpKTkzBt9Ei1atKB79+7ccccdLF68mGHDhnH55ZczY8YMTXNF0yXDAkITUVFRLF26lOHDhzNnzhxGjBhBYmIi48ePr1dPLyYmpto2s9nckE2tE0VRWLx4MWPHjmXhwoXceOONJCUlccMNN1BUVOT39ojGT3quQjNdunTho48+wuPxsHLlSj766CPeeOMNOnTooFmmoigAeDyeKtvLy8uJioqq99ecKDk5mddff53XXnuNDRs28MUXX/D8888THx/PG2+80VCnIIKE9FyFJr744gsSExPJzc1Fr9dzwQUX8Prrr9OsWTOysrLQ6/Wa5B7r6WZlZVVuKy4uZuvWrfX6GpfLVeUi2R9//EGLFi1YtWoViqKQnp7O008/TVpaWpWvE+IY6bkKTQwYMACPx8M111zDlClTiImJ4bPPPsNisTBy5Eg2b94MwKeffkq/fv0466yzGiS3Z8+epKSkMH36dGJjY9Hr9Tz33HNERkbW+jVxcXH079+fV199lc6dO9O8eXNeeeUVbDZb5dedc845mM1mbrnlFqZNm0bLli358ccfWb9+PZMmTWqQtovgIj1XoYlWrVqxaNEiYmNjue222xg+fDhr165l7ty5DB48mJEjR3Leeedx66238s9//rPBcvV6PXPnziU5OZnRo0dzzz33cMMNNzBy5MiTft3777/Peeedxx133MGtt95Keno69913X+X+iIgIfvjhB1JTU5k0aRKXX345X3/9NW+99ZbcRitqpMjTX4UQouFJz1UIITQgxVUIITQgxVUIITQgxVUIITRQr+KamZlJ9+7d6dy5MzNnztSqTUII0eTVebbAoUOH6N+/P2vXriUiIoL+/fvz8ccfk5aWpnUbhRCiyanzTQQ//vgjQ4YMqVwo4/rrr+eLL76oU3H1er0cPnyY6OjoylsNhRCiKVJVlbKyMpKTk9Hpan/zX+fievjwYZKTkys/b9WqVa1raDocDhwOR+Xnhw4donv37nWNEkKIRi8rK+ukjyWqc3H1er1Vep2qqtZatZ977rnK9TZP9O677wZkRSMhhGgoVquV22+/nejo6JMeV+fi2qZNG5YuXVr5eW5ubpWe7ImmTp1aucAx+FalT0lJwWw2M3HiRGw2W11jz5jJZGLWrFlkZGT4NVeyQys7FM85VLOPXaY61RBnnYvr0KFDeeKJJzhy5AiRkZH897//5d13363xWKPRiNForHGfzWbz+4sQyFzJDq3sUDznUM4+mToX19atW/Pss88yePBgXC4Xt99+u6aP1RBCaCPKrHDdsAjWbnaxeYc70M0JWvVacnDMmDGMGTNGq7YIIfwgIV7HG8/E8sSMMimuGpI7tIQQQgNSXIUQQgNSXIUQQgNSXOugQ1IE00a2ZdrItoy/xPd455HnJXDv5cnog+QnGNunD30WLCC6V6/KbR2nTKHPggX0WbCAxOHD/dYWBR03xd/PPUnPc0/Sc7QMa6tZ1sNRZ/NybK+T/iFcHdGKOfHn00JX8wyY06FDzy0JD3BFzOiTHndZzA38X8KD6NHmmWNCO/IMrVpER+hJjgsHoFWzcHRHp7SZwnV0TTbRtbWZFjFhR+e6Nf2HOYQ1a0Zc//7E9euHPiICgPDmzVGOPkjQ3KEDMeeeS+n69eD1Nni+go6U8I7oMaBTdBh1JnSKDlSV1mFnoaCQ4zrQ4Llnh0XTQR+JQu2vYyt9BH3D4zAqDVfgFBTahndGd4r+TYuwFNqFn42CDvCc9FjRuEhxrUVaiplJV/huktiUZeUfXxwE4KxEI8/d0B5FgTyLK5BNbHCKotDl+ecrP9+YkcG2Bx4AoOtLL9HurrtYdt55eP70yOmGEKaEc1vzR4nVJ+DFwws595Dn9j1VdVKLF/GoHmYemdrguUJoRYrrKXyyLJ8dOX+aoKyc+u6MpkpRFCp272bXtGlY1qyptk9r2+3r+K18ASWeguO5R/uVWphZvofOhijeanYOH1oP8qvzeK5Z0fNsTA9yvHYmFK8l3+s4yXeqHy8e/lv8Bslh7cho/gjflLxPvvtw5f4EQ0v+0iyDvY6trKz4EQ8yZaqpCZIRw4bVMjYMU7iOrEIn6w5UVCmuTo9KdqGTCkdwvkWzHThA6fr1HPn2Wxw5OZXbnbm5WPftI7JTJ8KOrozWUCJ1MbQIa0OhO4/9jm1stq3AoR7/mRe6cynzWmgZ1hajYmrQ7HWuEta7SrgsogUp+qrf24DCJcZEItDxg+MINrXhXnMVlZ329Vg8RfQ0XYBJF1Vlv0mJJM3UjzJPMTvs61GDYOgp1Ehx/RODDh66ug2pbSJ56NN9ZBVW7a0cKnLy0Kf7WLe/IkAt1I6qqmy57z42jR9fbd/eGTPYeNtt9P7qK9qMG9eguRdEXc5dSU/zUeFLLCqdU23/x4X/ZlnZdzzU8hU6GlMbNFsIrUhxrUZBrygoCnhr6Sx41eOLNwQdj8f33595vageD4rBgHKSNSxPh4KCHj1evDX20FS8ePGiQ6/JAEGex85Dlk2kGMw8Ft2VcBSGGVvwSHRXXirfyXx7zqm/yWk66NzFnKJX6W0exMXR1wAwKHoEfSMv4bOimRxw7tAsW2hLiuufqKgUW9043V4SogwkRBmIMR2/SqzXQUKUAWNYcP7owps3x9i6NcbWrdGZjr9NNsTGYkxKwpGTg7usrEEz7V4rFk8h0bpmNNM3p5m+OboTph5F6WIx6cyUeApwqc4GzQawqG7m2LKJ14VzjSkZvaKjV3gz/mJKZoE9l3WukgbPPKbQncvyih84y9iVbhG9AegW0ZsOEamsqFhMgTtXs2yhLbmg9SceLzw7L4u+HaP59y0dANicVcGL3x4CICXeyPTr2xFuUMgvDb7ZAqmvv456tOe6ecIEjnzzDQAdH36YxCuvZOVll+EqLm7Q3N/Lv2eddSn3tfgnMfp4vHiYkft3jrizAbi1+UN4VS/P5kzApQbXz1wELymuNXC6VfYdsfPlqkIA9AqMvqA54BsS+Gp1If07RxMRZL1XVVXJ+fxzbPv3AxDdowcx6ekAuEpKOPj667hKSlBdDVvgPHiweSv4pWw+Rp0JBegTeXHlHNBd9o0UuvNwqg13tb4mC+25ZHtsTIrqhFP18u/yXVgb8CLWyfxW/h3N9M25Kvb/2OvYhsVTIBexmjgprrU4VOzk0Gpfce3e2swDw1sDcKDAzpNfZpESH07nlg175boxyP3iC4p+/RWA1JkzSTp6Z9bOxx/n0Mcfa5brwc3S8m8B391L97Z4gRaG1qjAm/lPcNC5U7PsY3525LPNVcbSxEH8p3w3b1fs0zzzmJUVP9ElIp07E5/izfwn2G5fq1mW16tSUurF7pDirSUprnWwI8fKpA/3AuBVQ6c/sX3KFHY+8QQAngr/zY7w4uGt/GmVPVebN/hmZgTSoVwvPS/Px2oLld/kwJDiWgceL5TZfW8PY0x6hqfHcaTURXaRE29tUwqCgKe8XJO7serC5vV/7sDw5vQIi+FD60FNL2LV5FzzIOINSSwp+5oi9xFNs7xeKCwO3t/bxkKKay0UBQy66tN+kmLCuPGCRN74MYffdzXsVXPhfwYU9Eend10V0ZKBxuYMKVjaoDcM1EaPwXf3maIwMHo4Nm8Fb+dXf7CnaJqkuNbinHaRjBvUotr2nBInD2Tuw2KV2xGDwdMxqQwy+i5Wvl2xj1fKd2P3S2HVMyFpOvH6JAC+KH6LQ849mucK/5HiWotSm4fth6s/9Cy/1BV0C7YA2HNyyJkzB0deXqCb4le73OWYjq52td1dxiGv3S+5KipZzt2U6AtBVTnizqbU27BT3ERgSXGtxe48O7sXa3dnTmNTvmULm++8M9DN8Lv3rPsDkuvFy/yS2QHJFv4RXBM1hRCikZDiKoQQGqh3cS0rKyMtLY39R+/iEUIIUV29iuuKFSsYOHAgO3bISj1CCHEy9Squb775Jq+++irJyclatUcIIYJCvWYLzJ5dt6ubDocDh+P4IhulpaWVH5tM/r0f/1iev3MlO7SyQ/GcQzVbVVXs9lNP2VPU01j1uX379ixZsoT27dvXuH/atGlMn179TpPMzEzMZnN944QQotGwWq2MGTMGi8VCTExMrcdpMs916tSpTJ48ufLz0tJSUlJSAMjIyMBmqz45Xysmk4lZs2b5PVeyQys7FM85VLPr2h/VpLgajUaMRmON+2w2m99fhEDmSnZoZYfiOYdy9snIPFchhNDAafVcZY6rEEKcnPRchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA1JchRBCA/UqrjNmzCA1NZW0tDQyMjJwOp1atUsIIZq0OhfXlStXMnv2bFauXMnGjRtxuVy89tprWrZNCCGaLENdD4yLi2PmzJlERkYC0KtXLw4ePKhZw4QQoimrc3Ht3LkznTt3BuDIkSPMnDmT2bNn13isw+HA4XBUfl5aWlr5sclkOt22npZjef7OlezQyg7Fcw7VbFVVsdvtpzxOUVVVrc833r9/P8OHD2fMmDE8+uijNR4zbdo0pk+fXm17ZmYmZrO5PnFCCNGoWK1WxowZg8ViISYmptbj6lVc169fz/Dhw5kyZQr33HNPrcfV1HNNSUkhMzOTiRMnYrPZ6hp5xkwmE7NmzSIjI8OvuZIdWtmheM6hmn2s53qq4lrnYYH8/HyuuOIKXn/9da677rqTHms0GjEajTXus9lsfn8RApkr2aGVHYrnHMrZJ1Pn2QIvv/wypaWlPPnkk6Snp5Oenl7rsIBoeqK7NqPnP/sT1SnW79mDusXw+LUpRJv0fs8WQit17rk+88wzPPPMM1q2RQSQITKM6K7N0Jvr/CvRYOIjw+jUwoRBp/g9WwityB1aQgihASmuQgihAf+/B2yKwk0Q19r3sdsBhVkQ2wLCIqDgIFCv2WxNUnhCBHqzAVt2uV9Ot1WzcMINCiqQV+LE4Q7+n7HQVlJSEi1btqzTsfv27aOsrOyM8qS41kWbHvB/L/s+ztkBb90GQyZAm1R47SbwuALaPH9o89eOJPRrwdo7f8Fj82iapVfg71e2pk18OCrwxBcH2Jl76knbQpzMbbfdxlNPPVWnY//yl7+wYMGCM8qT4lqb1qnQ9+iUM1spfH30Yl64Ga59DNr2JBR6rGFxRtrd0gV7bgX73t2G1+nVJsegMPaiJBxuFVVV+WFTMQ6XFxTof3YM3Vub+XpNkSbZIjR8++23HD58uNb9jz76KB6Ph+eff54NGzaccZ4U19rEtYL0K6G8EPaugvXf+ba36gLDJ4Oig6LswLZRI4pBR3i8b56ysXkEsT3isWwqpOC3HM0yDTqFCzrHYHN6KLF6+GpVIbkW3zuCoanNcHuR4irOyKZNm9i0aVO17WazmaSkJK6//nrKy8v54IMPGiRPiutJqfD5Y5C9JdAN8avIs6JJe64fKAr2nArW3/cbHru2QwHH/LGrjPeW5OHyBP+7AtE4XHbZZXzyyScMGzaM5cuXN9j3leL6Z4oOBtzke/u/6FXfxasTx1RLj/i297wCIiID106NtBzWFtWjojPqyf/fIUo2FuKxuTUfAXF5vMxbU8S2Q9ZqhXXhxmISY8K55cJEft5i4VCxrCMszpxOp+Pvf/87MTExPP744+zevbtB16iWqVh/ptPDuVdDQhv4/VPfsMCJKop92/P3B6R5WlIUhbhzE4k7NxF3mYvidQUU/pHrl6FltwcWbyphU5a12r5lO8vYmWPlqnPiaREbpn1jRNAzGo0kJiZy3XXX0bp1a2bMmHHS8djTIT1XUUlVVXb+ewOlm31jmx3Gdyf5qvZsfOh3VHmbLoLIjTfeyAsvvMCIESPYunWrJhlSXP/M64E188AYCRfe7NtWnANbfvJ9HBkP6cMgqX3Amqglj9WNu9w3DFK8Jh9Hvp3ka86iZF0BFXtLT/HVp8+gh8t7NsPq8KIC/9tqofzoOO+FXWJIjA5j/toi8izBP+1NaCcsLIzbb7+d5s2bM2vWLPbv3095ebkmWVJc/0z1wrJPoPtguO4fvm3718HOZb6P45Lh4tsgzAgl2l09bwzylxwmItlM+owL8do92LLLNZuKZdApDD8nHlTweFU2ZVXgdHtRgCGpzXB5vDw7LzhnZwj/MBgMxMXF8dhjj/H9999z7733AtS4xrTD4cDjObOLuFJca7PrD3j1Rt/HrbvBPXN8HxcehNfGwLD7oUXHwLXPTxx5NtZO/JXW13Yg7YUL2DR1OV4NZg443CrTvzxISYUbvU7hrktbkRQThqrCu0ty2ZsnNxGIMzNhwgQeeughkpKSGDVqFJdeemmtx44bN46ff/75jPKkuNbGZQfL0T/ocLNvriv4eqslueAMrj92R4GdvMXZOIuqnpfqUXEW2CnfZQGvqsnY64ECO79ss5Bb4qTC4UVRYNshK7klvl/Pw8VOLBrfFSaC3759+/jhhx/qdGxBQcEZ50lxrYv8fcfv0ALfdC1U8GrzFjkQrAfK2P3Kxlr35y85RP6SQ5pkr91fwdr9FZWfqyp8tvzMf7mFONGCBQvO+JbW+pCpWPWV2B7u/BAObIBP/g4ed6BbJIRohKTnWpvoRGjdtfp2UywUH/LNcy3M8nuzhBBNgxTX2rTrBX+tYQWdnB3w5jhCYdEWIcTpk+Jam72rYdad1bc7bUhhFUKcihTX2lhL4MD6QLdCCNFEyQUtIYTQgBRXIYTQQL2K69SpU+nWrRvdu3dnxowZWrVJCCGavDqPuX733XcsW7aMTZs24XQ6SU1NZfjw4XTp0kXL9gkhRJNU5+J65ZVXcumll2IwGDh06BAej4fIyJoXi3Y4HDgcjsrPS0uPr6ZkMpnOoLn1dyzP37mSHVrZoXjOoZqtqip2+6lvf1dUVa3XvKLHHnuMGTNmMGrUKGbPno2iKNWOmTZtGtOnT6+2PTMzs8YVaIQQoqmwWq2MGTMGi8VCTExMrcfVu7ge++YjRoxg1KhR/O1vf6u2v6aea0pKCpmZmUycOBGbzVbfyNNmMpmYNWsWGRkZfs2V7NDKDsVzDtXsYz3XUxXXOg8LbNmyBa/XS1paGmazmWuvvZaNG2te6MNoNGI0GmvcZ7PZ/P4iBDJXsht/dpQulouir2azbQUHnbv8ltvQJLtxqfNsgW3btjFhwgScTicOh4Mvv/ySiy66SMu2CaG5cCWCBEMLBkQNIyW8ExGKDFuFElO4jkij7z9d9RHOM1Lnnuv111/P2rVrSU9PR6/XM2rUKEaNGtWwrRHCz/4adyeJYck8nzORK2JvZECLK/l33gO4VMepv1g0aToFpo5oQ3JcOKoKz8/PZs+RhlunuV63vz777LM8++yzDRYuRKDtdmyi1FtM78hBVHjL2GBdhleVhbmDXdsEI2ltzezIsbH76FMueqSYSYwJY/nusgbJkDu0REhbUfEjK8t/4srYmyh057GodA4eZI3eYHd2KxM3DUhiyTYLHy49wodLj5DeLpIhPZo1WIYs3CJCXoE7hxdyJlLu1e7ptqLxe2VRwz5wVIprI6KPjCRx2DDKNm+mYvv2mg9SFBIvvxx3RQXFS5f6t4EaSUtLIzU1lXnz5tGmTRv69esHwMGDB/nll1+qHDt48GDatGkDwLJly9i7d+8Z54cpRs4yduOAcyf57sZ31TmYhMcbie3VnJL1BbiKj49r600G4s9PonyXBduh44/8UfQK8f1a4Mi3Ub7TckbZbROMtE/0zWLq3DICHXDeWVF0TPK9U1l/oILSBnxWmwwLNCJhCQmkvvoqzU/yVEp0Ojo9/jjt7rrLfw3T2NVXX83bb79N8+bNueSSS5g9ezazZ89m4sSJ6HTHf0V1Oh33339/5f6BAwdW2X+6mhkSGJNwP52MaWf8vcTJRZ4Vw9mTe2FOiaqyPTzeSOf7ehHbq3mV7Tqjno7jU0m6pM0ZZ/c+K4q7hrbirqGtuLhbLIoCN/ZP5K6hrbhzaCtaxoafccaJpOcqGgWz2cx3333H4sWLOe+88wDo3bs3q1atYty4cYSFhfH222/zyiuv8MQTTwCQkZHBX//6V0aOHFnlphUhavLz1hLWHSgH4PyO0VzTJ4GXvz9MXqkTgJxiZ4PmSXFtRLw2G4U//4wuPJz4QYMoXrYM1X384ooxOZnoHj0o27wZawO8HW5M9Ho9PXr0YNmyZaxbtw6ADh06cM455xAZGUl4eDjnnHMOBQUFlfujoqJITU1tkN6r8A+XxUnxmnwiWpnxOj2UbS8hskMM5pQoStbmozfpie2ZgGVzEREtTZhToindVoz1YPkZZ1usHixW39v+Ti1MqEB2sYNDRQ1bVI+R38pGxJmfz/qbbiIsNpaes2ejj46usj/hkks4JzOT/f/5D3tfeCFArdRObXdi17R+xam+RjRO5bstbJ22isSLkjnr9u4AtPlrR1JGd2bbM2uISDLR5YF09EY9SYNbc/bkXux5cwu53x0IcMvrT3quolGwWq2MGzeODRs2VG779ddfGTp0KOPHj8fj8TB06NAq+1988UXmz5/PV199xaxZs/j8888D0XQhaiQ910bIlpVF2aZNxPToQUTr1qAoRKelYYiKwrJmDZ5GeB/1mfJ4PPz222/s2LGjclt+fj4///wznTp14qyzzuLnn3+msLCwcv+2bdtYu3YtAwcOpG3btoFothC1kuLaCGW98w4bx42j5/vvk3LHHegiIkj/+GOiU1NZecUV2PbtC3QThRCnIMMCjZWqVh1rPPaxjDGKIHDw012Y20TRdcq5lG4vJm9xNqpXJXdRFqXbS+g0sQfW7Ap2/nsD7nJXoJt7WqTn2kipXi8Ve/eier2YO3TAnp2NIy8v0M0SokGUbi6iYl8pCQNa4iywU7I2H1So2FtKyfoC4s5LAhWKluehuryBbu5pkZ5rI+W2WFh1xRW0u/tuzvv+e5YPGoTt4MFAN0sIUUdSXBuxY3NcdQaD72NPcK7WtHDhQo4cOYLFUvPtjS+99BJeb829l6KiIu677z5WrVqlZROFBux5Vva8sZnyPVVfd4/Vzb53t1GxV7u1HrYftjJ7SR4lFdot0iPFtbFSFMITE0FRcOTloQZpYQVYu3Yta9eurXX/V199Veu+srIy3nnnnXrlReqiAYUKWagloFwlTnK/q/5uzOvwkPdDlqbZ2UVOsjW6eeAYGXNtpAyxsZz/00+Excbyx4UX4shp2BV7QtktCQ/wfwkPBroZIshJz7URMcTG0vZvf0Mx+F6WQx99RMmKFXgqKk7xlaI+1lp/JV6fxLDYm45uUVlk+ZQs5+6AtksEFymujYghOpqUO+5AHxGBq7iYPwYNwl1SEuhmBZ2VFT/RLrwLdyY9CUCeK5v/5D2Il6Z5VVo0TlJcGxH74cP8MWCAb06rquKu5QKPOHPZzt08c3gCAF48UlhFg5Pi2ph4vTjz8wPdipDgwUOZtzjQzRBBTC5oCSGEBk6ruD7wwAOMHTu2gZsihBDBo97F9aeffuKDDz7Qoi1CCBE06lVci4qKePTRR3nkkUe0ao8QQgSFel3QGj9+PM888wxZWSe/e8LhcFR5plFp6fE7YUwmUz2beGaO5fk7V7JDKzsUzzlUs1VVxW63n/I4Ra3jczLeffddtm7dyowZM3j//fdZsmQJ77//fo3HTps2jenTp1fbnpmZidlsrkucEEI0SlarlTFjxmCxWIiJian1uDoX10svvZScnBwMBgNFRUWUl5dz880388orr1Q7tqaea0pKCpmZmUycOBGbH1fSN5lMzJo1i4yMDL/mSnZoZYfiOYdq9rGe66mKa52HBRYvXlz58bGea02FFcBoNGI0GmvcZ7PZ/P4iBDJXskMrOxTPOZSzT0bmuQohhAZOq7iOHTu21vFWIYQQ0nMVQghNSHEVQggNSHEVQggNyKpYovFRoM31HQmPM6KqcHj+PhSdQvLV7cldeBDrwfJAt/CM6dAxNOavlHgKWFnxEwBJhtZcGD0cgBJ3Pj+X1f54G1F/XSLOoUtEOj9YPsOuWlFQGBJzPTH6OFBVlpTNp8jTcE9YluIqGg1DTBiKoqDoFeL7tiCilRlUKF59BJ1RT6ur21O8riAoiquCjvMiLyHXdZCtttUAJIW14VzzRQDkug6yquJ/2LwVuHEFsqlBo214Zy6MGs7qiiWUeorQKXp6mPrS3NAKFZUt9tXYvOXY1IZ58ocUV9Eo6CL09Hz+AsLjI1A9KlumrcR22PdL3u2R3kSf3SywDdRId9N5PJb8FgB7HFt5+vB4AJLD2/FIqzf4rGgm623LAtnEoBKuGLm3xQuAF4/q4c38aeS7DqMAGYmP4FIdvJ3/ZINkSXEVjYbeHIY910rRyjwcR2x4jj72WBeuQ28Kzl9Vg2JATyQrKhazx7EF+9Fek9PrIEIXiV4JzvMOFEVRMClmspy72WxbSbH7SOXPPEwJR9eAl6HklRMBpxgU9BF6vE4PpVuLOJi5q8p+r8OLx+FBb9QHqIXa8ageXKqD38q/q/KARBUvTtWOTtETrhhxqo6TfBdRV6qq4lQd7HVsZaEls8o+p+pAVb0YlQhcqvOMH/0jswVEwLUc1o6eL/Zn+/NrOfDJzmr7t7+4jp0z1lPHZTCalK22VTybM4HDzv1Vtue6DvJszgQ6GXtwZ9JT6KUf1CCcqoNXj0zh+5JPqu37oOBFfi3/lkdavUknY9oZZ8krJgJObzIQHmfEZXFUDgWcyF3qxGVxBqBl2nOpTiyeomrbPXiweIowKOHE6OJQUALQumCkUuoprvGiVYW3FLvXSqw+gTAl/IyTpLiKwPOqqB4VRadD0fuKiOo5oZeqUyq3BxsFBR3HhjvUKm9FdehRUfHgCUzjxBmR4ioCLnfRQYrX5tPlwXQM0eGoHi/bnl6DPdcKwNmTexHTPS7ArdRGN1NvHm41E4B9jm3MKfKtNNfSkMLYxKn8Wjaf7y2fyHSsJkiKqwg4d5kLj92D9WA5hugwUCGmRzyRHXxrZXpsbhx5NoyJ/l/tXms2bwW5roMAuFUnvUz9ATDroslzHSTXlUWhOzeQTRSnSYqraBRUl5fdMzcBoOgV0l8ZiLltFKiw8aE/UAwKac/1C3ArG94+xzY+KHwRgLMj0rkr8SkAsl17+Ffu/agE30W8QPL9PE/9M22In7oUV9HoqB6VnS+tQ2fUgwrWg2VEdowNdLM0d9Cxk5fzHgTAodqlsDawlRU/scO+nnJPaa3HHHLu4eW8B8hzZZ9xnhRX0ShV7CsLdBP8zq5a2e/cHuhmBC2LpxCLp/Ckx9hVG/udOxokT+a5CiGEBqS4CiGEBqS4iibBa/dg3V+Gx1r9JoOmSEXliCubIs+RQDdFaETGXEWTUL7bwrp7lzbMZdxGwIuHdwueDnQzhIakuIqmI0gK6zEyGyC4ybCAEEJooN7FdfTo0Zx99tmkp6eTnp7OV1/JoyiEEOLP6j0ssHr1alasWEF8fLwW7RFCiKBQr55rUVER+fn5jB49mp49ezJ9+vSgXGNTCCHOVL16rrm5uQwZMoTXXnuNmJgYRowYwezZs8nIyKhynMPhwOE4vnJ6aenx281MJv8uvnEsz9+5kh1a2aF4zqGaraoqdrv9lMcp6hl0Pb/++ms+/PBDvvzyyyrbp02bxvTp06sdn5mZidlsPt04IYQIOKvVypgxY7BYLMTExNR6XL16rqtXr+bw4cOMGDECAI/Hg8FQ/VtMnTqVyZMnV35eWlpKSkoKABkZGdhstvrEnhGTycSsWbP8nivZoZXdFM85DAU9CvYzeFZUUzzvM1XX/mi9iqvH42HSpEkMGjQIs9nMm2++WW1IAMBoNGI0Gmv8Hjabze8vQiBzJTu0spvSOd8R2ZGrTcmMLPyDUvXM7nxrSuftL/W6oHX++eczadIk+vXrR/fu3enduzejR4/Wqm1CCA1EKnr+amqNUdGz1lnMCFMyvcKCf0lHf6v3VKz77ruP++67T4OmCCH8IU4XzjMxPfh3+S5mle/nf80v4lNbFhtclkA3LajI7a9ChJhcj52rCpcx0tSa2XF9GFu8miyPNdDNCjpSXIUIMW5UdrrL2eOuIFkXwQ53GRWqPGG2oUlxFSJEfW7L5nPbmT/ORNRMFm4RIkT9n7ktH8T1IUqRPpYWpLgKEaLa6s30Do/DgBLopgQlKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5CCKEBKa5ChIB4XTh3mNtztiEq0E0JGbJigxAhIEln5OHoLpSWujngPr52q1P1ctpPKBUnJT1XIULAHnc5lxT8yjlhzViSeBFLEi+i2OtiROHvlKmuQDcvKEnPVYgQ4ELloMfGJpcFk6IHYJu7lGxP43uwX7CQ4ipECPnElsUntqxANyMkyLCAEEJoQIqrEEJooF7F9ZtvvqFPnz5069aNSZMmadUmIYRo8upcXPfu3cuECRP4+uuv2bRpE+vWrWPBggVatk0IIZqsOl/Q+uqrr7jhhhto06YNAHPmzMFoNGrWMCGEaMrqXFx3796N0WjkmmuuYd++fVx99dU89dRTNR7rcDhwOByVn5eWllZ+bDKZzqC59Xcsz9+5kh1a2aF4zqGaraoqdrv9lMcpqqrW6QaNO+64g6VLl/Lrr78SHR3NiBEjuOmmmxg7dmy1Y6dNm8b06dOrbc/MzMRsNtclTgghGiWr1cqYMWOwWCzExMTUelyde64tW7ZkyJAhJCUlAXDttdeycuXKGovr1KlTmTx5cuXnpaWlpKSkAJCRkYHN5r+JyyaTiVmzZvk9V7KbTrZBp9A8OoxSmxur0+u33IYi2f7NrmN/tO7F9aqrruLmm2+muLiYmJgYFi1axNVXX13jsUajsdbxWJvN5vcXIZC5kt34s9vEh/PktW2Y9Use/9tq8VtuQ5PsxqXOswXOP/98pk6dysCBA+nevTutW7dm3LhxWrZNCM0N7dGMS1Kb8dFvR2gRE8aNFzTHoFMC3SwRBOo1zzUjI4PNmzezY8cOXn/9dfR6vVbtEsIvOrWIoGNSBGv2lRMZoadX20h0cmuNaACytoAIae8tySMlwcg/x5zFp7/n8/FvR3C6ZRE+cebk32gR0lwelYIyF9+uK2J3ng2HFFbRQKTnWoMos4LHq2I7OpVNr4dIk28czuOFCmto/AFGoMOg+P79dage3KhEKnqcqoqT07uqXle6CD3KCWOfqkfF6/BoklVm9/D9hmKcbm3P6c/ClQhUvLhUZ63HhCnh6NDhUE89r1I0LlJc/yQsDBZ9FM/G7S7ufNR388OA3uHMea0ZAJu2u7ni/4qo42yMJm16THcuj2gBwLNlO/jZcYR5Cf35wHqAtyv2aResU0iddh6m5MjKTaXbS9j+7BpN4lrGhvOPa1PI/D2fpTtKT/0FDUCPgbuSnuKwcz+fF79W63F/aXYbKeEdeSVvCh7cfmmbaBhSXP9EAZon6DivVzgTb/Xd8GA2KXyxwA4K2B0qE281s+hXBzv3atOTCqQrjC1I1kcAUKy6+MaeC0CyPoKbzG1ppY8gUmn4XxtFr5A4uDX6CD0oCmU7LVTsK6vc73V4aHVVe4pW5uE40rDTbvQ6aBZpINzgv1kCKl622tYQpoQzMOoq1lt/o8xbUrk/ShfLOeaB2LzlbLWtRpWHsTQ5Ulxr0TstjHN7xOByw4+/ORg+thiAc3sYWPVNc265ryQoi2tGZHv6hyfgRuXuknUsOFpcn41JZWxke81ylTAd7W7uQni8Ea/Tw/r7lmHLLq/cH5MaT4+nz8eeW9HgxTUQvHj5oXQO6eYLuTlhMlnO3VQ4y/DiQYeeeEML/hKXQWbhy6y1/hro5orTIMX1JFQVxtxTwvJ1tY+JBaNt7jLGF68lz+v/cb6C33I48NEOHPlVC2j5rhLW3v0LzkJHLV/ZNG2zreGFnHu4Nu42yj2lZBa9zA3xdxOjj+eFnHso9RQFuoniNElxrcWBQx5+X+1k/VYXh3KPX+gotqh89o2dVi30DL/EyPdLHHj9ex1EE0k6I/3C49npLqfU62Kvp6LK/o0uCwvtuQwxJjV4tikliqiOMZSsz6d0azH2HGu1Y7xOL/bD1bc3dQ7VRr77EIec+zDqTJxjHohDtXPIuZd896FAN0+cAZmKVYs/1jgZc28Jew5Ufeu/L8vDmHtLOCc1jJefiCEsSP55Sg2L4Y1m5/C9PZcXy3dW2z/Hls0Uy2bsasMPhSRc0JJOd6dx4KMd5P0Qms93WmD5iC22Vdya8CDbbGv41vJhoJskzpAUVyEagTHx93Fe5GBm5P2dc80XcXPCZHyXV0VTFST9robXMlHH0AvDASgq8bJ2s28aTHSkwvnnhFFQ5GXZamdQDAkAFHud/OosoK3ejD7c90e91V1Kgdc33txJH0n3sJjKea8NyZFnxbK5iOizm+GxeVBVlbLtJVXmtRqiwojqFEv53lLcpcEzBh6ta0ZyeHsUFCzuQg46d2HxFNLMkEiXiHQOO/dT5i0OdDPFaZDiWouLLzAyqJ+vuP74m5PLbvZdWOh8lp5FH8Vzy30lZM4Lnond610WRhet5PP48xkQngDAhJJ1fGPPAXyzCG41t0NRGr43lf/LYQpX5NH7zYsJTzCielTW3bMUW9bx2QLm9tGkPtWXrU+upnjVkQZvQ6B0ikjj1oSHmJH3dw46fcMx31o+pE1YR/7e8t98XPgv1lh/CXArxemQ4lqLJcsdPDfT98fdro2ehR/FA3CkwMOVtxaxYVtwTuh+umw7cUoYAEMjkhht9q3D+5ujgLtK1jGjWS9Ncr1ODzteWocuTAeKQtsbO2GIDq/c7yiwseUfKynf459J/lrToeeG+Ik4VBtv5P+DI67sKvvz3Yd5M/8Jukf0oUvEOXxW9Coegm/qXzCT4lqL3CNefljqe/vZNz2Mv43x9djyCxV+WOoM2ju0NrqOr2fa35hQWWgPeqysdBbjVjUaB/FC6eaj0450Ci0vS8EQHVa5255npWRdgTbZAWLSRVLqKmaHfV21fQ7Vxg77OjoaU4nXJSHjr02PFNc6WLneRd8RhZWfB2th/bPny3bwPDsAUPFN1/ILr8r2F9ZW3RZkP3MvHmYVPMepTuw7y8f4CmuQ/QBCgBTXOgqVgnqiE095lKkN54fH81jpFja5/PDWXMOf98jzElAU+GJl4akP1lRdTzIEf/mCgBRXUUVLnZEIpfoi6KlhMXQyRPF46RasGsx19afW8eEYw3S0jPUNOzQzG8i1OE/7+VlC1ESKq6jiX8160T88vtr26aXbeLp0G64g6EW9tjiHs1uZeOmms1AUOFTkZMqn+3F6mv65icZDiuufuD3wzKvlHCkIzV7Mx9aD/GyvPtVphbMoKAor+NbkzS1x8cmyfADK7R6cbll3SjQsKa5/4vXCh3Ob/qpLp+v7o6tgBbviCjffb5DJ+UI7cvurEEJoQIqrEEJooM7F9c033yQ9Pb3yv7i4OG655RYt2yaEEE1WnYvrhAkTWL9+PevXr+fzzz+nWbNmPP/881q2TQghmqzTGha4++67mT59Oq1bt27o9gghRFCo92yBX375hby8vJMOCTgcDhyO44/jKC09fkePyWSqb+QZOZbn71zJDq3sUDznUM1WVRW7/dQr4imqWr8bO2+88UauuOIKxo4dW+sx06ZNY/r06dW2Z2ZmYjab6xMnhBCNitVqZcyYMVgsFmJiYmo9rl7F1el00rp1a/bu3Ut0dHStx9XUc01JSSEzM5OJEydis/lvHqnJZGLWrFlkZGT4NfeMshPPgmYtYe8q8Jze0oZN8rybcHYonnOoZh/ruZ6quNZrWGDTpk107tz5pIUVwGg0YjTWvIKSzWbz+4sQyNzTyu56CZx7FfxnFJxhm5vUeQdBdiiecyhnn0y9Lmjt2bOHtm3batUWEZUA414DWxl8/hiMegb6jgx0qzSXPHo0vefNIywhIdBNEaLB1KvnOmrUKEaNGqVVWwQquJ2+5Tv14eBxgbdpr0BVF8bkZGJ790YXHn7qg4VoIuQOrcakvAg+uh8iomHkEzB3Gqz+OtCtEkKcBlm4pTFa+y3sWQUOa6BbIoQ4TY23uDZrBfowKDzo+1xngOZtQdGB6oX8A9DEF22ulb0MFMV3nn52Vlw4keHV39AcLnVRZPPfz9vcqRO6oxdFrXv34m2EFyxOV7xJT6uYMHYVOGpdQzbCoNApwUiWxYXFHqS/50Gu8RbXK+6F+BR481bfuGNUHNzxDoRF+IrPKzeCtSTQrdTGBTf6Zgu8cgPY/Pu001dGpDDorKhq2ycvyObdVf55LIpiMNDrww+J6tIFVJWVw4ZhWbXKL9n+MDKtGc9d3przX9vOniJnjcd0SYzgl7+dzR1fHuC/m0r820DRIBpvcVV0ENsCrnnU9wArtxO++7evN6fTw9A7Yd9q2LQ40C1teIriO/8AePm3I8zZUFRte6eECF4c1pp/LD6M3d3wy0rrjEa6PPccHqsVVJXs997zfQy0HDmS+AsvZN+//93guYGgQ0Gn4Huda6EAeh0oJzlGNG6Nt7gCmKIh/UpfD7UwC75/GdwOiIiCS+8CpzU4i2sA/bSnrMrnBh0kR4cxuEM0F3eM5qmfcrBrsGa/LiyMltdcg7usDGd+Pvv+9S+se/cC0HfsWLwuV9AU1zKHhyyLi6RIAxabmwJr1bf9SZEG4s0GDhQ7sTplSKCpatzF9Zif34G13/h6r8Kv2jUL57cJXTCH68ivOL27xeoj96uv2P7QQ3hPuMMv2Hy2sZhvt1v48fbObMixcceXB6vsf/UvKSRFGuj72g4c7tB83FAwaNzFtawQfv8UDqyvWlhdDl/BjWzm68H+9rHfxyaD1W19EuiYcPzuOrdX5fkluYzo3ox2cdrNQ/U6HOz7z38o/v13vH9aFOPg229jateOs596ikMff0zFjh2atcMfPCrY3SpGvUKYvvrb/mPbbS6vPNerCWvcxdVmgT8+rT6R3uOCVV/6LvwMvNU3F1SK6xkJ0ynEROgY1iWG89pEVm7fW+Tg0vd20T7eqG1xdbnInj0bR05OtX25c+cSN2AAfb79lqLffmvyxRVABYrtHpwelXiznlK7BwXfa2Bze2WGQBBo3MVV+M2F7SP5cFR7bv/yYJW3qR6virwzbXguj8qID/YwvGss6+/txogP9hBt1JN5Y3vu/Pogv+wrl15rE9e4i6s5Fgbc5Jsh4LDCmnm+Xqw+HPqMAGOkb9jAXh7oljZ5YXqFOJMeu8tLsR/ns4ayUocXl0clzqRHr1MI0+N7DdwqZQ75F62pa9zFNTIOBmUAKpQVwJaffOOtEVEw4GbY9AMsfj3QrQwKHi/YXCphegVTWPVxQIPcKK0Jt1fF6vISrlcw6BRsLhVP/ZZYFo1U4y6uhdnw0X2+3mpkHNz+NhiMvilYnzwAlrxAtzBoLDtQzjmvbuOfw1ozc0RKtf1xJj1lTulNNbRFu0rp8+p2Xh2RQoXTyzmvbqPAD7MyhPYad3H1un0F1OvxDQvsXQ2GcHDaofiwr8iKBmF3q2RbXCzPqqC4lospFrsHl7fhe1VlmzeTM2dO5U0DNXHk5XH444+xZ2c3eH4g2VwqWRYXvx+swO7ykm1xBbpJooE07uJ6InsZfPvPQLdCG4rOdxdaI7iE8Z9l+X7PLFi0iIJFi056jHX3brbcc4+fWuR/L/4i78KCjYykBVpCW7jzA+h6YaBbIoRoQE2n5xqsPC4oOuRbpKbrwOPbdv3u+78QoklqxD1XtTG8S9ZeSQ7MmQItOsLoF33/2cth7nRwBs8ye0KEmsbbc/3xLQgzhsRjTgD49QPf+gngu1gnhGjSGm9xzd8X6Bb4V+HB4wuDCyGavEY8LCCEEE2XFFchhNBAvYrrp59+SmpqKqmpqTzwwANatUkIIZq8OhdXm83GxIkT+d///seGDRtYunQpP/74o5ZtE0KIJqvOF7TcbjdutxubzVb5sclkqvFYh8OB44SV5EtLj6+1WtvXaOVYnr9zJTu0skPxnEM1W1VV7H9a0L0miqrWfQmeV199lYceegiz2cygQYOYO3dujQ9QmzZtGtOnT6+2PTMzE7PZXNc4IYRodKxWK2PGjMFisRATE1PrcXUurps2beLWW29l4cKFxMbGMmbMGPr168eDDz5Y7diaeq4pKSlkZmYyceJEbH58Br3JZGLWrFlkZGT4NVeyQys7FM85VLOP9VxPVVzrPCywcOFCBg8eTFJSEgDjxo3jjTfeqLG4Go1GjEZjte3gG7v194sQyNz6ZDeLiuLe66/npzVrWLZpk1+ztRCK2aF4zqGcfTJ1vqDVq1cvFi1aRGlpKaqq8s0339C7d28t2xZSzBERtElM5Lbhw+nXvTuxkZHIE+uFaLrqXFwvu+wybrnlFvr06UPPnj1xOp1MmTJFy7aFlGfvuIPZU6fS/667SIiJYdnrrxMbFRXoZgkhTlO9bn99+OGHefjhh7VqS0j7Y8sWbA4Hf734YuxOJ18sWYLDJatiCdFUyR1ajcRnP//MG/PmMfXmmympqGDa7NnYTrgoKIRoWhrvwi0h6HBBAeePH09xWVmgmyKEOENSXBsRY1gY/VJT2bB7N5aKCr9mJyckMPjcc/lxzRrcHg9X9O0LQKnVyre//86JM/Z6duxIWocOAOzMymLV9u1+bauWzEYjVw8YgEGvx+l2M/+332R4RpwWKa6NSPPYWN564AGmz57NtgMH/Jqd1rEjs6ZMYdiDD1Jht/POQw+hKAq7srP5YeXKygKjUxSuGTiQqTffDMBb8+axZscOvE38cdC6ozfDJMTG8vrkyZgjIigpL+fX9es5UlJCPe61EQKQ4ipOoCgKM++7j41799L/rrtAVWkRH8///vMf/vXZZyxZv54vnnySn9as4YIJEwC4+Jxz+HXmTEZPn07WkSMBPoPT06FVKz5+/HH0ej0lZWUMe/BBnC4X5ogIPvnHP/j29995+b//DXQzRRMjF7REFZ3atKF18+Zs2LWL9bt3s/fwYXp27Ejz2FjC9HrSOnRAVVXW797N+t27cTid9OrUCWNYWKCbftoijEZ6depEmMHAoYICNhw9t63799O1bVuSmzcPdBNFEyQ9V1FFKL/9fe3LL3lvwYJAN0MECSmuopKqqjz85pv8umFD5bMhs/PzGf7ww1zRty+v3X8/Nz31FNsPHn8czfxly9iZnc1Tt9/Oxj17eO7jjwPT+NP0xNixXHreeej1eib99a+MGjy4cp9Br6dZVBQjBw2iW7t23PHii+QWFQWwtaIpkWEBUcX63btZu3Nn5ec2h4Nf1q8n0mSiT9eu/L55Mwdycyv3HyooYOmGDfTs2JHU9u0D0OIz06NDB3p06MDq7duxlJdjjoio/C88LIx1u3ZxuKAAc0RE5UUvIepCeq4i5O3PyWHwpEm43e6THhe6AybidEhxFSHtX599Rre2bXl/6lR0Oh2FpaX8feZMmdsqzpgUVxHSlm/ZQn5JCfdefz0GvZ7C0lK6tG2L3emsPKa4rIz8kpLANVI0SVJcRcjbc+gQfcePByC5eXNWvf025hPWI371yy+Z+tZbgWqeaKKkuDYiRaWlTJ45k9UBuJ106/793Puf/7AzK6vG/Z//73+s2r69So/uGLfHw1MffEBBE+7duY6OtxaUlDD1rbcw6PWV+zbu2ROoZokmTIprI1JmswVsnmXWkSO8NX9+rft/27iR3zZurHGfV1WZ89NPWjXNryrsdpnrKhqETMUSQggNSHEVQggNSHEVQggNSHEVQggNSHEVQggNSHEVQggN1Ku4Pv/883Tp0oWePXvyzDPPaNUmIYRo8upcXH/66Sc+/vhjVq5cybp161i+fDlffvmllm0TQogmq87Fde3atQwbNozY2Fj0ej3Dhg1j3rx5WrZNCCGarDrfoXXuuedy//33M3XqVMxmM/Pnz8fr9dZ4rMPhwOFwVH5eWlpa+bHJZDqD5tbfsTx/50p2aGWH4jmHaraqqtjt9lMep6j1eK7HjBkzeP/994mPj2fo0KEsX76cb7/9ttpx06ZNY/r06dW2Z2ZmYjab6xonhBCNjtVqZcyYMVgsFmJiYmo9rs7FtaysjMLCQtofXW3+hRde4NChQ7zyyivVjq2p55qSkkJmZiYTJ07EZrPV83ROn8lkYtasWWRkZPg1V7JDKzsUzzlUs4/1XE9VXOs8LLB//35uuukm1qxZQ3l5Oe+99x6zZs2q8Vij0YjxhCXbTmSz2fz+IgQyV7JDKzsUzzmUs0+mzsU1LS2N0aNH06tXL9xuN5MnT+bCCy/Usm1CCNFk1WvJwalTpzJ16lSt2iKEEEFD7tASQggNSHEVQggNSHEVQggNyGNeGqHLjC240JhQbftaZwlf2w8HoEX+paAwJOZ6YvRxoKosKZuPTtFxUfTV/F6+kFzXQc2yzeE6rjsvAYNeqdy2JdvKqr3lmmU2Bhd3iOLKLrGVn6uqyr+XHSG3zN2gOd26dWP8+PG89tpr7Nq1q3J7YmIiU6ZM4csvv2TZsmWV2yMiInjkkUfYsGEDc+fObdC2aE2KayOiA+J04ZwXHsdfIpKr7Q9Hx1JnASVeFx7qfO9HkxGpi0FBQafo6WHqS3NDK1RUtthXE64YuSjqanbY1jV4cdUpEBXheyBhM7OBCzrHEG44XlzdHpUdOTbK7B7qfstN4xcZrsMc5nvz2ru1mb+mNavc51Hh660WrE4vpY6a78Q8He3atePee+9l/vz5VYprXFwcEydOZPfu3VWKa3h4OLfffjtz586V4ipOXytdBAuaD+Dtin0MzF9Sbf/VEa34JXEQ1xX+wU53cPWkwpUI7m3xPLH6eDyqhzfzp5HvOowCZCQ+QrvwszXLbtksnCevb4tep1BS4ebRz/fjdB+vopekNuOlMWfx6OcHyC9zadYOf7v/wiTuPD8RgPdWF5D+yrbKfXpFYe7NHThQ4mTsfw8EqolNmhTXRkRRFKJ1YahAqVr97dhGl4X3K/ZT5K3+eOtgEKGYKXDnstm2kmL3EexqBQBhSjhGnXb3j+sUiDTqWX+ggq2HrJTZPXhO6KztzLXxw6ZirE6PZm0IBJNBh9Gg8NbKAn7ZW47FfvykFWDOhmJK7A17znv27OHpp59mwIABtGvXjtmzZ3PdddeRmprKCy+8QGJiIvfddx+vv/46/fr146KLLuLdd99lxYoVDdoOf5Di2oioqorV60YBIhV9tf073OVsKi+t/oVNnB4DRiUCl+pkr2MrCy2ZVfY7VQdOr4NwXc13/Z2JML1CuEGH3eVlxe4ylmyzVDtmZ46NnTmN7w6g06XgG1tWUcmvcPPPX/KqFVEVeGtlQYNn79q1i3/84x/8+OOPREZG8v777zNq1CjS09NJS0vj5ZdfZvz48bz33nsMGTKESZMm0bVrV3Jzcxu8LVqT4tqI5HrtDC1Yym2RZ/Fr4sXV9s+zHebJsm3Vv7CJGxA1jIuir2Z2wfMUufOq7f+g4EU6GdMY13xKg2ffdnELWjUL58HMfZTZgqtnWpvkmDAWZnRi9upCBr+9E0sD906FjxTXRsQD5HkdrHeVEKtUf2mceLnJlMICey4lavCM/Rl1JmL0cZR7LdiODgWcqMJbSrm3eo+yIURF6ImK0FNU7sYbRBerTkavU2gVHYZHVcktb9jZAOI4Ka6NjAGFhfZcvrNXfxt0o6kNL8amscZVQok7eIqrihcPHnTo0OEbDvFyvDfl21p9mKQheL0qXq+KQafgUVVUlWpFVgF0OqqMwzZpqorLo6KgYDg6091bw3nrdYDqmznQ0DweDx6Ph7CwMFRVxe12V253u92EhYUB4HK5qMeqqI2KFNdGpKXOyIfx5zGrYj9zbNmBbo7f/FG+iG22tfxf8wcx66Lxqh7eK3iaArfvH5ibEyZzlrG7JtnvLz1Cm/hwnr2xPToFLFY3z83LxnlCRbmoWwzD0+N54ZtsCoOgp3e4zMVFb+/k5vR4VtzdFYAP1hTyyu/5lcfoFMi84SwOl7m4/9uG/1284447SE9PZ926dcyYMYNHH30Ul8vFM888w6effsrixYuZN28eAwYMoKCg4cd+/UGKayPiQmWXu5wW+giujGhZbX+cLpzv7LmU1TCToCmr8Jbh8NrJdR3ErItGRaWjsQetwzoAYPfaKHLnEadPbPDsonLfBcTsQgc6HThdKr07RHHiQzbiI8M4VOTErUUXLgDcXthV4GB7vp1OCb6LhLERev7S/fhNBApQYHWTbdFmZsrBgwdp1aoVXbt2paysjL179wKQl5eHTqejU6dOqKrKzp07Ncn3BymujUih18ndJet5LLor7zQ7t9r+ObZsJpSsC0DLtOfGxWdFMwHQoeehlq/QMqwtoPJy3kPoFQP3JD2nSXZhuZuXF/rufIuPMvDyzR0whh2/iWDBumL+syj47oz7dEMxn24oBnxzXj+5oX3lPrcXBry5gy15p36cyZmq6W1/Ux0KOJEU10ZotvUA39cw5loQpPNb/8yLhw8LXyJcMQIqOa6DtAnv6JfsUqubJ786iHK8tlJcEVzvFGoyZ0MRy/YfvzFFBfYWOWr/ggawZcsWBgwYUOVOLYCCggIuvfRSDh9u2v+gSXFthA55bBzyBM+8ytNx2LUvILluL+z2Q2+tsckpc5PTwOsInEp5eTnLly+vtt3lcrFq1Sq/tkULsiqWEEJoQIqrEEJoQIqraBKcqp3Drv3YVWugmyJEnciYq2gSspy7+WfuvahBuNSiCE7ScxVNhhRW0ZRIcRVCCA1IcRVCCA1IcRVCCA34pbgeu5XNarX6/bY2VVUDkivZoZUdiuccytnH8k9GUf3QsuzsbFJSUrSOEUIIv8nKyqJNmza17vdLcfV6vezYsYPu3buTlZVFTEyM1pGVSktLSUlJ8XuuZIdWdiiec6hmq6pKWVkZycnJ6HS1v/n3yzxXnU5H69atAYiJifH7ixDIXMkOrexQPOdQzI6NjT3lMXJBSwghNCDFVQghNOC34mo0GnniiScwGhv+8ciNMVeyQys7FM85lLPrwi8XtIQQItTIsIAQQmhAiqsQQmhAiqsQQmjAL8U1MzOT7t2707lzZ2bOnOmPyCrKyspIS0tj//79fs2dMWMGqamppKWlkZGRgdPpnwcMTp06lW7dutG9e3dmzJjhl8w/e+CBBxg7dqxfM0ePHs3ZZ59Neno66enpfPXVV37L/uabb+jTpw/dunVj0qRJfst98803K883PT2duLg4brnlFr9kf/rpp6SmppKamsoDDzzgl8xjnn/+ebp06ULPnj155pln/JpdZ6rGsrOz1bZt26oFBQVqeXm52rNnT3Xjxo1ax1Zavny52qtXLzUsLEzdt2+f33JXrFih9ujRQy0vL1e9Xq968803qzNmzNA8d8GCBerAgQNVl8ulVlRUqO3bt1e3b9+uee6JfvzxR7V58+bqrbfe6tfcTp06qYWFhX7NVFVV3bNnj5qcnKxmZWWpLpdLHThwoPrtt9/6vR07duxQ27dvr2ZnZ2ueZbVa1fj4eDUvL091uVxq37591cWLF2ueq6q+36/U1FS1pKREdbvd6lVXXaXOnTvXL9n1oXnP9ccff2TIkCEkJCQQGRnJ9ddfzxdffKF1bKU333yTV199leTkZL9lAsTFxTFz5kwiIyNRFIVevXpx8OBBzXOvvPJKfvrpJwwGA/n5+Xg8HiIjIzXPPaaoqIhHH32URx55xG+Zx3Lz8/MZPXo0PXv2ZPr06X5b0OOrr77ihhtuoE2bNhgMBubMmUO/fv38kn2iu+++m+nTp1feDaklt9uN2+3GZrNVfmwymTTPBVi7di3Dhg0jNjYWvV7PsGHDmDdvnl+y60Pz4nr48OEqha1Vq1bk5ORoHVtp9uzZDBw40G95x3Tu3JlBgwYBcOTIEWbOnMmIESP8kh0WFsZjjz1Gt27duOSSS/zyx3bM+PHjeeaZZ4iLi/NbJkBubi5Dhgzhgw8+YPny5SxdupTZs2f7JXv37t14vV6uueYaevXqxeuvv058fLxfso/55ZdfyMvL89uQQHR0NE8//TRdu3aldevWtGvXjv79+/sl+9xzz2XRokUUFRVht9uZP3++X2tKXWleXL1eL4qiVH6uqupJFzsINvv372fw4MHccccdDB482G+5Tz/9NAUFBWRnZ/POO+/4JfPdd98lJSWFIUOG+CXvRN27d2fu3Lm0bNkSs9nMxIkT+fbbb/2S7Xa7WbhwIW+//TbLly9nxYoVfPDBB37JPuaNN95g8uTJVf7WtLRp0yZmz57NgQMHOHz4MIqi8NJLL/kle8iQIYwdO5aLL76YK664ggsvvJDw8HC/ZNeH5lWuTZs2Vf5Vyc3N9ftb9EBZv349AwYMYMKECTz66KN+ydyyZQubNm0CwGw2c+2117Jx40a/ZH/22Wf88MMPpKen849//IP58+dz7733+iV79erVzJ8/v/Jzj8eDweCf52+2bNmSIUOGkJSUhMlk4tprr2XlypV+yQZwOp389NNPjBw50m+ZCxcuZPDgwSQlJWE0Ghk3bhxLlizxS3ZZWRnXXXcdGzduZMmSJYSFhdGhQwe/ZNeL1oO62dnZart27dS8vDy1vLxcTUtLU1esWKF1bDXt2rXz6wWtI0eOqC1atPD7QPt///tftX///qrD4VDtdrt6ySWXqJ999plf26Cqqjp79my/XtBavny52r59e7WkpER1Op3q0KFD1czMTL9ld+rUSS0qKlLdbrc6YsQI9Z133vFLtqqq6urVq9ULLrjAb3mqqqqLFi1SU1NTVYvFonq9XvVvf/ub+vjjj/sle+PGjWpaWprqdDrVoqIitXPnzurSpUv9kl0fmv/T3rp1a5599lkGDx6My+Xi9ttvp2/fvlrHBtzLL79MaWkpTz75JE8++SQAw4cP13zayPXXX8/atWtJT09Hr9czatQoRo0apWlmY3D++eczadIk+vXrh9vtZuTIkYwePdpv2VOnTmXgwIG4XC6GDBnCuHHj/JINsGfPHtq2beu3PIDLLruMW265hT59+mA0GunTpw9TpkzxS3ZaWhqjR4+mV69euN1uJk+ezIUXXuiX7PqQtQWEEEIDoXNlSQgh/EiKqxBCaECKqxBCaECKqxBCaECKqxBCaECKqxBCaECKqxBCaECKqxBCaECKqxBCaECKqxBCaECKqxBCaOD/AU7pqCMzj+++AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 30\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4fd8d4d9-a324-42fa-b0a9-92e9ca461232",
   "metadata": {
    "tags": []
   },
   "source": [
    "# 3. Three if-then clauses (controlled by min_depth parameter)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b1718aca-4f12-401d-a678-7f966d4e696c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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yMhInT9/Xm+99ZYWL16c4wxjxozR559/rri4OJ07d04hISFq166dunfvrhEjRqhp06Y6f/68JN1VjtWrV+u///2vPvroI50/f14NGjTQli1bcvFsIi/4+fnp448/1qRJk1SxYkXVrVtXoaGhslgsevrpp/Pda7Z3797at2+ftm3bpsTERLm7u6tjx44yDEP9+vXT4sWLbVcknD9/XkuWLFGfPn106dIltWjRQvfff7+OHj2qH3/8UfHx8Ro1apQtx08//aQyZcro+PHj+u677/TFF1/oq6++ys3TDRQeBgAAgB04ePCgIclISEiwbYuLizNcXFyMl156yQgMDLRtP3DggCHJ2LVrl21bZmam4evra8yfP9+YPXu2cd999xlWq9V2+/PPP280a9bMMAzDmDVrlhEQEJDt8Zs1a2aMGjXKMAzDqFChgjF9+nTbbdeuXTM2bNhgZGRkGKNGjbId525z9OzZ03jiiSey5ahTp44tB/K3gviaPXXqlCHJ2L17t+2+ly5dMpycnIytW7cahmEYVatWNT7++GPDMAxj6tSpRu3atQ3DMIwFCxYYfn5+2TLGxcUZbm5utoxFixbNdnujRo2M//3vfzk7oQCyYWQfAADYlb/OGF6+fHldu3ZNZ8+eVdmyZW3br19yXKlSJds2R0dHlS9fXklJSTp27JjKlSuXbWnSypUr5zjDiRMnFBAQYPu+SJEiatCggZycnLLd725zHDt2TOXLl892zL8eCwVDQXrNJiUlSZLq168vT09PeXp6qmzZsnJycrJ9bKBv37769NNPJf15aX7fvn1t+54+fVpeXl62fbt06aL09HSdPn1aklSmTJlsz8HZ2VlWqzXHzwPA/6HsAwAAu3Ls2DHb1wcPHlSxYsXk7e2drUBc/+zygQMHbNuysrJ06NAh+fn5qVy5cjp06FC2knH06FHb146OjrbPGV+XnJxs+7pcuXI6fPiw7fuMjAy98MILOnHiRLZ97jZHuXLllJiYmO2Yf70dBUNBes36+/tLknbv3q3z58/b/m3btk3t2rWTJEVHR2vTpk2Kj4/Xr7/+avsMv7+/vwIDA7Ptd/ToUf32228qXbr07Z00ALdE2QcAAHblpZdeUlpamo4fP66RI0eqR48ecnZ2znYfPz8/tWnTRgMHDtTJkyd15coVDR8+XFlZWWrfvr3at28vq9WqmJgY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61I418XGxuqzzz6zFbn09HTbbcnJydn2z+lSOOfPn7f9O3jwoLZv354r+a9P0rRixQotXLhQvXv3tj1u0aJFlZKSYnvcU6dOaceOHapTp85Nj1ehQgUlJycrLS3Nti01NVXJycny8/OTi4uLWrdurdjYWP3444965JFH1KpVK8XHx+vbb7+96xl071RB/jne6pzfKE+XLl1Ut25dnTlzRgkJCXrzzTdz/HgBAQE6fPhwtnP11+W//P391bNnz2zPde/evfr+++9veswXXnhBsbGxSk1N1ahRo3KcBSgs9u3bl6ePd/XqVR09ejRPHxOFT16sNGOxWLR27drbvg1AzlH2YbcK+lI4zs7O6t69u1577TW5u7urSZMmkqR69eopKChIQ4YM0cWLF3XlyhW98MILatGihTIzM2/6eMHBwapZs6YGDBig1NRUpaam6umnn1ZgYKAaN24sSerYsaMmTpyoKlWqyNvbW61atdL69euVkJCQ48vmc1tB/jnm5Jz/XWpqqooWLSpHR0edOXNGzz33nKTsb2jcTHh4uKxWq+1c7dmzRxMmTLDd3qdPH33++edasWKFrFar9u3bp4cfflhvv/32TY9ZpEgRlShRQp988onefvtt/fzzz7fMARQWuVWI/q3YrF+/XiVKlLB937RpU8XHx9/R4/Ts2dO2PBrwb1hpBrAPlH3YLXtYCqdXr17avn17tmxOTk5aunSpTp48qcDAQPn5+Wn//v1auXKl7fPdN3J9v8zMTFWpUkUBAQFKT0/XypUrbZ9lb9u2rdLS0hQWFiZJqlixovz9/dW8efNsl6LnpYL8c8zJOf+7WbNmacGCBXJ3d9dDDz0kf39/1alTRzt37rxlluLFi2vJkiWKjY2Vl5eXHn/8cYWFhdkuva9fv77mz5+vESNGyMvLS82aNVN4eLjGjRt3y2OHhoaqX79+6tGjhy5dunTrEwMUAnlRiJo2baqLFy9me0zYh4SEBIWEhMjNzU1ly5bVyJEjZRiG1q5d+4+r0v76Rk1MTIzCwsIUHByskiVLat26dapQoYIGDBggX19f1alTR1arVQkJCWrevLm8vLwUFBSkiRMn2l6vMTExioyMVPfu3eXp6Sl/f3+9/PLLkqQ5c+Zo7NixWr9+fbaPff2VxWLRwIED5e3trfbt20v68w33evXqydPTUzVr1tS8efNs98/IyNDgwYPl7e2t0qVLZ3sj+mZWrFih2rVrq0SJEqpXr55+++232z3FAEyaGBBADqSkpBguLi7G0aNHzY6CAiA5Odn48ccfs22bNGmS0ahRI5MSAXevoC692blzZ2PQoEHZsvn4+NiO/e233xrly5c3DOPPFU1efvllo1atWkbx4sWN4OBgY+fOnYZhZF9hpWXLlobFYjFcXFyMZ5991nZ+bpb/76Kjo402bdoY4eHhhqenp1G7dm1j2bJld/BTwd0qyCvNGMafr9k2bdoYly5dMs6dO3fL1V5ee+01IygoyDhw4IBx8eJF48knn/zXlXwkGY0aNTJOnjxpXL582Xj00UeNsLCwuzvpQCHEyD6QD127dk27du3SSy+9pDZt2ui+++4zOxIKgMzMTIWGhtpWVUhKStLUqVPVrl07k5MBd+bs2bNq2bKlmjdvruTkZK1fv16zZs3SjBkzcrT/qlWrNH78eB0+fFiNGjWSJG3atEm7d+/WmjVrdPLkSYWGhioyMlKnT59WbGyspk6dmu34X3/9tcLCwpSSkqIZM2Zo/Pjx2rhxo6KjozVixAg1bdr0hldndezY0fa7KP05SpmWlma7SmfJkiXq2LGj7fYffvhBcXFxOnPmjLy9vTVkyJB/HHPFihUqX768pk2bpsmTJ+v48eO3zP93cXFxio6O1pkzZ/TCCy8oIiJCBw4cyNH5RO4pyCvNXPfEE0+oWLFitpVm/m21l88++0zDhg1TpUqVVLx4cU2aNOmGc+r81eDBg+Xj46OiRYuqQ4cOvE6BO0DZB/Kha9euqVGjRvr5559Zugk55uPjo4ULF2r48OFyc3NT06ZNFRkZqWHDhpkdDbgjBbkQtW3bVgcPHlRiYqJ+/fVXFS1aVGFhYbYVTpYuXZpt4tM7KTY5yf937du3V6dOneTk5KQePXrooYce0oIFC275WMhdN1tp5u8r7dzM7aw0c/3f0KFDs03ueDcrBt3o8b755ptsj/fBBx/oyJEjkqRjx46pfPnytvt7enqqZMmS/3r8UqVK2b4uUqTIv85LBODGWHoPyIfc3d2VmppqdgwUQBEREYqIiDA7BpArCvLSm56engoJCdGyZct06dIltWzZUtWrV1dcXJwaN24sq9Vqm3hVurNik5P8f1exYsVs35cvX17Hjh275WMhd/11pZnrr+/Y2FilpaWpQoUKkv6cmPX6nCvJycny9va27Z/TlWaWL19u25aSkqILFy7k2nP4++P17NlT06ZNs207ceKEbY6AcuXKZVse+NKlSzedrwhA7mFkHwAA5EsFeelNSerQoYOWLVum+Ph4hYWFqVWrVlq3bp2++uorRUREyMHh7v4Mu5P8x48fz/Z9YmKirVwi7xTklWZu5FarvfTt21dvvfWW/vjjD129elVDhgxRVlbWbT0nALePsg8AAPKlgl6IOnTooB9++EEbN25UaGioqlWrplKlSmnKlCnZLuG/Ha6urrYrv+4kf2xsrL7//ntlZGToo48+0h9//KGoqKg7yoI7V5BXmrmRW632Mnz4cHXv3l3NmjWTn5+fPDw8sl3NAuAeMXN2QAAAgH+zfft2o3nz5oaXl5fh7+9vvPnmm7bbpkyZYlSuXNlwc3MzIiIijGeeeSbbjOV/n008ICDAmDVrVrZtP//8s9G0aVPDy8vLKF26tNGrVy8jNTU1R8f47bffjPLlyxtubm7GuXPnbpi/fv36RsOGDW3f9+3b1/D09DTS09Nt2/S3WclnzZplBAQEGIZh/GNm9rfeessoVqyYERUVdcv8fxcdHW107drVePjhh22z/v/00083vC8AoOCzGMY9XiAWAAAAAADkKS7jBwAAAADAzlD2AQAAAACwM5R9AAAAAADsDGUfAAAAAAA7Q9kHAAAAAMDOUPYBAAAAALAzlH0AAAAAAOwMZR8AAAAAADtD2QcAAAAAwM5Q9gEAAADk2OzZs3X06FGzYwC4Bco+YKLvvvtOO3bsMDsG8sDJkydltVrNjgHgHjtx4oTZEYB7buzYsRo3bpzZMQDcAmUfMNHAgQP1xRdfmB0D91hGRoaCgoK0bNkys6MAuIdOnDghf39//frrr2ZHAe6p1q1ba8mSJTIMw+woAP4FZR8wybVr15SUlKTAwECzo+Aey8rK0sWLF3X+/HmzowC4hy5cuCCr1crvOuxeeHi4jhw5ol9++cXsKAD+BWUfMMn+/ftltVpVtWpVs6MAAADkWLNmzeTh4aHY2FizowD4F5R9wCS7d++WJFWrVs3kJAAAADnn7OysRx99VEuWLDE7CoB/QdkHTLJnzx55eXnJ29vb7CgAAAC3JTw8XAkJCTpy5IjZUQDcBGUfMMmePXtUtWpVWSwWs6MAAADclkcffVROTk769ttvzY4C4CYo+4BJrpd9AACAgsbT01PNmjXjUn4gH6PsAyYwDEO7d++m7AMAgAIrPDxcq1evVlpamtlRANwAZR8wwenTp5WamsrkfAAAoMAKDw9XRkaG4uLizI4C4AYo+4AJ9uzZI0mM7AMAgAKrQoUKevDBB7mUH8inKPuACfbs2SMHBwdVrlzZ7CgAAAB3LDw8XN99950yMjLMjgLgbyj7gAn27NmjihUrysXFxewoAAAAdywiIkLnzp3TTz/9ZHYUAH9D2QdMwOR8AADAHvznP/9R2bJlFRsba3YUAH9D2QdMsGfPHibnAwAABZ6Dg4PCw8MVGxsrwzDMjgPgLyj7QB5LT0/XwYMHGdkHAAB2ITw8XAcPHtTvv/9udhQAf0HZB/LYgQMHlJWVRdkHAAB2oXnz5ipevDiX8gP5DGUfyGO7d++WxLJ7AADAPri6uqp169YswQfkM5R9II/t2bNH7u7u8vHxMTsKAABArggPD9emTZt04sQJs6MA+P8o+0Aeuz45n8ViMTsKAABArmjTpo0cHBy0dOlSs6MA+P8o+0Ae27NnD5fwAwAAu+Lt7a0mTZpwKT+Qj1D2gTxkGIZ2795N2QcAAHYnPDxc8fHxunTpktlRAIiyD+Sp5ORknTt3jrIPAADsTnh4uK5evaqVK1eaHQWAKPtAntqzZ48kZuIHAAD2JygoSNWrV+dSfiCfoOwDeWjPnj2yWCwKDAw0OwoAAECuCw8P19KlS5WVlWV2FKDQo+wDeWjPnj0KCAhQ0aJFzY4CAACQ6yIiInTmzBlt3LjR7ChAoUfZB/LQ9WX3AAAA7FG9evVUpkwZLuUH8gHKPpCHmIm/cDEMQ+np6UpPT5ckZWZmKj09nUsbATtjtVqz/a5nZGTwu45Cy9HRUe3atVNsbKzZUYBCj7IP3GNPPPGESpYsqQYNGmjfvn06fPiwlixZomPHjpkdDfdY9+7d5eLiIg8PD0lSz5495eLiIm9vb125csXkdAByS7NmzeTi4qIHHnhAkvTII4/IxcWFK7lQaEVERGjPnj3as2ePDMNQSkqKDMMwOxZQ6FD2gXusWLFiOnfunDZt2iTDMBQbG6uIiAjdf//9ZkfDPVajRo1/bLNYLCpXrpxcXV1NSATgXrjZ73r16tVNSAOYr3nz5ipSpIj69++vSpUqydvbW+vWrTM7FlDoUPaBeywyMjLb91arVRaLRQMGDDApEfLKc889J3d392zbDMPQmDFjZLFYTEoFILeNGDFCTk5O2bYZhqH//e9/JiUCzHH27Fn16tVL5cqVU3p6utatW6ekpCRJkqenp6nZgMKIsg/cY6GhoSpRooTteycnJz344IP8EVgIuLu768UXX7QVe4vFogceeEDt27c3ORmA3BQQEKDevXvL0dFR0p+fWW7fvr3q1KljcjIgbx09elSffvqpUlNTs213cHBgziLABJR94B4rUqSIIiIibIXP0dFRCxYsUJEiRUxOhrzw3HPP2d7sYVQfsF8jRoywfZ2VlcUbuiiUHnzwQc2ZM+cf/z8XEBDAx9cAE1D2gTwQGRlpm5jm/fff593tQsTd3V1DhgyRJJUrV45RfcBOBQQE2D621ahRI0b1UWh1795dH374YbZttWrVMikNULhR9oE8EBYWJovFomrVqql///5mx0EeGzhwoDw8PPTqq68yqg/Ysddee00lSpRgVB+F3lNPPaV33nnH9j0rUwDmcLr1XQDcrWLFimnNmjWqVasWZa8Q8vLy0vnz582OAeAeq1mzpi5cuGB2DCBfGDx4sBITEzVlyhTbErQA8pbFYNFLAAAAALnMMAzNnTtXjz32mFxcXMyOAxQ6lH0AAAAAAOwMn9kHAAAAAMDOUPYBAAAAALAzlH0AAAAAAOwMZR8AAAAAADtD2QcAAAAAwM5Q9gEAAAAAsDOU/f/X3n1HRXG+bwO/liIdqQqKgIqVxI6KSsACNgQLVuyNGPNNYkksidFYEk2MsSb2Fk0sMQpiQbEbe2I0moi9U0QRVFDK3u8fvszPVVQsMLBcn3M8R2Z3Zq/Z3Xlm7pnZ5yEiIiIiIiLSMyz2iYiIiIiIiPQMi30iIiIiIiIiPcNin4iIiIiIiEjPsNgnIiIiIiIi0jMs9omIiIiIiIj0DIt9IiIiIiIiIj3DYp+IiIiIiIhIz7DYJyIiIiIiItIzLPaJiIiIiIiI9AyLfSIiIiIiIiI9w2KfiIiIiIiISM+w2CciIiIiIiLSMyz2iYiIiIiIiPQMi30iIiIiIiIiPcNin4iIiIiIiEjPsNgnIiIiIiIi0jMs9oneQGxsLB48eKB2DCpA+J0gKhq4rRO9Hm47RPmHxT7RE65evQpLS0tcvXoVe/fuhaurK6ysrPDTTz8989z4+HhUqFABt27dAgCMGzcOfn5++ZyY8hq/E0RFA7d1otfDbYeo4DJSOwBRQeLq6or79+8DACZMmICaNWsiPDw8x+empaXxzHQRwO8EUdHAbZ3o9XDbISq4eGWf6AmXL1+GRqNBx44dsXTpUmzevBmWlpZ49OiRzvOysrLg6ekJAPD09MTq1asBAPfv38eAAQPg7OwMBwcHfP7558o86enp+PLLL1GuXDnY2dmhVatWOH/+vPK4RqPBrFmzUKlSJVhZWaFhw4b4559/8mGt6UX4nSAqGritE70ebjtEBZgQkeLSpUsCQC5duiS9evWSXr165eq5IiJjx44VjUYjP//8s2i1Wtm5c6doNBo5cOCAiIgMHz5catasKRcvXpS0tDT56quvpGzZspKWliYiIgDE29tbYmNj5e7du9KsWTNp3rx5Xq8yvQS/E0RFA7d1otfDbYeo4OKVfaK3yNPTE927d4dGo0Hjxo3h5OSECxcuQETw008/4ZtvvkHZsmVhamqKMWPGID09HZs2bVLm/+ijj+Dk5ITixYujU6dOOHv2rIprQ28DvxNERQO3daLXw22HKO+w2CfKhZUrV8LS0lL5t3LlyhyfZ29vr/N3sWLFkJmZiVu3buHBgwfo2LEjbGxsYGNjA1tbW9y5cweXL19Wnu/k5KT839jYGFqtNk/Wh94cvxNERQO3daLXw22HSH3soI8oF0JDQxEaGqoz7ckdzcs4ODjA1NQU27ZtQ/369ZXpMTExKF269NuKSfmI3wmiooHbOtHr4bZDpD5e2Sd6TaampgCA5OTklz7XwMAA/fr1w8iRI3H9+nVotVosW7YMnp6eOHfuXF5HpXzC7wRR0cBtnej1cNshyl8s9oleU8mSJdGuXTt4e3tj7ty5L33+1KlTUb9+ffj4+MDGxgY//PAD1q1bh5o1a+ZDWsoP/E4QFQ3c1oleD7cdovylERFROwQRERERERERvT28sk9ERERERESkZ1jsExEREREREekZFvtEREREREREeobFPhEREREREZGeYbFPREREREREpGdY7BMRERERERHpGRb7RERERERERHqGxT4RERERERGRnmGxT0RERERERKRnWOwTERERERER6RkW+0RERERERER6hsU+ERERERERkZ5hsU9ERERERESkZ1jsU5F0+/ZtZGRkqB2DiIiIiPJYRkYGbt++rXYMonzHYp+KnGXLlqFUqVL4/fff1Y5CRERE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",
      "text/plain": [
       "<Figure size 1000x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "task_graph = taskgen.TaskGraph(starting_operators=config.STARTING_OPS,\n",
    "                               ending_operators=config.ENDING_OPS,\n",
    "                               min_depth=7)\n",
    "plt.figure(figsize=(10,7))\n",
    "task_graph.plot_graph()\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bf0a822b-27dd-40df-9cb3-fd8657616c19",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "7dd8c0cb-fbb3-42a7-886f-ebd0aa7728d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current yellow y sum is even , then [ if current orange o sum is odd , then [ if current yellow f sum is even , then loc of current cyan g , else current brown h + current green u sum is odd ] , else [ if current orange k sum is even , then current green x product is odd , else current white z exist ] ] , else [ if current pink t + current brown k sum is even , then [ if current green r * current white b product is odd , then loc of current yellow b , else current green a sum is even ] , else [ if current brown k * current red h product is even , then shape of current brown object , else loc of current green f ] ] ]\n",
      "Target output: (1, 0)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 3\n",
    "\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c471967e-6de8-42c6-984a-fc826a5fb84e",
   "metadata": {},
   "source": [
    "## Generate an image that satifies this task graph, but add more distractors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "e741721a-e69d-4968-9c26-7a6eb993c029",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instruction: [ if current yellow y sum is even , then [ if current orange o sum is odd , then [ if current yellow f sum is even , then loc of current cyan g , else current brown h + current green u sum is odd ] , else [ if current orange k sum is even , then current green x product is odd , else current white z exist ] ] , else [ if current pink t + current brown k sum is even , then [ if current green r * current white b product is odd , then loc of current yellow b , else current green a sum is even ] , else [ if current brown k * current red h product is even , then shape of current brown object , else loc of current green f ] ] ]\n",
      "Target output: True\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVcAAAFwCAYAAAAMmDiWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABJTUlEQVR4nO3deXxTVfrH8c9N0qbpvrGVFlAoCFg2UQFFxbqwKK6DgjpgXUdRlFFHZBzBn7iNw7ig4gYuM1VHcQFEQFAWkR0KyL5TSktbujd7cn9/RCq1LbSQm6TJ856Xr0lvbvs9IeXh5Nxzz1FUVVURQgjhVTp/N0AIIYKRFFchhNCAFFchhNCAFFchhNCAFFchhNCAFFchhNCAFFchhNCAFFchhNCAFFfhN3L/ighmUlyFX2zbto2LLrqo1jFFUZg0aZJP8jt06MCYMWN8kiVCk8HfDRCh6X//+x8rV66sdWzlypWkpqb6qUVCeJcUVxEw+vXr5+8mCOE1MiwgNLNhwwYyMzOJi4sjJiaGK664gtWrVzNp0iQmT54M1B4KOPHxkiVLUBSFH3/8kUGDBmEymWjXrh3vv/8++fn53HjjjURHR5OWlsarr75ak3n8+5YsWVKrLZdddhmXXXZZve08cOAAiqLw4Ycf1jo+ZswYOnToUPP1vn37uO6660hKSiIyMpL+/fvz/fffn8GfkAhmUlyFJioqKhg8eDDJycl8+eWXfPbZZ1RXV3P11Vdz5513ctdddwGeoYC77767wZ9z6623cu211zJnzhw6d+7M/fffz6BBg8jIyGDWrFmcd955PProo6xZs0bT1+N2u7nmmmuoqqrik08+4dtvvyUpKYnhw4ezZ88eTbNF8yTDAkIT27Zto6ioiIcffrjmwtU555zDO++8g06nqxlbPdVQQFZWFuPHjwcgOjqa/v37c8EFF9T0fPv27cu3337LL7/8wgUXXKDZ6yksLGT79u1MnDiRoUOHAtS0w2q1apYrmi8prkIT5557Li1atODaa6/llltuYejQoWRmZvLyyy836ecMGDCg5nHr1q2B2gU5KSkJgLKysjNv9Em0atWKbt26cc899/DDDz8wZMgQrr76aqZOnapprmi+ZFhAaCI6Oprly5czbNgwPvvsM4YPH06LFi247777mtTTi42NrXMsMjLSm01tFEVR+OGHHxgzZgzz58/n1ltvpWXLltxyyy2UlJT4vD0i8EnPVWimS5cufPLJJ7hcLtasWcMnn3zC22+/zdlnn61ZpqIoALhcrlrHq6qqiI6ObvL3nCglJYW33nqLN998k02bNvHll1/y4osvkpiYyNtvv+2tlyCChPRchSa+/PJLWrRoQUFBAXq9nv79+/PWW28RHx9Pbm4uer1ek9zjPd3c3NyaY6WlpWzbtq1J3+NwOGpdJFu5ciWtWrVi7dq1KIpCr169eO6558jIyKj1fUIcJz1XoYmLLroIl8vF9ddfz5NPPklsbCyff/455eXl3HTTTfz6668AfPrpp/Tr14+zzjrLK7k9evQgLS2NyZMnExcXh16v54UXXiAqKqrB70lISGDAgAG88cYbpKenk5yczOuvv47FYqn5vt69exMZGckdd9zBpEmTaN26NYsWLSInJ4dx48Z5pe0iuEjPVWiiTZs2LFiwgLi4OO666y6GDRvGhg0bmDVrFoMGDeKmm27i/PPPZ/To0fzzn//0Wq5er2fWrFmkpKQwcuRIHnroIW655RZuuummk37fhx9+yPnnn88999zD6NGj6dWrF4888kjN8xERESxcuJDu3bszbtw4rr76ar755hveeecduY1W1EuR3V+FEML7pOcqhBAakOIqhBAakOIqhBAakOIqhBAaaFJxzc7Oplu3bqSnpzNt2jSt2iSEEM1eo2cL5OXlMWDAADZs2EBERAQDBgzgP//5DxkZGVq3UQghmp1G30SwaNEiMjMzaxbKuPnmm/nyyy8bVVzdbjdHjhwhJiam5lZDIYRojlRVpbKykpSUFHS6hj/8N7q4HjlyhJSUlJqv27Rp0+AamjabDZvNVvN1Xl4e3bp1a2yUEEIEvNzc3JNuS9To4up2u2v1OlVVbbBqv/DCCzXrbZ7o/fff98uKRkII4S1ms5m7776bmJiYk57X6OKamprK8uXLa74uKCio1ZM90YQJE2oWOAbPqvRpaWlERkYyduxYLBZLY2PPmMlkYsaMGWRlZfk0t9ll63TojEbcNhu43b7N9iJ/ZYfiaw7V7OOXqU41xNno4nrFFVfwzDPPUFhYSFRUFF988QXvv/9+vecajUaMRmO9z1ksFp+/Cf7MbS7ZCRdfzLlvv83mu+6i3EtbpjSH1x0suZLtn+yTafRUrLZt2/L8888zaNAgevfuze23367pthqhKDo6mj//+c+ce+65Ps1tMXQosb16UbJkCfF9+9Ji8GCf5vvTZWdHM7xrHIF6mfXSSy/l5ptvPumFExGYmrTk4KhRoxg1apRWbQl5SUlJvP322zzzzDM1S/JpTqfj7Mcfx15YyMZRozhv1iz0JhNFCxZACKzpc9+FyXRKMjJvZznOMxsN0cQ999zDhRdeyJw5c2pdJBaBT9ZzDXVuN5uzsog//3z6L1/OvldeoWLDhpAorEJoSYqrwLJ/P4bYWCz791O9YweWAwf83SQhmj0prgKAyk2byLntNn83Q4igIaPkAW7kyJEsXbqUpUuX8sQTT2iWE9e3L32/+46Ynj01y2huosN1fD7qLO69INkneX379q15r9999125m7GZk55rAOrQoQMXXXQRAGeddVbNleI2bdowYMAAcnJyMJvNXs0Mi48nYcAAwuLivPpzm6u0uDA6JRkx6hV0Gta45ORkunTpAkB6enrNex0bG8tFF11EixYttAsXmpLiGoAeeOABHnjgAQBefvllBg4cCEBWVhZLly6lT58+bNmyxZ9NDHp3nZ/M3ecn0fv1HRRVOzXLyczM5NNPPwU863ccf6/79OnDmjVr0Ol07N27V7N8oR0prgFIURQqKyt54IEH2Lhxo7+bEzLuOT+Jyzt5bmncdMTC3bMOUW51+ST7b3/7GytWrKh1TFEUGRpoxqS4BqCCggL27t3LnDlzKC8vrzleWlrKtm3bSE1NpaysjNzcXD+2MngY9TrOaRHBpWfHMKRzHHtLbCzYVcH8XRWaZSqKQseOHYmJieHXX3/l+++/rzW32WKxsHXrVtLS0jRrg9CWFNcA9O9//5t//etfuFy1e03ffPMN8+bNY+XKlRw4cIAbb7zRTy0MLmcnhrPi/i7odJBf4WDQu7uotGt7R0FYWBizZ88mJyeHPn364HTWHnrYvn07ffr04eOPP+b888/XtC1CG1JcA5Db7a5TWMGzYITT6USv16PX6/3QsuCUX+nkhSUFuNwq4XqFKVenMGd7OQt3V2qaq9frURSlTmE9zul04j7DRXSE/0hxDUDx8fE160RWVlbWDA1ERUWRnJzMsWPHKC4u9mcTg0qZ1cnHG47hdEOraAMP9G/BoTIHWwqsHK1y4NbgZjVVVcnPz8disdS81zabjaKiIsDTs23VqpUs0dmMyTzXAPT444+zY8cOduzYwWOPPVZz/MYbb2TTpk088cQTNbMJhHcVVjm56O2dRIbpWHZfOgkmbT4hOBwOhgwZwqJFi2re6w8++KDm+e7du7Nt2zauvfZaTfKF9qTnGoAWL15cs3ZueHg4U6ZMATx/IV944QUOHjwoi3hoRAXMDpUf91ZgdrgY278Fqw5Vs0CDIQKLxcLGjRtr3l+9Xl/z2O1288ILLzBixAiio6O9ni20J8U1gLjdbsrKypg3b17N7roPP/wwzzzzDAD//e9/efjhh7XJdjpxlpXhdjg0+fmBqtrupsLq5o+f/JcfqGZTvoXl93VGBU2KK3guXG3fvh2Ayy67jFmzZgGwadMmMjMz6dChA+eddx6N3EdUBBAprgEkLy+PHj161Lr76r333iM7OxsAq9WqWXbpihX83Lcvzgrtph8FokfnHkavKLjquW5UaXMz6L3d2Jy+KWwrVqyouVvL6XSiqiqPPfYYBoMBu93ukzYI75HiGkDcbjfHjh2rdcxXq6yrDgeOP2SHgkpbw1fjVaDE4pubCMAz7PPHC5WVldrOWBDakQtaQgihASmuQgihASmuQgihASmuQgihASmuQgihASmuQgihgSYX18rKSjIyMjggm9gJIUSDmlRcV69ezcCBA9m5c6dW7RFCiKDQpOI6ffp03njjDVJSUrRqjxBCBIUm3aE1c+bMRp1ns9lqLSxSccItlSaTqSmRZ+x4nq9zJTu0skPxNYdqtqqqjboVXVFPY0WIDh06sGTJEjp06FDv85MmTWLy5Ml1jmdnZ8v6lEKIZs1sNjNq1CjKy8uJjY1t8DxN1haYMGEC48ePr/m6oqKiZi+grKwsn9wrf5zJZGLGjBk+z5Xs0MoOxdccqtmN7Y9qUlyNRiNGo7He53y1EEmg5Ep2aGWH4msO5eyTkXmuQoSY6Agdoy9pSUaaDNFp6bR6rjLHVYjmyxSm54pz4ympcrIl13zqbxCnRXquQgihASmuQgihAdmJQAhRi14H4QYdVoebYNy6Kzo6Gp2ubr+yuroal8t7O09IcRVC1NKvUwy3X9yS577OJa80uPbuioqKYtmyZbRu3brOc8OHD2fdunVey5LiKoQAQKfAwHNiSYoOY/WeSsz2hvcXa66cTidz584lPj6+znODBg0iLS2Nr7/+2itZUlyFCHF6HSgohBsUbjo/mV8Pm3n3xwJ/N0sTNpuNf/zjH7WO6XQ6wsLC+Omnn7DZbFJchRBnLjJcx99vSCMqXI/DpfLmD/kUlAXXUMCpXHHFFbzxxhukpaWxevVqr/1cKa5ChKgOyUb6pceQmmCkuMrB/iIrR0rtVFp9t524rxkMBoYOHVprsZeUlBQ2bNhAYmKid7O8+tOEEM3GxV1iuaiLZ+GR9fuqyP6liCCcHFCLyWRi2rRptG3btubYrFmzGDFiBCtWrPBqlhRXIULU95tKWb7Dsxxoj3ZRTLqpHf/+Po8yc3D2XO+8806ysrLIysqirKys5nhpaakmeVJchQhRx6qc7C30rEvaMi4Mq8NElzaR5JXaOFwSfOOubdq0oWfPnmzbto0jR45onid3aAkhWLm7kn/Ny+PPA1tyTW/vjj2GKum5CiEAcLhUpi08QsdWEUwYnsr7S45SVOHwd7O85tNPP2XTpk28/vrrREdH13pOURS6detGTk6O1/KkuAoRYpxulf2FVsrMzlrHVRW2H7EQZdTTP12PXvFTAzWyf/9+CgoKeOCBB0hKSqrz/J49e7y6+aoUVyFCTGm1k2e+PNTgzIB1+6tYv78qKGcOWCwWrrnmGp9kSXEVIgSdqnAGY2E97jS2DTwtckFLCCE0IMVVCCE0IMVVCCE0IMVVCCE0IMVVCCE0IMVVCCE00KTiOnXqVLp3705GRgZZWVnY7cF3/7EQQnhDo4vrmjVrmDlzJmvWrGHz5s04HA7efPNNLdsmhBDNVqNvIkhISGDatGlERUUB0LNnTw4dOqRZw4QQojlrdHFNT08nPT0dgMLCQqZNm8bMmTPrPddms2Gz2Wq+rqioqHl84grgvnA8z9e5kh1a2aH4mkM1W1VVrFbrKc9T1CbeC3bgwAGGDRvGqFGjmDhxYr3nTJo0icmTJ9c5np2dTWRkZFPihBAioJjNZkaNGkV5eTmxsbENntek4pqTk8OwYcN48skneeihhxo8r76ea1paGtnZ2YwdOxaLxdLYyDNmMpmYMWMGWVlZPs2V7NDKDsXXHKrZx3uupyqujR4WKCoqYvDgwbz11lvceOONJz3XaDRiNBrrfc5isfj8TfBnrmSHVnYovuZQzj6ZRs8WePXVV6moqODZZ5+lV69e9OrVq8FhgWBzfs8wfvkqiV++SmLmK3EoQbbOpQgtrVvo+OmzREZdF+HvpgS1Rvdcp0yZwpQpU7RsS0Dqc66BjC4GrDbP6El4uMJl/cLZuttJYbHbz60ToumMRoULeoXz3Y+2U58sTpus53oSigJvTYmjolLl8pElgKfYrpmTzJ8fKSP721NfMRRChCYprk2056CL6+4qZePW4NlbSAjhfc2muCoGA1Hp6aDTobrdmHftwhAfj7FVK6p370Z1eKfYKQp0PluPMVxBUSAyQsHthh5dPX9UFqsqH6e8LCwunLB4I5bDVaiu+iev6CL0RLSOxHbUgsvirPcccfpaJOlo09JzCaakzM3hfG2GvPQmPcZWkVgLzLitrnrPUfQKptQoHOV2HGXN9xb7ZrNwS3jLllywcCH9ly3j/LlzMSQk0GbECC784QciUlK8lhNmgG/eTWTDd8msn5vMuV0M9OsdxobvktnwXTL/fS1eLmh5Waur0ujxcn/C4sIbPCe6Uxy9XxtIbHfZ9lkLo2821fyOPzMuRrOcmK6J9H59IDGd4xs8xxAbTo+XBtD66naatcMXArrnamzThk4TJ4JOh9tmY8eECeByoRgMpD/9NDEZGaDX481q53TBUy9XEButAwX+MS4as0XllXeqAThW5sZHW/CEjJK1hTjKbLQb1ZmK7aUULj5c6/m0WzphiA1n9+ubqN5f0cBPEU11y7URdO/iKQGH8lzc9Xg5AK1b6vjgn3E8M7XS6z1YRQEa89dVh1f/XvtDQBdXQ1wcbW69FWd5Oea9e9n51FO4LRYMcXGk/+MfhLdogasRt6E1hdsNXy/wfOxXFPjLHZFUVKp8NCvw5tEFC/OBSqz5Zlpd3Q63w0X5FhP2Y1YUg46wuHBiusTjsrrYvzjP300NKn17hNO7exh5BW7e+qS65nc8a4SJ5x4z8eoH1V4vrm67C1uhBUOUgbAEI47S2kNshpgwwhON2IutOKub93WNgC6ux+194QXyPvkEt03GOoOV2+Ziy4RVtLoild7TLmHT+J8xpUbT5fHebH1mDZU7yvzdxKBUVqHS/4ZiCo/5Zlph+a8lbPjLUrr+vS8pw89iy4RVtZ5PuzWdpH6t2DR+Bc4qKa6aSBk1iqj0dHZPmkTpL7/UKqxuq5U9L75IcmYmSZdf7sdWCm9SHW4qtpeS++kuWmamglvl4Cc7sR6pRnXKnGJvm7vIyvdLbJSUuXGecI1wzSYHT75YyajrTOzq4WTm/7z4qU0Ft92NoldQwupe8tEZFHRhOtx2d4MXN5uLgC2uLYYOJapjR1ZefDGqq/ZVRbfNxuEPPkBvNEpxDTKWvGocZTa6Pd0XS76ZvG+24jLL7AAtLF1t561PzHWO/7rTyfY9TjZ8l0y3dIN3i+tvjr+nhthwXGYHqlvFEBWG6lZxVDpo4npSAanZzBYQoaHFJSn0nnYJe9/ZSunaQs575zKiOja8OIZonnZNzSH38z2cN/1SEvq2JKJVJH3euhRLXjWbn/ilwWlazUnA9lwL584lKj2d9mPHAuCsrCTv449RnU50RiNt//xnEi+5xM+tFN6iGBRaXdWOsNgwji7MxXbUgtvm5ujCXOJ7JRPROoriZUf83cygcln/cHS/da9Wb3SwdLVnTmnGOQaGXGZk7mIbu/Zr86nBZXHhtrkwxIShM+hQdAqGmDBUN7iqg+OTSsAW1/zPPiOqc2cuXLQIxWDAVlDA0W+/xWU2ExYXR4eHH8bYqhWqW8bimjtFr2CICqPtDWdRuq6Ife9sBcBRbufAhzs4d8qFqBkqJauP4na4QN5yr7hyoJHL+nnmFk/7yMzazZ4LSBf2CmPi2GgG3HiMrbu0K3SqW8VtddWMv7ptLlRX8Ly5AVtcAcz79vFL//6gKIQnJ3PB/PnoIiJwVVWx8dZbaXXddXR4+GF/N1OcodZD2tHmmg7seHEDtqN1x/d2/nMjMV0S6PP2pex+bRPlm475oZXB55/vVPPOfz3zt2+73sT2xS0A+O5HK+deVURBobaFrnp/BRseWEq72zrTZlh7csb9jL0seGYEBXRxVZ1OrHmeuY3OqipKli1DFx6Oy2LBcvAgzrIybfNVmLPIhsXa/AfXA5n1qIXyTcVYC8z1fiR0lNmxHK6iLKcYR3nzvR0yUFRVu/l4lpnla+zkHvEU0JxtTn742VPY1mxy1BzXkupUsRVZ0Rn1GGLDsRVZmv0MgRMFdHE9kbOsjO1//evvB3Q6UBTPTAINryxOeaNKs58tPErXFlK6tvCk51jyqtnz+mYftSi4HStV+cvE2ne6zV9iY/4SP/QadQqogDt4iupxzXK2gD46mr5z5hDeogWrMzOxHpELHUI0N5EdYuj9+sWU5RSz7bn1QdVrhQDvueqjo0m8+GJqLmn+Rhcejv3oUar37KF6xw4/tU4I0VRhceHEnJNQ89haYMacW4X1SLWfW+Z9AV1cI1JT6fnJJyiG2s10lpfzc9++OIqL/dQyIcTpiO4UR9e/nwdA5c4yNj/2i59bpJ2ALq6WgwdZN3w4yh9Wx3E7nZpfzBJCeF/lzjK2POlZTyDY1+UN6OLqtlgoW7nS380QQniJs8pBxdYSfzfDJ5rlBS0hhAh0UlyFEEIDTSquEyZMoGvXrnTr1o2pU6dq1SYhhGj2Gj3mOm/ePFasWMGWLVuw2+10796dYcOG0aVLFy3bJ4QQzVKji+vQoUO58sorMRgM5OXl4XK5iIqKqvdcm82G7YTFrSsqfr8bxGQynUFzm+54nq9zJTu0skPxNYdqtqqqWBuxvZSiNnFV2r///e9MnTqVESNGMHPmzDrTpAAmTZrE5MmT6xzPzs4mMjKyKXFCCBFQzGYzo0aNory8nNjYhtcabnJxPf7Dhw8fzogRI7j33nvrPF9fzzUtLY3s7GzGjh2LxeK7zf5MJhMzZswgKyvLp7mSHVrZofiaQzX7eM/1VMW10cMCW7duxe12k5GRQWRkJDfccAObN9e/kIbRaMRoNNb7nMVi8fmb4M9cyQ6t7FB8zaGcfTKNni2wfft27r//fux2Ozabja+++opLZCcAIbQVFgHG+q9tiMDW6J7rzTffzIYNG+jVqxd6vZ4RI0YwYsQILdsmhBj8MKScA+/fB67mvdV0qGnS7a/PP/88zz//vFZtEUL8UXgUmGSDxuZI7tASQggNSHEVQggNBOyqWJf07ElsZCTfrVrFBV270qltWwBy9uxh6/79NefpdDquHTCAaJMJVVX5fvVqSisrvdqW1tEGBnWMqXXsl4PVHCyT/ZyEF0UnQccLPI8t5bAreNc69YfI9jFEto+hZFUBbvvve4QZW0QQe24SZRuKau3RZogOI+H8llRuL8VaYG5yXsAW14duuon01FQWrl3L6MGDuXPoUACemTGD7QcO4FZVFCAiLIwX7ruPs9q0we12c/GDD1JWVcVpTN+tQ/fb/RHdW5l454Z2tZ6756tD5Jbbg3HrH+Frx2/EadURbnja8zh/J+xZDXXv0RGnKfHCVqT9qSPrtx7Dfuz3efjR6fF0Ht+TzY+vrFVcw5Mj6PxIT3a/vim4iivAWW3a8PNbb/HJ/Pn0v/9+AK4fOJCFU6fyp6efZnC/foy94QYefu01isvKUBSFiXfcweGiIh55440zys7sFMOzV7QBYEeRlYHv7Kr1/J3nJXHTufHc9vkBHEG294/woU4XwhUPeB4X7Yd3xngex7WGez+AhBSwVDT47SJwBXRxNRmN9OrUiXdsNnL27AHgpksvJePsszEYDLSMjyejY0f25uWxPz8fnaKQ1qoV4WFhZ5ydEKGnZxsTq3PNHCpzsCm/9iTlA6V2wg2/7VwpxOmKiIE2nSF3C5QVQP7xf8QVz3FFJ8XVS6z51ZRtKibmnAQsuVWYD1UR2z2B8EQjpeuLiEyLQnWrVO0qI7pTHKa0aEo3FGErPvU6AvUJ6OLaqI/2Gm6rrQJPfJ/H+ry6HwleXXHyraCFaDwVvn8V8rbVOSz/entP8fJ8StYWct70yyhZe5R907fS6cEMzLlVbJu0lh7/7I/qVNkyYRXtRqVjbGFi47jl4D71z65PQM8WOHj0KEOfeIJ5q1bVHJsxbx6jn3+edx9/nOT4eK558knyjx0DwK2qPDh1Kt/+/DMLXnmFnp06NTnToIN3b2xH/3ZRXPPhXnad5r9aQpyUTg83/gPa9YQPH4LiA7WfP5YLHz0E+9b5pXnizAV0ca22WFiak1NTPAH25+ezautWzj/nHIxhYSzbtAmr/fdB6HU7d3K4qIjLevcmISamvh97UjpF4cLUSJKiDCzdX0Wl7TT/2RLiZBQdpJ4LUfGwfz3Y/vDpyG72HK8Kjf2mglFAF1chhGiuAnrM1R+cbpXH5uVxTssIPhnRAYBfj1p4aenRWuf9pV8ynRKN/G1+Hk7p3Iqmcjth3lRoeRaMmOI5dnQPLJ3peZyQAlc+4OnduoN7C2pfctvd7HlzC1HtY+j8WC/yvt6POdczL/7gJ7swpUZzzpN9KN1YjCW36rTHW0GKax1uFX7YU4lO8Uy38hxT6ZxcewnFbi0jaB8fjk5RkIsOoslUFfas8sxxPe+63465Ibm953FCW8+814hoMJf5rZlBx61SurYQY1IESf1bcyh7t6eIAuWbj6G6VTr+pTtHFx+mLKf4jKKkuDZg4e5Kfty7E4BLz45m9YO19wr7y9e5PPrrYem1ijOzexXsXet5fPZ58OB/PI/zd8Fbf/bcVJDazX/tE6ctYIvr+3PmEBcdjctdt3qZbTaeeu89dufm1vu92w4c4OHXXmNXA883hgo4frv9anuhlSfm5dV6fl2eWQqr8AL194/9hfth3r89j81lniUGN8yBXSvA7fJbC4NRxbYS9r2zFUeprdZx65Fq9r69FfPBM7+FPmCL64K1axt8zu5w8PH8+Q0+n1tYyDuzZwPe2bwsr8LBe2uPnfpEIc5ERSGs/ar2sX0N/z0Qp898yHMTwR/ZS2wUzDvolQyZLSCEEBqQ4iqEEBqQ4iqEEBqQ4iqEEBqQ4iqEEBqQ4iqEEBo4reL62GOPMWbMGC83RQghgkeTi+vixYv56KOPtGiLEEIEjSYV15KSEiZOnMhTTz2lVXuEECIoNOkOrfvuu48pU6aQe4rbSm02Gzbb77eVVVT8vk2FN+6Yaorjeb7OlezQyg7F1xyq2aqqYrWeehF9RW3kNqnvv/8+27ZtY+rUqXz44YcsWbKEDz/8sN5zJ02axOTJk+scz87OJjIysjFxQggRkMxmM6NGjaK8vJzY2NgGz2t0cb3yyivJz8/HYDBQUlJCVVUVt99+O6+//nqdc+vruaalpZGdnc3YsWOxWCx1vkcrJpOJGTNmkJWV5dNcyQ6t7FB8zaGafbzneqri2uhhgR9++KHm8fGea32FFcBoNGI0Gut9zmKx+PxN8GeuZIdWdii+5lDOPhmZ53oK53TUk36W3t/NEEI0M6e15OCYMWNCYp6rosDMV+Ipr1IZfIdsFCeEaDzpuZ6CogOd4u9WCCGaGymuQgihASmuQgihgYDd5gUgLMFI6k1no/zhc7nL5iL38z24rd7fV0ivhyf/Ek2LJB2KAu3b6rHb4dVnPFMuDue7+Ne71Zrs92qIDiN1RCdK1xVSvrmBbWUUaHvj2TirHBxdcPp7hAkhtBXQxdUQaSB5YAqK/g/F1eykcPFhbMVWrxdYnQ6GZRo5u51nhkBinA63CrcOjwBg83Yn/3qvWpPdtPWRBtoMa4+jzHaS4qrQ8rK2WAstUlyFCGABXVwtR6rZ8Jel8IcLSoZIA+c+34/iZfkc/GSnVzMdDrj69hJ0Ok+h/eG/SVRUubnhnlIAXG7PlvNCCHEyAV1cUT291BPF9Ugivmcy4QlGdOHaDBlXVnuqp6KA06XidEJ5pVRUIUTjBXZxVUBnrD2BP75nMinDO9Q5LoQQgSSgi6spJYru/3cBiu73Hmr+vIPkjF9Bj5f6+7FlQghxcgFbXON7JxOZFk3puqJaY67Ve8uxl1hR3fIxXQgRuAK2uLYZ2p6IlCg2PrQc/lBI9VH+bXaYAZwubS5sqS43QM0MCdWt/j4zQfntuNwxJkTAk5sImqhbuoGN3ycz7PL6V/06E/ZjVjY9ugJDTBi9p11C72mX0Pb6s2qeT+rfmt6vD8SUEuX1bCGEdwVsz7ViRymOSgdJ/VvVmVOqj9CjC9P+3wVVhZ9+sRMdpXDTEM8814Q4he17nJRXuL2f51Kx5FVjPlSFKaUSAH1UGEkDWgMQ0ToSc24l4YneL+xCCO8K2OKaN2sfke2i6fX6wDo3EfjShJcqueLicBb+JxGADb86Of/aYk3nuhb9lEfRT3kAtL3pbM6Z0AeAoz8cZseLG+n92sXahQshvCJgiyuAtcDMlr+tbHCM0V5iq/8JL1u7ycGAGz13TFWbVZ/eRFD0Ux4VWz3LHTrK7OBW2fmvHFSH93vOQgjvCeji6ra7qdxZ5u9mUF6psmqDwy/Z9hJbnX9EzAcq/dIWIUTjyQUtIYTQgBRXIYTQgBRXIYTQgBRXIYTQgBRXIYTQgBRXIYTQQJOL68iRI+ncuTO9evWiV69efP3111q0SwghmrUmz3Ndt24dq1evJjExUYv2CCFEUGhSz7WkpISioiJGjhxJjx49mDx5MqrseSKEEHU0qedaUFBAZmYmb775JrGxsQwfPpyZM2eSlZVV6zybzYbN9vtdRRUVFTWPTSbTGTa5aY7n+TpXskMrOxRfc6hmq6qK1Wo95XmKegZdz2+++YaPP/6Yr776qtbxSZMmMXny5DrnZ2dnExkZebpxQgjhd2azmVGjRlFeXk5sbGyD5zWp57pu3TqOHDnC8OHDAXC5XBgMdX/EhAkTGD9+fM3XFRUVpKWlAZCVlYXFYmlK7BkxmUzMmDHD57mnk60AEUYjDqcTp+vMtgxvTq87GLJD8TWHanZj+6NNKq4ul4tx48Zx6aWXEhkZyfTp0+sMCQAYjUaMxvrXHLVYLD5/E/yZ25Tsti1asOCVV3j1iy94f+5cn2ZrIRSzQ/E1h3L2yTTpgtaFF17IuHHj6NevH926deO8885j5MiRWrUtpFyckcE1/fuzfPNmWiYkcGtmJuFhYf5uVsAISzDS6spUwpMj/N0UIRqlyfNcH3nkEbZv387u3bt58cUXtWhTSPrz4ME8OmIEj7/1FjEmE6888ABREVJIjjO1jaLTwz2IOqvhMS4hAklAr+caSibPnEmn1FQW/fvfzFq6lCsefZSK6mp/N0sIcZqkuAaIvOJi7E4n+44cYWduLjsOHfJ3k4QQZ0CKawApKitj1LPP+rsZQggvaDbFNVoXyx1Jj2FQwrGpFj4pfgWLGlwfm1slJjLzySf58Pvv+d9PP/m7Of6jU0gf14OIViZQYe/bv/q7RT7RJ8XEC4PbArD7mI2Hvs3948bHzd6FF17Iyy+/3KhzZ8yYwUcffeS17NuuvJKRmZmMeeEFisvL0et0vPfEE7Rv1QoVGPfaa2w9cMBreQFdXMMUI6lhZwNg0kWhUwzoFB0G1UB7Y2cKHUcocR31cyu9JyIsjIsyMli0bp2/m+J7OojuGIdi0KHoFPQmPYpOQVUh6qxYDDHBOXMiKVJP+m8zIDolGjm+0XGsUUe/dlHsLrZSbD6zOc+BRFEUdLqGr6N37NiRpKQk1q9fj6J4d9fntJYtubhHDwacey7F5eXodDqiTKaa9mR07AiKwtb9+72SF9DFNcnQiodavYAOPWWuYzyffz921YpJiWJiyjusq/6Jb8o+8HczhRfowvV0nXge4UkRqC6VjQ8tx5JbBUCPl/sT0zXB63/ZAsFlZ8fw0Z/aA/Dj3iqu+GAPAL3amFh2X2fu/uoQ/9tc6s8metWqVasYOHBgg8+/+eabXH/99QwePLjWbfPeYjIa+eK3oTeny0Xfe+5h+8GDKMBPr7+Ow+nkyhNugDoTAV1cPRR+rprHr5bVOFS7vxsjNKVQtrGY/O8OYi+2nHg4KAsr/L5r/N8X5rPqUO1hriB9yfVKSUnhtddeY926ddx1112YzWZNco7/Hv2wdi3Tv/2W3MJCAFR+fy+8JWAXy47XJxOvT6bAcYjd1s3ssG5AxQ2AGzeFjjxcuGhlSEPfHP6NEA0yxIYTmRqN9aiZiu2llKw+isvy+0dha4EF61FzUK3ApgAdE8OJMerZVmjlh90VrMr9vbhanW62F1qJDtfRMTHc63/xA0lqairdunUjPT2dAwcOMH/+fJxOpyZZLrebXbm5rNy6lTm//ELVCXd27S8ooKisjG4dOhDthcVgArYq3ZBwDy0MKUwtGI+T2n/QNtXCtMIJXBIznL+2nspL+WM5FkRjr6Gm9dVppN7UkY0PLcNWXHe1oV3/ziHu3CTOnXKhH1qnjTC9wv9uO5vN+RYGvL0Tp7v28zuKbAx4eyfTb2jHQwNa0O/NndhcwfOPy4lefvllevbsSd++fRu12tSZsNhsDH38cQ4XFdV57q4XX2Rgjx6sffddbn76ab5fvfqMsgK2uOp++58bF9RzzdT9Wy9Wp+hD6/NTMFIUFL2C6lbre6vBjee5IGNQPL+6fyysxzndno+WBl1w/n6fddZZTJgwgZycHL766itsNpvmn05UVcXpduOuJ8f123GDXu+VYaiALa7V7goi3THE65Nx//a/ClcJAAoKsfoEdOgocxbjVoPnamoocpmd2I5ZCYs31vxD6Si1of7WUwuLCyc8vv6FgJorVYWCKidWh5u2sZ6ZEDanu2ZmQJhOoWW0AYtTpaDSEXRTslq0aEHnzp25+uqrmT17NnO9tFBRIAnY4vplyXRah7XjiTZvoENPuesYLxc8jEO1EaFE8kirf5Jj/oWXCx7CLhe6mrWC7w9SvPwIPf45gPBEI6pLZdNfV2A57BmD7PJEb2KDbLaAw61y3cd7ua5bPBsfPgeApfuq+FO2ZxpQ15YRLLyrE+PnHuax7w5jD7IhgZkzZxITE0P37t0DckUrbwjY4urEQamriB8qvkD57X9Xxd6CAqio/FK1gIO2ndhV2yl/lghsqkvFWe3gyOz96E2eX8kWl7VF+e3jcPnmY1gLzLS6Ks2fzfQ6q1MlJ9/My0s91wv0OoVJV7QBwO1WeWXZUTYesWBxBk9h7dy5M6NHj6Z79+6EhYXx1FNPNTgUsHjxYn788Ucft9B7Ara4gmdoYHHFlwDE6hP5a6uphCtGLGo1/yoYT7Xb+/Pg/MmtqpRWVmK1h15PXHWq5M89CICiV8h4qT+mtlEAbH1mDYpeR9KA1qgNDVA2UzuLbOws8kwHGtghmk9HdgBgS4GFoTP3Bt1wQLt27bj//vtrvr7vvvsaPLesrMyrxdVqt1NWVYXb3fDvkMPppLSyEocXZisEdHE9UaWrlJcLHgIUVFTM7ip/N8nr8oqKOO/uuzHbQrs3rrpUtk1aC7/1XF3VDgDW37cUl9nhz6ZpatWhanq+th3wXMwKtsIKsHTpUrp06dKoc7091/Wd2bP5ZMECSisrGzxn3Y4dnDt6tFdWpGs2xVVFpdrd8B9KMHCrKsc0uCulOXJW1S2izorg7tE73CrHguhW1/o4HA6Ki4v9km2x2bCcouPicLkoLi/3Sl7A3kQghBDNmRRXIYTQgBRXIYTQgBRXIYTQgBRXIYTQgBRXIYTQQJOK65w5c+jbty9du3Zl3LhxWrVJCCGavUYX13379nH//ffzzTffsGXLFjZu3Mh3332nZduEEKLZavRNBF9//TW33HILqampAHz22WcYjcG1UpEQQnhLo4vrnj17MBqNXH/99ezfv59rr72W//u//6v3XJvNhu2EOyFO3AvH5IUVvpvieJ6vcyU7tLJD8TWHaraqqo1a1FtRG7k67T333MPy5ctZtmwZMTExDB8+nNtuu40xY8bUOXfSpElMnjy5zvHs7GwiIyMbEyeEEAHJbDYzatQoysvLiY2NbfC8RvdcW7duTWZmJi1btgTghhtuYM2aNfUW1wkTJjD+hB0UKyoqSEvzLBeXlZXl0/UbTSYTM2bM8HmuZIdWdii+5lDNbuxuCY0urtdccw233347paWlxMbGsmDBAq699tp6zzUajQ2Ox1osFr8sjuuvXMkOrexQfM2hnH0yjZ4tcOGFFzJhwgQGDhxIt27daNu2LXfeeaeWbfMLPQrjo9O51ZTq76YIobnIiAheuO8+hl90kb+bEnSatORgVlYWWVlZWrUlIOiAG01t2eIo5zPLYX83RwhNRYSHc+eQIahuN7NXrPB3c4KK3KElhBAakOIqhBAaaDY7EfiTHgWTogfAjYpZtvIWzZiiKESbTChATGQkiqIQHhZG7G/TJO1OZ0ju4+ZtUlwb4fzwBKbH9wZgu7OSUSVrgnJ/IxEa2iYn8+OrrxIRHo5OpyMuKoq7hg1jxKBBAHz+4488/vbbfm5l8yfFtQFnGaLIimwPgEnRM8eaDyjYVRd3RnZgia2Ifa4z38RMCF+rtlr55uefCdPriQgP57arrmJnbi4rf/0VgPW7dvm5hcFBimsDeoTFkREbixOVZbZi7ihdC0CGIZbvky/mobIcKa6iWSqtrOSJ33qmibGx3HDJJfy4fj1Pvfeen1sWXKS4noQKPFC2kfX2Mn83RQjRzMhsgQYcdlmYbT3CVkcFBe7fF2koUx18az1CK30EVxhbyh+gEKJeUhsasN5eygNlORxwmWsdz3VZeLAsh3PDYnk2thsG+SMUQtRDKoMQQmhAiqsQopY2SUlc3qcP0X5YozWYSHEVQtRy9QUXMPell+jQurW/m9KsyWwBIUJYZXU1t0yaRP/u3fnupZcA2Lp/P9c++SQHCgr83LrmTYrrH6jADmclB/9wIeuPDjnNRCp6VLlXSzRjDpeLpTk5pLVsSeJvq+qXVVezeP16P7es+ZPi+gdOVO4pPfUv1j+rPHexSGkVweA/Cxfy3x9+8HzRyJX2xclJca1HY3615NdPBJvGbl8iGkcuaAkhhAakuAohhAakuAohhAakuAohhAakuAohhAakuAohhAYaXVynT59Or169av5LSEjgjjvu0LJtQgjRbDW6uN5///3k5OSQk5PD//73P+Lj43nxxRe1bJsQQjRbpzUs8OCDDzJ58mTatm3r7fYIIURQaPIdWkuXLuXo0aMnHRKw2WzYbLaarysqKmoem3y8jNnxPF/nSnZoZYfiaw7VbFVVsVqtpzxPUZt4z9utt97K4MGDGTNmTIPnTJo0icmTJ9c5np2dTeRve6MLIURzZDabGTVqFOXl5cT+tthNfZpUXO12O23btmXfvn3ExMQ0eF59Pde0tDSys7MZO3YsFoulsZFnzGQyMWPGDLKysnyaK9mhlR2KrzlUs4/3XE9VXJs0LLBlyxbS09NPWlgBjEYjRqOx3ucsFovP3wR/5kp2aGWH4msO5eyTaVJx3bt3L+3atdOqLUKEtHbh6dyYcC8AhY48skteQ9Zfa76aNFtgxIgRfPbZZ1q1RYiQlRrWkZSwDjhVB07VgUExkG7MIEYX7++midMk67kKEQBGJD6AxW1mWuFTgKfY/rX1v/nPsX+x3rzUz60Tp0OKqxABqNiZz3tF/0eeY6+/myJOkxRXIfykpSEVg2JAQSFMMaLqVFLCOgDgUO1ss671emZaWhpRUVHs3LmzwZ0HEhISSE1NZffu3Y2azynqJ8VVCD/QY+DuFhNpYfDc5aigAPB469cBOGzfw9Sjf/X6BpiTJ0/mkksuISMjo8Er7Ndddx3Tp0+nb9++/Prrr17NDyVSXIXwAzcu5pZ9TITOc1PN1XEjcbht/Fj5FQDVrgpNdhZWFAW9Xn/Sc3Q6HXq9HkVRvJ4fSqS4CuEHKiqbLStrvr44eigWt5k11Ys1zS0uLqagoIC0tDQKCgpq3ZquKApt27bFaDRy4MAB7Ha7pm0JdrKeqxAh5KmnnmL06NGsXLmSrKysWs9FRESwaNEievfuTUZGBrt27fJTK4OD9FyFCCEOhwObzUZERAQGQ92//hEREeh0OrmQ5QXScxUixLjdbo4dO4ZOpyMxMRFFUTCZTCQmJlJeXk5VVZW/mxgUpLgKEWLy8vLo2bMniYmJrF69mri4OO6++25Wr17NbbfdxsSJE/3dxKAgxVWIEON2uyktLUWn05GQkIBOp8NkMpGQkEBFRQXV1dX+bmJQkOIqRIiy2+1YLBYiIiIAzzqlTVzeWZyEFFchQtQrr7zCkCFDWLBgAfHx8fTu3ZsjR474u1lBQ2YLCBEAfrWswaHaTn2iF5WVleFwOPjxxx/ZsGEDhw8f9ml+sJPiKkQAWFjxuV9yq6urGTdunF+yg50MCwghhAakuAohhAakuAohhAakuAohhAakuAohhAakuAohhAakuAohhAaaVFw//fRTunfvTvfu3Xnssce0apMQQjR7jS6uFouFsWPH8tNPP7Fp0yaWL1/OokWLtGybEEI0W42+Q8vpdOJ0OrFYLDWPTSZTvefabDZstt9v5TtxK4mGvkcrx/N8nSvZoZUdiq85VLNVVW3UYuKK2oRlcN544w2eeOIJIiMjufTSS5k1a1a9m5hNmjSJyZMn1zmenZ1NZGRkY+OEECLgmM1mRo0aRXl5ObGxsQ2e1+jiumXLFkaPHs38+fOJi4tj1KhR9OvXj8cff7zOufX1XNPS0sjOzmbs2LENbumrBZPJxIwZM8jKyvJprmSHVnYovuZQzT7ecz1VcW30sMD8+fMZNGgQLVu2BODOO+/k7bffrre4Go1GjEZjvT/HYrH4/E3wZ65kh1Z2KL7m5pQdbjAw7k9/YuehQ8xesULTdjX6glbPnj1ZsGABFRUVqKrKnDlzOO+887Rsm/AhvQ6ijDp0obZVfbgJjFH+boXwgYjwcFrEx3PHVVdxRd++xEdHo9NpNxu10T/5qquu4o477qBv37706NEDu93Ok08+qVnDhG91TYnktT+fTec2vr8w4VfDHofb/wWK3t8tERq7d/hwlrz+OrdOnsy2AwfYNHMmHVNSNMtr0nquf/vb3/jb3/6mVVuEHxn0CjERegyh1nWNiAJTLCiA7HAS1H7dt4+vli1j8AUXEBEezqeLFlGu4X5hsli2ECIk/LhhA6u3bWP9++8zf/VqHnnjDU3zpLgKIUKG2WbjyvHjMdu031JHimsAiYpUuO5KIznbnGzb7az3HEWBYZcbqTar/LTSrml7uqaYaBEbBsDuAiv5ZdrmBYSwCDjnEtDpweWAHcvAqeHrjm8D7XvVPW4ph12/aBJpDFM4/6wYGnMt51iVk62HzZq0wx/0Oh19zzmHvKIijpWXa5olxTWAJCfqeO+leJ6ZWtlgcdXpYMrjMRw47NKkuCqK5z+Aq3sk0K9TDAAzlh6loMwevMOSig4UN0TGwfC/QZgJrJWwfwM4S9FsQDa1G9zwdN3j+Tthz2pwu7weGRuh597M1oTrGxhfV34fgl6/ryqoimtEeDhTH3yQeatWsWb7dk2zpLiKGoqicPeg1ljtbgAWbinlm/XHABjYJY6nrk/jlbmHsTmDrMQmtIV7PwBV9RTUjx729FrDIuCWKZ7e6y+fapO9Zw28M6bu8bjWnjYtfgd2r/RqZGm1k6e/OEg9N1cCcP7ZMdx0fhKvzT/C3sJT3+Yp6ifFNYBYrCoLl9kID1fIvCicZavtOE7owKa21tGjaxibtjvYc8D7PRqANvHhVNtc7Mq3kFdq50CRZ2wqs7tCuyQjOiUIL6uHGaFNZzi6FyqKIH83uOwQEQ0tOsCRHdplWyshv7L2sZSuENfK0yZTjNcjnW44WFx3zFFRPFPyLHY3Gw9Ws+eolaJKh9fzQ4UU1wBSWOzmhntLefmpGD5/M4HOlxZSUv57IbvqEiPvvBBHn2HFbNlR/7DBmVJVlSOldl6YHUJ72B+/A3zV/2D9t/5tC0DmvdCpHw12LTUSpld48Mo2bMmt5qU5IfT+a0SKq6ihqiqf/FzEtry6Y2zzckrZdLCaR4aksGJXBct2VNTzE5qpsnyY/SIU7qt93G6BT5+E9j3hjn/D189B1THvZp/VBy7Nqn1sy0LYvgyurXtruVYGpMdwWbc4Plx2lCOlIXDh0gdkJ4IAdCjPRc42Bz27hZGW4rkltVc3A9FRCqtzHJgt2n0sP1BkZV8942z5ZXb2HLXQ5YQZBEHDYYX966GyuPZxtwsObfLMFujQxzN84DUKtE6H5A6esd0T/zu6F/K2eTGrYToFzm4ZQau4cML1OnYXeIaDxJmTnmsAmvaRmU9nW9jxU0s++MzM5Fcr+frdBBb/Ymfgzcdo/CKRImDpDTDiOcjfBe/dXff5Nl180oxIo46J16Xy47ZyJn11yCeZoUKKa4BS1dpDbscfS2HVQGxL+NP/ef5wLRUwb+rvswWGjvcMBXz5DFSVeDnYv7caD+wSS6/2UcxcVsihei5wiTMjxTVAud2wZ78TlxvSOxg4dMRNQZHb380KToZwaNXRU1zN5dCiPTgdnhWzWnWEY7mwfYl3M1UVSo+A3QzJ7es+H9/Gu3kn0OugZWwY3VMj6XNWNN9vKsXpVklJCK9zrtXupqRam4unwU6Ka4Aqq1AZePMxHr07imVfJHHesGIOHNZm+lXIKzkM0+/0jLHGtoC/fAzhEWCtgrfu0KDHCrid8N+/QvfL4cH/1HOCglY924QoAy/c0oGIMB2KAs/eXE9x/836A1X867s8TdoR7KS4BrDjc1zDwhQcLnBp2HE9XGLjgyUnv1Jstrv5eHlhzdzXoLD2a898VqcdUKG6DBZO+/32V0sFqBr9wbtdkLcd5v274XPyvH8XUZXVzSc/F6JvxApoRRUyz/V0SXENUIoCrZI9MwXyC124XNoOthZXOlm4peyk59idKj9u1fZ+bJ/bs6r21w6Lb+e6lhz2/OdDVoebxcH2PjYgNioKU3g4hWVlNGG7QK+QqVgBKj5WYdW3ycTF6ug1uJgjR2W8VYimevK221j6xhvE+GFjVOm5BpD4WIWxo6MIM3huMJ3xuZkV6+xUmWWKgBCnY8nGjVRbrTzypz/VHHv/u+/YsGuX5tlSXANIbLTC2NGRREQolJS5OW9YMaXlUliFOF0L165lw65drH7nHWKjoqi2WOh3//0UlGhwkfIPpLgGkLwCNz0HF6MonqlYZRVSWIU4UyUVFfS//34UnQ5VVSkuK/NJrhTXAOJyw9FiGVsVwpvcqkqhjwrqieSClhBCaKBJxfXFF1+kS5cu9OjRgylTpmjVJiGEaPYaXVwXL17Mf/7zH9asWcPGjRtZtWoVX331lZZtE0KIZqvRxXXDhg0MGTKEuLg49Ho9Q4YM4dtvA2BhYSGECECNvqDVp08fHn30USZMmEBkZCSzZ8/G7a7/4ovNZsN2wta1FRW/L6xsMpnOoLlNdzzP17mSHVrZofiaQzVbVVWs1lPvLaaoTbgnbOrUqXz44YckJiZyxRVXsGrVKubOnVvnvEmTJjF58uQ6x7Ozs4n0w50SQgjhLWazmVGjRlFeXk5sbGyD5zW6uFZWVnLs2DE6dOgAwEsvvUReXh6vv/56nXPr67mmpaWRnZ3N2LFjsVgsTXw5p89kMjFjxgyysrJ8mivZoZUdiq85VLOP91xPVVwbPSxw4MABbrvtNtavX09VVRUffPABM2bMqPdco9GI0Vj/lhgWi8Xnb4I/cyU7tLJD8TWHcvbJNLq4ZmRkMHLkSHr27InT6WT8+PFcfPHFWrZNCCE0FdkuGl24HgDz4SrcVu+tmdykO7QmTJjAhAkTvBYuhBD+ougVuvytD5Fp0QBsfuIXKneUee3ny+2vQoiQE9cjiVZXppI/5wAuixMUaHFZW+J7JpP7+R6vZEhxFUKEHFNKFMkDU8j9314suVUAJF7YCkO097aNl+IqhBDArldyvPrzpLgKEWIiddFcGTuCbZZ17LZtrvccBYXLY27E7K5iZfUCr2Wb0qJpM6QdR+YexHqkGoCWmalEd/RMaSr+OZ+KbaVeyztRfO9kEs9vCUBk+xgUnULanzrirHKgqnBk9n5sR70360CKqxAhJkKJ5OLoYVS6yhosrqDQN+oySpyFXi2uES1NtLm2A+W/luCq9mx+GN8zifg+LQCo2lehWXGNbBdN8iUpAJ4ZAgok9G2J6lZBhaIleVJchRDNl6IodH60J+pvm27unf4re9/ZCoDbpt328fnzDnF0kWczyFZXpNLhzq5snbQWS55nzNVl8W62FFchQozFXc2iii8IV4wMirmBn6u+w6H+vqV627Cz6G66gM2WVRQ68jRpg95kwFZs5eiiXKr3V+CqdmqScyLV4cbl8KyH4rZ5/t9lcWqWLYtlCxFiLGo1Cyo+I1wXwZWxfyJMCa/1fGp4J4bEjSLHvIL15iWatMFlc2E5UsWh/+zCfLBKkwx/k56rEMKnVFVl9783Ubb5mL+boikprkKEqIO2nYQrRvpEXkKufQ+59j30jhxIrD6eX6oWYHZXapbtqLDjrLCf+sRmTIYFhAhRmyy/MK/8vwyNu4MekQPQKwauiR9NsqENX5S+RbkruHuWWpPiKoQQGpDiKkQIc6lOfrWsxqU6Odd0IXusW8i1e+fe+lAnxVWIEGZTLWSXvIrNbWFU4iPMK/8PP1fN83ezgoJc0BJC+EzFjlI2P/4L5kP+nX51bFUB1fsrsB01a5YhxVWIEKZDTwdjF3SKnr22X3GqDk3zXNVOr66ZerocZXYcZdrOVpBhASFCWIQukruTnyZCF8n0omeodJf5u0lBQ3quQoSYaF0cIxIfQK+E4VQdfF7yBgWOQ/5uVtCR4ipEiNEpeuL1yRiUcCzuanZac7Cq2o09hioprkKEmApXCf8++ljN1yqqH1sTvKS4ChGCpKBqTy5oCSGEBqS4CiGEBqS4CiGEBnxSXFXVM75jNptrHvuKqqp+yZXs0MoOxdccytnH809GUX3QssOHD5OWlqZ1jBBC+Exubi6pqakNPu+T4up2u9m5cyfdunUjNzeX2NhYrSNrVFRUkJaW5vNcyQ6t7FB8zaGaraoqlZWVpKSkoNM1/OHfJ1OxdDodbdu2BSA2Ntbnb4I/cyU7tLJD8TWHYnZcXNwpz5ELWkIIoQEprkIIoQGfFVej0cgzzzyD0Wj0VaRfcyU7tLJD8TWHcnZj+OSClhBChBoZFhBCCA1IcRVCCA1IcRVCCA34pLhmZ2fTrVs30tPTmTZtmi8ia6msrCQjI4MDBw74NHfq1Kl0796djIwMsrKysNu13bPnuAkTJtC1a1e6devG1KlTfZL5R4899hhjxozxaebIkSPp3LkzvXr1olevXnz99dc+y54zZw59+/ala9eujBs3zme506dPr3m9vXr1IiEhgTvuuMMn2Z9++indu3ene/fuPPbYY6f+Bi968cUX6dKlCz169GDKlCk+zW40VWOHDx9W27VrpxYXF6tVVVVqjx491M2bN2sdW2PVqlVqz5491bCwMHX//v0+y129erV67rnnqlVVVarb7VZvv/12derUqZrnfvfdd+rAgQNVh8OhVldXqx06dFB37Nihee6JFi1apCYnJ6ujR4/2aW6nTp3UY8eO+TRTVVV17969akpKipqbm6s6HA514MCB6ty5c33ejp07d6odOnRQDx8+rHmW2WxWExMT1aNHj6oOh0O94IIL1B9++EHzXFX1/H51795dLSsrU51Op3rNNdeos2bN8kl2U2jec120aBGZmZkkJSURFRXFzTffzJdffql1bI3p06fzxhtvkJKS4rNMgISEBKZNm0ZUVBSKotCzZ08OHdJ+n6KhQ4eyePFiDAYDRUVFuFwuoqKiNM89rqSkhIkTJ/LUU0/5LPN4blFRESNHjqRHjx5MnjzZZwt6fP3119xyyy2kpqZiMBj47LPP6Nevn0+yT/Tggw8yefLkmrshteR0OnE6nVgslprHJpNJ81yADRs2MGTIEOLi4tDr9QwZMoRvv/3WJ9lNoXlxPXLkSK3C1qZNG/Lz87WOrTFz5kwGDhzos7zj0tPTufTSSwEoLCxk2rRpDB8+3CfZYWFh/P3vf6dr165cfvnlPvnLdtx9993HlClTSEhI8FkmQEFBAZmZmXz00UesWrWK5cuXM3PmTJ9k79mzB7fbzfXXX0/Pnj156623SExM9En2cUuXLuXo0aM+GxKIiYnhueee45xzzqFt27a0b9+eAQMG+CS7T58+LFiwgJKSEqxWK7Nnz/ZpTWkszYur2+1GUZSar1VVPeliB8HmwIEDDBo0iHvuuYdBgwb5LPe5556juLiYw4cP89577/kk8/333yctLY3MzEyf5J2oW7duzJo1i9atWxMZGcnYsWOZO3euT7KdTifz58/n3XffZdWqVaxevZqPPvrIJ9nHvf3224wfP77W3zUtbdmyhZkzZ3Lw4EGOHDmCoii88sorPsnOzMxkzJgxXHbZZQwePJiLL76Y8PBwn2Q3heZVLjU1tda/KgUFBT7/iO4vOTk5XHTRRdx///1MnDjRJ5lbt25ly5YtAERGRnLDDTewefNmn2R//vnnLFy4kF69evGPf/yD2bNn8/DDD/ske926dcyePbvma5fLhcHgmy3iWrduTWZmJi1btsRkMnHDDTewZs0an2QD2O12Fi9ezE033eSzzPnz5zNo0CBatmyJ0WjkzjvvZMmSJT7Jrqys5MYbb2Tz5s0sWbKEsLAwzj77bJ9kN4nWg7qHDx9W27dvrx49elStqqpSMzIy1NWrV2sdW0f79u19ekGrsLBQbdWqlc8H2r/44gt1wIABqs1mU61Wq3r55Zern3/+uU/boKqqOnPmTJ9e0Fq1apXaoUMHtaysTLXb7eoVV1yhZmdn+yy7U6dOaklJiep0OtXhw4er7733nk+yVVVV161bp/bv399neaqqqgsWLFC7d++ulpeXq263W7333nvVp59+2ifZmzdvVjMyMlS73a6WlJSo6enp6vLly32S3RSa/9Petm1bnn/+eQYNGoTD4eDuu+/mggsu0DrW71599VUqKip49tlnefbZZwEYNmyY5tNGbr75ZjZs2ECvXr3Q6/WMGDGCESNGaJoZCC688ELGjRtHv379cDqd3HTTTYwcOdJn2RMmTGDgwIE4HA4yMzO58847fZINsHfvXtq1a+ezPICrrrqKO+64g759+2I0Gunbty9PPvmkT7IzMjIYOXIkPXv2xOl0Mn78eC6++GKfZDeFrC0ghBAaCJ0rS0II4UNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgNSXIUQQgP/D/vuH7VqnwOfAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "max_distractors = 30\n",
    "task_ex = taskgen.MetaTask(task_graph)\n",
    "objset = task_ex.generate_objset(n_distractor=max_distractors)\n",
    "targets = task_ex.get_target(objset)\n",
    "\n",
    "print('Instruction:', task_ex)\n",
    "print('Target output:', targets[0])\n",
    "img_array = objset.create_img()\n",
    "\n",
    "plt.figure(figsize=(4,4))\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",
    "# plt.savefig(figurename + '_stimuli.png',transparent=True,dpi=300)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
