{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_json(path_to_file):\n",
    "    with open(path_to_file) as f:\n",
    "        data = json.load(f)\n",
    "    return data\n",
    "\n",
    "\n",
    "f_train = load_json(\"arc-agi_training_challenges.json\")\n",
    "f_train_solution = load_json(\"arc-agi_training_solutions.json\")\n",
    "\n",
    "f_eval = load_json(\"arc-agi_evaluation_challenges.json\")\n",
    "f_eval_solution = load_json(\"arc-agi_evaluation_solutions.json\")\n",
    "\n",
    "f_submission = load_json(\"arc-agi_test_challenges.json\")\n",
    "f_sample_submission = load_json(\"sample_submission.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train 400, eval 400, submission 100 \n"
     ]
    }
   ],
   "source": [
    "# check files okay, get number of examples in each\n",
    "n_train = len(f_train)\n",
    "n_submission = len(f_submission)\n",
    "n_eval = len(f_eval)\n",
    "print(\"train %d, eval %d, submission %d \" % (n_train, n_eval, n_submission))\n",
    "train_ids = list(f_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# notebook source: https://www.kaggle.com/code/allegich/arc-2024-starter-notebook-eda\n",
    "\n",
    "from matplotlib import colors\n",
    "\n",
    "# 0:black, 1:blue, 2:red, 3:green, 4:yellow, # 5:gray, 6:magenta, 7:orange, 8:sky, 9:brown\n",
    "CMAP = colors.ListedColormap(\n",
    "    [\n",
    "        \"#000000\",\n",
    "        \"#0074D9\",\n",
    "        \"#FF4136\",\n",
    "        \"#2ECC40\",\n",
    "        \"#FFDC00\",\n",
    "        \"#AAAAAA\",\n",
    "        \"#F012BE\",\n",
    "        \"#FF851B\",\n",
    "        \"#7FDBFF\",\n",
    "        \"#870C25\",\n",
    "    ]\n",
    ")\n",
    "NORM = colors.Normalize(vmin=0, vmax=9)\n",
    "\n",
    "plt.figure(figsize=(4, 1), dpi=200)\n",
    "plt.imshow([list(range(10))], cmap=CMAP, norm=NORM)\n",
    "plt.xticks(list(range(10)))\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n samples 5\n",
      "train id 007bbfb7, n_colors 1, shape in (3, 3) shape out (9, 9)\n"
     ]
    },
    {
     "data": {
      "image/png": "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r68vW7t2bfbII48cdJsrrrgiGxgYOOI5H3C48z+w3gO3ffTRR7N3v/vdWW9vb3biiSdmg4ODWb1en7mP0dHRLCKyLVu2HDIvIrLh4eGD7u9I+w0cTEbJKCgyGSWjoMhklIyCIpNRMqqTdB+xGScX73rXu2L79u1x2223xWc+85lYvnx5REScfPLJM7f5/ve/H1/72tdiw4YNsXz58li5cmVERHzuc5+LtWvXxnvf+97Yu3dvfPWrX413v/vdceedd8bFF1886+yNGzfGsmXLYnh4OHbs2BGf/exnY8OGDXH77be/7J+755574qKLLorf/u3fjmq1GvV6PTZv3hxvfvOb46GHHppZX7NuueWWWL9+fZx33nlx1VVXRUTEKaecctBtLr/88li5cmVcf/318eMf/zhqtVrs2bMnbr755lc0q5n9Bl4go2QUFJmMklFQZDJKRkGRySgZ1VHa3cDz/CdncYRPfSIiW7BgQfbzn//8kH83NTV10OW9e/dmZ511Vva2t73toOuP9InbmjVrsunp6Znrr7nmmmzhwoXZ2NjYy673jW98Y/aqV70q+/d///eZ67Zu3ZotWLAge//73z9zXbOfuGVZli1ZsuSgNb70tmvXrj3o+g9/+MNZRGRbt27Nsqz5T9yy7OX3GziUjJJRUGQySkZBkckoGQVFJqNkVKfwHeDHgLe+9a3xute97pDre3p6Zv55z549MT4+HhdccEE89NBDTd3vVVddFV1dXTOXL7jggti/f3/s3LnziH9m165d8dOf/jSuvPLKOPHEE2euf8Mb3hDveMc74q677mpq9it19dVXH3R548aNEREtmwc0T0bJKCgyGSWjoMhklIyCIpNRMioVCvBjwKpVqw57/Z133hm/93u/F4sWLYoTTzwxTj755Pj85z8f4+PjTd3vihUrDrq8bNmyiHg+vI7kQBidccYZh/y7M888M371q1/Fs88+29T8V+K000476PIpp5wSCxYsiB07dsz7LOCVkVEyCopMRskoKDIZJaOgyGSUjEqFAvwY8OJP1g647777Yu3atbFo0aK48cYb46677oq777471q1bF1mWNXW/CxcuPOz1zf752bz407wX279//7zfdytnAS9PRs1+3zIK2kdGzX7fMgraR0bNft8yCtpHRs1+3zLq2OCXYBbAkV4sL+cb3/hGLFq0KL7zne9E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",
      "text/plain": [
       "<Figure size 1500x600 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test img colors [0 7], shape (3, 3)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# adapted from: https://www.kaggle.com/code/allegich/arc-2024-starter-notebook-eda\n",
    "\n",
    "\n",
    "def plot_one(task, ax, i, train_or_test, input_or_output):\n",
    "    input_matrix = task[train_or_test][i][input_or_output]\n",
    "    ax.imshow(input_matrix, cmap=CMAP, norm=NORM)\n",
    "    ax.grid(True, which=\"both\", color=\"lightgrey\", linewidth=0.5)\n",
    "    ax.set_yticks([x - 0.5 for x in range(1 + len(input_matrix))])\n",
    "    ax.set_xticks([x - 0.5 for x in range(1 + len(input_matrix[0]))])\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    ax.set_title(train_or_test + \" \" + input_or_output)\n",
    "\n",
    "\n",
    "def plot_sample(sample):\n",
    "    \"\"\"\n",
    "    Plots the first train and test pairs of a specified task,\n",
    "    using same color scheme as the ARC app\n",
    "    \"\"\"\n",
    "    n_samples = len(sample[\"train\"])\n",
    "    print(\"n samples\", n_samples)\n",
    "    print(\n",
    "        \"train id %s, n_colors %s, shape in %s shape out %s\"\n",
    "        % (\n",
    "            train_ids[0],\n",
    "            len(np.unique(sample[\"train\"][0][\"input\"])) - 1,\n",
    "            np.array(sample[\"train\"][0][\"input\"]).shape,\n",
    "            np.array(sample[\"train\"][0][\"output\"]).shape,\n",
    "        )\n",
    "    )\n",
    "\n",
    "    fig, axs = plt.subplots(2, n_samples, figsize=(3 * n_samples, 3 * 2))\n",
    "    for i in range(n_samples):\n",
    "        plot_one(sample, axs[0, i], i, \"train\", \"input\")\n",
    "        plot_one(sample, axs[1, i], i, \"train\", \"output\")\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "    print(\n",
    "        \"test img colors %s, shape %s\"\n",
    "        % (np.unique(sample[\"test\"][0][\"input\"]), np.array(sample[\"test\"][0][\"input\"]).shape)\n",
    "    )\n",
    "    fig, axs = plt.subplots(1, 1, figsize=(2, 2))\n",
    "    plot_one(sample, axs, 0, \"test\", \"input\")\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "plot_sample(f_train[train_ids[0]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Z8+KfFKWl3aKCJKSknDnzh0UK1YsS0JWVCk6KdNoNKhTpw527Nihf6ZMp9Nhx44dGDRokHmDIyKiQlG6dGlcuHABWq0W9+7dM3c4BUJE9LfqimLSmcHYdhYrVsyiOmHMnpQlJCTg0qVL+um4uDjExsaiRIkSKF++PCIiIhASEoK6deuifv36mDVrFhITE/W/xiQioqJNpVLhyZMnL/11/essNTUVe/fuRdOmTYvkbbkMxrTTxsbGYnrIMpg9KTt8+DBatGihn854CD8kJATLli1Dz549cffuXYwdOxa3bt1CzZo1sXnz5iwP/xsrOjoa0dHRSE9Pf6V6iIiocKjV6iKbsKjVaqSlpcHW1rbIthGwnHbml9mTssyvgMjOoEGDTH67MiwsDGFhYYiPj4eLi4tJ6yYiIiIyltmTMqLXXmQuSX3k48KLg4iIXmtF9yceRERERK8RJmVERERECsCkjIiIiEgBmJQRERERKQCTMiIiIiIFsNikLDo6Gv7+/qhXr565QyEiIiKy3CExOE4ZGcN71MYc512xLcRAiIioyLLYnjIiIiIiJWFSRkRERKQATMqIiIiIFIBJGREREZECMCkjIiIiUgAmZUREREQKYLFJGccpIyIiIiWx2KQsLCwMZ86cQUxMjLlDISIiIrLcpIyIiIhISZiUERERESkAkzIiIiIiBWBSRkRERKQATMqIiIiIFIBJGREREZECMCkjIiIiUgCLTco4eCwREREpicUmZRw8loiIiJTEYpMyIiIiIiWxNncAZLkCvgvIcd7JkJOFGAkREZH5saeMiIiISAHYU1aAvEdtzHHelckdCzESIiIiUjr2lBEREREpAJMyIiIiIgVgUkZERESkAEzKiIiIiBSASRkRERGRAjApIyIiIlIAi03K+O5LIiIiUhKLTcr47ksiIiJSEotNyoiIiIiUhEkZERERkQIwKSMiIiJSACZlRERERArAF5KbS6RLLvMeF14cREREpAjsKSMiIiJSACZlRERERArApIyIiIhIAZiUERERESkAkzIiIiIiBWBSRkRERKQAFpuU8YXkREREpCQWm5TxheRERESkJBablBEREREpidFJ2ebNm/HHH3/op6Ojo1GzZk307t0bDx8+NGlwRERERJbC6KRsxIgRiI+PBwCcPHkSw4YNQ4cOHRAXF4eIiAiTB0hERERkCYx+92VcXBz8/f0BAL/88gs6deqEiRMn4ujRo+jQoYPJAyQiIiKyBEb3lGk0GiQlJQEAtm/fjrZt2wIASpQooe9BIyIiIiLjGN1T1rhxY0RERCAoKAiHDh3CqlWrAAAXLlyAp6enyQMkIiIisgRG95TNmzcP1tbWWLNmDRYsWICyZcsCADZt2oT27dubPEAiIiIiS2B0T1n58uWxYcOGLOUzZ87E06dPTRIUERERkaUxuqds8ODB2ZYnJibyQX8iIiKifDI6Kdu4cSPGjRtnUJaYmIj27dsjLS3NZIERERERWRKjb19u3boVTZo0QfHixREeHo4nT56gXbt2sLa2xqZNmwoiRiIiIqIiz+ikzNfXF5s3b0aLFi1gZWWFlStXQqvVYuPGjXBwcCiIGImIiIiKPKOTMgCoUaMGNmzYgDZt2qBBgwbYsGED7OzsTB0bERERkcXIU1JWq1YtqFSqLOVarRY3btxAUFCQvuzo0aOmi46IiIjIQuQpKevSpUsBh0FEihbpksu8x4UXBxFREZanpCzzry2JiIiIyLSMHhLj+vXr+Pvvv/XThw4dQnh4OBYvXmzSwApadHQ0/P39Ua9ePXOHQkRERGR8Uta7d2/s2rULAHDr1i20bt0ahw4dwueff47x48ebPMCCEhYWhjNnziAmJsbcoRAREREZn5SdOnUK9evXBwCsXr0aAQEB2L9/P3788UcsW7bM1PERERERWQSjk7LU1FRotVoAwPbt2/Hmm28CAKpUqYKbN2+aNjoiIiIiC2F0UlatWjUsXLgQ//vf/7Bt2za0b98eAHDjxg2ULFnS5AESERERWQKjk7IpU6Zg0aJFaN68OXr16oXAwEAAwG+//aa/rUlERERExjF6RP/mzZvj3r17iI+PR/HixfXlH374Iezt7U0aHBEREZGlyNdrltRqtUFCBgDe3t6miIeIiIjIIuUrKVuzZg1Wr16Na9euISUlxWAeX7NEREREZDyjnymbM2cO+vbtCzc3Nxw7dgz169dHyZIl8ddffyE4OLggYiQiIiIq8oxOyubPn4/Fixdj7ty50Gg0GDlyJLZt24bBgwfj8WO+A4+IiIgoP4xOyq5du4ZGjRoBAOzs7PDkyRMAwHvvvYeVK1eaNjoiIiIiC2F0Uubu7o4HDx4AAMqXL48///wTABAXFwcRMW10RERERBbC6KSsZcuW+O233wAAffv2xdChQ9GmTRv07NkTXbt2NXmARERERJbA6F9fLl68GDqdDsDzl3qXLFkS+/fvx5tvvomBAweaPEAiIiIiS2B0Uvb333+jXLly+ul3330X7777LkQE169fR/ny5U0aIBEREZElMPr2pY+PD+7evZul/MGDB/Dx8TFJUERERESWxuikTESgUqmylCckJMDW1tYkQRERERFZmjzfvoyIiAAAqFQqjBkzxuA9l+np6Th48CBq1qxp8gCJiIiILEGek7Jjx44BeN5TdvLkSWg0Gv08jUaDwMBADB8+3PQREhEREVmAPCdlu3btAvB8GIzZs2fD2dm5wIIiIiIisjRG//py6dKlBREHERERkUUz+kF/IiIiIjI9JmVERERECsCkjIiIiEgB8pSU1a5dGw8fPgQAjB8/HklJSQUaVGGIjo6Gv78/6tWrZ+5QiIiIiPKWlJ09exaJiYkAgKioKCQkJBRoUIUhLCwMZ86cQUxMjLlDISIiIsrbry9r1qyJvn37onHjxhARfPXVV3B0dMx22bFjx5o0QCIiIiJLkKekbNmyZRg3bhw2bNgAlUqFTZs2wdo660dVKhWTMiIiIqJ8yFNSVrlyZfz0008AACsrK+zYsQOlS5cu0MCIiIiILInRg8fqdLqCiIOIiIjIohmdlAHA5cuXMWvWLJw9exYA4O/vjyFDhsDX19ekwRG97gK+C8hx3smQk4UYyct5j9qY47wrtoUYCBGRhTJ6nLItW7bA398fhw4dQo0aNVCjRg0cPHgQ1apVw7Zt2woiRiIiIqIiz+ieslGjRmHo0KGYPHlylvLPPvsMbdq0MVlwRERERJbC6J6ys2fPon///lnK+/XrhzNnzpgkKCIiIiJLY3RPmaurK2JjY+Hn52dQHhsby19kmkhuzyEBynsWiYiIiF6d0UnZBx98gA8//BB//fUXGjVqBADYt28fpkyZgoiICJMHSERERGQJjE7KxowZAycnJ0yfPh2jR48GAHh4eCAyMhKDBw82eYBERERElsDopEylUmHo0KEYOnQonjx5AgBwcnIyeWBEREREliRf45RlYDJGREREZBpG//qSiIiIiEyPSRkRERGRAjApIyIiIlIAo5Ky1NRUtGrVChcvXiyoeIiIiIgsklFJmY2NDU6cOFFQsRARERFZLKNvX/7rX//CN998UxCxEBEREVkso4fESEtL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RJbIZM+UBQcH45dffjFVdUREREQWxWRJ2Zo1a1CiRAlTVUdERERkUYy+fVmrVi2DB/1FBLdu3cLdu3cxf/58kwZHREREZCmMTsq6dOliMG1lZQVXV1c0b94cVapUMVVcRERERBbF6KRs3LhxBREHERERkUWz2MFjo6Oj4e/vj3r16pk7FCIiIqK8J2VWVlZQq9W5/rO2NrrjzWzCwsJw5swZxMTEmDsUIiIiorzfvly3bl2O8w4cOIA5c+ZAp9OZJCgiIiIiS5PnpOytt97KUnb+/HmMGjUKv//+O/r06YPx48ebNDgiIiIiS5GvZ8pu3LiBDz74AAEBAUhLS0NsbCy+++47eHl5mTo+IiIiIotgVFL2+PFjfPbZZ6hYsSJOnz6NHTt24Pfff0f16tULKj4iIiIii5Dn25dTp07FlClT4O7ujpUrV2Z7O5OIiIiI8ifPSdmoUaNgZ2eHihUr4rvvvsN3332X7XJr1641WXBEREREliLPSdn7779v8HolIiIiIjKdPCdly5YtK8AwiIiIiCwbR/TniP5ERESkABablHFEfyIiIlISi03KiIiIiJSESRkRERGRAjApIyIiIlIAJmVERERECsCkjIiIiEgBmJQRERERKQCTMiIiIiIFYFJGREREpABMyoiIiIgUIM/vvixqoqOjER0djfT0dHOHQvRaC/guIMd5J0NOFmIkL+c9amOO867YFmIgRETZsNieMr5miYiIiJTEYpMyIiIiIiVhUkZERESkAEzKiIiIiBSASRkRERGRAjApIyIiIlIAJmVERERECsCkjIiIiEgBmJQRERERKQCTMiIiIiIFYFJGREREpABMyoiIiIgUgEkZERERkQJYmzsAc4mOjkZ0dDTS09PNHQoRUeGJdMll3uPCi4OIsrDYnrKwsDCcOXMGMTEx5g6FiIiIyHKTMiIiIiIlYVJGREREpABMyoiIiIgUgEkZERERkQIwKSMiIiJSACZlRERERArApIyIiIhIAZiUERERESkAkzIiIiIiBWBSRkRERKQATMqIiIiIFIBJGREREZECMCkjIiIiUgAmZUREREQKwKSMiIiISAGszR2AuURHRyM6Ohrp6enmDoWIyGS8R23Mdf4V20IKhIiMZrE9ZWFhYThz5gxiYmLMHQoRERGR5SZlRERERErCpIyIiIhIAZiUERERESkAkzIiIiIiBWBSRkRERKQATMqIiIiIFIBJGREREZECMCkjIiIiUgAmZUREREQKwKSMiIiISAGYlBEREREpAJMyIiIiIgVgUkZERESkAEzKiIiIiBSASRkRERGRAjApIyIiIlIAJmVERERECsCkjIiIiEgBmJQRERERKQCTMiIiIiIFYFJGREREpABMyoiIiIgUgEkZERERkQJYmzsAc4mOjkZ0dDTS09PNHQoRERnJe9TGHOddmdyxECMhMh2L7SkLCwvDmTNnEBMTY+5QiIiIiCw3KSMiIiJSEiZlRERERArApIyIiIhIAZiUERERESkAkzIiIiIiBWBSRkRERKQATMqIiIiIFIBJGREREZECMCkjIiIiUgAmZUREREQKwKSMiIiISAGYlBEREREpAJMyIiIiIgVgUkZERESkAEzKiIiIiBSASRkRERGRAjApIyIiIlIAJmVERERECsCkjIiIiEgBmJQRERERKQCTMiIiIiIFYFJGREREpABMyoiIiIgUgEkZERERkQIwKSMiIiJSACZlRERERArApIyIiIhIAZiUERERESkAkzIiIiIiBWBSRkRERKQATMqIiIiIFIBJGREREZECMCkjIiIiUgAmZUREREQKwKSMiIiISAGKRFK2YcMGVK5cGX5+fliyZIm5wyEiIiIymrW5A3hVaWlpiIiIwK5du+Di4oI6deqga9euKFmypLlDIyIiIsqz176n7NChQ6hWrRrKli0LR0dHBAcHY+vWreYOi4iIiMgoZk/K9u7di86dO8PDwwMqlQq//vprlmWio6Ph7e0NW1tbNGjQAIcOHdLPu3HjBsqWLaufLlu2LP7555/CCJ2IiIjIZMyelCUmJiIwMBDR0dHZzl+1ahUiIiIwbtw4HD16FIGBgWjXrh3u3LlTyJESERERFRyzP1MWHByM4ODgHOfPmDEDH3zwAfr27QsAWLhwITZu3Ihvv/0Wo0aNgoeHh0HP2D///IP69evnWF9ycjKSk5P10/Hx8QCA1NRUpKamvlJbMj6f8V+tWnJe1so2x3laaPO0HnMwpo1A/tuppDYCBbMv2caCZ6pzEmZuR25MeU4qtZ1GH68KbUdusmtjUWTKdhbFbaUSkdzP4EKkUqmwbt06dOnSBQCQkpICe3t7rFmzRl8GACEhIXj06BHWr1+PtLQ0VK1aFbt379Y/6L9///4cH/SPjIxEVFRU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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Data\n",
    "data1 = np.array([len(f_train[id_][\"train\"]) for id_ in train_ids])\n",
    "data2 = np.array([len(f_eval[id_][\"train\"]) for id_ in list(f_eval)])\n",
    "data3 = np.array([len(f_submission[id_][\"train\"]) for id_ in list(f_submission)])\n",
    "\n",
    "# Define common bin edges\n",
    "bin_width = 0.5\n",
    "min_bin = min(data1.min(), data2.min(), data3.min())\n",
    "max_bin = max(data1.max(), data2.max(), data3.max())\n",
    "bin_edges = np.arange(start=np.floor(min_bin), stop=np.ceil(max_bin) + bin_width, step=bin_width)\n",
    "\n",
    "# Calculate positions for each series\n",
    "bin_centers = (bin_edges[:-1] + bin_edges[1:]) / 2\n",
    "width = bin_width / 4  # Width of each bar\n",
    "\n",
    "# Plotting each histogram\n",
    "plt.bar(bin_centers - width, np.histogram(data1, bins=bin_edges)[0], width=width, label=\"train\")\n",
    "plt.bar(bin_centers, np.histogram(data2, bins=bin_edges)[0], width=width, label=\"eval\")\n",
    "plt.bar(bin_centers + width, np.histogram(data3, bins=bin_edges)[0], width=width, label=\"submission\")\n",
    "\n",
    "# Adding labels and titles\n",
    "plt.xlabel(\"Number of examples in task\")\n",
    "plt.ylabel(\"Number of tasks\")\n",
    "plt.title(\"Distribution of number of examples in each task for different datasets\")\n",
    "plt.yscale(\"log\")\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
