{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "6831e2fd",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "960it [00:00, 379754.02it/s]\n",
      "400it [00:00, 557753.19it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<ds.ARCDataset at 0x13b6614f0>"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from ds import ARCDataset, ARC2Dataset\n",
    "\n",
    "train_dataset = ARCDataset(\"../data\", \"train\")\n",
    "test_dataset = ARCDataset(\"../data\", \"test\")\n",
    "\n",
    "train_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "fea9238e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x13f2cab70>"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaAAAAGdCAYAAABU0qcqAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAFthJREFUeJzt3XuMVPXd+PHPcltRYSkiLJRLwWvrhaZWKfHyYCCgTQyoTbTaBBqDkaIpUqvBeG2bbKO/WGND9a9Km3iriUg0T3miIBBbsBFLiLESIbRgBLwk7AIWRDm/nPP7sQ+roAV3/bAzr1dyMjszZ3fO8YzznnPOd4aGoiiKAICvWI+v+gEBoCRAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkKJXHGX27dsX77zzTvTr1y8aGhqyFweAw1R+v8GOHTti2LBh0aNHj+4ToDI+I0aMyF4MAL6kzZs3x/Dhw7tPgMo9n9IF8f3oFb2zFweAw/Rx7I2X47/bX8+/8gDNnz8/7r///ti6dWuMHTs2fvvb38Z55533hb+3/7BbGZ9eDQIE0O38/28Y/aLTKF0yCOGpp56KuXPnxt133x2vvfZaFaApU6bEu+++2xUPB0A31CUBeuCBB2LmzJnx4x//OL71rW/FI488Escee2z8/ve/74qHA6Ab6vQAffTRR7F69eqYNGnS/z5Ijx7V9ZUrV35m/j179kRbW1uHCYDa1+kBev/99+OTTz6JIUOGdLi9vF6eD/q0lpaWaGpqap+MgAOoD+kfRJ03b160tra2T+WwPQBqX6ePghs0aFD07Nkztm3b1uH28npzc/Nn5m9sbKwmAOpLp+8B9enTJ84555xYsmRJh283KK+PHz++sx8OgG6qSz4HVA7Bnj59enz3u9+tPvvz4IMPxq5du6pRcQDQZQG66qqr4r333ou77rqrGnjw7W9/OxYvXvyZgQkA1K+GovzWuKNIOQy7HA03Iab6JgSAbujjYm8si0XVwLL+/fsfvaPgAKhPAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRAbQTonnvuiYaGhg7T6aef3tkPA0A316sr/ugZZ5wRL7744v8+SK8ueRgAurEuKUMZnObm5q740wDUiC45B/TWW2/FsGHDYsyYMXHttdfGpk2bDjnvnj17oq2trcMEQO3r9ACNGzcuFixYEIsXL46HH344Nm7cGBdeeGHs2LHjoPO3tLREU1NT+zRixIjOXiQAjkINRVEUXfkA27dvj1GjRsUDDzwQ11133UH3gMppv3IPqIzQhJgavRp6d+WiAdAFPi72xrJYFK2trdG/f/9DztflowMGDBgQp556aqxfv/6g9zc2NlYTAPWlyz8HtHPnztiwYUMMHTq0qx8KgHoO0C233BLLly+Pf/7zn/HXv/41Lr/88ujZs2f88Ic/7OyHAqAb6/RDcG+//XYVmw8++CBOPPHEuOCCC2LVqlXVzwDQZQF68sknO/tPAlCDfBccACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRA9wjQihUr4rLLLothw4ZFQ0NDPPvssx3uL4oi7rrrrhg6dGj07ds3Jk2aFG+99VZnLjMA9RigXbt2xdixY2P+/PkHvf++++6Lhx56KB555JF45ZVX4rjjjospU6bE7t27O2N5AagRvQ73Fy699NJqOphy7+fBBx+MO+64I6ZOnVrd9sc//jGGDBlS7SldffXVX36JAagJnXoOaOPGjbF169bqsNt+TU1NMW7cuFi5cuVBf2fPnj3R1tbWYQKg9nVqgMr4lMo9ngOV1/ff92ktLS1VpPZPI0aM6MxFAuAolT4Kbt68edHa2to+bd68OXuRAOhuAWpubq4ut23b1uH28vr++z6tsbEx+vfv32ECoPZ1aoBGjx5dhWbJkiXtt5XndMrRcOPHj+/MhwKg3kbB7dy5M9avX99h4MGaNWti4MCBMXLkyJgzZ0786le/ilNOOaUK0p133ll9ZmjatGmdvewA1FOAXn311bj44ovbr8+dO7e6nD59eixYsCBuvfXW6rNC119/fWzfvj0uuOCCWLx4cRxzzDGdu+QAdGsNRfnhnaNIeciuHA03IaZGr4be2YsDwGH6uNgby2JRNbDs887rp4+CA6A+CRAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASNErasD/vLOmyx9j/C03HNb8A95oO+zH2LfmjcP+HYDuyh4QACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiBFTXwZ6Vfx5aIr/88jhzX/pd+/5jCXCKC+2AMCIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASNGrHr/X7Ui+2+1wH2NAtB3mEgHUF3tAAHSPAK1YsSIuu+yyGDZsWDQ0NMSzzz7b4f4ZM2ZUtx84XXLJJZ25zADUY4B27doVY8eOjfnz5x9ynjI4W7ZsaZ+eeOKJL7ucANT7OaBLL720mj5PY2NjNDc3f5nlAqDGdck5oGXLlsXgwYPjtNNOi1mzZsUHH3zQFQ8DQDfW6aPgysNvV1xxRYwePTo2bNgQt99+e7XHtHLlyujZs+dn5t+zZ0817dfWZvQYQD3o9ABdffXV7T+fddZZcfbZZ8dJJ51U7RVNnDjxM/O3tLTEvffe29mLAUC9D8MeM2ZMDBo0KNavX3/Q++fNmxetra3t0+bNm7t6kQCohw+ivv3229U5oKFDhx5ywEI5AVBfDjtAO3fu7LA3s3HjxlizZk0MHDiwmsrDaVdeeWU1Cq48B3TrrbfGySefHFOmTOnsZQegngL06quvxsUXX9x+fe7cudXl9OnT4+GHH461a9fGH/7wh9i+fXv1YdXJkyfHL3/5S3s5AHTQUBRFEUeRchRcU1NTTIip0auh93/0Oz2+/a042uxb80b2IgCk+LjYG8tiUXVev3///oecz3fBAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABq898D+ir44k+A7sceEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAADj6A9TS0hLnnntu9OvXLwYPHhzTpk2LdevWdZhn9+7dMXv27DjhhBPi+OOPjyuvvDK2bdvW2csNQD0FaPny5VVcVq1aFS+88ELs3bs3Jk+eHLt27Wqf5+abb47nnnsunn766Wr+d955J6644oquWHYAurGGoiiKI/3l9957r9oTKkNz0UUXRWtra5x44onx+OOPxw9+8INqnjfffDO++c1vxsqVK+N73/veF/7Ntra2aGpqigkxNXo19D7SRQMgycfF3lgWi6om9O/fv2vOAZV/vDRw4MDqcvXq1dVe0aRJk9rnOf3002PkyJFVgA5mz549VXQOnACofUccoH379sWcOXPi/PPPjzPPPLO6bevWrdGnT58YMGBAh3mHDBlS3Xeo80rlHs/+acSIEUe6SADUQ4DKc0Gvv/56PPnkk19qAebNm1ftSe2fNm/e/KX+HgDdQ68j+aUbb7wxnn/++VixYkUMHz68/fbm5ub46KOPYvv27R32gspRcOV9B9PY2FhNANSXw9oDKscrlPFZuHBhLF26NEaPHt3h/nPOOSd69+4dS5Ysab+tHKa9adOmGD9+fOctNQD1tQdUHnYrR7gtWrSo+izQ/vM65bmbvn37VpfXXXddzJ07txqYUI5+uOmmm6r4/Ccj4ACoH4cVoIcffri6nDBhQofbH3300ZgxY0b1829+85vo0aNH9QHUcoTblClT4ne/+11nLjMA9f45oK7gc0AA3dtX8jkgADhSAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgEC4OgPUEtLS5x77rnRr1+/GDx4cEybNi3WrVvXYZ4JEyZEQ0NDh+mGG27o7OUGoJ4CtHz58pg9e3asWrUqXnjhhdi7d29Mnjw5du3a1WG+mTNnxpYtW9qn++67r7OXG4BurtfhzLx48eIO1xcsWFDtCa1evTouuuii9tuPPfbYaG5u7rylBKDmfKlzQK2trdXlwIEDO9z+2GOPxaBBg+LMM8+MefPmxYcffnjIv7Fnz55oa2vrMAFQ+w5rD+hA+/btizlz5sT5559fhWa/a665JkaNGhXDhg2LtWvXxm233VadJ3rmmWcOeV7p3nvvPdLFAKCbaiiKojiSX5w1a1b8+c9/jpdffjmGDx9+yPmWLl0aEydOjPXr18dJJ5100D2gctqv3AMaMWJETIip0auh95EsGgCJPi72xrJYVB0l69+/f+fuAd14443x/PPPx4oVKz43PqVx48ZVl4cKUGNjYzUBUF8OK0DlztJNN90UCxcujGXLlsXo0aO/8HfWrFlTXQ4dOvTIlxKA+g5QOQT78ccfj0WLFlWfBdq6dWt1e1NTU/Tt2zc2bNhQ3f/9738/TjjhhOoc0M0331yNkDv77LO7ah0AqPVzQOWHSg/m0UcfjRkzZsTmzZvjRz/6Ubz++uvVZ4PKczmXX3553HHHHZ97HPBA5TmgMmjOAQF0T11yDuiLWlUGp/ywKgB8Ed8FB0AKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKXrFUaYoiury49gb8f9+BKAbqV6/D3g97zYB2rFjR3X5cvx39qIA8CVfz5uamg55f0PxRYn6iu3bty/eeeed6NevXzQ0NHS4r62tLUaMGBGbN2+O/v37Rz2ox3Wu1/Wux3UuWe/NNbfeZVbK+AwbNix69OjRffaAyoUdPnz4585Tbqxa22BfpB7XuV7Xux7XuWS9a8vn7fnsZxACACkECIAU3SpAjY2Ncffdd1eX9aIe17le17se17lkvRujXh11gxAAqA/dag8IgNohQACkECAAUggQACm6TYDmz58f3/jGN+KYY46JcePGxd/+9reoZffcc0/1TRAHTqeffnrUkhUrVsRll11WfVq6XL9nn322w/3l+Ji77rorhg4dGn379o1JkybFW2+9FbW+3jNmzPjMtr/kkkuiO2tpaYlzzz23+oaTwYMHx7Rp02LdunUd5tm9e3fMnj07TjjhhDj++OPjyiuvjG3btkWtr/eECRM+s71vuOGGqAfdIkBPPfVUzJ07txqy+Nprr8XYsWNjypQp8e6770YtO+OMM2LLli3t08svvxy1ZNeuXdW2LN9cHMx9990XDz30UDzyyCPxyiuvxHHHHVdt9/KFqpbXu1QG58Bt/8QTT0R3tnz58iouq1atihdeeCH27t0bkydPrv5b7HfzzTfHc889F08//XQ1f/mVXFdccUXU+nqXZs6c2WF7l8/9ulB0A+edd14xe/bs9uuffPJJMWzYsKKlpaWoVXfffXcxduzYol6UT8WFCxe2X9+3b1/R3Nxc3H///e23bd++vWhsbCyeeOKJolbXuzR9+vRi6tSpRS179913q3Vfvnx5+7bt3bt38fTTT7fP849//KOaZ+XKlUWtrnfpv/7rv4qf/vSnRT066veAPvroo1i9enV1+OXA74srr69cuTJqWXm4qTxMM2bMmLj22mtj06ZNUS82btwYW7du7bDdy++WKg+/1vp2Ly1btqw6ZHPaaafFrFmz4oMPPoha0traWl0OHDiwuiz/Hy/3Dg7c3uUh55EjR9bU9v70eu/32GOPxaBBg+LMM8+MefPmxYcffhj14Kj7MtJPe//99+OTTz6JIUOGdLi9vP7mm29GrSpfaBcsWFC9AJW75Pfee29ceOGF8frrr1fHk2tdGZ/Swbb7/vtqVXn4rTz0NHr06NiwYUPcfvvtcemll1YvxD179ozurvzG+zlz5sT5559fveCWym3ap0+fGDBgQM1u74Otd+maa66JUaNGVW82165dG7fddlt1nuiZZ56JWnfUB6helS84+5199tlVkMon6Z/+9Ke47rrrUpeNrnX11Ve3/3zWWWdV2/+kk06q9oomTpwY3V15TqR8I1Vr5zSPdL2vv/76Dtu7HHRTbufyzUe53WvZUX8IrtwtLd/1fXo0THm9ubk56kX5zvDUU0+N9evXRz3Yv23rfbuXykOw5f8HtbDtb7zxxnj++efjpZde6vDPrpTbtDzcvn379prc3oda74Mp32yWamF7d/sAlbvl55xzTixZsqTDrmx5ffz48VEvdu7cWb0jKt8d1YPy8FP5wnPgdi//Aa9yNFw9bffS22+/XZ0D6s7bvhxvUb4IL1y4MJYuXVpt3wOV/4/37t27w/YuD0OV5z278/b+ovU+mDVr1lSX3Xl7/8eKbuDJJ5+sRj8tWLCgeOONN4rrr7++GDBgQLF169aiVv3sZz8rli1bVmzcuLH4y1/+UkyaNKkYNGhQNYqmVuzYsaP4+9//Xk3lU/GBBx6ofv7Xv/5V3f/rX/+62s6LFi0q1q5dW40MGz16dPHvf/+7qNX1Lu+75ZZbqpFf5bZ/8cUXi+985zvFKaecUuzevbvormbNmlU0NTVVz+ktW7a0Tx9++GH7PDfccEMxcuTIYunSpcWrr75ajB8/vpq6sy9a7/Xr1xe/+MUvqvUtt3f5XB8zZkxx0UUXFfWgWwSo9Nvf/rZ6cvbp06calr1q1aqill111VXF0KFDq/X9+te/Xl0vn6y15KWXXqpegD89lcOQ9w/FvvPOO4shQ4ZUb0AmTpxYrFu3rqjl9S5fmCZPnlyceOKJ1bDkUaNGFTNnzuz2b7YOtr7l9Oijj7bPU76x+MlPflJ87WtfK4499tji8ssvr16sa3m9N23aVMVm4MCB1XP85JNPLn7+858Xra2tRT3wzzEAkOKoPwcEQG0SIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIDI8H8BbVkSgvDCzFEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.imshow(train_dataset[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "c9a7ced0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x13b5e4950>"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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e/bE9u3b20wA1L52DVAZn1K5x3Og8v7+5z6pubm5itT+adiwYe25SAAcpdJHwc2dOzdaWlpap02bNmUvEgCdLUBNTU3V7datW9s8Xt7f/9wnNTY2Ru/evdtMANS+dg3QiBEjqtAsXry49bHynE45Gm7s2LHt+asAqLdRcDt37ox169a1GXiwevXq6NevXwwfPjxmz54dv/zlL+OUU06pgnT77bdXnxmaMmVKey87APUUoFdffTUuuuii1vtz5sypbqdOnRrz58+Pm2++ufqs0HXXXRfbtm2L888/PxYtWhTHHHNM+y45AJ1aQ1F+eOcoUh6yK0fDjYtLo1tD9+zFAeAwfVTsjaWxsBpY9lnn9dNHwQFQnwQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgM4RoOXLl8cll1wSQ4YMiYaGhnj22WfbPD9t2rTq8QOniy++uD2XGYB6DNCuXbti9OjRMW/evEPOUwZn8+bNrdPjjz/+RZcTgBrT7XC/YfLkydX0WRobG6OpqemLLBcANa5DzgEtXbo0Bg4cGKeddlrMmDEj3n///Y74NQDU0x7Q5ykPv11++eUxYsSIWL9+fdx6663VHtOKFSuia9eun5p/z5491bTf9u3b23uRAKiHAF111VWtX5911lkxatSoOOmkk6q9ovHjx39q/ubm5rj77rvbezEAqPdh2CNHjowBAwbEunXrDvr83Llzo6WlpXXatGlTRy8SALW4B/RJb731VnUOaPDgwYccsFBOANSXww7Qzp072+zNbNiwIVavXh39+vWrpvJw2hVXXFGNgivPAd18881x8sknx6RJk9p72QGopwC9+uqrcdFFF7XenzNnTnU7derUeOihh2LNmjXxu9/9LrZt21Z9WHXixInxi1/8wl4OAF8sQOPGjYuiKA75/J/+9KfD/ZEA1CHXggMghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUA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1/Wux3UuWe/GqFdH3SAEAOpDp9oDAqB2CBAAKQQIgBQCBECKThOgefPmxde+9rU45phjYsyYMfHXv/41atldd91VXQniwOn000+PWrJ8+fK45JJLqk9Ll+v37LPPtnm+HB9zxx13xODBg6Nnz54xYcKEePPNN6PW13vatGmf2vYXX3xxdGbNzc1xzjnnVFc4GThwYEyZMiXWrl3bZp7du3fHzJkzo3///nH88cfHFVdcEVu3bo1aX+9x48Z9antff/31UQ86RYCefPLJmDNnTjVk8bXXXovRo0fHpEmT4p133oladsYZZ8TmzZtbp5dffjlqya5du6ptWb65OJh77rknHnjggXj44YfjlVdeieOOO67a7uULVS2vd6kMzoHb/vHHH4/ObNmyZVVcVq5cGS+88ELs3bs3Jk6cWP232O/GG2+M5557Lp5++ulq/vKSXJdffnnU+nqXpk+f3mZ7l3/7daHoBM4999xi5syZrfc//vjjYsiQIUVzc3NRq+68885i9OjRRb0o/xQXLFjQen/fvn1FU1NTce+997Y+tm3btqKxsbF4/PHHi1pd79LUqVOLSy+9tKhl77zzTrXuy5Yta9223bt3L55++unWef7xj39U86xYsaKo1fUu/dd//Vfxk5/8pKhHR/0e0IcffhirVq2qDr8ceL248v6KFSuilpWHm8rDNCNHjoxrrrkmNm7cGPViw4YNsWXLljbbvby2VHn4tda3e2np0qXVIZvTTjstZsyYEe+//37UkpaWluq2X79+1W35/3i5d3Dg9i4POQ8fPrymtvcn13u/Rx99NAYMGBBnnnlmzJ07Nz744IOoB0fdxUg/6b333ouPP/44Bg0a1Obx8v4bb7wRtap8oZ0/f371AlTukt99991xwQUXxOuvv14dT651ZXxKB9vu+5+rVeXht/LQ04gRI2L9+vVx6623xuTJk6sX4q5du0ZnV17xfvbs2XHeeedVL7ilcpv26NEj+vbtW7Pb+2DrXbr66qvjxBNPrN5srlmzJm655ZbqPNEzzzwTte6oD1C9Kl9w9hs1alQVpPKP9Kmnnoprr702ddnoWFdddVXr12eddVa1/U866aRqr2j8+PHR2ZXnRMo3UrV2TvNI1/u6665rs73LQTfldi7ffJTbvZYd9Yfgyt3S8l3fJ0fDlPebmpqiXpTvDE899dRYt25d1IP927bet3upPARb/n9QC9t+1qxZ8fzzz8dLL73U5p9dKbdpebh927ZtNbm9D7XeB1O+2SzVwvbu9AEqd8vPPvvsWLx4cZtd2fL+2LFjo17s3LmzekdUvjuqB+Xhp/KF58DtXv4DXuVouHra7qW33nqrOgfUmbd9Od6ifBFesGBBLFmypNq+Byr/H+/evXub7V0ehirPe3bm7f15630wq1evrm478/b+jxWdwBNPPFGNfpo/f37x97//vbjuuuuKvn37Flu2bClq1U9/+tNi6dKlxYYNG4o///nPxYQJE4oBAwZUo2hqxY4dO4q//e1v1VT+Kd53333V1//617+q53/1q19V23nhwoXFmjVrqpFhI0aMKP79738Xtbre5XM33XRTNfKr3PYvvvhi8a1vfas45ZRTit27dxed1YwZM4o+ffpUf9ObN29unT744IPWea6//vpi+PDhxZIlS4pXX321GDt2bDV1Zp+33uvWrSt+/vOfV+tbbu/yb33kyJHFhRdeWNSDThGg0oMPPlj9cfbo0aMalr1y5cqill155ZXF4MGDq/X96le/Wt0v/1hryUsvvVS9AH9yKoch7x+KffvttxeDBg2q3oCMHz++WLt2bVHL612+ME2cOLE44YQTqmHJJ554YjF9+vRO/2brYOtbTo888kjrPOUbix//+MfFV77yleLYY48tLrvssurFupbXe+PGjVVs+vXrV/2Nn3zyycXPfvazoqWlpagH/jkGAFIc9eeAAKhNAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAEQGf4vcn8ab64BgmQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(test_dataset[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "b5a2ce53",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader\n",
    "train_loader = DataLoader(train_dataset, batch_size=100, shuffle=False)\n",
    "a = next(iter(train_loader))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "c14e18b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x14dc4de20>"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaAAAAGdCAYAAABU0qcqAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAFrlJREFUeJzt3XuMFfXd+PHPcltRuRQRli2XgtfWC6ZWKfFSDAS0iRG1iVabQGMwUjBFajUYr22TbTSxRkP1r0qbeKuJSDRPaRQEYgs2YgmPsfITQgtGwEvCcrEgyvwy8/uxD6sgD7jbD3vO65VMzp5zZvfMMMt5n5n5nrMNRVEUAQD/Yd3+0w8IACUBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQ94iizd+/eeO+996JPnz7R0NCQvTgAHKby8w22b98ezc3N0a1bt64ToDI+w4YNy14MAL6ijRs3xtChQ7tOgMo9n9KF8f3oET077XG6nX36Yc2/d/XbnbYsALXk09gTr8Z/tT2f/8cDNHfu3HjggQdi8+bNMXr06HjkkUfi/PPPP+T37TvsVsanR0MnBqh742HNv7cTlwWgpvz/Txg91GmUThmE8Mwzz8Ts2bPjnnvuiTfeeKMK0KRJk+L999/vjIcDoAvqlAA9+OCDMW3atPjxj38c3/rWt+Kxxx6LY489Nn73u991xsMB0AV1eIA++eSTWLlyZUyYMOF/HqRbt+r68uXLvzD/7t27Y9u2be0mAGpfhwfoww8/jM8++ywGDx7c7vbyenk+6PNaWlqiX79+bZMRcAD1If2NqHPmzInW1ta2qRy2B0Dt6/BRcAMHDozu3bvHli1b2t1eXm9qavrC/I2NjdUEQH3p8D2gXr16xbnnnhuLFi1q9+kG5fWxY8d29MMB0EV1yvuAyiHYU6ZMie985zvVe38eeuih2LlzZzUqDgA6LUDXXHNNfPDBB3H33XdXAw/OOeecWLhw4RcGJgBQvzrtkxBmzpxZTQBwVI6CA6A+CRAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASNEjjlLz/89/R98+ndnHVVFvJjWfk70IAG3sAQGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkOGo/C+7KU8+KHg09O+3ndzvnW4c1/95Vb3XasgDUI3tAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECoDYCdO+990ZDQ0O76fTTT+/ohwGgi+uUvwd0xhlnxMsvv/w/D9LjqP2zQwAk6ZQylMFpamrqjB8NQI3olHNA77zzTjQ3N8eoUaPi+uuvjw0bNhx03t27d8e2bdvaTQDUvg4P0JgxY2LevHmxcOHCePTRR2P9+vVx0UUXxfbt2w84f0tLS/Tr169tGjZsWEcvEgBHoYaiKIrOfICtW7fGiBEj4sEHH4wbbrjhgHtA5bRPuQdURmhcXBE9Gnp22nJ1O+dbhzX/3lVvddqyANSST4s9sSQWRGtra/Tt2/eg83X66ID+/fvHqaeeGmvXrj3g/Y2NjdUEQH3p9PcB7dixI9atWxdDhgzp7IcCoJ4DdOutt8bSpUvjn//8Z/z1r3+NK6+8Mrp37x4//OEPO/qhAOjCOvwQ3LvvvlvF5qOPPooTTzwxLrzwwlixYkX1NQB0WoCefvrpjv6RANQgnwUHQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFD2iTu1d9Vb2IgDUNXtAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIAC6RoCWLVsWl19+eTQ3N0dDQ0M8//zz7e4viiLuvvvuGDJkSPTu3TsmTJgQ77zzTkcuMwD1GKCdO3fG6NGjY+7cuQe8//7774+HH344HnvssXjttdfiuOOOi0mTJsWuXbs6YnkBqBE9DvcbLrvssmo6kHLv56GHHoo777wzrrjiiuq2P/zhDzF48OBqT+naa6/96ksMQE3o0HNA69evj82bN1eH3fbp169fjBkzJpYvX37A79m9e3ds27at3QRA7evQAJXxKZV7PPsrr++77/NaWlqqSO2bhg0b1pGLBMBRKn0U3Jw5c6K1tbVt2rhxY/YiAdDVAtTU1FRdbtmypd3t5fV9931eY2Nj9O3bt90EQO3r0ACNHDmyCs2iRYvabivP6ZSj4caOHduRDwVAvY2C27FjR6xdu7bdwINVq1bFgAEDYvjw4TFr1qz41a9+FaecckoVpLvuuqt6z9DkyZM7etkBqKcAvf7663HJJZe0XZ89e3Z1OWXKlJg3b17cdttt1XuFbrzxxti6dWtceOGFsXDhwjjmmGM6dskB6NIaivLNO0eR8pBdORpuXFwRPRp6Zi8OAIfp02JPLIkF1cCyLzuvnz4KDoD6JEAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAAdI0ALVu2LC6//PJobm6OhoaGeP7559vdP3Xq1Or2/adLL720I5cZgHoM0M6dO2P06NExd+7cg85TBmfTpk1t01NPPfVVlxOAGtPjcL/hsssuq6Yv09jYGE1NTV9luQCocZ1yDmjJkiUxaNCgOO2002L69Onx0UcfdcbDAFBPe0CHUh5+u+qqq2LkyJGxbt26uOOOO6o9puXLl0f37t2/MP/u3buraZ9t27Z19CIBUA8Buvbaa9u+Puuss+Lss8+Ok046qdorGj9+/Bfmb2lpifvuu6+jFwOAeh+GPWrUqBg4cGCsXbv2gPfPmTMnWltb26aNGzd29iIBUIt7QJ/37rvvVueAhgwZctABC+UEQH057ADt2LGj3d7M+vXrY9WqVTFgwIBqKg+nXX311dUouPIc0G233RYnn3xyTJo0qaOXHYB6CtDrr78el1xySdv12bNnV5dTpkyJRx99NFavXh2///3vY+vWrdWbVSdOnBi//OUv7eUA8NUCNG7cuCiK4qD3//nPfz7cHwlAHfJZcACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQAEd/gFpaWuK8886LPn36xKBBg2Ly5MmxZs2advPs2rUrZsyYESeccEIcf/zxcfXVV8eWLVs6erkBqKcALV26tIrLihUr4qWXXoo9e/bExIkTY+fOnW3z3HLLLfHCCy/Es88+W83/3nvvxVVXXdUZyw5AF9ZQFEVxpN/8wQcfVHtCZWguvvjiaG1tjRNPPDGefPLJ+MEPflDN8/bbb8c3v/nNWL58eXz3u9895M/ctm1b9OvXL8bFFdGjoeeRLhoAST4t9sSSWFA1oW/fvp1zDqj84aUBAwZUlytXrqz2iiZMmNA2z+mnnx7Dhw+vAnQgu3fvrqKz/wRA7TviAO3duzdmzZoVF1xwQZx55pnVbZs3b45evXpF//792807ePDg6r6DnVcq93j2TcOGDTvSRQKgHgJUngt688034+mnn/5KCzBnzpxqT2rftHHjxq/08wDoGnocyTfNnDkzXnzxxVi2bFkMHTq07fampqb45JNPYuvWre32gspRcOV9B9LY2FhNANSXw9oDKscrlPGZP39+LF68OEaOHNnu/nPPPTd69uwZixYtarutHKa9YcOGGDt2bMctNQD1tQdUHnYrR7gtWLCgei/QvvM65bmb3r17V5c33HBDzJ49uxqYUI5+uPnmm6v4/G9GwAFQPw4rQI8++mh1OW7cuHa3P/744zF16tTq69/85jfRrVu36g2o5Qi3SZMmxW9/+9uOXGYA6v19QJ3B+4AAurb/yPuAAOBICRAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgKM/QC0tLXHeeedFnz59YtCgQTF58uRYs2ZNu3nGjRsXDQ0N7aabbrqpo5cbgHoK0NKlS2PGjBmxYsWKeOmll2LPnj0xceLE2LlzZ7v5pk2bFps2bWqb7r///o5ebgC6uB6HM/PChQvbXZ83b161J7Ry5cq4+OKL224/9thjo6mpqeOWEoCa85XOAbW2tlaXAwYMaHf7E088EQMHDowzzzwz5syZEx9//PFBf8bu3btj27Zt7SYAat9h7QHtb+/evTFr1qy44IILqtDsc91118WIESOiubk5Vq9eHbfffnt1nui555476Hml++6770gXA4AuqqEoiuJIvnH69Onxpz/9KV599dUYOnToQedbvHhxjB8/PtauXRsnnXTSAfeAymmfcg9o2LBhMS6uiB4NPY9k0QBI9GmxJ5bEguooWd++fTt2D2jmzJnx4osvxrJly740PqUxY8ZUlwcLUGNjYzUBUF8OK0DlztLNN98c8+fPjyVLlsTIkSMP+T2rVq2qLocMGXLkSwlAfQeoHIL95JNPxoIFC6r3Am3evLm6vV+/ftG7d+9Yt25ddf/3v//9OOGEE6pzQLfccks1Qu7ss8/urHUAoNbPAZVvKj2Qxx9/PKZOnRobN26MH/3oR/Hmm29W7w0qz+VceeWVceedd37pccD9leeAyqA5BwTQNXXKOaBDtaoMTvlmVQA4FJ8FB0AKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKXrEUaYoiury09gT8f++BKALqZ6/93s+7zIB2r59e3X5avxX9qIA8BWfz/v163fQ+xuKQyXqP2zv3r3x3nvvRZ8+faKhoaHdfdu2bYthw4bFxo0bo2/fvlEP6nGd63W963GdS9Z7Y82td5mVMj7Nzc3RrVu3rrMHVC7s0KFDv3SecmPV2gY7lHpc53pd73pc55L1ri1ftuezj0EIAKQQIABSdKkANTY2xj333FNd1ot6XOd6Xe96XOeS9W6MenXUDUIAoD50qT0gAGqHAAGQQoAASCFAAKToMgGaO3dufOMb34hjjjkmxowZE3/729+ilt17773VJ0HsP51++ulRS5YtWxaXX3559W7pcv2ef/75dveX42PuvvvuGDJkSPTu3TsmTJgQ77zzTtT6ek+dOvUL2/7SSy+NrqylpSXOO++86hNOBg0aFJMnT441a9a0m2fXrl0xY8aMOOGEE+L444+Pq6++OrZs2RK1vt7jxo37wva+6aaboh50iQA988wzMXv27GrI4htvvBGjR4+OSZMmxfvvvx+17IwzzohNmza1Ta+++mrUkp07d1bbsnxxcSD3339/PPzww/HYY4/Fa6+9Fscdd1y13csnqlpe71IZnP23/VNPPRVd2dKlS6u4rFixIl566aXYs2dPTJw4sfq32OeWW26JF154IZ599tlq/vIjua666qqo9fUuTZs2rd32Ln/360LRBZx//vnFjBkz2q5/9tlnRXNzc9HS0lLUqnvuuacYPXp0US/KX8X58+e3Xd+7d2/R1NRUPPDAA223bd26tWhsbCyeeuqpolbXuzRlypTiiiuuKGrZ+++/X6370qVL27Ztz549i2effbZtnn/84x/VPMuXLy9qdb1L3/ve94qf/vSnRT066veAPvnkk1i5cmV1+GX/z4srry9fvjxqWXm4qTxMM2rUqLj++utjw4YNUS/Wr18fmzdvbrfdy8+WKg+/1vp2Ly1ZsqQ6ZHPaaafF9OnT46OPPopa0traWl0OGDCguiz/j5d7B/tv7/KQ8/Dhw2tqe39+vfd54oknYuDAgXHmmWfGnDlz4uOPP456cNR9GOnnffjhh/HZZ5/F4MGD291eXn/77bejVpVPtPPmzauegMpd8vvuuy8uuuiiePPNN6vjybWujE/pQNt93321qjz8Vh56GjlyZKxbty7uuOOOuOyyy6on4u7du0dXV37i/axZs+KCCy6onnBL5Tbt1atX9O/fv2a394HWu3TdddfFiBEjqhebq1evjttvv706T/Tcc89FrTvqA1Svyiecfc4+++wqSOUv6R//+Me44YYbUpeNznXttde2fX3WWWdV2/+kk06q9orGjx8fXV15TqR8IVVr5zSPdL1vvPHGdtu7HHRTbufyxUe53WvZUX8IrtwtLV/1fX40THm9qakp6kX5yvDUU0+NtWvXRj3Yt23rfbuXykOw5f+DWtj2M2fOjBdffDFeeeWVdn92pdym5eH2rVu31uT2Pth6H0j5YrNUC9u7yweo3C0/99xzY9GiRe12ZcvrY8eOjXqxY8eO6hVR+eqoHpSHn8onnv23e/kHvMrRcPW03UvvvvtudQ6oK2/7crxF+SQ8f/78WLx4cbV991f+H+/Zs2e77V0ehirPe3bl7X2o9T6QVatWVZddeXv/rxVdwNNPP12Nfpo3b17x1ltvFTfeeGPRv3//YvPmzUWt+tnPflYsWbKkWL9+ffGXv/ylmDBhQjFw4MBqFE2t2L59e/H3v/+9mspfxQcffLD6+l//+ld1/69//etqOy9YsKBYvXp1NTJs5MiRxb///e+iVte7vO/WW2+tRn6V2/7ll18uvv3tbxennHJKsWvXrqKrmj59etGvX7/qd3rTpk1t08cff9w2z0033VQMHz68WLx4cfH6668XY8eOraau7FDrvXbt2uIXv/hFtb7l9i5/10eNGlVcfPHFRT3oEgEqPfLII9UvZ69evaph2StWrChq2TXXXFMMGTKkWt+vf/3r1fXyl7WWvPLKK9UT8OenchjyvqHYd911VzF48ODqBcj48eOLNWvWFLW83uUT08SJE4sTTzyxGpY8YsSIYtq0aV3+xdaB1recHn/88bZ5yhcWP/nJT4qvfe1rxbHHHltceeWV1ZN1La/3hg0bqtgMGDCg+h0/+eSTi5///OdFa2trUQ/8OQYAUhz154AAqE0CBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAARAZ/i84U/eDdPzRdgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.imshow(a[0][80])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ae0c5f6e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x14dc69520>"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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AEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQAAc/QFqaWmJ8847L/r06RODBg2KyZMnx5o1a9rNs2vXrpgxY0accMIJcfzxx8fVV18dW7Zs6ejlBqCeArR06dIqLitWrIiXXnop9uzZExMnToydO3e2zXPLLbfECy+8EM8++2w1/3vvvRdXXXVVZyw7AF1YQ1EUxZF+8wcffFDtCZWhufjii6O1tTVOPPHEePLJJ+MHP/hBNc/bb78d3/zmN2P58uXx3e9+95A/c9u2bdGvX78YF1dEj4aeR7poACT5tNgTS2JB1YS+fft2zjmg8oeXBgwYUF2uXLmy2iuaMGFC2zynn356DB8+vArQgezevbuKzv4TALXviAO0d+/emDVrVlxwwQVx5plnVrdt3rw5evXqFf3792837+DBg6v7DnZeqdzj2TcNGzbsSBcJgHoIUHku6M0334ynn376Ky3AnDlzqj2pfdPGjRu/0s8DoGvocSTfNHPmzHjxxRdj2bJlMXTo0Lbbm5qa4pNPPomtW7e22wsqR8GV9x1IY2NjNQFQXw5rD6gcr1DGZ/78+bF48eIYOXJku/vPPffc6NmzZyxatKjttnKY9oYNG2Ls2LEdt9QA1NceUHnYrRzhtmDBguq9QPvO65Tnbnr37l1d3nDDDTF79uxqYEI5+uHmm2+u4vO/GQEHQP04rAA9+uij1eW4cePa3f7444/H1KlTq69/85vfRLdu3ao3oJYj3CZNmhS//e1vO3KZAaj39wF1Bu8DAuja/iPvAwKAIyVAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIACO/gC1tLTEeeedF3369IlBgwbF5MmTY82aNe3mGTduXDQ0NLSbbrrppo5ebgDqKUBLly6NGTNmxIoVK+Kll16KPXv2xMSJE2Pnzp3t5ps2bVps2rSpbbr//vs7erkB6OJ6HM7MCxcubHd93rx51Z7QypUr4+KLL267/dhjj42mpqaOW0oAas5XOgfU2tpaXQ4YMKDd7U888UQMHDgwzjzzzJgzZ058/PHHB/0Zu3fvjm3btrWbAKh9h7UHtL+9e/fGrFmz4oILLqhCs891110XI0aMiObm5li9enXcfvvt1Xmi55577qDnle67774jXQwAuqiGoiiKI/nG6dOnx5/+9Kd49dVXY+jQoQedb/HixTF+/PhYu3ZtnHTSSQfcAyqnfco9oGHDhsW4uCJ6NPQ8kkUDINGnxZ5YEguqo2R9+/bt2D2gmTNnxosvvhjLli370viUxowZU10eLECNjY3VBEB9OawAlTtLN998c8yfPz+WLFkSI0eOPOT3rFq1qrocMmTIkS8lAPUdoHII9pNPPhkLFiyo3gu0efPm6vZ+/fpF7969Y926ddX93//+9+OEE06ozgHdcsst1Qi5s88+u7PWAYBaPwdUvqn0QB5//PGYOnVqbNy4MX70ox/Fm2++Wb03qDyXc+WVV8add975pccB91eeAyqD5hwQQNfUKeeADtWqMjjlm1UB4FB8FhwAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKQQIABSCBAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRACgECIIUAAZBCgABIIUAApBAgAFIIEAApBAiAFAIEQAoBAiCFAAGQQoAASCFAAKToEUeZoiiqy09jT8T/+xKALqR6/t7v+bzLBGj79u3V5avxX9mLAsBXfD7v16/fQe9vKA6VqP+wvXv3xnvvvRd9+vSJhoaGdvdt27Ythg0bFhs3boy+fftGPajHda7X9a7HdS5Z7401t95lVsr4NDc3R7du3brOHlC5sEOHDv3SecqNVWsb7FDqcZ3rdb3rcZ1L1ru2fNmezz4GIQCQQoAASNGlAtTY2Bj33HNPdVkv6nGd63W963GdS9a7MerVUTcIAYD60KX2gACoHQIEQAoBAiCFAAGQossEaO7cufGNb3wjjjnmmBgzZkz87W9/i1p27733Vp8Esf90+umnRy1ZtmxZXH755dW7pcv1e/7559vdX46Pufvuu2PIkCHRu3fvmDBhQrzzzjtR6+s9derUL2z7Sy+9NLqylpaWOO+886pPOBk0aFBMnjw51qxZ026eXbt2xYwZM+KEE06I448/Pq6++urYsmVL1Pp6jxs37gvb+6abbop60CUC9Mwzz8Ts2bOrIYtvvPFGjB49OiZNmhTvv/9+1LIzzjgjNm3a1Da9+uqrUUt27txZbcvyxcWB3H///fHwww/HY489Fq+99locd9xx1XYvn6hqeb1LZXD23/ZPPfVUdGVLly6t4rJixYp46aWXYs+ePTFx4sTq32KfW265JV544YV49tlnq/nLj+S66qqrotbXuzRt2rR227v83a8LRRdw/vnnFzNmzGi7/tlnnxXNzc1FS0tLUavuueeeYvTo0UW9KH8V58+f33Z97969RVNTU/HAAw+03bZ169aisbGxeOqpp4paXe/SlClTiiuuuKKoZe+//3617kuXLm3btj179iyeffbZtnn+8Y9/VPMsX768qNX1Ln3ve98rfvrTnxb16KjfA/rkk09i5cqV1eGX/T8vrry+fPnyqGXl4abyMM2oUaPi+uuvjw0bNkS9WL9+fWzevLnddi8/W6o8/Frr2720ZMmS6pDNaaedFtOnT4+PPvooaklra2t1OWDAgOqy/D9e7h3sv73LQ87Dhw+vqe39+fXe54knnoiBAwfGmWeeGXPmzImPP/446sFR92Gkn/fhhx/GZ599FoMHD253e3n97bffjlpVPtHOmzevegIqd8nvu+++uOiii+LNN9+sjifXujI+pQNt93331ary8Ft56GnkyJGxbt26uOOOO+Kyyy6rnoi7d+8eXV35ifezZs2KCy64oHrCLZXbtFevXtG/f/+a3d4HWu/SddddFyNGjKhebK5evTpuv/326jzRc889F7XuqA9QvSqfcPY5++yzqyCVv6R//OMf44YbbkhdNjrXtdde2/b1WWedVW3/k046qdorGj9+fHR15TmR8oVUrZ3TPNL1vvHGG9tt73LQTbmdyxcf5XavZUf9Ibhyt7R81ff50TDl9aampqgX5SvDU089NdauXRv1YN+2rfftXioPwZb/D2ph28+cOTNefPHFeOWVV9r92ZVym5aH27du3VqT2/tg630g5YvNUi1s7y4foHK3/Nxzz41Fixa125Utr48dOzbqxY4dO6pXROWro3pQHn4qn3j23+7lH/AqR8PV03Yvvfvuu9U5oK687cvxFuWT8Pz582Px4sXV9t1f+X+8Z8+e7bZ3eRiqPO/Zlbf3odb7QFatWlVdduXt/b9WdAFPP/10Nfpp3rx5xVtvvVXceOONRf/+/YvNmzcXtepnP/tZsWTJkmL9+vXFX/7yl2LChAnFwIEDq1E0tWL79u3F3//+92oqfxUffPDB6ut//etf1f2//vWvq+28YMGCYvXq1dXIsJEjRxb//ve/i1pd7/K+W2+9tRr5VW77l19+ufj2t79dnHLKKcWuXbuKrmr69OlFv379qt/pTZs2tU0ff/xx2zw33XRTMXz48GLx4sXF66+/XowdO7aaurJDrffatWuLX/ziF9X6ltu7/F0fNWpUcfHFFxf1oEsEqPTII49Uv5y9evWqhmWvWLGiqGXXXHNNMWTIkGp9v/71r1fXy1/WWvLKK69UT8Cfn8phyPuGYt91113F4MGDqxcg48ePL9asWVPU8nqXT0wTJ04sTjzxxGpY8ogRI4pp06Z1+RdbB1rfcnr88cfb5ilfWPzkJz8pvva1rxXHHntsceWVV1ZP1rW83hs2bKhiM2DAgOp3/OSTTy5+/vOfF62trUU98OcYAEhx1J8DAqA2CRAAKQQIgBQCBEAKAQIghQABkEKAAEghQACkECAAUggQACkECIAUAgRAZPi/4Kz3ohm2gI0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.imshow(a[1][80])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "729e8e36",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/400 [00:00<?, ?it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[0, 0, 5],\n",
       "        [0, 5, 0],\n",
       "        [5, 0, 0]])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "import json\n",
    "import os\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from tqdm import tqdm\n",
    "\n",
    "train_jsons = [\n",
    "    f\n",
    "    for f in os.listdir(\"dataset/raw-data/ARC-AGI/data/training\")\n",
    "    if f.endswith(\".json\")\n",
    "]\n",
    "train_dataset = []\n",
    "test_dataset = []\n",
    "for f in tqdm(train_jsons):\n",
    "    with open(f\"dataset/raw-data/ARC-AGI/data/training/{f}\", \"r\") as json_file:\n",
    "        group_id = hash(f.split(\".\")[0])\n",
    "        json_data = json.load(json_file)\n",
    "        for train_data in json_data[\"train\"]:\n",
    "            train_dataset.append(torch.tensor(train_data[\"input\"]))\n",
    "        break\n",
    "\n",
    "train_dataset[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f442320",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0, 0, 5],\n",
       "        [0, 5, 0],\n",
       "        [5, 0, 0]])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_dataset[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c6c67b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 400/400 [00:00<00:00, 2492.14it/s]\n"
     ]
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "import json\n",
    "import os\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from tqdm import tqdm\n",
    "train_jsons = [f for f in os.listdir(\"dataset/raw-data/ARC-AGI/data/training\") if f.endswith(\".json\")]\n",
    "train_dataset = []\n",
    "test_dataset = []\n",
    "for f in tqdm(train_jsons):\n",
    "    with open(f\"dataset/raw-data/ARC-AGI/data/training/{f}\", \"r\") as json_file:\n",
    "        group_id = hash(f.split(\".\")[0])\n",
    "        json_data = json.load(json_file)\n",
    "        # Process json_data as needed\n",
    "        for train_data in json_data[\"train\"]:\n",
    "            input_tensor = torch.tensor(train_data[\"input\"])\n",
    "            h, w = input_tensor.shape\n",
    "            input_pad = F.pad(\n",
    "                input_tensor,\n",
    "                (0, 30 - w, 0, 30 - h),\n",
    "            )\n",
    "\n",
    "            output_tensor = torch.tensor(train_data[\"output\"])\n",
    "            h, w = output_tensor.shape\n",
    "            output_pad = F.pad(\n",
    "                output_tensor,\n",
    "                (0, 30 - w, 0, 30 - h),\n",
    "            )\n",
    "            train_dataset.append([input_pad, output_pad, group_id])\n",
    "\n",
    "        input_tensor = torch.tensor(json_data[\"test\"][0][\"input\"])\n",
    "        input_pad = F.pad(\n",
    "            input_tensor,\n",
    "            (0, 30 - input_tensor.shape[0], 0, 30 - input_tensor.shape[1]),\n",
    "        )\n",
    "        output_tensor = torch.tensor(json_data[\"test\"][0][\"output\"])\n",
    "        output_pad = F.pad(\n",
    "            output_tensor,\n",
    "            (0, 30 - output_tensor.shape[0], 0, 30 - output_tensor.shape[1]),\n",
    "        )\n",
    "        train_dataset.append([input_pad, output_pad, group_id])\n",
    "os.makedirs(\"../data/arc-orig/train\", exist_ok=True)\n",
    "with open(\"../data/arc-orig/train/dataset.pt\", \"wb\") as f:\n",
    "    torch.save(train_dataset, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "8331f407",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([30, 30])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_dataset[4][1].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "19888d67",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([31, 29])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[d[0] for d in train_dataset][5].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "192935fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../data/arc-orig/train/dataset.pt\", \"rb\") as f:\n",
    "    train_dataset = torch.load(f)\n",
    "len(train_dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db5e6235",
   "metadata": {},
   "outputs": [],
   "source": [
    "len(train_dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbd09adb",
   "metadata": {},
   "outputs": [],
   "source": [
    "len(test_dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf5483bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_dataset[0][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76d65647",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_dataset[4][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36548dac",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(train_dataset[4][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e795fabc",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(train_dataset[4][1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "078dc29e",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(test_dataset[3][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "137a80b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(test_dataset[3][1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30e673e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "max_len = 0\n",
    "for f in train_jsons:\n",
    "    with open(f\"dataset/raw-data/ARC-AGI/data/training/{f}\", \"r\") as json_file:\n",
    "        json_data = json.load(json_file)\n",
    "        # Process json_data as needed\n",
    "        max_len = max(max_len, len(json_data[\"train\"]))\n",
    "\n",
    "print(max_len)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "01f89a8c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from ds import MazeDataset, ARCDataset, ExtremeSudokuAugDataset\n",
    "from puzzle_dataset import PuzzleDataset, PuzzleDatasetConfig\n",
    "%cd ../"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f40d35a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds_orig_train = PuzzleDataset(\n",
    "    PuzzleDatasetConfig(\n",
    "        seed=42,\n",
    "        dataset_path=\"./data/arc-aug-1000\",\n",
    "        global_batch_size=1000,\n",
    "        test_set_mode=False,\n",
    "        epochs_per_iter=1,\n",
    "        rank=0,\n",
    "        num_replicas=1,\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c212d56",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds_orig_test = PuzzleDataset(\n",
    "    PuzzleDatasetConfig(\n",
    "        seed=42,\n",
    "        dataset_path=\"./data/arc-aug-1000\",\n",
    "        global_batch_size=1000,\n",
    "        test_set_mode=True,\n",
    "        epochs_per_iter=1,\n",
    "        rank=0,\n",
    "        num_replicas=1,\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "090e101f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473fe4ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7818a462",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader\n",
    "\n",
    "ds_loader_train = DataLoader(ds_orig_train, batch_size=1000, shuffle=False)\n",
    "ds_loader_test = DataLoader(ds_orig_test, batch_size=1000, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d17d2d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds_loader_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23a03298",
   "metadata": {},
   "outputs": [],
   "source": [
    "set_test = set(next(iter(ds_loader_test))[1][\"puzzle_identifiers\"].flatten().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "675ad112",
   "metadata": {},
   "outputs": [],
   "source": [
    "set_train = set(next(iter(ds_loader_train))[1][\"puzzle_identifiers\"].flatten().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47499a42",
   "metadata": {},
   "outputs": [],
   "source": [
    "a = next(iter(ds_loader_train))[1]\n",
    "b = next(iter(ds_loader_test))[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cee94d3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "a[\"puzzle_identifiers\"][0][10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0723e95c",
   "metadata": {},
   "outputs": [],
   "source": [
    "set_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed239c8b",
   "metadata": {},
   "outputs": [],
   "source": [
    "max(set_train), min(set_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1d1f196",
   "metadata": {},
   "outputs": [],
   "source": [
    "min(set_test), max(set_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f111afc",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader\n",
    "import matplotlib.pyplot as plt\n",
    "ds = ARCDataset(\"./data\", split=\"train\")\n",
    "ds_loader = DataLoader(ds, batch_size=10, shuffle=False)\n",
    "d = next(iter(ds_loader))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a827268b",
   "metadata": {},
   "outputs": [],
   "source": [
    "len(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f29d024",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(d[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b300190",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(d[0][1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "84861b41",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(ds[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe8d3640",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds[1][3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "50b11934",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds[0][3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e9892cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(ds[1][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee8f2e78",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "np."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d1431b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds[:][3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "910945a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(ds[3][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2d0d116",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(ds[3][1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d30b00b",
   "metadata": {},
   "outputs": [],
   "source": [
    "d[1][\"puzzle_identifiers\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca78c5ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(dataset_train[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf5d4164",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_test[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f16db0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_train = ARCDataset(dataset_dir=\"./data\", split=\"train\")\n",
    "dataset_test = ARCDataset(dataset_dir=\"./data\", split=\"test\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47e45fb2",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_train[0][3], dataset_test[0][3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cec48657",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.imshow(dataset_train[1][0].cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36989c0b",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(dataset_train[1][1].cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "98c02493",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(dataset_test[0][0].cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45972378",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(dataset_test[0][1].cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94c3e6ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(dataset[100][1].cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ad6aead",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(dataset[100][2].to(int).cpu().numpy())"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "c-voting",
   "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.12.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
