{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-05-14T11:25:39.665786Z",
     "start_time": "2025-05-14T11:25:37.118383Z"
    }
   },
   "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"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "execution_count": 182
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": [
    "def set_seed(val):\n",
    "    torch.manual_seed(val)\n",
    "    torch.cuda.manual_seed(val)\n",
    "    torch.cuda.manual_seed_all(val) # for multi gpu\n",
    "    np.random.seed(val)\n",
    "    random.seed(val)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "set_seed(0)"
   ],
   "id": "49fd96a807f21b17"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-14T11:33:24.694015Z",
     "start_time": "2025-05-14T11:33:24.640956Z"
    }
   },
   "cell_type": "code",
   "source": [
    "ratios = [0.05, 0.10, 0.15]\n",
    "mnist_dir = '/home/dataset/mnist'\n",
    "background_predictability = 0.70\n",
    "img_size = 48\n",
    "min_mask_ratio = 0.10\n",
    "colors = torch.tensor([\n",
    "    [255, 0, 0],\n",
    "    [0, 255, 0],\n",
    "    [0, 0, 255],\n",
    "    [255, 255, 0],\n",
    "    [255, 0, 255],\n",
    "    [0, 255, 255],\n",
    "    [0, 123, 123],\n",
    "    [123, 0, 123],\n",
    "    [123, 123, 0],\n",
    "    [123, 0, 0]\n",
    "], dtype=torch.float32)"
   ],
   "id": "ed92ea73351ec3ec",
   "outputs": [],
   "execution_count": 204
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-14T11:33:25.158173Z",
     "start_time": "2025-05-14T11:33:25.101601Z"
    }
   },
   "cell_type": "code",
   "source": [
    "bias = 0.2\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": 205
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-14T11:35:24.048247Z",
     "start_time": "2025-05-14T11:35:16.522660Z"
    }
   },
   "cell_type": "code",
   "source": [
    "mnist_train = torchvision.datasets.MNIST(root=mnist_dir, train=True, download=True, transform=Transform.Compose([Transform.ToTensor()]))\n",
    "mnist_test = torchvision.datasets.MNIST(root=mnist_dir, train=False, download=True, transform=Transform.Compose([Transform.ToTensor()]))\n",
    "\n",
    "total_pixel = img_size * img_size\n",
    "mask_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",
    "        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": "stdout",
     "output_type": "stream",
     "text": [
      "마스크 비율 계산 중...\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0it [00:00, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "6760404084774c4fb9d4df0a5dd86d6b"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "0it [00:00, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "bcc25a06e47242ac9eeeae2f889c4550"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0\n"
     ]
    }
   ],
   "execution_count": 209
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-14T11:32:46.163872Z",
     "start_time": "2025-05-14T11:32:43.538319Z"
    }
   },
   "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.show()"
   ],
   "id": "7db99e6a5c5d6533",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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+fLl4rzzzhNffvmlKC4uFvfee6+YOXOmaG1tldosXLhQXH311WLPnj3ixx9/FJdccol45JFHpOeNRqOYNm2aWLRokTh69Kj49NNPRW5urli7dq3UZteuXWLcuHHitddeEyUlJeIf//iHyM7OFkeOHOn/TnDTnXfeKdatWyeOHj0qiouLxV133SUuuugiYTabpTZPPPGEKCoqElu2bBH79+8X8+fPFzfccIP0vM1mE1dddZW44447xKFDh8SmTZvE5MmTxQsvvCC1KS8vF3l5eWLp0qWipKRErF69WowbN05s3rxZauPrn82vv/5abNq0SZSVlYnS0lLx4osviuzsbHH06FEhBPupJ3v37hUzZswQs2fPFk899ZS0n/3ltGzZMnHllVeK2tpa6T+DwSA9z37q1NDQIGbMmCEee+wxsXfvXlFeXi6+//57cfLkSamNv32/B20Yuf7668WSJUukx3a7XRQWForly5fLWFX/+XkYcTgc4oILLhArVqyQ9jU1NYmcnBzx6aefCiGEKCkpERkZGWLfvn1Sm++++05kZmaK06dPCyGEWLNmjZg0aZJoa2uT2vz9738Xl112mfT4N7/5jbj77rtd6pk3b554/PHHvftDepHBYBAZGRlix44dQghn32RnZ4vPPvtMatPRP7t37xZCOMPf2LFjhU6nk9q8/fbbYsKECVL/PPfcc+LKK690ea+HH35Y3HnnndJjf/xsTpo0Sbz33nvspx6YTCZx6aWXih9++EHceuutUhhhf3VatmyZuPrqq7t9jv3k6u9//7u46aabenzeH7/fg3KYxmKx4ODBg5g2bZq0T6lUYtq0adi9e7eMlQ2cyspK6HQ6lz6Ijo5GXl6e1Ae7d+9GTEwMxo8fL7WZNm0alEqldNpyz549mDhxItRqtdSmsLAQZWVlaGxslNpMnTrV5f0LCwuxZ8+e/vrxzpnRaAQAxMbGAgAOHDgAq9Xq0l+jRo3CoEGDpJ9jz549yMjIQGJiotSmsLAQJpMJJSUlUpve+sLfPpt2ux0bNmxAc3MzCgoK2E89ePLJJ1FUVORSL8DP1c+dPHkShYWFmDVrFhYtWoSqqioA7Kef++abb5CTk4OHHnoIU6dOxbXXXov33ntPet4fv99DPGodIOrr62G326HVal32a7XaLvMEApVOpwOAbvugYxxWr9cjISHB5fmQkBDE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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 203
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-14T11:33:29.799678Z",
     "start_time": "2025-05-14T11:33:29.740348Z"
    }
   },
   "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 != 0).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",
    "    actual_data = torch.permute(actual_data, [2, 1, 0]) # width height channel\n",
    "    out = cv2.resize(src=actual_data.numpy(), dsize=(new_width, new_height))\n",
    "    out = torch.permute(torch.asarray(out), [1, 0]) # channel height width\n",
    "    out = out.unsqueeze(dim=0)\n",
    "    x_offset = max(0, (img_size - new_height) // 2)\n",
    "    y_offset = max(0, (img_size - new_width) // 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 + out.shape[1], x_offset:x_offset + out.shape[2]] = out\n",
    "    result = result * (result > 0.1).float() + background * (result <= 0.1).float()\n",
    "    return result"
   ],
   "id": "7c35ea5bd1f21730",
   "outputs": [],
   "execution_count": 206
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-14T11:55:50.309021Z",
     "start_time": "2025-05-14T11:35:26.610222Z"
    }
   },
   "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",
    "        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"
     ]
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4146 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "650c4b88dac04f2cbb70e3b13797c8e6"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1777 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "ce9437988d414b0c91698b08f187f099"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4719 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "f65a75aba75742eeb3b39cff24754b6a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/2023 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "7c9e67fe459d4e43a0c05a060c45339c"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4171 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "bd5842470c67453cae188895a1baa23b"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1787 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "e48ad08923e849e9ab0e80a82e928538"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4292 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "7423db62977048a58d4d6333161d362f"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1839 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "9a19d3c3a5c04fb18c371db0bfc53c04"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4089 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "5f676425213c40049fec7c43bc1ca1cd"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1753 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "886e3281de7943cb91b7a127f74b7703"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/3795 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "0940a934760f4eb6be60028c27087bd2"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1626 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "7dbc2d07e799440cb51b6bd7b9e77eca"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4143 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "ef79faac71bc49c8bfa3f83e430fef9b"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1775 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "62a0a03613a64e9c8389e1c6770a0277"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4386 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "83b40489dd914630b0a1c6a978c1c9a9"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1879 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "802fd68769284a2d90d24f63838e97f3"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4096 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "a2ac1678e6d74d0e8efb917d94bf7113"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1755 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "914903b40907427a99b80528c19a1e06"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4164 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "301cbf722cdb4d6b856b8475b48af883"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1785 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "d3bb704cbe6c4d25bc377af4c4c6ba79"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/686 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "8af9554ec8684cb6b310d1875cf1102c"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/294 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "ca84eca9c7644217aa31a06b6d906aa5"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/794 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "e27905c280d149d1b237dbdf95b00424"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/341 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "33249503fec54ab6a9d3fb773cbd0762"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/722 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "c05fee5b548a49fa8591969aaa20dfbe"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/310 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "8737ce3f26e64bdcadf7b73871fb08aa"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/707 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "45791df6ea5d4b389c6a0669b802be55"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/303 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "c7172f5290824f4581ca6acdd36c6d49"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/687 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "fc70a3e58ee7411eaad3fe2a34fb4ca6"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/295 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "28572ea04c854663bae0d209a5d7b5e6"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/624 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "c149ecfda9cf4672a66dd17a02cf819e"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/268 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "7a1c9f14de084088914d05e12f08c7fb"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/671 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b734a5ce01174f6fbd7cd4b24ad7d515"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/287 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "dc59463ad1164f03b95fe5bb1c36859f"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/720 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "588da267f21f4573b3aa16b327e93809"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/308 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "89128ce91edb493f9dec7f789b443c51"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/682 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "72289f9a44764d28be9547878330416b"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/292 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "f40cf84f4cff4aca90887a08a0284ae6"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/706 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "2edcf75b6e6d40a9a0e1ec4a7d19dd16"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/303 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "132c437734724566bc7803e13535d196"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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"
     ]
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4146 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b767a52dee6c46a8854708079535dd21"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1777 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "1749050b362a4ba58a499e0b2d463696"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4719 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "91016cb841aa4e39b54e31877e65f23a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/2023 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "eb766af91f8d4caabf745afadf77f030"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4171 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "230bd7ff75fa4d27bd47e47ca617e58c"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1787 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "5f23ade2e4f143c48804d0e16d86a232"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4292 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "3c4b39c1db2f4af9b81b73b9b91c0868"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1839 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "d1ad366a4efc4d039b7c8ec16b8bf41e"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4089 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "afd6dbb2d07943fbbfe545bd9133d3d2"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1753 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "07e2b0ba8ecd428ba255c17730b17464"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/3795 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "d3954f9d897e43d69ac41ed64e614f7f"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1626 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "a2cfd6836a134961956c45aff8484a89"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4143 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "6e357ff7241c4299b629f11ee9927d3d"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1775 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b851b8f0d3e9495e8507dfc3f158c421"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4386 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b3479e6d45804e8c93712398b3a65f3a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1879 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "f1c28c31cef14df98b6c36032e9038f0"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4096 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "6ecb8e3b1aed48129e0499590f0b22a3"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1755 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "1050439cac844a4ebac12b4f22c1eefa"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4164 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "cbf2e75645e143369af7d8ecd322b6f1"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1785 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "31cfefbb62df471cab9fe9b4f3ebc0ea"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/686 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "30d810697f9047818b324a2582b566cc"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/294 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b61351d29e64423fa6bdcd3fc81760e1"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/794 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "9c12a6e6d15a4b16972b40111bd2b1e8"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/341 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "85a22211017543e7914b79fc5695dcb0"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/722 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "aa1f057374964a91845830a5c5a1e03f"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/310 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "82aba5bf6c214ca486caf26d91e44cff"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/707 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "0129b69b6d554e59b3b5ef60a4b53661"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/303 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b3ddcad3a7824542adabd10bc070aa18"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/687 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "28d2a3453d9b407bb10d036b6e66917f"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/295 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "386c34d5ced8489ead4ec55bcad5d5af"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/624 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "46000c41d31d47ce8feb784a00a9ec56"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/268 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "923de584b57343c18d8e54e813bb1ace"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/671 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "16040116e2104ac19ade8e53a003ec40"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/287 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "1eb1e4640d3b4e5a80f491c641893a27"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/720 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "8fa6ac5201d249e1bf20eb26a7b4ae35"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/308 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "706a8e3d9c564aa7af5b23d99e60be08"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/682 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "de8e8b59e150400d8f66c3a9ab4a789b"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/292 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "e908d760c362478599634a8e32c48e21"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/706 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b406ed2591ab4685ad59f2e2aa0f3bc2"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/303 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "90164dd25b1146b2acccc8faf96733f6"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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"
     ]
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4146 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "93c391b696b24d5a919f7d84364581e9"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1777 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "c3e92fbb64e54e13af842ca799677613"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4719 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "154d4bd7d8064fb69fb54e6442e37e98"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/2023 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "ac087b1246fc4910af3814c0c2f6a794"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4171 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "1ae01cff97eb4c659fd4214e07459d37"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1787 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "47892f5d93584f2ba3c684776aab0644"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4292 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "ea3c8baf2e424d00bb2c989daa4572df"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1839 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "a4b51d9f6d8143888e4ecdc1718b5172"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4089 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "7c9e6632aec4498ab8cee7b6d903509a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1753 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "dcfaece4648e4704a4cc3ff3b5e9d19e"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/3795 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "19224a3de2314da28ae926b3a31fbbe3"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1626 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "5b47137a291e42b0b5b69b75aeec7239"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4143 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "240b452463ac4a149aaba09e5f5f691e"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1775 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "3626f14e303142708e2b5e6cd922f17a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4386 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "edfa50520d5a4e7ea8f6c1207ef53c22"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1879 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "43b3af42c5974e9aae8ebab2b186d796"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4096 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "861744f9c06c47848849920aefd0be97"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1755 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "a59314452bdd48c0ad30bc58b845c674"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/4164 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "be32cafcb72e4c36af7257eff1728382"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/1785 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "b739ec94e4f44d56b6c1c2dfe0ee8978"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/686 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "9543de7fe3074a8587ba72e8865a6c03"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/294 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "229ed07393094504b8133e40ffd87c1a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/794 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "1d1f7513295b48c3bab4f5f91a82ed5e"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/341 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "9dcf036d3a784d81a31f12983866fa89"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/722 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "703d40ef851a4211aaf44f541475c651"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/310 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "0bb6303fe1ef4eb2a9d5f31fd800f191"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/707 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "18ca4281899842d0ba4c0b315338715f"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/303 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "dbe532b95a684dfaab2461697f3ea3ad"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/687 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "0ce1a2ee224749f79ba3e276ee656a9a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/295 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "8268834505aa488db31ff68e836c091d"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/624 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "7a40c01e811342e89965e23f07e46237"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/268 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "48258ea5b1b24af2b904c1929b8db2be"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/671 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "e6cc53e37dfa488abc5cac724bae72d4"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/287 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "83a3f9bbe38d4350889651eda6c86c22"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/720 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "c9648d5adef349e7950845c6c33be01a"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/308 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "efc7b48a53154bd8945f370e84d16f43"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/682 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "406c422de22d4b16b3ae4395bbdff8ae"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/292 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "f2ce4579d2e444a9a499c5a0a04023da"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/706 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "5793ac3b442942e1960c6d3a0c64ea10"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "  0%|          | 0/303 [00:00<?, ?it/s]"
      ],
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "af94957d5ac04367aa210a271cbb0d86"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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"
     ]
    }
   ],
   "execution_count": 210
  }
 ],
 "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
}
