{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:21.385745Z",
     "start_time": "2025-09-18T23:37:18.903723Z"
    }
   },
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import os\n",
    "import numpy as np\n",
    "import random\n",
    "from tqdm.auto import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "import cv2\n",
    "import torch\n",
    "import torchvision\n",
    "from torchvision.transforms.functional import to_pil_image\n",
    "import torchvision.transforms.v2 as Transform\n",
    "from iclr.common import *\n",
    "import seaborn as sns"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "execution_count": 10
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:21.473606Z",
     "start_time": "2025-09-18T23:37:21.409412Z"
    }
   },
   "cell_type": "code",
   "source": [
    "device = torch.device(\"cuda\")\n",
    "sns.set_theme(style=\"whitegrid\", font=\"cmr10\", font_scale=1.9)\n",
    "plt.rcParams[\"axes.formatter.use_mathtext\"] = True\n",
    "colors = sns.color_palette()\n",
    "colors"
   ],
   "id": "49fd96a807f21b17",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(0.2980392156862745, 0.4470588235294118, 0.6901960784313725),\n",
       " (0.8666666666666667, 0.5176470588235295, 0.3215686274509804),\n",
       " (0.3333333333333333, 0.6588235294117647, 0.40784313725490196),\n",
       " (0.7686274509803922, 0.3058823529411765, 0.3215686274509804),\n",
       " (0.5058823529411764, 0.4470588235294118, 0.7019607843137254),\n",
       " (0.5764705882352941, 0.47058823529411764, 0.3764705882352941),\n",
       " (0.8549019607843137, 0.5450980392156862, 0.7647058823529411),\n",
       " (0.5490196078431373, 0.5490196078431373, 0.5490196078431373),\n",
       " (0.8, 0.7254901960784313, 0.4549019607843137),\n",
       " (0.39215686274509803, 0.7098039215686275, 0.803921568627451)]"
      ],
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#4c72b0;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#dd8452;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#55a868;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#c44e52;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8172b3;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#937860;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#da8bc3;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8c8c8c;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ccb974;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#64b5cd;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 11
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:21.547727Z",
     "start_time": "2025-09-18T23:37:21.488453Z"
    }
   },
   "cell_type": "code",
   "source": [
    "ratios = [0.075]\n",
    "mnist_dir = '/home/dataset/mnist'\n",
    "background_predictability = 0.70\n",
    "img_size = 48\n",
    "min_mask_ratio = 0.10\n",
    "colors = F.normalize(torch.tensor([\n",
    "    [1, 0, 0],\n",
    "    [0, 1, 0],\n",
    "    [0, 0, 1],\n",
    "    [1, 1, 0],\n",
    "    [1, 0, 1],\n",
    "    [0, 1, 1],\n",
    "    [2, 1, 0],\n",
    "    [2, 0, 1],\n",
    "    [1, 2, 0],\n",
    "    [0, 1, 2]\n",
    "], dtype=torch.float32)) * 255\n",
    "colors"
   ],
   "id": "ed92ea73351ec3ec",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[255.0000,   0.0000,   0.0000],\n",
       "        [  0.0000, 255.0000,   0.0000],\n",
       "        [  0.0000,   0.0000, 255.0000],\n",
       "        [180.3122, 180.3122,   0.0000],\n",
       "        [180.3122,   0.0000, 180.3122],\n",
       "        [  0.0000, 180.3122, 180.3122],\n",
       "        [228.0789, 114.0395,   0.0000],\n",
       "        [228.0789,   0.0000, 114.0395],\n",
       "        [114.0395, 228.0789,   0.0000],\n",
       "        [  0.0000, 114.0395, 228.0789]])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 12
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:21.693748Z",
     "start_time": "2025-09-18T23:37:21.648435Z"
    }
   },
   "cell_type": "code",
   "source": [
    "bias = 0.05\n",
    "def get_max_bounding_box(mask):\n",
    "    # Find indices where mask is 1\n",
    "    y_indices, x_indices = np.where(mask)\n",
    "    # If no 1s are found, return None\n",
    "    if len(y_indices) == 0:\n",
    "        return (0, 0, 0, 0)\n",
    "\n",
    "    # Get min and max coordinates\n",
    "    min_y, max_y = np.min(y_indices), np.max(y_indices)\n",
    "    min_x, max_x = np.min(x_indices), np.max(x_indices)\n",
    "\n",
    "    return (min_y, min_x, max_y, max_x)\n",
    "\n",
    "def get_ratio(mask):\n",
    "    bbox = get_max_bounding_box(mask)\n",
    "    min_y, min_x, max_y, max_x = bbox\n",
    "    bbox_area = (max_y - min_y + 1) * (max_x - min_x + 1)\n",
    "    if bbox_area < 10:\n",
    "        return 0\n",
    "    mask_area = torch.sum(mask)\n",
    "    ratio = mask_area / bbox_area\n",
    "\n",
    "    return ratio.item()"
   ],
   "id": "ea4170e92ba5fc54",
   "outputs": [],
   "execution_count": 13
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:30.604577Z",
     "start_time": "2025-09-18T23:37:21.778083Z"
    }
   },
   "cell_type": "code",
   "source": [
    "mnist_train = torchvision.datasets.MNIST(root=mnist_dir, train=True, download=False, transform=Transform.Compose([Transform.ToTensor()]))\n",
    "mnist_test = torchvision.datasets.MNIST(root=mnist_dir, train=False, download=False, transform=Transform.Compose([Transform.ToTensor()]))\n",
    "\n",
    "total_pixel = img_size * img_size\n",
    "mask_ratios = [[], []]\n",
    "pure_pixel_ratios = [[], []]\n",
    "filtered_img_ids = [[], []]\n",
    "imgs = [[[] for _ in range(10)] for _ in range(2)]\n",
    "\n",
    "print(\"calculate mask ratio...\")\n",
    "for i in range(2):\n",
    "    for index, (x, label) in tqdm(enumerate([mnist_train, mnist_test][i])):\n",
    "        ratio = get_ratio(x.squeeze() > bias)\n",
    "        pure_pixel_ratios[i].append(torch.sum(x.squeeze() > bias) / (28*28))\n",
    "        mask_ratios[i].append(ratio)\n",
    "        if ratio < min_mask_ratio:\n",
    "            filtered_img_ids[i].append(index)\n",
    "            print(f\"Filtering {index} with mask ratio {ratio:.2f}\")\n",
    "        else:\n",
    "            imgs[i][label].append(x)\n",
    "print(len(filtered_img_ids[0]), len(filtered_img_ids[1]))"
   ],
   "id": "d002ebf80c4b3df6",
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/gpuadmin/jhkim/.venv/lib/python3.12/site-packages/torchvision/transforms/v2/_deprecated.py:42: UserWarning: The transform `ToTensor()` is deprecated and will be removed in a future release. Instead, please use `v2.Compose([v2.ToImage(), v2.ToDtype(torch.float32, scale=True)])`.Output is equivalent up to float precision.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "calculate mask ratio...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "60000it [00:07, 8014.54it/s]\n",
      "10000it [00:01, 9785.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "execution_count": 14
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:31.460308Z",
     "start_time": "2025-09-18T23:37:30.666480Z"
    }
   },
   "cell_type": "code",
   "source": [
    "plt.plot(np.sort(mask_ratios[0]))\n",
    "plt.plot(np.sort(mask_ratios[1]))\n",
    "plt.axhline(min_mask_ratio, color='r', linestyle='--')\n",
    "plt.title('mask ratio')\n",
    "plt.show()\n",
    "plt.plot(np.sort(pure_pixel_ratios[0]))\n",
    "plt.plot(np.sort(pure_pixel_ratios[1]))\n",
    "plt.title('pure pixel ratio')\n",
    "plt.show()\n",
    "print(min(pure_pixel_ratios[0]), max(pure_pixel_ratios[0]))\n",
    "print(min(pure_pixel_ratios[1]), max(pure_pixel_ratios[1]))"
   ],
   "id": "7db99e6a5c5d6533",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkUAAAHKCAYAAAANcD9RAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAYJFJREFUeJzt3Xl8VPW9//HXZN93kkAIO0FANsFdUBERrCJ14ZafvSqIK4JWS0VttXqxarXai1ZFq+XicmstiiBirwsqUFQ22YQAgQABEhKy77Oc3x9DhsRkQmYyk8lM3s/Hw4dn5nznzIfhm8mbc77n+zUZhmEgIiIi0sUF+boAERERkc5AoUhEREQEhSIRERERQKFIREREBFAoEhEREQEUikREREQAhSIRERERQKFIREREBIAQXxcgIgJQX1/P4cOHKSsrc/zXr18/hg8f7uvSRKSLUCgSkU5hy5Yt3HTTTU2eu+eee7p8KFq8eDEvvfQSAwYMYOHChaSmpvq6JJGApctnItIpnHvuuezYsYP333+fiIgIX5fjVVarlcWLF7ep7YsvvkhFRQVbtmzh008/9W5hIl2cQpGIdBqhoaEMHz6cwYMH+7oUryoqKmLJkiVtajtnzhxiYmIYNmwYV1xxhZcrE+nadPlMRDqd0NBQX5fgVQUFBW1ue8stt3DLLbd4rxgRcdCZIhGRDvbvf//b1yWISAsUikREOtgnn3zi6xJEpAUKRSIiHejzzz8nOzvbpdfU19dTUFBARUWFl6oSEdCYIhG/k52dTUlJCSUlJZSWlpKSksLll18OwOHDh/nuu+8oKSkhPT2dsWPHkpCQ0OT127ZtY9u2bdTW1tK7d28uvPBCoqKiWn3P2tpaNmzYwKFDh6isrCQ5OZlzzz2XzMzM09ZrtVrZsmUL2dnZVFVVkZGRwYUXXkhcXByrVq3iZz/7mdufRXvs3r3b8TmWlJSQmZnJuHHjqKys5PPPP6e4uJhx48YxYMCAZq915/MoLy/n//7v/3jyySfbVN/OnTu55557KC0tpbq6GoCnnnqKa6+91ulrrFYrmzZtYs+ePdTU1JCRkcGoUaPo3r17m95TpKvTmSIRP3PNNddw8803c9999/H73/+eFStWYLVaefLJJ3niiSeorKwEYNGiRVxyySUsW7YMgJKSEu644w7effddTCYTlZWVPPLII1x++eVs2rSpxfcyDINnnnmG8847j+3bt9OtWzdSUlLIzc3lP/7jP7j11lvZv3+/01q//vprJk6cyKuvvkplZSWxsbHs2rWLm266iRkzZvCnP/3JpT/7o48+yqBBg5r8N3z4cLcuR11zzTXccsst/OpXv+KJJ57g888/Jycnh1/84hfs3buXxYsXM2XKlCbjf9rzeUydOpWXX36ZsLAwAPLz8xk/fnyT/xr/Obp3786cOXMYP358m/48S5cu5dJLL+WFF16gurqaqKgovv32W6666irmzp3r0uBukS7LEBG/c+zYMePqq682srKyjDlz5hjz58833nvvvSZtCgsLjaFDhxqDBw829u3bZ/y///f/jK1btzZp89lnnxlZWVnG2LFjDbPZ3Ox9vvrqKyMrK8vIysoyHn/88Sb7Tpw4YVx++eXGOeecY+zdu7fZa7Ozs40hQ4YYq1ataravsrLSmDZtmnHppZe2+Of75S9/aWRlZRkLFy5s8rzNZjNmzJhhZGVlGTNmzDC+/fZbw2KxtPwhnYbFYjEOHz5sXHXVVUZWVpbxyCOPGNdff72xf/9+o7i42PHnfuyxxxyvac/n0WDp0qVGVlaW0z/7T9lsNmPkyJFGVlaWsXTp0hb3//a3vzUGDRpkvPvuu832FxQUGFdffbVxwQUXGNu3b2/Te4p0VTpTJOKH0tPTueSSSwD7TNAhISFMmzatSZuUlBRGjBiB1Wrl1ltv5Re/+EWz2aEvvvhiQkJCKCgo4Icffmj2Pn379qVXr16kpKRw9dVXN9mXlJTEnXfeSWlpKc8880yz13788cdYLBbGjRvXbF90dDTz5s1z8U8NBw4cIDs7m8cff5w333yTc889l+DgYJePAxAcHEzPnj259NJLAfjiiy+4/PLL6du3L4mJiUyZMoXMzEymTJnieE17Pg93mUwmEhMTne5//fXX+cc//sE111zD9OnTm+1PTU3lL3/5C2VlZcyZM4fS0lKP1SYSaDSmSMRPNczlc/z4cWbNmtVim7S0NMf2VVdd1eIxEhMTKSws5NixY8329+rVi88++8xpDRkZGQAtXn5rGAfz9ttvc/vttzfbP3ToUOLi4pwe+6c2bdrEI488wn//938zZsyYNr/udBo+x+LiYq655hrH888++2yztu35PLyhsLCQl19+GYCf//znTttlZmYyevRovv32WxYtWsSDDz7YIfWJ+BuFIhE/l5CQQO/evVvc1zB+Zfjw4ZhMplbbmM3mVt+nrq6O1atXs2nTJnbv3s3x48cdd0NVVVU1a3/FFVfw1ltv8ac//YnPP/+cK6+8kjPOOIOsrCySkpKIjIx0jHc6nU8++YTHH3+c9957jz59+rTpNa5KS0trEiJPx9XPwxtWrlxJTU0NQIsDwhvr378/3377LR988AH3339/wE+QKeIOhSIRPxcdHX3aNqe7u6w1dXV1vPzyy7z99tvYbDauu+467r77boYNG8bOnTubLeLa4Oyzz2bBggUsWLCArVu3snXrVse+wYMHc8sttzB16tTTvv+iRYt44YUXMAyDdevWeTUUtYW7n4c3NL7kGRsb22rbmJgYAEpLSzly5IjXPkcRf6ZQJCJOHTt2jBkzZnDgwAFGjBjBiy++6NLZlBtuuIEJEybw2WefsXr1anbv3s3Ro0fZtWsXDz74IN988w3PPfccQUEtD2/83//9XwYPHszTTz/Ngw8+yDPPPMM555zDwIEDPfVHdGjLIrTt/Tw8zZV5i6xWq2O7uLhYoUikBRpoLSJO/eY3v+HAgQOkpKTw2muvuRQADhw4QHV1NYmJiUybNo1XXnmF1atXs379eubNm0dUVBQrV65k6dKlTo9x3nnnsWjRIqZOncq0adOoq6vj/vvvp66uzhN/PJe15/NoC1fH+vTo0cOxfbqAdOLECce25i0SaZlCkYi0KC8vj++//x6wz+nz00kggRbDya9+9Svy8/NZtGgRH374YbP9SUlJzJo1yzFAePXq1U5rOPvsswkJsZ/Qfuihh+jTpw979uzhj3/8ozt/pHZp7+fRFhs2bHCppvPOO8+xffDgwVbbHj16FIA+ffqQnp7u0vuIdBUKRSLSosZnFhruqvqpnTt3NnuuqKgIi8UC2G/Ld+b8888nISHB6QDwn4qKiuK5554jNDSUt99+u9Uw5Q2e+Dzg1GW6hrvzGlRWVhIZGelSTVdccQU9e/YEYP369U7blZWVsXnzZgBmzZrV5s9cpKtRKBKRFvXt25fw8HAAxy/UxkpKSli6dKnjTE7DmBWz2ewY2L1582Y+/fTTFo9fWFhIZWUlF1xwQZtrGjZsGHfffTdgP3PU0jQC3uKJzwNgyJAhgH3Ac1FRkeP57du3M3jwYJdqCgkJYeHChURGRvL3v/+9SXBr7MMPP8RsNjN58mRuuOEGl95DpCtRKBLxQ/X19ezevRuwD5ptuDTSWGVlJTk5OQDk5OQ4lv9oLC8vj+LiYgB27NjRZDBuXFwcjzzyCEFBQXz88ce8+eabjjMeO3fu5NZbb2X27Nmcc845AHz//fcUFRURGxtLUlISAEFBQTz//PO888471NbWAvalMr7//nvuvPNOzjrrrGaTThYXF5OXl+d4n8Y1AVx55ZXAqWVLTnfZqDWNP8fc3FzH59UST3weYL989fOf/xzDMFi4cCEWi4XKykr+8pe/tHjn2uHDhx3hqaWFZIcOHcr//M//EB4ezq233sqmTZuw2WyA/WzUu+++ywsvvMAvf/lLn1x2FPEnJsMwDF8XISJtN3bsWEpKSprNK5ScnMzLL79Meno6119/PcXFxU0CRXBwMElJSfzzn//khx9+4Pe//z0lJSVNjhEWFsaQIUN47733HM/t2LGDt99+mw0bNjgWoO3fvz+33XYbo0aNIi8vjwcffJDdu3dz0UUX8cgjj5Camsqjjz7K0KFDmTRpEq+++ipffvklZrOZoKAg0tPTmTx5MtOmTXPMl/PDDz8we/ZsTpw4QeOvpcY15efnM3ny5GaXnhITE1m2bJlLY2WcfY4xMTFceOGFLFy4sMXXuft5NGaxWHjjjTf44IMPKC4uJjU1lXvvvZeJEyc62nz66act/h1FR0czd+5cbrnllibPV1VVsXz5cj7++GOOHj1KUFAQERERjBgxosXZzEWkOYUiEREREXT5TERERARQKBIREREBFIpEREREAIUiEREREUChSERERARQKBIREREBIMTXBXS0LVu2YBiGY24UERER6fzMZjMmk4lRo0Z57T263JkiwzDw1tRMhmFQX1/vteNL16R+Jd6iviXe4K1+5c3f3w263JmihjNEw4YN8/ixq6ur2bVrFwMGDGiy1pFIe6hfibeob4k3eKtfbd++3WPHcqbLnSkSERERaYlCkYiIiAgKRSIiIiKAQpGIiIgIoFAkIiIiAigUiYiIiAAevCV/8eLF7N+/nyeeeKLdx1qzZg2LFy/m0KFDREdHYxgGEyZMYMaMGcTExHigWhEREZGmPHKm6LPPPuO5556jvr6+3cdavHgxs2bNYvjw4axatYply5bxwgsvsGzZMqZNm8aJEyc8ULGIiIhIU26HIrPZzLZt23jooYe45557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y6EoNDTUMXni8uXLm+3Pyclh586dxMXFMXXq1Cb7duzYwfjx45k4caJjdurG8vLyuOeee3jggQeIiYkhJyen2X8ffvih25fkvMl2MhQpD4mIiPgnt5Zznz17NitXrmTJkiVMmzbNMfgaYOHChQDMnz+/2fIey5Yt48iRIwAsXbqUhx9+2LGvvLyc22+/nYKCAubPn9/q+8+cOdOdsr2q4USRQpGIiIh/cisUJSQk8M477zB37lxuvPFGZs6cSXx8PKtWrWLdunXMmzeP6667rtnrrr32Wr788kuAZmeR3n33XaeX436qX79+7pTtVY4zRT6uQ0RERNzjVigC6Nu3LytWrGDjxo1kZ2eTn5/PpEmTWLBggdMFYIcMGeIIRT915513cuedd7pbjs+dOlOkWCQiIuKP3A5FDcaMGcOYMWM8UYtfMzSmSERExK+1OxSJXWJcBPExYSRo+SARERG/pFDkIeGhwbz4q4vYu7f5XXUiIiLS+bl8S744Fx4WTHCQrp+JiIj4I4UiERERERSKRERERACFIhERERFAoUhEREQEUCgSERERARSKRERERACFIhERERFAoUhEREQEUCgSERERARSKRERERACFIhERERFAoUhEREQEUCgSERERARSKRERERACFIhERERFAoUhEREQEUCgSERERARSKRERERACFIhEREREAQnxdgE8YBtba2hZ3mYKCCAoLczx21s7e2ERweHiTtkZ9PdbaWqxBQa23rasDw2jbcT3VFgiOiHCrra2+HsNm80jboPBwTCaTva3ZjGG1eqZtWBimk5+7R9uGhmIKDna9rcWCYbG0u621trbJ52lYrdjMZqfHNYWEEBQS4vm2wcEEhYa63tZmw1Zf7/m2hoGtrs4zbV34uW/vd0Sb23bAd0RL31n6jnCjrY+/I37atlN8R9hsLf8udNK2rT/33tYlQ1Ht8eN8+7vHW9yXOPoshjz6iOPx9zfNdPplGnfmUIY9+YTj8Y9z78dSUcG2FtrGDOjPiD/90fF4yz33Une8sMXjRmb25KyX/tvxeOsDv6HmcF6LbcNTuzHm9Vcdj3c8/Dsq9+W02DYkLo5z3/rbqXqfeJLyHTtbbBsUHs75/3jX8Xj3089Ssmlzi20BLvxoqWN7zwsLOfHv9U7bnvfeO44vyJyXX+X4l185bXvOkjcJjY8H4MAbi8lf9anTtqNfe4WItFQADr79LkeXLXfadtSLLxDVqxcAef/8gMN//4fTtsOfe4bYgQMAOLpiJQf/5y2nbc9c8Djxw84EoOBfn7H/tb86bTv4dw+TNGY0AIVff8O+hX9x2jb0+p/D0KEAnPj2O7L/+CenbQfMnU3aZeMBKNnyA7v+6w9O2/a7fRbdfzYZgPIfd7Hjt485bdv75v+k57VTAajcf4Btv37QadvMX0yj1/T/AKAmL48tc37ltG2PqVPoO+NmAOoKi9h0+11O26ZPnkT/O28DwFJezvc3zXTaNnX8JQy8dw4Atro6vv2PG522Tb7gfM548NeOx621bc93xMbb7sJSXt5iW19+RzR8Z+k74hR/+44Y9JsHSLnwAqBzfEcYx/LZtuBpp23d/Y7wNl0+ExEREQFMhtHKudEAtH37djAMhmRltbi/PafGK4qLyc7OZtCgQURFRbXaVpfPdGq8rW2rq6vJzslhyNChREVFdY5T47p81qa2nf3yWXV1dbPvLH1HuNFWl8/sbU/+zFVXV/Pjzp0M6t+/+e/Cn7SFtv/cb9++HYBhw4Y5bdteXfLyGSZTkx/Q1rS1XUNbU1gYwRERp31d4y+p0x63E7Rt/EvAo21DQ6GN14r9rm1ICIS07UestbbBNpvjyxnsXxDBJ7/8TqdTtA0KavPPkUttXfg5dqUtuP5z75W2HfBzH2yztfqdpe8IL7f10HfET3Wmn/u29HlXfu69TZfPRERERFAoEhEREQEUikREREQAhSIRERERQKFIREREBFAoEhEREQEUikREREQAhSIRERERQKFIREREBFAoEhEREQEUikREREQAhSIRERERAEyG0coSyAFo8+bNGIZBmAsLEraVYRiYzWZCQ0MdqzaLtJf6lXiL+pZ4g7f6VX19PSaTibPOOstjx/ypti25G0C8+YNvMpm8Eraka1O/Em9R3xJv8Fa/MplMXg/vXe5MkYiIiEhLNKZIREREBIUiEREREUChSERERARQKBIREREBFIpEREREAIUiEREREUChSERERARQKBIREREBFIpEREREAIUiEREREUChSERERARQKBIREREBFIpEREREAAjxdQGBYM2aNSxevJhDhw4RHR2NYRhMmDCBGTNmEBMT4+vyxAOsVivvv/8+y5cvp6qqipKSEtLT07nyyiu54YYbiI6Odvra9vQPd1/ri/cUz3nppZfYsmULb7zxhtM26ldyOsXFxSxevJjVq1cD9u+xM888kwceeIC0tLQWX9Pl+5Uh7fK3v/3NyMrKMv785z8bZrPZMAzDyMnJMcaPH29MnjzZKCoq8nGF0l7V1dXGzTffbDz99NNGdXW1YRiGUVtba7z44otGVlaWcdlllxk7d+5s8bXt6R/uvtYX7ymes3v3bmPo0KHGL3/5S6dt1K/kdH744QfjggsuMO6++27j6NGjhmEYhs1mM5YvX25cccUVju+yxtSvDEOhqB127dplDBkyxJg2bVqzfV9//bWRlZVlzJgxwweViSc9+OCDxlNPPdXivqefftrIysoyLrzwQiM/P7/Jvvb0D3df64v3FM+xWq3G9ddfb2RlZTkNRepXcjoHDx40zj33XOOuu+4ybDab43mLxWLMnz/fGDZsmLFixYomr1G/stOYonZ48sknsVgsTJ8+vdm+sWPHkpmZybp161i/fr0PqhNPyM3N5fPPP+eee+5pcf+dd95JaGgohYWFvP766032tad/uPtaX7yneM6SJUsoKipqtY36lbTGarUye/ZsDMPgv/7rvzCZTI59P/74Ix988AF1dXUcO3asyevUr+wUitxUUFDAhg0bABg3blyz/SaTibFjxwLw0UcfdWht4jnr16+nsrKSSZMmsWXLlmb74+PjGTZsGAArVqxwPN+e/uHua33xnuI5eXl5LF26lFmzZjlto34lp7NixQr27NnDlVdeSXJycpN9WVlZjBo1ivT0dC677DLH8+pXp2igtZtWr16NYRikpaWRlJTUYpvBgwcDsHbt2o4sTTyoqqoKwzAoLCzk448/ZtSoUc3adO/eHYDS0lLKy8uJi4trV/9w97W+eE/xnMcee4yHH3642b/gG1O/ktN57bXXAJgwYUKzfeHh4fz9739v9rz61Sk6U+Smffv2AZCamuq0TcO+wsLC054Sl87pqquuYsCAAaSmpjJlypQW29TV1Tm2DcMA2tc/3H2tL95TPOPDDz8kLS2N888/v9V26lfSmgMHDpCTkwNAv3792vw69atTFIrcdPDgQcB++cSZhIQEx3ZhYaG3SxIvSE9PZ+XKlaxZs4YRI0a02CY7Oxuw/xA29If29A93X+uL95T2O3HiBG+88QYPPvjgaduqX0lrGp8V6datGxs3buSmm27i6quv5rLLLuPxxx/n+PHjzV6nfnWKQpGbiouLAYiIiHDaJjw83LFdVlbm9Zqk4+3atYvDhw8DNDmT1J7+4e5rffGe0n4LFixgzpw5rX7BN1C/ktY0nEEB2Lp1K8uWLWPRokWsWLGC999/nz179nDVVVexbdu2Jq9TvzpFochN1dXVAISGhjpt03hfRUWF12uSjtdw/T4xMZHbbrvN8Xx7+oe7r/XFe0r7rF69GrPZzBVXXNGm9upX0prGl4nefvttHn30USIjIwFISkri2Wefpbq6mrvuuouSkhJHW/WrUxSK3GQ2mwGa3O74UzabzbHd8JcogWPdunWsWrWKkJAQnnvuuSana9vTP9x9rS/eU9xXWVnJ888/z6OPPtrm16hfSWuqqqoc2yNGjCAsLKzJ/h49ejBy5EiKioqaTCGifnWKQpGbGp+ac8ZisTi2o6KivFmOdLCysjIeeughgoKCePrpp7noooua7G9P/3D3tb54T3Hfn/70J2666aZWB4v+lPqVtKbx533eeee12KZv374ALF++vMXXOdNV+pVCkZtiY2NP26a2ttax3draWOJfrFYr999/P8XFxTz//PNcffXVzdq0p3+4+1pfvKe4Z+PGjRw4cIAbbrjBpdepX0lrGp+t7tWrV4ttGsauFRYWOsZDql+dolDkpoyMDADq6+udtikvL3dsp6ene70m6RgLFixg8+bNvPrqq0yaNKnFNu3pH+6+1hfvKa6rr6/nD3/4A0888YTLr1W/ktY0/vycnR1pPNamYQyS+tUpmrzRTQMGDADsE/Y503AbYEhICJmZmR1RlnjZ3/72N1asWMGbb77ZbCLHvLw80tPTCQkJaVf/cPe1vnhPcd3OnTspKSlhzpw5Le5v+EW1Y8cOrrnmGgDGjx/Pvffeq34lrRoyZIhju76+vtmYIjg1lxpAXFwc4Ju/487arxSK3NTwC3H//v1O2+zZsweAoUOHtjpKXvzDZ599xiuvvMIbb7zR4pxFs2fP5v333wfa1z/cfa0v3lNcN2rUKFavXu10//z58/nwww8588wzeeutt5q9FtSvpGWjR48mKCgIm81GSUkJaWlpzdo0XFYKCwtznHFRvzpFl8/cNHr0aBISEiguLnbMIPpTmzZtAmDixIkdWZp4wbZt23j88cd5/fXXWwxE9fX1mM1mx7/M2tM/3H2tL95TOpb6lbQmJSWFs88+G3AeGPLz8wG45JJLHPP8qF+dolDkptDQUMdkfY1H8TfIyclh586dxMXFMXXq1A6uTjwpLy+Pe+65hwceeICYmBhycnKa/ffhhx82OUXbnv7h7mt98Z7SsdSv5HRuvfVWgBbPRlqtVjZu3EhwcDC3336743n1q0YMcVtJSYlx/vnnGyNHjjTy8vKa7Js7d66RlZVl/POf//RRdeIJZWVlxuTJk42srKzT/vf00083eW17+oe7r/XFe4rnVFZWGtddd52RlZVlXHzxxUZRUVGzNupXcjr33XefMWLECOPQoUNNnn/nnXeMrKws4y9/+Uuz16hf2ZkMo9GoK3HZgQMHmDt3LhUVFcycOZP4+HhWrVrFunXruPfee5k1a5avS5R2ePXVV3nhhRfa1HbBggXNbrFuT/9w97W+eE9pny+++IJnnnmGo0ePOiamAwgKCqJ79+5MmTKF++67z/G8+pW0pr6+nkcffZS1a9dy8803k56ezubNm/nXv/7FnDlzmD59eouvU78ChSIP2bhxI9nZ2VRWVpKWlsZFF11ESkqKr8uSTqI9/cPd1/riPaVjqV9Ja/bt28eWLVsoKyujV69eXHjhhW2as6cr9yuFIhERERE00FpEREQEUCgSERERARSKRERERACFIhERERFAoUhEREQEUCgSERERARSKRERERACFIhERERFAoUhEREQEUCgSERERARSKRERERACFIhERERFAoUhEREQEgP8P2Bg0jdtO6V0AAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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u8rPo3PnzndMoJzpTv+OarUa8+bNw759+xASEoJvv/0WMTExTorOlCX/bjqdTiyrVCpHhENkEz4+I3Kg69evi+Xqr9NLofr98/LyJIykij0/n/z8fOzZswcxMTFQqVSYM2cO1Gp1jfUr71dfPou6+uyzz7Bv3z7IZDJ88skndk+I3nvvPYsmaGzWrJlYvlOCVH0aitoSViKpMCkicqA///xTLA8ePNji8wsKCuwWy7333iuWL1y4UGtdjUZjNEeSo9j6+VTS6/WYP38+nnzySXz++edo2bIlTp8+jWXLltV4TuXnkZaWdscZs1UqlUMHWlti+/btAIAuXbqgd+/eJscrKipM9m3YsAE//fRTna5/9uxZi95au/vuu8V5jlJTU2utW5kEu7m5oU+fPnW+B5GzMCkiskFtPRFlZWXYuXMnAMMXsLkJACtndK7+WKG66hP72apt27biINy9e/fWWnfTpk3YuHGjzfe09fOpqw8//BDh4eF47LHH4OvrixUrVsDd3R2bN28W73G7xx57DN7e3tDr9fj5559rvf60adNw48YNq+Ozp8penObNm5s9bm4Ac1FRkdHj0+qP6G5fFLakpMRkCoXahIeHi2/M/f7777XWPXDgAABg9OjRNcZPJCUmRUQ2+OWXXxAfH2/22Icffojs7GyEh4fjnXfeMVunckBs9ccKlQoLC42+rO3Rc/POO+8gPDwccXFx4hfU7TIyMrBp0yb87W9/s/l+tn4+dfHdd9/hwIEDWLx4sbivc+fOWLhwIQBg8eLFSExMNDmvWbNm4qvha9asqfHRz7fffovWrVubzHMklcrlMhISEkySTkEQ8Omnn8LHxwcAxJnFNRqNUaITEhIiDuiuPgC/pKQEJSUlCAoKsiim1157DVFRUTh+/HiNifz58+eRkJCA1q1b44033rDo+kTOwqSIyAY9e/bE66+/jv/+97/iF1Rubi7eeOMNfPPNN+jRowc2b95c48R3c+fOhVKpxNatW40ePSQlJWHhwoV4/vnnxX0vv/wyPvnkE8TFxYn71Go1Ll68CABISUm547w0QUFB2Lx5M7p27Yp//vOf+P7778WeAq1Wi19++QUzZszA0qVLERoaat2HUo0tn09aWprYK2IuqUlMTMTLL7+MxYsXIywszGTCwEceeQR+fn4oKyvDjBkzcPr0aZNrjB07Fh9//DHy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Jk2y6Dy2K6pN9d7qli1bmq1TOXYtOztbHA/JdlWFSZGVIiIiAABqtbrGOoWFhWI5PDzc4TGRcyxZsgQnT57E2rVrMWrUKLN1bGkf1p4rxT3Jcmq1Gu+88w7efvtti89lu6LaVP/8auodqT7WpnIMEttVFU7eaKV27doBMEzYV5PK1wAVCgUiIyOdERY52FdffYXdu3fjyy+/NJnIMT09HeHh4VAoFDa1D2vPleKeZLmEhATk5eVh9uzZZo9XflGdO3cODz30EABg6NChmDt3LtsV1apTp05iWa1Wm4wpAqrmUgMAf39/ANL8G9fXdsWkyEqVX4jJyck11rl06RIAoHPnzrWOkifXsG/fPqxZswbr1683O2fRzJkzsWXLFgC2tQ9rz5XinmS5nj174uDBgzUeX7RoEbZv344uXbrgm2++MTkXYLsi82JiYiCXy6HX65GXl4ewsDCTOpWPldzd3cUeF7arKnx8ZqWYmBgEBgZCpVKJM4je7sSJEwCAESNGODM0coAzZ87grbfewrp168wmRGq1GhqNRvzLzJb2Ye25UtyTnIvtimoTEhKCu+++G0DNCUNmZiYA4N577xXn+WG7qsKkyEpKpVKcrK/6KP5KSUlJSEhIgL+/P8aPH+/k6Mie0tPTMWvWLMyfPx++vr5ISkoy+d/27duNumhtaR/WnivFPcm52K7oTv7xj38AgNneSJ1Oh7i4OLi5ueHZZ58V97NdVSOQ1fLy8oR+/foJPXr0ENLT042OzZkzR4iOjhZ++OEHiaIjeygoKBAeeOABITo6+o7/W758udG5trQPa8+V4p5kP8XFxcLEiROF6OhoYciQIUJOTo5JHbYrupMXX3xR6N69u3Dt2jWj/Zs2bRKio6OF//u//zM5h+3KQCYI1UZdkcWuXr2KOXPmoKioCNOmTUNAQAD27t2L2NhYzJ07F88884zUIZIN1q5di48//rhOdZcsWWLyirUt7cPac6W4J9nm119/xbvvvovr16+LE9MBgFwuR7NmzTBu3Di8+OKL4n62K6qNWq3GG2+8gaNHj+Kpp55CeHg4Tp48iZ9//hmzZ8/GlClTzJ7HdgUwKbKTuLg4JCYmori4GGFhYRg4cCBCQkKkDovqCVvah7XnSnFPci62K6rNlStXEB8fj4KCArRs2RIDBgyo05w9jbldMSkiIiIiAgdaExEREQFgUkREREQEgEkREREREQAmRUREREQAmBQRERERAWBSRERERASASRERERERACZFRERERACYFBEREREBYFJEREREBIBJEREREREAJkVEREREAJgUEREREQEA/h/C6EKEkhFXBQAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0434) tensor(0.4464)\n",
      "tensor(0.0510) tensor(0.3865)\n"
     ]
    }
   ],
   "execution_count": 15
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:31.528880Z",
     "start_time": "2025-09-18T23:37:31.504965Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def colorize(image, label, target_pixel):\n",
    "    (min_y, min_x, max_y, max_x) = get_max_bounding_box(image.squeeze())\n",
    "    actual_data = image[:, min_y:max_y+1, min_x:max_x+1]\n",
    "    scale = torch.sqrt(target_pixel / (actual_data > bias).sum()).item()\n",
    "    new_height = min(img_size, round(scale * actual_data.shape[1]))\n",
    "    new_width = min(img_size, round(scale * actual_data.shape[2]))\n",
    "    scaled_img = torch.permute(actual_data, [1, 2, 0])\n",
    "    scaled_img = cv2.resize(src=scaled_img.numpy(), dsize=(new_width, new_height))\n",
    "    scaled_img = torch.asarray(scaled_img).unsqueeze(dim=0)\n",
    "    x_offset = max(0, (img_size - new_width) // 2)\n",
    "    y_offset = max(0, (img_size - new_height) // 2)\n",
    "    background = torch.ones(3, img_size, img_size)\n",
    "    result = torch.zeros(3, img_size, img_size)\n",
    "    background = background * colors[label].unsqueeze(dim=-1).unsqueeze(dim=-1) / 255\n",
    "    result[:, y_offset:y_offset + scaled_img.shape[1], x_offset:x_offset + scaled_img.shape[2]] = scaled_img\n",
    "    # result = result * (result > bias).float() + background * (result <= bias).float()\n",
    "    result = (1 - result) * result.float() + background * (1 - result)\n",
    "    return 1 - result"
   ],
   "id": "7c35ea5bd1f21730",
   "outputs": [],
   "execution_count": 16
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:37:31.627256Z",
     "start_time": "2025-09-18T23:37:31.543456Z"
    }
   },
   "cell_type": "code",
   "source": [
    "correct_label = [[round(len(imgs[t][i]) * background_predictability) for i in range(10)] for t in range(2)]\n",
    "uncorrect_label = [[len(imgs[t][i]) - correct_label[t][i] for i in range(10)] for t in range(2)]\n",
    "print(correct_label)\n",
    "print(uncorrect_label)\n",
    "for r in ratios:\n",
    "    target_pixel = round(0.2 * total_pixel)\n",
    "    converted_img = colorize(imgs[0][5][0], 2, target_pixel)\n",
    "    plt.imshow(to_pil_image(converted_img))\n",
    "    plt.show()\n",
    "    break"
   ],
   "id": "c7f928e58fb83fa7",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[4146, 4719, 4171, 4292, 4089, 3795, 4143, 4386, 4096, 4164], [686, 794, 722, 707, 687, 624, 671, 720, 682, 706]]\n",
      "[[1777, 2023, 1787, 1839, 1753, 1626, 1775, 1879, 1755, 1785], [294, 341, 310, 303, 295, 268, 287, 308, 292, 303]]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    }
   ],
   "execution_count": 17
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:45:19.530596Z",
     "start_time": "2025-09-18T23:37:31.641170Z"
    }
   },
   "cell_type": "code",
   "source": [
    "correct_label = [[round(len(imgs[t][i]) * background_predictability) for i in range(10)] for t in range(2)]\n",
    "uncorrect_label = [[len(imgs[t][i]) - correct_label[t][i] for i in range(10)] for t in range(2)]\n",
    "print(correct_label)\n",
    "print(uncorrect_label)\n",
    "for r in ratios:\n",
    "    target_pixel = round(r * total_pixel)\n",
    "    output_dir = f'/home/dataset/cmnist/{r}'\n",
    "    counts = [[0 for j in range(10)] for i in range(2)]\n",
    "    for t in range(2):\n",
    "        set_seed(0)\n",
    "        for label in range(10):\n",
    "            indexes = torch.randperm(len(imgs[t][label]))\n",
    "            correct_indexes = indexes[:correct_label[t][label]]\n",
    "            uncorrect_indexes = indexes[correct_label[t][label]:]\n",
    "            if t == 0:\n",
    "                output_path = os.path.join(output_dir, f\"train/{label}\")\n",
    "                os.makedirs(f\"{output_dir}/train/{label}\", exist_ok=True)\n",
    "            else:\n",
    "                output_path = os.path.join(output_dir, f\"test/{label}\")\n",
    "                os.makedirs(f\"{output_dir}/test/{label}\", exist_ok=True)\n",
    "\n",
    "            lists = [i for i in range(10)]\n",
    "            lists.remove(label)\n",
    "\n",
    "            for index in tqdm(correct_indexes):\n",
    "                op = os.path.join(output_path, f\"{counts[t][label]}.png\")\n",
    "                converted_img = colorize(imgs[t][label][index], label, target_pixel)\n",
    "                to_pil_image(converted_img).save(op)\n",
    "                counts[t][label] += 1\n",
    "            for index in tqdm(uncorrect_indexes):\n",
    "                op = os.path.join(output_path, f\"{counts[t][label]}.png\")\n",
    "                converted_img = colorize(imgs[t][label][index], lists[random.randint(0, len(lists) - 2)], target_pixel)\n",
    "                to_pil_image(converted_img).save(op)\n",
    "                counts[t][label] += 1\n",
    "    print(counts)"
   ],
   "id": "71abaa392068d41f",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[4146, 4719, 4171, 4292, 4089, 3795, 4143, 4386, 4096, 4164], [686, 794, 722, 707, 687, 624, 671, 720, 682, 706]]\n",
      "[[1777, 2023, 1787, 1839, 1753, 1626, 1775, 1879, 1755, 1785], [294, 341, 310, 303, 295, 268, 287, 308, 292, 303]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4146/4146 [00:27<00:00, 150.74it/s]\n",
      "100%|██████████| 1777/1777 [00:11<00:00, 148.88it/s]\n",
      "100%|██████████| 4719/4719 [00:31<00:00, 149.90it/s]\n",
      "100%|██████████| 2023/2023 [00:13<00:00, 148.84it/s]\n",
      "100%|██████████| 4171/4171 [00:28<00:00, 148.72it/s]\n",
      "100%|██████████| 1787/1787 [00:11<00:00, 148.97it/s]\n",
      "100%|██████████| 4292/4292 [00:28<00:00, 149.66it/s]\n",
      "100%|██████████| 1839/1839 [00:12<00:00, 148.76it/s]\n",
      "100%|██████████| 4089/4089 [00:27<00:00, 149.68it/s]\n",
      "100%|██████████| 1753/1753 [00:11<00:00, 152.03it/s]\n",
      "100%|██████████| 3795/3795 [00:24<00:00, 153.16it/s]\n",
      "100%|██████████| 1626/1626 [00:10<00:00, 150.19it/s]\n",
      "100%|██████████| 4143/4143 [00:27<00:00, 149.55it/s]\n",
      "100%|██████████| 1775/1775 [00:11<00:00, 150.06it/s]\n",
      "100%|██████████| 4386/4386 [00:29<00:00, 148.68it/s]\n",
      "100%|██████████| 1879/1879 [00:12<00:00, 148.53it/s]\n",
      "100%|██████████| 4096/4096 [00:27<00:00, 146.93it/s]\n",
      "100%|██████████| 1755/1755 [00:11<00:00, 148.30it/s]\n",
      "100%|██████████| 4164/4164 [00:27<00:00, 149.42it/s]\n",
      "100%|██████████| 1785/1785 [00:11<00:00, 149.56it/s]\n",
      "100%|██████████| 686/686 [00:04<00:00, 148.13it/s]\n",
      "100%|██████████| 294/294 [00:01<00:00, 148.42it/s]\n",
      "100%|██████████| 794/794 [00:05<00:00, 149.35it/s]\n",
      "100%|██████████| 341/341 [00:02<00:00, 148.45it/s]\n",
      "100%|██████████| 722/722 [00:04<00:00, 148.80it/s]\n",
      "100%|██████████| 310/310 [00:02<00:00, 148.83it/s]\n",
      "100%|██████████| 707/707 [00:04<00:00, 149.42it/s]\n",
      "100%|██████████| 303/303 [00:02<00:00, 148.51it/s]\n",
      "100%|██████████| 687/687 [00:04<00:00, 152.54it/s]\n",
      "100%|██████████| 295/295 [00:01<00:00, 153.14it/s]\n",
      "100%|██████████| 624/624 [00:04<00:00, 155.54it/s]\n",
      "100%|██████████| 268/268 [00:01<00:00, 154.04it/s]\n",
      "100%|██████████| 671/671 [00:04<00:00, 149.24it/s]\n",
      "100%|██████████| 287/287 [00:01<00:00, 150.69it/s]\n",
      "100%|██████████| 720/720 [00:04<00:00, 153.82it/s]\n",
      "100%|██████████| 308/308 [00:02<00:00, 151.84it/s]\n",
      "100%|██████████| 682/682 [00:04<00:00, 150.77it/s]\n",
      "100%|██████████| 292/292 [00:01<00:00, 154.96it/s]\n",
      "100%|██████████| 706/706 [00:04<00:00, 150.09it/s]\n",
      "100%|██████████| 303/303 [00:02<00:00, 150.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[5923, 6742, 5958, 6131, 5842, 5421, 5918, 6265, 5851, 5949], [980, 1135, 1032, 1010, 982, 892, 958, 1028, 974, 1009]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "execution_count": 18
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-18T23:45:19.633740Z",
     "start_time": "2025-09-18T23:45:19.628450Z"
    }
   },
   "cell_type": "code",
   "source": "",
   "id": "a8d24c4752bb1bf3",
   "outputs": [],
   "execution_count": null
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
