{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c78646a5-1243-4cf2-9ff0-be144d5743b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import trange\n",
    "from tsp_rtdl_fast import plot_tour, two_opt_rtdl, two_opt, Logger, calculate_total_distance\n",
    "from tsp_rtdl_util import create_problem\n",
    "from one_tree import optimize_D_1tree"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c3d17b1a-02d5-4427-a9c0-3cf4f9b3f6d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "N_CITIES = 100\n",
    "TRIALS = 100\n",
    "MAX_ITER = 10**5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6e3894fa-fc61-4b72-a756-4a3dc3618fa2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:00<01:28,  1.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 357 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:02<01:43,  1.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 416 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [00:03<01:49,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:04<02:03,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 397 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [00:06<02:00,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 346 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [00:07<02:05,  1.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 439 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [00:08<01:53,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 394 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:09<01:41,  1.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [00:10<01:49,  1.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 421 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:11<01:42,  1.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 334 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:12<01:38,  1.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 375 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [00:13<01:35,  1.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 389 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [00:14<01:32,  1.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [00:15<01:31,  1.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 399 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [00:17<01:33,  1.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 393 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [00:18<01:34,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 414 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [00:19<01:42,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 425 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [00:20<01:35,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 382 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [00:22<01:39,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 412 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [00:23<01:33,  1.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 411 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [00:24<01:36,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 377 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [00:25<01:32,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 404 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [00:27<01:36,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 419 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [00:28<01:40,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 433 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [00:29<01:28,  1.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [00:30<01:30,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [00:31<01:29,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 410 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [00:32<01:23,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 390 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [00:33<01:16,  1.08s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [00:35<01:18,  1.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [00:36<01:22,  1.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 409 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [00:37<01:21,  1.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 407 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [00:38<01:17,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 374 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [00:39<01:10,  1.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 386 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [00:40<01:02,  1.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [00:41<01:09,  1.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 425 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [00:42<01:08,  1.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 403 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [00:43<01:05,  1.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 377 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [00:44<01:04,  1.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 389 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [00:45<01:04,  1.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [00:46<01:03,  1.08s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [00:48<01:06,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 408 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [00:49<01:09,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 442 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [00:50<01:01,  1.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 352 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [00:51<00:56,  1.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 411 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [00:52<01:03,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 384 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [00:53<01:00,  1.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 408 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [00:55<00:59,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 364 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [00:56<00:55,  1.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [00:57<00:58,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 424 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [00:58<00:55,  1.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 365 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [00:59<00:55,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 393 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [01:00<00:47,  1.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [01:01<00:44,  1.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 397 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [01:02<00:42,  1.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [01:02<00:38,  1.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 371 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [01:03<00:40,  1.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [01:04<00:35,  1.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 375 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [01:05<00:35,  1.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 372 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [01:06<00:43,  1.08s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [01:08<00:43,  1.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [01:08<00:37,  1.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [01:09<00:35,  1.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 404 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [01:10<00:34,  1.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [01:11<00:34,  1.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 338 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [01:12<00:34,  1.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 389 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [01:13<00:28,  1.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 354 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [01:14<00:29,  1.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 414 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [01:15<00:30,  1.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 395 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [01:16<00:29,  1.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [01:17<00:27,  1.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 371 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [01:18<00:26,  1.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 333 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [01:19<00:28,  1.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 382 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [01:21<00:30,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 447 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [01:22<00:30,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 376 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [01:23<00:27,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 386 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [01:25<00:29,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 403 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [01:26<00:28,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 419 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [01:27<00:28,  1.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 390 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [01:28<00:25,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [01:30<00:23,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [01:31<00:24,  1.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 401 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [01:32<00:21,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 333 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [01:34<00:20,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 444 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [01:35<00:19,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 380 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [01:36<00:15,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 351 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [01:37<00:14,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 390 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [01:38<00:12,  1.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 330 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [01:38<00:10,  1.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 354 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [01:39<00:09,  1.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [01:40<00:08,  1.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [01:42<00:10,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 459 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [01:44<00:08,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 403 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [01:44<00:06,  1.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [01:45<00:05,  1.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 410 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [01:47<00:04,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 409 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [01:48<00:03,  1.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 98/100 [01:49<00:02,  1.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [01:50<00:01,  1.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:51<00:00,  1.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 379 4850\n",
      "CPU times: user 1min 50s, sys: 1.26 s, total: 1min 51s\n",
      "Wall time: 1min 51s\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "logger_orig = Logger(MAX_ITER)\n",
    "data_orig = []\n",
    "\n",
    "for t in trange(TRIALS):\n",
    "\n",
    "    cities, distance_matrix = create_problem(t, N_CITIES)\n",
    "    initial_tour = list(range(cities.shape[0]))\n",
    "\n",
    "    logger_orig.problem_started()\n",
    "    optimized_tour, _ = two_opt(initial_tour, distance_matrix, max_iterations = MAX_ITER, logger = logger_orig)\n",
    "    optimized_distance = calculate_total_distance(optimized_tour, distance_matrix)\n",
    "    logger_orig.problem_solved()\n",
    "    \n",
    "    data_orig.append(optimized_distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c13a431e-377b-4b44-9345-6ddd575bfd1a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8.243598960015682, 0.03096911361093383)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(data_orig), np.std(data_orig) / np.sqrt(TRIALS-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "51d03c61-57dd-4486-ba52-f778c87bd401",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "111.35646224021912"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logger_orig.time_end - logger_orig.time_start"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a450dbc7-80b9-4507-b3a0-25248e5cad9a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 42\n",
      "1 best 38\n",
      "2 best 36\n",
      "3 best 34\n",
      "4 best 32\n",
      "7 best 28\n",
      "18 best 26\n",
      "21 best 24\n",
      "35 best 20\n",
      "64 best 18\n",
      "71 best 16\n",
      "87 best 14\n",
      "106 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:02<04:10,  2.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 315 4850\n",
      "0 best 34\n",
      "1 best 32\n",
      "4 best 26\n",
      "5 best 24\n",
      "13 best 22\n",
      "16 best 20\n",
      "20 best 19\n",
      "24 best 18\n",
      "30 best 14\n",
      "81 best 12\n",
      "82 best 10\n",
      "141 best 8\n",
      "209 best 6\n",
      "216 best 4\n",
      "281 best 2\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:05<04:57,  3.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 351 4850\n",
      "0 best 41\n",
      "1 best 40\n",
      "5 best 38\n",
      "6 best 36\n",
      "8 best 32\n",
      "9 best 30\n",
      "10 best 28\n",
      "13 best 26\n",
      "14 best 24\n",
      "17 best 22\n",
      "21 best 20\n",
      "24 best 18\n",
      "36 best 14\n",
      "39 best 12\n",
      "46 best 10\n",
      "85 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [00:08<04:38,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 334 4850\n",
      "0 best 40\n",
      "2 best 38\n",
      "3 best 36\n",
      "6 best 28\n",
      "17 best 26\n",
      "27 best 24\n",
      "33 best 20\n",
      "49 best 18\n",
      "76 best 16\n",
      "120 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:11<04:37,  2.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 378 4850\n",
      "0 best 33\n",
      "1 best 30\n",
      "2 best 29\n",
      "3 best 27\n",
      "5 best 25\n",
      "7 best 21\n",
      "9 best 20\n",
      "16 best 18\n",
      "28 best 16\n",
      "44 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [00:13<04:20,  2.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 337 4850\n",
      "0 best 40\n",
      "3 best 38\n",
      "5 best 32\n",
      "12 best 28\n",
      "15 best 24\n",
      "16 best 23\n",
      "32 best 22\n",
      "36 best 18\n",
      "47 best 16\n",
      "48 best 14\n",
      "90 best 12\n",
      "101 best 10\n",
      "102 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [00:16<04:16,  2.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 335 4850\n",
      "0 best 46\n",
      "2 best 37\n",
      "3 best 35\n",
      "5 best 32\n",
      "6 best 30\n",
      "9 best 28\n",
      "10 best 26\n",
      "18 best 24\n",
      "27 best 20\n",
      "34 best 19\n",
      "38 best 18\n",
      "43 best 16\n",
      "47 best 14\n",
      "76 best 12\n",
      "80 best 10\n",
      "87 best 8\n",
      "92 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [00:19<04:07,  2.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 323 4850\n",
      "0 best 38\n",
      "5 best 34\n",
      "8 best 28\n",
      "12 best 26\n",
      "17 best 25\n",
      "18 best 24\n",
      "26 best 20\n",
      "38 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:21<03:56,  2.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 329 4850\n",
      "0 best 42\n",
      "1 best 41\n",
      "3 best 36\n",
      "7 best 34\n",
      "8 best 32\n",
      "12 best 28\n",
      "14 best 26\n",
      "37 best 25\n",
      "42 best 24\n",
      "47 best 22\n",
      "58 best 21\n",
      "62 best 20\n",
      "63 best 16\n",
      "97 best 14\n",
      "198 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [00:24<04:08,  2.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 358 4850\n",
      "0 best 42\n",
      "1 best 41\n",
      "4 best 40\n",
      "5 best 35\n",
      "11 best 32\n",
      "16 best 28\n",
      "17 best 26\n",
      "18 best 22\n",
      "50 best 20\n",
      "54 best 16\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:26<03:54,  2.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 297 4850\n",
      "0 best 35\n",
      "1 best 33\n",
      "3 best 32\n",
      "5 best 30\n",
      "9 best 28\n",
      "13 best 26\n",
      "17 best 24\n",
      "25 best 20\n",
      "27 best 16\n",
      "83 best 14\n",
      "145 best 12\n",
      "158 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:29<03:48,  2.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 280 calc rtdl\n",
      "stat 280 4850\n",
      "0 best 46\n",
      "1 best 44\n",
      "2 best 40\n",
      "4 best 39\n",
      "5 best 36\n",
      "7 best 31\n",
      "9 best 28\n",
      "19 best 26\n",
      "21 best 24\n",
      "22 best 20\n",
      "42 best 18\n",
      "81 best 16\n",
      "99 best 14\n",
      "106 best 12\n",
      "155 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "iter 380 calc rtdl\n",
      "iter 390 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [00:32<04:01,  2.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 391 4850\n",
      "0 best 39\n",
      "2 best 37\n",
      "7 best 31\n",
      "8 best 29\n",
      "11 best 27\n",
      "14 best 25\n",
      "15 best 23\n",
      "18 best 22\n",
      "25 best 20\n",
      "29 best 18\n",
      "35 best 16\n",
      "87 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [00:35<03:52,  2.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 325 4850\n",
      "0 best 52\n",
      "1 best 50\n",
      "2 best 48\n",
      "4 best 46\n",
      "5 best 43\n",
      "8 best 41\n",
      "9 best 39\n",
      "11 best 35\n",
      "14 best 31\n",
      "23 best 30\n",
      "27 best 28\n",
      "29 best 23\n",
      "31 best 21\n",
      "35 best 17\n",
      "74 best 16\n",
      "93 best 14\n",
      "105 best 12\n",
      "107 best 10\n",
      "176 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [00:38<03:59,  2.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 358 4850\n",
      "0 best 48\n",
      "2 best 47\n",
      "3 best 46\n",
      "4 best 44\n",
      "5 best 40\n",
      "6 best 38\n",
      "8 best 34\n",
      "11 best 32\n",
      "15 best 29\n",
      "25 best 28\n",
      "27 best 24\n",
      "32 best 20\n",
      "60 best 18\n",
      "95 best 16\n",
      "115 best 14\n",
      "203 best 13\n",
      "241 best 10\n",
      "327 best 7\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [00:41<04:11,  2.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 339 4850\n",
      "0 best 40\n",
      "6 best 37\n",
      "7 best 36\n",
      "11 best 32\n",
      "20 best 28\n",
      "24 best 26\n",
      "29 best 22\n",
      "31 best 20\n",
      "44 best 18\n",
      "138 best 16\n",
      "139 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "iter 380 calc rtdl\n",
      "iter 390 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [00:44<04:14,  3.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 393 4850\n",
      "0 best 38\n",
      "2 best 32\n",
      "4 best 31\n",
      "6 best 29\n",
      "12 best 26\n",
      "14 best 24\n",
      "22 best 20\n",
      "34 best 16\n",
      "46 best 14\n",
      "112 best 12\n",
      "123 best 10\n",
      "127 best 6\n",
      "178 best 4\n",
      "184 best 2\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [00:47<04:14,  3.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 368 4850\n",
      "0 best 43\n",
      "3 best 42\n",
      "5 best 38\n",
      "9 best 32\n",
      "13 best 30\n",
      "18 best 28\n",
      "21 best 22\n",
      "31 best 20\n",
      "40 best 18\n",
      "107 best 14\n",
      "169 best 12\n",
      "241 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [00:51<04:18,  3.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 359 4850\n",
      "0 best 41\n",
      "3 best 40\n",
      "7 best 38\n",
      "9 best 36\n",
      "10 best 32\n",
      "11 best 29\n",
      "31 best 27\n",
      "41 best 23\n",
      "42 best 22\n",
      "64 best 19\n",
      "67 best 18\n",
      "82 best 17\n",
      "133 best 15\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [00:54<04:11,  3.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "stat 371 4850\n",
      "0 best 55\n",
      "1 best 50\n",
      "2 best 44\n",
      "3 best 40\n",
      "4 best 38\n",
      "6 best 36\n",
      "7 best 32\n",
      "8 best 30\n",
      "11 best 28\n",
      "19 best 26\n",
      "31 best 24\n",
      "32 best 20\n",
      "66 best 16\n",
      "113 best 14\n",
      "115 best 12\n",
      "126 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [00:57<04:01,  3.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 337 4850\n",
      "0 best 42\n",
      "1 best 36\n",
      "3 best 34\n",
      "4 best 32\n",
      "7 best 26\n",
      "11 best 22\n",
      "20 best 21\n",
      "24 best 17\n",
      "30 best 16\n",
      "32 best 15\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [00:59<03:42,  2.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 313 4850\n",
      "0 best 38\n",
      "5 best 36\n",
      "8 best 34\n",
      "11 best 32\n",
      "14 best 30\n",
      "16 best 26\n",
      "25 best 24\n",
      "36 best 22\n",
      "38 best 20\n",
      "46 best 14\n",
      "82 best 12\n",
      "169 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [01:02<03:39,  2.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 319 4850\n",
      "0 best 35\n",
      "1 best 31\n",
      "3 best 30\n",
      "6 best 28\n",
      "10 best 26\n",
      "15 best 24\n",
      "22 best 23\n",
      "37 best 20\n",
      "43 best 18\n",
      "87 best 16\n",
      "111 best 12\n",
      "119 best 10\n",
      "141 best 6\n",
      "179 best 4\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [01:05<03:44,  2.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 361 4850\n",
      "0 best 37\n",
      "3 best 34\n",
      "7 best 32\n",
      "8 best 29\n",
      "12 best 28\n",
      "13 best 26\n",
      "16 best 22\n",
      "21 best 20\n",
      "24 best 18\n",
      "38 best 14\n",
      "56 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [01:08<03:37,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "stat 366 4850\n",
      "0 best 42\n",
      "2 best 39\n",
      "4 best 37\n",
      "5 best 36\n",
      "7 best 35\n",
      "8 best 34\n",
      "10 best 32\n",
      "15 best 28\n",
      "22 best 27\n",
      "23 best 26\n",
      "39 best 24\n",
      "49 best 22\n",
      "60 best 16\n",
      "83 best 14\n",
      "98 best 12\n",
      "99 best 11\n",
      "102 best 10\n",
      "111 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [01:10<03:28,  2.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 330 4850\n",
      "0 best 40\n",
      "1 best 34\n",
      "6 best 31\n",
      "7 best 30\n",
      "10 best 28\n",
      "13 best 26\n",
      "33 best 24\n",
      "38 best 22\n",
      "47 best 20\n",
      "63 best 14\n",
      "90 best 12\n",
      "104 best 10\n",
      "142 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "stat 336 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [01:13<03:27,  2.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 52\n",
      "1 best 50\n",
      "3 best 44\n",
      "4 best 40\n",
      "6 best 38\n",
      "11 best 36\n",
      "13 best 34\n",
      "21 best 32\n",
      "24 best 31\n",
      "27 best 24\n",
      "50 best 18\n",
      "77 best 16\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [01:16<03:24,  2.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "stat 374 4850\n",
      "0 best 51\n",
      "1 best 49\n",
      "2 best 48\n",
      "3 best 46\n",
      "6 best 38\n",
      "10 best 36\n",
      "11 best 32\n",
      "14 best 30\n",
      "17 best 26\n",
      "21 best 24\n",
      "26 best 22\n",
      "30 best 20\n",
      "31 best 18\n",
      "58 best 16\n",
      "125 best 14\n",
      "186 best 12\n",
      "191 best 10\n",
      "220 best 8\n",
      "233 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [01:19<03:26,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\n",
      "0 best 34\n",
      "13 best 33\n",
      "18 best 29\n",
      "22 best 25\n",
      "30 best 24\n",
      "39 best 23\n",
      "45 best 21\n",
      "61 best 20\n",
      "73 best 18\n",
      "80 best 14\n",
      "115 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [01:22<03:24,  2.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 351 4850\n",
      "0 best 37\n",
      "1 best 36\n",
      "2 best 32\n",
      "5 best 28\n",
      "8 best 26\n",
      "10 best 22\n",
      "17 best 20\n",
      "30 best 16\n",
      "55 best 14\n",
      "72 best 12\n",
      "95 best 10\n",
      "138 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [01:25<03:20,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 353 4850\n",
      "0 best 47\n",
      "1 best 46\n",
      "4 best 40\n",
      "6 best 35\n",
      "7 best 34\n",
      "8 best 28\n",
      "17 best 26\n",
      "23 best 24\n",
      "39 best 23\n",
      "46 best 22\n",
      "119 best 21\n",
      "120 best 20\n",
      "160 best 17\n",
      "168 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [01:27<03:16,  2.85s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 331 4850\n",
      "0 best 43\n",
      "1 best 41\n",
      "3 best 38\n",
      "5 best 36\n",
      "6 best 34\n",
      "8 best 28\n",
      "11 best 26\n",
      "20 best 24\n",
      "22 best 22\n",
      "25 best 20\n",
      "27 best 16\n",
      "45 best 14\n",
      "89 best 8\n",
      "161 best 6\n",
      "179 best 4\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [01:30<03:15,  2.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 367 4850\n",
      "0 best 51\n",
      "2 best 47\n",
      "4 best 43\n",
      "9 best 40\n",
      "14 best 39\n",
      "15 best 38\n",
      "16 best 33\n",
      "18 best 32\n",
      "39 best 28\n",
      "40 best 26\n",
      "41 best 25\n",
      "42 best 24\n",
      "55 best 20\n",
      "140 best 19\n",
      "166 best 18\n",
      "167 best 14\n",
      "170 best 12\n",
      "248 best 11\n",
      "249 best 10\n",
      "263 best 9\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [01:33<03:17,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 337 4850\n",
      "0 best 54\n",
      "1 best 52\n",
      "4 best 50\n",
      "5 best 44\n",
      "7 best 38\n",
      "9 best 36\n",
      "29 best 29\n",
      "56 best 28\n",
      "66 best 24\n",
      "83 best 22\n",
      "96 best 18\n",
      "133 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [01:36<03:11,  2.91s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 333 4850\n",
      "0 best 42\n",
      "2 best 40\n",
      "7 best 36\n",
      "8 best 34\n",
      "11 best 28\n",
      "27 best 26\n",
      "29 best 24\n",
      "33 best 22\n",
      "54 best 20\n",
      "58 best 18\n",
      "68 best 16\n",
      "83 best 14\n",
      "90 best 12\n",
      "114 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [01:39<03:05,  2.85s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 332 4850\n",
      "0 best 50\n",
      "1 best 44\n",
      "2 best 42\n",
      "3 best 38\n",
      "4 best 36\n",
      "5 best 32\n",
      "11 best 27\n",
      "20 best 24\n",
      "41 best 23\n",
      "45 best 22\n",
      "56 best 20\n",
      "81 best 19\n",
      "85 best 18\n",
      "107 best 16\n",
      "112 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [01:42<03:00,  2.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 344 4850\n",
      "0 best 47\n",
      "2 best 45\n",
      "6 best 43\n",
      "7 best 42\n",
      "16 best 38\n",
      "18 best 36\n",
      "22 best 34\n",
      "49 best 30\n",
      "59 best 24\n",
      "136 best 18\n",
      "142 best 14\n",
      "189 best 10\n",
      "233 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [01:45<03:04,  2.93s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 348 4850\n",
      "0 best 42\n",
      "1 best 38\n",
      "2 best 36\n",
      "3 best 34\n",
      "5 best 32\n",
      "8 best 28\n",
      "12 best 24\n",
      "18 best 22\n",
      "23 best 21\n",
      "29 best 20\n",
      "35 best 18\n",
      "44 best 16\n",
      "46 best 14\n",
      "67 best 10\n",
      "141 best 8\n",
      "230 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [01:48<03:06,  3.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 346 4850\n",
      "0 best 45\n",
      "1 best 43\n",
      "2 best 39\n",
      "4 best 35\n",
      "5 best 31\n",
      "12 best 30\n",
      "18 best 28\n",
      "19 best 26\n",
      "22 best 24\n",
      "24 best 22\n",
      "25 best 20\n",
      "26 best 18\n",
      "96 best 16\n",
      "156 best 15\n",
      "244 best 14\n",
      "247 best 12\n",
      "261 best 10\n",
      "293 best 9\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 348 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [01:52<03:10,  3.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 43\n",
      "1 best 41\n",
      "2 best 39\n",
      "3 best 37\n",
      "4 best 35\n",
      "5 best 33\n",
      "8 best 32\n",
      "12 best 28\n",
      "15 best 24\n",
      "27 best 20\n",
      "32 best 18\n",
      "78 best 16\n",
      "162 best 15\n",
      "211 best 14\n",
      "298 best 13\n",
      "305 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [01:55<03:13,  3.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 370 calc rtdl\n",
      "stat 370 4850\n",
      "0 best 49\n",
      "1 best 45\n",
      "3 best 43\n",
      "4 best 39\n",
      "6 best 34\n",
      "10 best 33\n",
      "13 best 30\n",
      "14 best 28\n",
      "18 best 24\n",
      "20 best 22\n",
      "26 best 20\n",
      "33 best 18\n",
      "43 best 16\n",
      "73 best 14\n",
      "108 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [01:58<03:00,  3.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "stat 327 4850\n",
      "0 best 51\n",
      "1 best 47\n",
      "2 best 45\n",
      "4 best 41\n",
      "7 best 37\n",
      "9 best 36\n",
      "13 best 31\n",
      "20 best 30\n",
      "22 best 27\n",
      "33 best 25\n",
      "35 best 24\n",
      "52 best 20\n",
      "63 best 18\n",
      "71 best 16\n",
      "78 best 13\n",
      "83 best 12\n",
      "155 best 10\n",
      "218 best 8\n",
      "231 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [02:01<02:57,  3.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "stat 332 4850\n",
      "0 best 46\n",
      "1 best 44\n",
      "2 best 42\n",
      "6 best 37\n",
      "9 best 35\n",
      "10 best 34\n",
      "11 best 32\n",
      "14 best 30\n",
      "15 best 28\n",
      "17 best 24\n",
      "29 best 23\n",
      "30 best 18\n",
      "39 best 16\n",
      "52 best 14\n",
      "88 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [02:03<02:47,  2.93s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "stat 346 4850\n",
      "0 best 38\n",
      "1 best 36\n",
      "2 best 35\n",
      "3 best 31\n",
      "6 best 29\n",
      "7 best 27\n",
      "11 best 20\n",
      "16 best 18\n",
      "30 best 16\n",
      "32 best 12\n",
      "65 best 10\n",
      "155 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [02:06<02:40,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 324 4850\n",
      "0 best 40\n",
      "2 best 39\n",
      "3 best 34\n",
      "4 best 31\n",
      "6 best 28\n",
      "19 best 26\n",
      "20 best 24\n",
      "23 best 22\n",
      "27 best 20\n",
      "32 best 16\n",
      "42 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [02:09<02:33,  2.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "stat 347 4850\n",
      "0 best 46\n",
      "1 best 42\n",
      "2 best 40\n",
      "6 best 38\n",
      "8 best 36\n",
      "10 best 32\n",
      "11 best 30\n",
      "13 best 28\n",
      "15 best 26\n",
      "17 best 24\n",
      "23 best 20\n",
      "30 best 18\n",
      "35 best 16\n",
      "110 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [02:11<02:29,  2.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 330 4850\n",
      "0 best 44\n",
      "1 best 42\n",
      "3 best 38\n",
      "4 best 36\n",
      "7 best 32\n",
      "8 best 30\n",
      "12 best 28\n",
      "13 best 24\n",
      "15 best 22\n",
      "19 best 20\n",
      "32 best 18\n",
      "69 best 14\n",
      "120 best 12\n",
      "145 best 8\n",
      "200 best 6\n",
      "289 best 4\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [02:15<02:33,  2.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 308 4850\n",
      "0 best 36\n",
      "2 best 34\n",
      "5 best 31\n",
      "8 best 30\n",
      "16 best 28\n",
      "24 best 26\n",
      "29 best 19\n",
      "42 best 18\n",
      "68 best 16\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "stat 299 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [02:17<02:21,  2.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 48\n",
      "3 best 43\n",
      "5 best 39\n",
      "7 best 35\n",
      "11 best 31\n",
      "14 best 30\n",
      "16 best 26\n",
      "17 best 24\n",
      "20 best 20\n",
      "28 best 18\n",
      "31 best 16\n",
      "96 best 14\n",
      "108 best 12\n",
      "132 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [02:20<02:20,  2.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "stat 354 4850\n",
      "0 best 52\n",
      "2 best 51\n",
      "4 best 49\n",
      "6 best 43\n",
      "7 best 37\n",
      "10 best 36\n",
      "12 best 34\n",
      "13 best 32\n",
      "17 best 31\n",
      "23 best 30\n",
      "24 best 28\n",
      "36 best 26\n",
      "41 best 23\n",
      "53 best 18\n",
      "105 best 16\n",
      "117 best 12\n",
      "129 best 11\n",
      "144 best 10\n",
      "162 best 9\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [02:22<02:15,  2.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 317 4850\n",
      "0 best 38\n",
      "1 best 36\n",
      "2 best 32\n",
      "5 best 30\n",
      "6 best 26\n",
      "17 best 22\n",
      "18 best 20\n",
      "35 best 18\n",
      "48 best 16\n",
      "58 best 12\n",
      "75 best 10\n",
      "77 best 8\n",
      "95 best 7\n",
      "117 best 6\n",
      "153 best 5\n",
      "229 best 4\n",
      "327 best 2\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [02:26<02:20,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "stat 314 4850\n",
      "0 best 46\n",
      "1 best 44\n",
      "2 best 42\n",
      "6 best 36\n",
      "8 best 34\n",
      "9 best 32\n",
      "10 best 30\n",
      "11 best 28\n",
      "21 best 26\n",
      "22 best 25\n",
      "25 best 24\n",
      "37 best 22\n",
      "45 best 20\n",
      "49 best 18\n",
      "65 best 16\n",
      "85 best 14\n",
      "86 best 12\n",
      "128 best 10\n",
      "182 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [02:29<02:19,  2.91s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 360 4850\n",
      "0 best 47\n",
      "1 best 44\n",
      "2 best 42\n",
      "4 best 40\n",
      "6 best 38\n",
      "9 best 36\n",
      "12 best 34\n",
      "14 best 30\n",
      "20 best 28\n",
      "27 best 26\n",
      "28 best 24\n",
      "32 best 22\n",
      "33 best 20\n",
      "43 best 18\n",
      "45 best 14\n",
      "46 best 12\n",
      "67 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [02:31<02:12,  2.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 340 4850\n",
      "0 best 52\n",
      "1 best 48\n",
      "2 best 46\n",
      "3 best 40\n",
      "4 best 38\n",
      "5 best 36\n",
      "14 best 34\n",
      "15 best 32\n",
      "23 best 28\n",
      "27 best 26\n",
      "29 best 22\n",
      "33 best 20\n",
      "48 best 18\n",
      "75 best 16\n",
      "134 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [02:34<02:09,  2.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n",
      "0 best 40\n",
      "2 best 38\n",
      "3 best 36\n",
      "4 best 35\n",
      "5 best 33\n",
      "9 best 32\n",
      "10 best 28\n",
      "17 best 26\n",
      "27 best 25\n",
      "30 best 24\n",
      "46 best 22\n",
      "62 best 16\n",
      "131 best 12\n",
      "196 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [02:37<02:06,  2.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 326 4850\n",
      "0 best 45\n",
      "1 best 40\n",
      "9 best 34\n",
      "16 best 32\n",
      "21 best 30\n",
      "22 best 28\n",
      "25 best 27\n",
      "29 best 25\n",
      "47 best 24\n",
      "52 best 20\n",
      "57 best 19\n",
      "70 best 18\n",
      "73 best 11\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [02:39<02:01,  2.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 346 4850\n",
      "0 best 42\n",
      "3 best 40\n",
      "9 best 38\n",
      "12 best 32\n",
      "13 best 31\n",
      "14 best 26\n",
      "32 best 24\n",
      "46 best 22\n",
      "67 best 20\n",
      "75 best 16\n",
      "91 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "stat 367 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [02:42<02:01,  2.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 46\n",
      "2 best 40\n",
      "3 best 34\n",
      "7 best 32\n",
      "9 best 31\n",
      "10 best 28\n",
      "19 best 26\n",
      "22 best 22\n",
      "26 best 20\n",
      "75 best 16\n",
      "153 best 10\n",
      "154 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "stat 310 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [02:45<01:58,  2.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 45\n",
      "1 best 38\n",
      "5 best 36\n",
      "8 best 34\n",
      "10 best 30\n",
      "13 best 28\n",
      "16 best 24\n",
      "20 best 22\n",
      "26 best 20\n",
      "29 best 19\n",
      "31 best 16\n",
      "37 best 15\n",
      "45 best 14\n",
      "66 best 10\n",
      "98 best 8\n",
      "124 best 6\n",
      "136 best 4\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [02:48<01:57,  2.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "stat 373 4850\n",
      "0 best 43\n",
      "2 best 36\n",
      "3 best 34\n",
      "4 best 32\n",
      "10 best 28\n",
      "22 best 26\n",
      "23 best 23\n",
      "31 best 20\n",
      "62 best 18\n",
      "76 best 14\n",
      "91 best 10\n",
      "129 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [02:51<01:54,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 334 4850\n",
      "0 best 51\n",
      "1 best 49\n",
      "2 best 43\n",
      "4 best 41\n",
      "6 best 39\n",
      "7 best 37\n",
      "9 best 35\n",
      "11 best 31\n",
      "15 best 30\n",
      "19 best 28\n",
      "27 best 26\n",
      "31 best 24\n",
      "35 best 20\n",
      "115 best 14\n",
      "197 best 12\n",
      "203 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [02:54<01:54,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 352 4850\n",
      "0 best 39\n",
      "1 best 37\n",
      "6 best 36\n",
      "14 best 34\n",
      "15 best 32\n",
      "18 best 26\n",
      "21 best 25\n",
      "22 best 24\n",
      "28 best 20\n",
      "33 best 18\n",
      "71 best 16\n",
      "93 best 12\n",
      "134 best 10\n",
      "187 best 9\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [02:57<01:50,  2.90s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 328 4850\n",
      "0 best 45\n",
      "1 best 38\n",
      "2 best 36\n",
      "3 best 34\n",
      "9 best 31\n",
      "12 best 30\n",
      "14 best 28\n",
      "15 best 26\n",
      "34 best 24\n",
      "49 best 22\n",
      "53 best 18\n",
      "68 best 14\n",
      "115 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [02:59<01:42,  2.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 296 4850\n",
      "0 best 40\n",
      "2 best 39\n",
      "3 best 38\n",
      "4 best 34\n",
      "6 best 32\n",
      "7 best 27\n",
      "12 best 26\n",
      "16 best 22\n",
      "24 best 18\n",
      "59 best 16\n",
      "133 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [03:02<01:40,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 352 4850\n",
      "0 best 47\n",
      "1 best 41\n",
      "2 best 39\n",
      "3 best 36\n",
      "4 best 34\n",
      "7 best 28\n",
      "8 best 26\n",
      "11 best 22\n",
      "14 best 20\n",
      "20 best 19\n",
      "21 best 18\n",
      "24 best 14\n",
      "49 best 12\n",
      "139 best 10\n",
      "147 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "stat 320 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [03:05<01:37,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 48\n",
      "1 best 47\n",
      "3 best 45\n",
      "4 best 43\n",
      "5 best 38\n",
      "8 best 34\n",
      "11 best 30\n",
      "15 best 26\n",
      "17 best 22\n",
      "47 best 21\n",
      "70 best 20\n",
      "78 best 16\n",
      "90 best 13\n",
      "99 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "stat 357 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [03:08<01:33,  2.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 27\n",
      "2 best 25\n",
      "4 best 21\n",
      "15 best 20\n",
      "19 best 18\n",
      "23 best 16\n",
      "44 best 15\n",
      "64 best 12\n",
      "72 best 10\n",
      "94 best 8\n",
      "140 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [03:10<01:30,  2.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 335 4850\n",
      "0 best 50\n",
      "3 best 48\n",
      "5 best 42\n",
      "6 best 40\n",
      "11 best 38\n",
      "12 best 37\n",
      "16 best 36\n",
      "21 best 35\n",
      "27 best 34\n",
      "28 best 30\n",
      "32 best 29\n",
      "44 best 28\n",
      "46 best 27\n",
      "76 best 21\n",
      "100 best 20\n",
      "101 best 18\n",
      "124 best 17\n",
      "131 best 16\n",
      "162 best 15\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [03:13<01:29,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 330 4850\n",
      "0 best 39\n",
      "2 best 37\n",
      "8 best 36\n",
      "9 best 31\n",
      "13 best 30\n",
      "14 best 23\n",
      "64 best 22\n",
      "76 best 18\n",
      "95 best 12\n",
      "168 best 11\n",
      "264 best 10\n",
      "350 best 9\n",
      "357 best 8\n",
      "403 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [03:17<01:33,  3.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 308 4850\n",
      "0 best 49\n",
      "2 best 44\n",
      "4 best 42\n",
      "5 best 40\n",
      "6 best 38\n",
      "9 best 36\n",
      "12 best 32\n",
      "15 best 30\n",
      "16 best 28\n",
      "22 best 26\n",
      "45 best 21\n",
      "51 best 20\n",
      "70 best 18\n",
      "74 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "stat 335 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [03:19<01:26,  2.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 46\n",
      "1 best 42\n",
      "2 best 38\n",
      "3 best 34\n",
      "6 best 32\n",
      "12 best 30\n",
      "18 best 25\n",
      "20 best 24\n",
      "27 best 22\n",
      "32 best 20\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "stat 322 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [03:22<01:18,  2.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 52\n",
      "1 best 48\n",
      "3 best 46\n",
      "4 best 44\n",
      "8 best 40\n",
      "11 best 36\n",
      "12 best 34\n",
      "13 best 32\n",
      "15 best 30\n",
      "20 best 28\n",
      "27 best 26\n",
      "31 best 24\n",
      "34 best 20\n",
      "56 best 16\n",
      "60 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [03:24<01:14,  2.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 330 4850\n",
      "0 best 57\n",
      "2 best 53\n",
      "3 best 49\n",
      "4 best 48\n",
      "5 best 46\n",
      "9 best 40\n",
      "14 best 36\n",
      "15 best 35\n",
      "17 best 34\n",
      "19 best 32\n",
      "21 best 28\n",
      "25 best 27\n",
      "27 best 26\n",
      "30 best 24\n",
      "36 best 20\n",
      "45 best 18\n",
      "51 best 16\n",
      "139 best 11\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [03:27<01:13,  2.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 344 4850\n",
      "0 best 41\n",
      "1 best 33\n",
      "3 best 31\n",
      "5 best 29\n",
      "8 best 28\n",
      "25 best 26\n",
      "36 best 21\n",
      "40 best 18\n",
      "107 best 16\n",
      "183 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [03:30<01:12,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 376 4850\n",
      "0 best 42\n",
      "1 best 38\n",
      "6 best 36\n",
      "7 best 32\n",
      "16 best 30\n",
      "18 best 29\n",
      "25 best 25\n",
      "33 best 22\n",
      "51 best 21\n",
      "55 best 19\n",
      "56 best 16\n",
      "71 best 14\n",
      "86 best 13\n",
      "93 best 12\n",
      "117 best 6\n",
      "138 best 4\n",
      "176 best 2\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [03:33<01:11,  2.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 352 4850\n",
      "0 best 42\n",
      "6 best 41\n",
      "7 best 39\n",
      "8 best 37\n",
      "10 best 35\n",
      "17 best 34\n",
      "23 best 32\n",
      "26 best 30\n",
      "36 best 28\n",
      "38 best 26\n",
      "46 best 20\n",
      "52 best 16\n",
      "82 best 15\n",
      "83 best 12\n",
      "100 best 9\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [03:36<01:10,  2.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 380 calc rtdl\n",
      "stat 384 4850\n",
      "0 best 38\n",
      "4 best 36\n",
      "12 best 34\n",
      "14 best 28\n",
      "34 best 26\n",
      "45 best 24\n",
      "67 best 20\n",
      "72 best 19\n",
      "78 best 18\n",
      "85 best 16\n",
      "181 best 13\n",
      "189 best 11\n",
      "232 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [03:39<01:07,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 348 4850\n",
      "0 best 39\n",
      "4 best 37\n",
      "5 best 35\n",
      "9 best 34\n",
      "12 best 30\n",
      "14 best 28\n",
      "16 best 26\n",
      "29 best 24\n",
      "31 best 22\n",
      "52 best 21\n",
      "63 best 20\n",
      "92 best 19\n",
      "105 best 18\n",
      "123 best 16\n",
      "219 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [03:42<01:04,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 325 4850\n",
      "0 best 35\n",
      "1 best 33\n",
      "2 best 28\n",
      "6 best 26\n",
      "7 best 24\n",
      "9 best 22\n",
      "13 best 20\n",
      "36 best 18\n",
      "76 best 16\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [03:45<01:00,  2.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 370 calc rtdl\n",
      "stat 378 4850\n",
      "0 best 40\n",
      "1 best 36\n",
      "4 best 34\n",
      "5 best 31\n",
      "7 best 30\n",
      "11 best 29\n",
      "17 best 26\n",
      "27 best 24\n",
      "33 best 20\n",
      "58 best 19\n",
      "93 best 18\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "stat 322 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [03:47<00:55,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 34\n",
      "2 best 32\n",
      "7 best 28\n",
      "10 best 26\n",
      "17 best 24\n",
      "18 best 22\n",
      "24 best 20\n",
      "29 best 18\n",
      "32 best 14\n",
      "37 best 12\n",
      "41 best 10\n",
      "63 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "stat 373 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [03:50<00:53,  2.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 best 38\n",
      "1 best 36\n",
      "3 best 30\n",
      "15 best 28\n",
      "17 best 26\n",
      "23 best 24\n",
      "57 best 20\n",
      "66 best 18\n",
      "76 best 14\n",
      "128 best 12\n",
      "131 best 8\n",
      "132 best 6\n",
      "152 best 4\n",
      "180 best 2\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [03:53<00:51,  2.84s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 328 4850\n",
      "0 best 42\n",
      "2 best 38\n",
      "5 best 37\n",
      "10 best 35\n",
      "11 best 33\n",
      "12 best 30\n",
      "13 best 27\n",
      "18 best 26\n",
      "19 best 22\n",
      "26 best 20\n",
      "39 best 18\n",
      "57 best 16\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [03:56<00:47,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 355 4850\n",
      "0 best 41\n",
      "1 best 40\n",
      "3 best 38\n",
      "4 best 36\n",
      "5 best 35\n",
      "6 best 34\n",
      "8 best 32\n",
      "11 best 30\n",
      "17 best 27\n",
      "21 best 26\n",
      "26 best 23\n",
      "30 best 20\n",
      "75 best 16\n",
      "152 best 14\n",
      "156 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [03:59<00:44,  2.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 326 4850\n",
      "0 best 43\n",
      "3 best 41\n",
      "4 best 37\n",
      "7 best 36\n",
      "8 best 32\n",
      "10 best 29\n",
      "13 best 26\n",
      "16 best 21\n",
      "35 best 20\n",
      "41 best 18\n",
      "70 best 16\n",
      "88 best 14\n",
      "94 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [04:01<00:41,  2.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "stat 367 4850\n",
      "0 best 49\n",
      "1 best 47\n",
      "2 best 45\n",
      "3 best 41\n",
      "4 best 39\n",
      "7 best 36\n",
      "9 best 34\n",
      "11 best 32\n",
      "12 best 30\n",
      "19 best 28\n",
      "22 best 26\n",
      "27 best 22\n",
      "63 best 21\n",
      "72 best 20\n",
      "98 best 18\n",
      "101 best 14\n",
      "120 best 13\n",
      "160 best 12\n",
      "233 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [04:04<00:38,  2.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 300 calc rtdl\n",
      "stat 305 4850\n",
      "0 best 50\n",
      "1 best 47\n",
      "2 best 45\n",
      "3 best 43\n",
      "5 best 41\n",
      "6 best 39\n",
      "9 best 37\n",
      "10 best 35\n",
      "15 best 31\n",
      "22 best 30\n",
      "31 best 28\n",
      "41 best 21\n",
      "42 best 20\n",
      "111 best 19\n",
      "135 best 18\n",
      "194 best 16\n",
      "228 best 14\n",
      "295 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [04:08<00:38,  3.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 363 4850\n",
      "0 best 40\n",
      "1 best 39\n",
      "4 best 37\n",
      "5 best 36\n",
      "7 best 34\n",
      "11 best 32\n",
      "12 best 26\n",
      "15 best 24\n",
      "23 best 20\n",
      "29 best 18\n",
      "78 best 16\n",
      "82 best 14\n",
      "115 best 12\n",
      "156 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [04:11<00:35,  2.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 324 4850\n",
      "0 best 37\n",
      "3 best 35\n",
      "4 best 34\n",
      "5 best 32\n",
      "8 best 30\n",
      "13 best 28\n",
      "14 best 26\n",
      "38 best 22\n",
      "53 best 21\n",
      "65 best 20\n",
      "93 best 19\n",
      "96 best 18\n",
      "101 best 16\n",
      "112 best 13\n",
      "153 best 12\n",
      "154 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [04:14<00:32,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "stat 332 4850\n",
      "0 best 46\n",
      "3 best 42\n",
      "6 best 41\n",
      "11 best 38\n",
      "13 best 33\n",
      "14 best 29\n",
      "15 best 22\n",
      "21 best 19\n",
      "26 best 18\n",
      "36 best 16\n",
      "69 best 14\n",
      "119 best 10\n",
      "122 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [04:16<00:29,  2.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 337 4850\n",
      "0 best 44\n",
      "2 best 43\n",
      "3 best 41\n",
      "4 best 35\n",
      "6 best 33\n",
      "8 best 30\n",
      "10 best 28\n",
      "12 best 26\n",
      "27 best 22\n",
      "33 best 20\n",
      "37 best 18\n",
      "40 best 14\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [04:19<00:25,  2.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 343 4850\n",
      "0 best 39\n",
      "2 best 37\n",
      "3 best 36\n",
      "4 best 32\n",
      "6 best 28\n",
      "10 best 26\n",
      "16 best 24\n",
      "22 best 22\n",
      "31 best 16\n",
      "41 best 14\n",
      "51 best 13\n",
      "52 best 11\n",
      "55 best 8\n",
      "89 best 7\n",
      "113 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [04:22<00:22,  2.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 354 4850\n",
      "0 best 49\n",
      "1 best 45\n",
      "2 best 43\n",
      "3 best 41\n",
      "5 best 35\n",
      "7 best 34\n",
      "9 best 32\n",
      "11 best 30\n",
      "19 best 24\n",
      "23 best 22\n",
      "26 best 21\n",
      "31 best 20\n",
      "34 best 18\n",
      "36 best 14\n",
      "64 best 12\n",
      "71 best 10\n",
      "76 best 8\n",
      "78 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "iter 380 calc rtdl\n",
      "iter 390 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [04:25<00:19,  2.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n",
      "0 best 46\n",
      "1 best 42\n",
      "2 best 38\n",
      "3 best 36\n",
      "8 best 34\n",
      "11 best 32\n",
      "12 best 30\n",
      "15 best 28\n",
      "26 best 27\n",
      "39 best 26\n",
      "53 best 23\n",
      "63 best 22\n",
      "67 best 20\n",
      "68 best 19\n",
      "71 best 18\n",
      "77 best 16\n",
      "83 best 13\n",
      "116 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [04:27<00:16,  2.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 323 4850\n",
      "0 best 47\n",
      "1 best 45\n",
      "2 best 39\n",
      "3 best 37\n",
      "5 best 35\n",
      "7 best 29\n",
      "14 best 27\n",
      "17 best 25\n",
      "23 best 24\n",
      "24 best 22\n",
      "27 best 21\n",
      "44 best 18\n",
      "54 best 16\n",
      "55 best 14\n",
      "72 best 10\n",
      "158 best 6\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [04:30<00:13,  2.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 325 4850\n",
      "0 best 33\n",
      "1 best 31\n",
      "3 best 29\n",
      "17 best 25\n",
      "21 best 20\n",
      "25 best 18\n",
      "32 best 16\n",
      "46 best 15\n",
      "90 best 14\n",
      "93 best 12\n",
      "111 best 10\n",
      "123 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [04:33<00:11,  2.85s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 363 4850\n",
      "0 best 44\n",
      "2 best 41\n",
      "5 best 37\n",
      "8 best 33\n",
      "9 best 31\n",
      "15 best 29\n",
      "23 best 28\n",
      "32 best 24\n",
      "39 best 20\n",
      "86 best 18\n",
      "88 best 16\n",
      "147 best 12\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [04:36<00:08,  2.90s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 347 4850\n",
      "0 best 41\n",
      "1 best 38\n",
      "3 best 36\n",
      "4 best 33\n",
      "8 best 30\n",
      "9 best 26\n",
      "14 best 24\n",
      "24 best 18\n",
      "29 best 16\n",
      "30 best 14\n",
      "36 best 12\n",
      "56 best 10\n",
      "154 best 8\n",
      "212 best 4\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 98/100 [04:39<00:05,  2.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 311 4850\n",
      "0 best 50\n",
      "1 best 40\n",
      "2 best 38\n",
      "5 best 34\n",
      "11 best 32\n",
      "17 best 30\n",
      "18 best 28\n",
      "20 best 26\n",
      "28 best 24\n",
      "34 best 23\n",
      "38 best 21\n",
      "42 best 16\n",
      "74 best 14\n",
      "77 best 13\n",
      "79 best 12\n",
      "145 best 11\n",
      "147 best 10\n",
      "199 best 8\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [04:42<00:02,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 325 4850\n",
      "0 best 39\n",
      "3 best 38\n",
      "4 best 37\n",
      "6 best 36\n",
      "8 best 35\n",
      "9 best 34\n",
      "11 best 33\n",
      "16 best 32\n",
      "19 best 30\n",
      "23 best 28\n",
      "25 best 26\n",
      "42 best 24\n",
      "45 best 20\n",
      "85 best 18\n",
      "97 best 16\n",
      "151 best 14\n",
      "160 best 13\n",
      "200 best 12\n",
      "291 best 10\n",
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 50 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 70 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 110 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 130 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 170 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 190 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 230 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 250 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 310 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [04:45<00:00,  2.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 318 4850\n",
      "CPU times: user 4min 44s, sys: 1.53 s, total: 4min 46s\n",
      "Wall time: 4min 45s\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "logger_rtdl = Logger(MAX_ITER)\n",
    "data_rtdl = []\n",
    "\n",
    "for t in trange(TRIALS):\n",
    "    cities, distance_matrix = create_problem(t, N_CITIES)\n",
    "    initial_tour = list(range(cities.shape[0]))\n",
    "    _, distance_matrix_mod = optimize_D_1tree(distance_matrix, 1e-2)\n",
    "\n",
    "    logger_rtdl.problem_started()\n",
    "    optimized_tour, _ = two_opt_rtdl(initial_tour, distance_matrix_mod, max_iterations = MAX_ITER, logger = logger_rtdl,\\\n",
    "                                                      progressive = True, random_vlist = False)\n",
    "    optimized_distance = calculate_total_distance(optimized_tour, distance_matrix)\n",
    "    logger_rtdl.problem_solved()\n",
    "    data_rtdl.append(optimized_distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "94402bb9-9a8b-4afc-aa71-23d6f88359a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8.170096085129105, 0.031083619836805063)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(data_rtdl), np.std(data_rtdl) / np.sqrt(TRIALS-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "149a038c-1f5b-44f8-9251-a5b08b0c93cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "285.8555507659912"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logger_rtdl.time_end - logger_rtdl.time_start"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c874aafe-f8d7-4967-ac89-c5b6dc571073",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jBhBYmKiY5w3ftaX0xif76Xm94S/RVVVFQ888AC1tbW88cYbTtMee+wxx/309HQ6duxIv3792LBhA3369AE8b7kb63vtact9oXfffZeHHnqIkJAQp/Ge/Hlf7jcL3Offt1duMmvdujX+/v51mmFhYWGdJuqJnnrqKebPn8+SJUtISkq64rwJCQmkpKSwe/duAOLj46msrKSoqMhpPk/624SHh5ORkcHu3bsdR5td6bP29GU+cOAAX3/9NT/96U+vOJ83ftaN9fnGx8dz9OjROq9/7Ngxt/5bVFVVcd9995Gbm0t2drbT2qFL6dOnD4GBgU7fAU9c7gs15Hvtycv9zTffsHPnzqv+ewfP+bwv95vlbv++vbIQBQUF0bdvX8dqxPOys7PJzMy0KNW1M02T8ePHM3fuXBYvXkxqaupVn3PixAkOHjxIQkICAH379iUwMNDpb5Ofn8/WrVs95m9TUVHBjh07SEhIcKw+vnB5KisrycnJcSyPpy/ze++9R2xsLHfccccV5/PGz7qxPt+BAwdSXFzMmjVrHPOsXr2a4uJit/1bnC9Du3fv5uuvv6ZVq1ZXfc62bduoqqpyfAc8cbkv1pDvtScv9zvvvEPfvn3p2bPnVed198/7ar9Zbvfvu/77h3uWOXPmmIGBgeY777xjbt++3Zw4caIZHh5u7t+/3+poDfbEE0+YNpvNXLp0qZmfn+8YysvLTdM0zdLSUvPZZ581V65caebm5ppLliwxBw4caLZp08YsKSlxvM7jjz9uJiUlmV9//bW5YcMGc+jQoWbPnj3N6upqqxbtip599llz6dKl5r59+8xVq1aZd955pxkREeH4LF955RXTZrOZc+fONbds2WI++OCDZkJCgkcv83k1NTVm27ZtzV/+8pdO473psy4tLTU3btxobty40QTM6dOnmxs3bnQcTdVYn+9tt91m9ujRw/z222/Nb7/91szIyDDvvPPOZl/e86603FVVVebIkSPNpKQkc9OmTU7/3isqKkzTNM09e/aYL7/8srl27VozNzfX/OKLL8wuXbqYvXv39tjlbszvtSct93nFxcVmWFiY+eabb9Z5vid+3lf7zTJN9/r37bWFyDRN889//rOZkpJiBgUFmX369HE6PN0TAZcc3nvvPdM0TbO8vNwcPny4GRMTYwYGBppt27Y1H374YTMvL8/pdc6cOWOOHz/ejI6ONkNDQ80777yzzjzu5P777zcTEhLMwMBAMzEx0Rw9erS5bds2x/Ta2lrzpZdeMuPj483g4GBz8ODB5pYtW5xew9OW+byvvvrKBMydO3c6jfemz3rJkiWX/F4//PDDpmk23ud74sQJ86GHHjIjIiLMiIgI86GHHjKLioqaaSnrutJy5+bmXvbf+5IlS0zTNM28vDxz8ODBZnR0tBkUFGR26NDBfPrpp80TJ044vY8nLXdjfq89abnP++tf/2qGhoaap06dqvN8T/y8r/abZZru9e/bOBdaRERExGd55T5EIiIiIq5QIRIRERGfp0IkIiIiPk+FSERERHyeCpGIiIj4PBUiERER8XkqRCIiIuLzVIhERETE56kQiYjXadeuHTNmzLA6hoh4EBUiEbkmjzzyCKNGjQIgKyuLiRMnNtt7z5o1i6ioqDrj165dy89+9rNmyyEini/A6gAiIherrKwkKCiowc+PiYlpxDQi4gu0hkhEGsUjjzxCTk4Or7/+OoZhYBgG+/fvB2D79u3cfvvttGjRgri4OMaOHcvx48cdz83KymL8+PE888wztG7dmmHDhgEwffp0MjIyCA8PJzk5mSeffJLTp08DsHTpUn784x9TXFzseL/JkycDdTeZ5eXlcffdd9OiRQsiIyO57777OHr0qGP65MmT6dWrFx988AHt2rXDZrPxwAMPUFpa6pjnn//8JxkZGYSGhtKqVStuueUWysrKmuivKSLNTYVIRBrF66+/zsCBA3nsscfIz88nPz+f5ORk8vPzGTJkCL169WLdunUsWLCAo0ePct999zk9f/bs2QQEBLBixQr++te/AuDn58cf//hHtm7dyuzZs1m8eDGTJk0CIDMzkxkzZhAZGel4v+eee65OLtM0GTVqFCdPniQnJ4fs7Gz27t3L/fff7zTf3r17+fTTT/n888/5/PPPycnJ4ZVXXgEgPz+fBx98kEcffZQdO3awdOlSRo8eja6NLeI9tMlMRBqFzWYjKCiIsLAw4uPjHePffPNN+vTpw5QpUxzj3n33XZKTk9m1axedOnUCIC0tjWnTpjm95oX7I6WmpvLf//3fPPHEE7zxxhsEBQVhs9kwDMPp/S729ddfs3nzZnJzc0lOTgbggw8+oHv37qxdu5b+/fsDUFtby6xZs4iIiABg7NixLFq0iN///vfk5+dTXV3N6NGjSUlJASAjI+Ma/loi4m60hkhEmtT69etZsmQJLVq0cAxdunQB7GtlzuvXr1+d5y5ZsoRhw4bRpk0bIiIi+NGPfsSJEydc2lS1Y8cOkpOTHWUIoFu3bkRFRbFjxw7HuHbt2jnKEEBCQgKFhYUA9OzZk5tvvpmMjAx++MMf8vbbb1NUVFT/P4KIuD0VIhFpUrW1tdx1111s2rTJadi9ezeDBw92zBceHu70vAMHDnD77beTnp7OJ598wvr16/nzn/8MQFVVVb3f3zRNDMO46vjAwECn6YZhUFtbC4C/vz/Z2dl8+eWXdOvWjT/96U907tyZ3NzceucQEfemQiQijSYoKIiamhqncX369GHbtm20a9eOtLQ0p+HiEnShdevWUV1dzR/+8Aeuv/56OnXqxJEjR676fhfr1q0beXl5HDx40DFu+/btFBcX07Vr13ovm2EY3HDDDbz88sts3LiRoKAg5s2bV+/ni4h7UyESkUbTrl07Vq9ezf79+zl+/Di1tbWMGzeOkydP8uCDD7JmzRr27dvHwoULefTRR69YZjp06EB1dTV/+tOf2LdvHx988AF/+ctf6rzf6dOnWbRoEcePH6e8vLzO69xyyy306NGDhx56iA0bNrBmzRp+9KMfMWTIkEtupruU1atXM2XKFNatW0deXh5z587l2LFjLhUqEXFvKkQi0miee+45/P396datGzExMeTl5ZGYmMiKFSuoqanh1ltvJT09nQkTJmCz2fDzu/z/BfXq1Yvp06fz6quvkp6ezt///nemTp3qNE9mZiaPP/44999/PzExMXV2ygb7mp1PP/2Uli1bMnjwYG655Rbat2/Pxx9/XO/lioyMZNmyZdx+++106tSJ//2//zd/+MMfGDFiRP3/OCLi1gxTx42KiIiIj9MaIhEREfF5KkQiIiLi81SIRERExOepEImIiIjPUyESERERn6dCJCIiIj5PhUhERER8ngqRiIiI+DwVIhEREfF5KkQiIiLi81SIRERExOf9f1PhLl5dZtAzAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(logger_orig.sum_distances / TRIALS, label = '2-opt')\n",
    "plt.plot(logger_rtdl.sum_distances / TRIALS, label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "ax.set_xlim([0, 2000])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Tour length')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c841d575-56dd-4b9a-8957-058719542b66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0bcbf66f-c80b-441a-8ab8-1ad074730da1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_113752/3112441879.py:1: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nancumsum(np.nanmean(logger_orig.sum_attempts, axis = 0)), label = '2-opt')\n",
      "/tmp/ipykernel_113752/3112441879.py:2: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nancumsum(np.nanmean(logger_rtdl.sum_attempts, axis = 0)), label = '2-opt + RTDL')\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAloAAAGwCAYAAABxbMuTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABDWElEQVR4nO3de3hU1b3/8c8kJEMSwkAIyTCAXA4qYhAlKBepQRFQQQ61xwtiFPXYooTLARVvP0VaCKKlqBSsHo/aesGnBVq0FgmoUDRcDFISUdAKhEtCFJMJ19xm/f6AbByCmMAMs9m8X88zj2Tv7+y9ZhOdj2utvbbLGGMEAACAkIuKdAMAAACciqAFAAAQJgQtAACAMCFoAQAAhAlBCwAAIEwIWgAAAGFC0AIAAAiTRpFuwNkmEAho165dSkxMlMvlinRzAABAPRhjtHfvXvl8PkVF1b+fiqB1mu3atUtt27aNdDMAAMBJ2L59u9q0aVPveoLWaZaYmCjp8F9U06ZNI9waAABQH+Xl5Wrbtq31PV5fBK3TrHa4sGnTpgQtAADOMA2d9sNkeAAAgDAhaAEAAIQJQQsAACBMCFoAAABhQtACAAAIE4IWAABAmBC0AAAAwoSgBQAAECYELQAAgDAhaAEAAIQJQQsAACBMCFoAAABhwkOlHcYYo93lFaoOBCLdFAAAIqJ1s7gGP/w5XAhaDjP171/of1duiXQzAACImM2/uVaxjQhaCIP128skSTHRLkXZJM0DAHC2Img5jDnyz+eHd9c1ad6ItgUAgLMdk+EdxpjDUYvOLAAAIo+g5TC1PVrkLAAAIo+g5TBHOrRsc7cFAABnM4KWw9CjBQCAfRC0nIY5WgAA2AZBy2GsHi2CFgAAEUfQchhrjhaDhwAARBxBy2GMrKQFAAAijKDlMIacBQCAbRC0HIblHQAAsA+ClsOwvAMAAPZB0HIYHsEDAIB9ELQcirsOAQCIPIKWwxydoxXZdgAAAIKW49Qu70DOAgAg8ghaDmOYDQ8AgG0QtBzmaM4iaQEAEGkELYfhrkMAAOyDoOUwjBwCAGAfBC2nYWV4AABsg6DlMFaPFjkLAICIi2jQqq6u1mOPPaYOHTooLi5OHTt21JQpUxQIBKwaY4wmT54sn8+nuLg49evXT59//nnQcSoqKjRmzBglJycrISFBQ4cO1Y4dO4JqSktLlZmZKY/HI4/Ho8zMTJWVlQXVFBYW6vrrr1dCQoKSk5M1duxYVVZWBtXk5+crIyNDcXFxat26taZMmWLNi7IDa45WhNsBAAAiHLSeeuopvfDCC5o9e7a++OILzZgxQ08//bSef/55q2bGjBmaOXOmZs+erbVr18rr9WrAgAHau3evVTN+/HgtXLhQ8+bN08qVK7Vv3z4NGTJENTU1Vs2tt96q9evXa/HixVq8eLHWr1+vzMxMa39NTY0GDx6s/fv3a+XKlZo3b57mz5+viRMnWjXl5eUaMGCAfD6f1q5dq+eff17PPPOMZs6cGeYrVX/0aAEAYCMmggYPHmzuuuuuoG033HCDue2224wxxgQCAeP1es306dOt/YcOHTIej8e88MILxhhjysrKTExMjJk3b55Vs3PnThMVFWUWL15sjDFm48aNRpJZtWqVVZObm2skmS+//NIYY8x7771noqKizM6dO62at956y7jdbuP3+40xxsyZM8d4PB5z6NAhqyY7O9v4fD4TCATq9Zn9fr+RZB0z1Po+tcy0m/Suydv2fViODwDA2ehkv78j2qPVt29fLVu2TJs3b5Yk/etf/9LKlSt13XXXSZK2bNmi4uJiDRw40HqP2+1WRkaGPvnkE0lSXl6eqqqqgmp8Pp/S0tKsmtzcXHk8HvXs2dOq6dWrlzweT1BNWlqafD6fVTNo0CBVVFQoLy/PqsnIyJDb7Q6q2bVrl7Zu3Xrcz1hRUaHy8vKgVzhZj+AJ61kAAEB9NIrkySdNmiS/36/OnTsrOjpaNTU1mjp1qoYPHy5JKi4uliSlpqYGvS81NVXbtm2zamJjY9W8efM6NbXvLy4uVkpKSp3zp6SkBNUce57mzZsrNjY2qKZ9+/Z1zlO7r0OHDnXOkZ2drSeffPKnL0aIGO46BADANiLao/X222/r9ddf15tvvql169bptdde0zPPPKPXXnstqO7Y0GCM+ckgcWzN8epDUWOsBUKP356HH35Yfr/fem3fvv2E7Q4VYhYAAJEX0R6tBx54QA899JBuueUWSVLXrl21bds2ZWdn64477pDX65V0uLeoVatW1vtKSkqsniSv16vKykqVlpYG9WqVlJSoT58+Vs3u3bvrnP/bb78NOs7q1auD9peWlqqqqiqoprZ364fnker2utVyu91BQ43hZlgZHgAA24hoj9aBAwcUFRXchOjoaGt5hw4dOsjr9SonJ8faX1lZqeXLl1shKj09XTExMUE1RUVFKigosGp69+4tv9+vNWvWWDWrV6+W3+8PqikoKFBRUZFVs2TJErndbqWnp1s1K1asCFryYcmSJfL5fHWGFCOFZx0CAGAjIZ+W3wB33HGHad26tXn33XfNli1bzIIFC0xycrJ58MEHrZrp06cbj8djFixYYPLz883w4cNNq1atTHl5uVUzatQo06ZNG7N06VKzbt06c9VVV5lu3bqZ6upqq+aaa64xF110kcnNzTW5ubmma9euZsiQIdb+6upqk5aWZvr372/WrVtnli5datq0aWOysrKsmrKyMpOammqGDx9u8vPzzYIFC0zTpk3NM888U+/PHO67DntOXWraTXrX5O8oC8vxAQA4G53s93dEg1Z5ebkZN26cOeecc0zjxo1Nx44dzaOPPmoqKiqsmkAgYJ544gnj9XqN2+02V1xxhcnPzw86zsGDB01WVpZJSkoycXFxZsiQIaawsDCoZs+ePWbEiBEmMTHRJCYmmhEjRpjS0tKgmm3btpnBgwebuLg4k5SUZLKysoKWcjDGmA0bNpif/exnxu12G6/XayZPnlzvpR2MCX/QumxqDkELAIAQO9nvb5cxNlrW/CxQXl4uj8cjv9+vpk2bhvz4l01dqpK9Ffr72L660OcJ+fEBADgbnez3N886dBjmaAEAYB8ELYc5uo5WZNsBAAAIWg7E8g4AANgFQcthjj6Ch6QFAECkEbQcxpqjRc4CACDiCFoOU3sTKTkLAIDII2g5DD1aAADYB0HLYY6uikbSAgAg0ghaDmN4qDQAALZB0HKYowuWAgCASCNoOY21YClRCwCASCNoOQw9WgAA2AdBy2GYowUAgH0QtByGh0oDAGAfBC2H4aHSAADYB0HLYYzVpwUAACKNoOUw9GgBAGAfBC2HqQ1aUSQtAAAijqDlMLVDh+QsAAAij6DlMNbQIXcdAgAQcQQth7GWdyBnAQAQcQQth7EWLI1wOwAAAEHLcazFHUhaAABEHEHLYZijBQCAfRC0HIo5WgAARB5By0Fq52dJjBwCAGAHBC0H+UHOkosuLQAAIo6g5SA/fMohMQsAgMgjaDlI0NAhSQsAgIgjaDlIcI8WSQsAgEgjaDmIYewQAABbIWg5iBFDhwAA2AlBy0GC7jqMXDMAAMARBC2HYnkHAAAij6DlIPRoAQBgLwQtB2GOFgAA9kLQcpDgHi2SFgAAkUbQcpCg1R3IWQAARBxBy0FM0EJaAAAg0ghaDkKPFgAA9kLQchDmaAEAYC8ELSf5YdAiZwEAEHEELQcJWt4hgu0AAACHEbQc5IdDh1F0aQEAEHEELQcJGBYsBQDATghaDhJ81yFJCwCASCNoOQjLaAEAYC8ELQepnQxPZxYAAPZA0HKSIz1a5CwAAOyBoOUgtSOHzM8CAMAeCFoOYujRAgDAVghaDsIcLQAA7IWg5SBHe7RIWgAA2AFBy0Gs1R3IWQAA2AJBy0HMkS4tchYAAPZA0HIQa+iQpAUAgC0QtByIOVoAANgDQctB6NECAMBeCFoOYi3vEOF2AACAwwhaDnK0R4uoBQCAHRC0HMR6BE9EWwEAAGoRtBzE8AweAABshaDlIPRoAQBgLwQtB2GOFgAA9kLQchQeKg0AgJ0QtByEKVoAANhLxIPWzp07ddttt6lFixaKj4/XxRdfrLy8PGu/MUaTJ0+Wz+dTXFyc+vXrp88//zzoGBUVFRozZoySk5OVkJCgoUOHaseOHUE1paWlyszMlMfjkcfjUWZmpsrKyoJqCgsLdf311yshIUHJyckaO3asKisrg2ry8/OVkZGhuLg4tW7dWlOmTDk6CT3CrDladGkBAGALEQ1apaWluvzyyxUTE6N//OMf2rhxo37729+qWbNmVs2MGTM0c+ZMzZ49W2vXrpXX69WAAQO0d+9eq2b8+PFauHCh5s2bp5UrV2rfvn0aMmSIampqrJpbb71V69ev1+LFi7V48WKtX79emZmZ1v6amhoNHjxY+/fv18qVKzVv3jzNnz9fEydOtGrKy8s1YMAA+Xw+rV27Vs8//7yeeeYZzZw5M7wXqp7o0QIAwGZMBE2aNMn07dv3R/cHAgHj9XrN9OnTrW2HDh0yHo/HvPDCC8YYY8rKykxMTIyZN2+eVbNz504TFRVlFi9ebIwxZuPGjUaSWbVqlVWTm5trJJkvv/zSGGPMe++9Z6KioszOnTutmrfeesu43W7j9/uNMcbMmTPHeDwec+jQIasmOzvb+Hw+EwgE6vWZ/X6/kWQdM5S+KPKbdpPeNem/XhLyYwMAcDY72e/viPZoLVq0SD169NCNN96olJQUXXLJJXrppZes/Vu2bFFxcbEGDhxobXO73crIyNAnn3wiScrLy1NVVVVQjc/nU1pamlWTm5srj8ejnj17WjW9evWSx+MJqklLS5PP57NqBg0apIqKCmsoMzc3VxkZGXK73UE1u3bt0tatW4/7GSsqKlReXh70CpejI5j0aQEAYAcRDVrffPON5s6dq3PPPVfvv/++Ro0apbFjx+qPf/yjJKm4uFiSlJqaGvS+1NRUa19xcbFiY2PVvHnzE9akpKTUOX9KSkpQzbHnad68uWJjY09YU/tzbc2xsrOzrXlhHo9Hbdu2/YmrcuqYogUAgD1ENGgFAgF1795d06ZN0yWXXKJf/epXuueeezR37tygumMndxtjfnLC97E1x6sPRY0x5rjbaz388MPy+/3Wa/v27Sds96mwyZx8AABwRESDVqtWrdSlS5egbRdccIEKCwslSV6vV1Ld3qKSkhKrJ8nr9aqyslKlpaUnrNm9e3ed83/77bdBNceep7S0VFVVVSesKSkpkVS3162W2+1W06ZNg17hYmrX0QrbGQAAQENENGhdfvnl2rRpU9C2zZs3q127dpKkDh06yOv1Kicnx9pfWVmp5cuXq0+fPpKk9PR0xcTEBNUUFRWpoKDAqundu7f8fr/WrFlj1axevVp+vz+opqCgQEVFRVbNkiVL5Ha7lZ6ebtWsWLEiaMmHJUuWyOfzqX379qG4JKfk6MrwkW0HAAA4IvTz8utvzZo1plGjRmbq1Knmq6++Mm+88YaJj483r7/+ulUzffp04/F4zIIFC0x+fr4ZPny4adWqlSkvL7dqRo0aZdq0aWOWLl1q1q1bZ6666irTrVs3U11dbdVcc8015qKLLjK5ubkmNzfXdO3a1QwZMsTaX11dbdLS0kz//v3NunXrzNKlS02bNm1MVlaWVVNWVmZSU1PN8OHDTX5+vlmwYIFp2rSpeeaZZ+r9mcN512H+jjLTbtK7pufUpSE/NgAAZ7OT/f6OaNAyxph33nnHpKWlGbfbbTp37mxefPHFoP2BQMA88cQTxuv1Grfbba644gqTn58fVHPw4EGTlZVlkpKSTFxcnBkyZIgpLCwMqtmzZ48ZMWKESUxMNImJiWbEiBGmtLQ0qGbbtm1m8ODBJi4uziQlJZmsrKygpRyMMWbDhg3mZz/7mXG73cbr9ZrJkyfXe2kHY8IbtDZsPxy0ek0jaAEAEEon+/3tMoYp1KdTeXm5PB6P/H5/yOdr5e/w6/rZK9XK01i5D/cP6bEBADibnez3d8QfwYPQYTI8AAD2QtBykKOT4YlaAADYAUHLQRgDBgDAXghaDmKsxVMj3BAAACCJoOVIBC0AAOyBoOUgDB0CAGAvBC0HsSbDc98hAAC2QNByFOZoAQBgJwQtBznaowUAAOyAoOVArKMFAIA9ELQchMnwAADYC0HLQRg6BADAXghaDmJIWgAA2ApBy0Fqhw7JWQAA2ANBy4GYDA8AgD0QtBzEMBseAABbIWg5iKldsDTC7QAAAIcRtJykdi48SQsAAFsgaDnI0cnwJC0AAOyAoOUghh4tAABshaAFAAAQJgQtBzE8hAcAAFshaDnI0aFDxg4BALADgpaDsDI8AAD2QtBykNpnHdKhBQCAPRC0HIigBQCAPRC0HISp8AAA2AtBy0lqJ8MzSwsAAFsgaDmI9axDchYAALZA0HIQa3mHyDYDAAAcQdByIrq0AACwBYKWgxhmwwMAYCsELQdhwVIAAOyFoOUgLFgKAIC9ELQchB4tAADshaDlIDxUGgAAeyFoAQAAhAlBy1GOzNGKcCsAAMBhBC0HOTp0GNl2AACAwwhaDnJ0MjxJCwAAOyBoOYjhtkMAAGzllINWTU2N1q9fr9LS0lC0ByFAzgIAwB4aHLTGjx+vl19+WdLhkJWRkaHu3burbdu2+uijj0LdPjSAEc/gAQDAThoctP7yl7+oW7dukqR33nlHW7Zs0Zdffqnx48fr0UcfDXkDUX9MhgcAwF4aHLS+++47eb1eSdJ7772nG2+8Ueedd57uvvtu5efnh7yBqD8mwwMAYC8NDlqpqanauHGjampqtHjxYl199dWSpAMHDig6OjrkDUT98axDAADspVFD33DnnXfqpptuUqtWreRyuTRgwABJ0urVq9W5c+eQNxANR9ACAMAeGhy0Jk+erLS0NG3fvl033nij3G63JCk6OloPPfRQyBsIAABwpmpw0JKk//qv/6qz7Y477jjlxuDUWJPhmaMFAIAt1CtoPffcc/U+4NixY0+6MTg1tcs7MHQIAIA91Cto/e53v6vXwVwuF0ErggzLaAEAYCv1ClpbtmwJdzsQQi66tAAAsAWedegg9GgBAGAvJzUZfseOHVq0aJEKCwtVWVkZtG/mzJkhaRgajmdKAwBgLw0OWsuWLdPQoUPVoUMHbdq0SWlpadq6dauMMerevXs42oh6YsFSAADspcFDhw8//LAmTpyogoICNW7cWPPnz9f27duVkZGhG2+8MRxtRD3RowUAgL00OGh98cUX1ppZjRo10sGDB9WkSRNNmTJFTz31VMgbiAawHipN1AIAwA4aHLQSEhJUUVEhSfL5fPr3v/9t7fvuu+9C1zKcNGIWAAD20OA5Wr169dLHH3+sLl26aPDgwZo4caLy8/O1YMEC9erVKxxtRD0ZcdshAAB20uCgNXPmTO3bt0/S4ece7tu3T2+//bY6depU74VNER7WI3jo0gIAwBYaHLQ6duxo/Tk+Pl5z5swJaYNw8o72Z5G0AACwAxYsdRB6tAAAsJd69WglJSVp8+bNSk5OVvPmzU94V9v3338fssbh5JCzAACwh3o/VDoxMVGSNGvWrHC2B6eAyfAAANhLvYJW7bpZ1dXVkqRBgwbJ6/WGr1U4KQwdAgBgLw2ao9WoUSPde++91jpasJejK8OTtAAAsIMGT4bv2bOnPvvss3C0BaeKZx0CAGArDQ5a9913nyZOnKjZs2crNzdXGzZsCHqdrOzsbLlcLo0fP97aZozR5MmT5fP5FBcXp379+unzzz8Pel9FRYXGjBmj5ORkJSQkaOjQodqxY0dQTWlpqTIzM+XxeOTxeJSZmamysrKgmsLCQl1//fVKSEhQcnKyxo4dq8rKyqCa/Px8ZWRkKC4uTq1bt9aUKVOsBznbCUELAAB7qPc6WnfddZdmzZqlm2++WZI0duxYa5/L5ZIxRi6XSzU1NQ1uxNq1a/Xiiy/qoosuCto+Y8YMzZw5U6+++qrOO+88/eY3v9GAAQO0adMma3L++PHj9c4772jevHlq0aKFJk6cqCFDhigvL0/R0dGSpFtvvVU7duzQ4sWLJUm//OUvlZmZqXfeeUeSVFNTo8GDB6tly5ZauXKl9uzZozvuuEPGGD3//POSpPLycg0YMEBXXnml1q5dq82bN2vkyJFKSEjQxIkTG/yZw8F+kQ8AgLOcqaeoqCize/dus3Xr1hO+Gmrv3r3m3HPPNTk5OSYjI8OMGzfOGGNMIBAwXq/XTJ8+3ao9dOiQ8Xg85oUXXjDGGFNWVmZiYmLMvHnzrJqdO3eaqKgos3jxYmOMMRs3bjSSzKpVq6ya3NxcI8l8+eWXxhhj3nvvPRMVFWV27txp1bz11lvG7XYbv99vjDFmzpw5xuPxmEOHDlk12dnZxufzmUAg8KOf79ChQ8bv91uv7du3G0nWcUPp1Y+3mHaT3jX3vZ4X8mMDAHA28/v9J/X9Xe+hQ3NkiKxdu3YnfDXU6NGjNXjwYF199dVB27ds2aLi4mINHDjQ2uZ2u5WRkaFPPvlEkpSXl6eqqqqgGp/Pp7S0NKsmNzdXHo9HPXv2tGp69eolj8cTVJOWliafz2fVDBo0SBUVFcrLy7NqMjIy5Ha7g2p27dqlrVu3/ujny87OtoYsPR6P2rZt29BLVG/Guu0wbKcAAAAN0KA5WidaqPRkzJs3T+vWrVN2dnadfcXFxZKk1NTUoO2pqanWvuLiYsXGxqp58+YnrElJSalz/JSUlKCaY8/TvHlzxcbGnrCm9ufamuN5+OGH5ff7rdf27dt/tPZUHb3rEAAA2EGDnnV43nnn/WTYqu/K8Nu3b9e4ceO0ZMkSNW7c+Efrjj2fOTIX7ESOrTlefShqjHWX34+3x+12B/WChdPRdbSIWgAA2EGDgtaTTz4pj8cTkhPn5eWppKRE6enp1raamhqtWLFCs2fP1qZNmyQd7i1q1aqVVVNSUmL1JHm9XlVWVqq0tDSoV6ukpER9+vSxanbv3l3n/N9++23QcVavXh20v7S0VFVVVUE1x/ZclZSUSKrb6wYAACA1MGjdcsstxx2GOxn9+/dXfn5+0LY777xTnTt31qRJk9SxY0d5vV7l5OTokksukSRVVlZq+fLleuqppyRJ6enpiomJUU5Ojm666SZJUlFRkQoKCjRjxgxJUu/eveX3+7VmzRpddtllkqTVq1fL7/dbYax3796aOnWqioqKrFC3ZMkSud1uKwj27t1bjzzyiCorKxUbG2vV+Hw+tW/fPiTX5FQxdAgAgL3UO2iFejgqMTFRaWlpQdsSEhLUokULa/v48eM1bdo0nXvuuTr33HM1bdo0xcfH69Zbb5UkeTwe3X333Zo4caJatGihpKQk3X///eratas1uf6CCy7QNddco3vuuUd/+MMfJB1e3mHIkCE6//zzJUkDBw5Uly5dlJmZqaefflrff/+97r//ft1zzz1q2rSppMNLRDz55JMaOXKkHnnkEX311VeaNm2aHn/8cdsM1RkWLAUAwFbqHbRMBBbmfPDBB3Xw4EHdd999Ki0tVc+ePbVkyRJrDS3p8AOvGzVqpJtuukkHDx5U//799eqrr1praEnSG2+8obFjx1p3Jw4dOlSzZ8+29kdHR+vvf/+77rvvPl1++eWKi4vTrbfeqmeeecaq8Xg8ysnJ0ejRo9WjRw81b95cEyZM0IQJE07DlWgYchYAAPbgMpFIUGex8vJyeTwe+f1+q7csVF5a8Y2mvveFfn5Ja/3u5otDemwAAM5mJ/v93eBH8MD+6NECAMAeCFoOYngIDwAAtkLQchDDbYcAANgKQctBjuYskhYAAHZA0HKQoyvDR7YdAADgMIKWA5GzAACwB4KWgzAZHgAAeyFoOQhDhwAA2AtBy4GYDA8AgD0QtByEZx0CAGAvBC0HImgBAGAPBC0H4amVAADYC0HLQY7mLLq0AACwA4KWg3DXIQAA9kLQcpDadbTIWQAA2ANBy0Ho0QIAwF4IWg7EOloAANgDQctBuOkQAAB7IWg5CQuWAgBgKwQtB6nt0SJnAQBgDwQtBzk6GZ6oBQCAHRC0AAAAwoSg5SCG6fAAANgKQctBWEcLAAB7IWg5yNHJ8CQtAADsgKDlIPRoAQBgLwQtByJnAQBgDwQtB2EyPAAA9kLQchKGDgEAsBWCloNYk+FJWgAA2AJBy0FM7bMOI9wOAABwGEHLQQwPOwQAwFYIWgAAAGFC0HIQFiwFAMBeCFoOEjgydhhFzgIAwBYIWg7CyvAAANgLQcuBokhaAADYAkHLQQIs7wAAgK0QtBzk6PIORC0AAOyAoOUgtc86ZDI8AAD2QNBykEDtZHgGDwEAsAWCloNw1yEAAPZC0HIUhg4BALATgpaDBAKH/+miSwsAAFsgaDmIsR7CAwAA7ICg5SC1c7RYsBQAAHsgaDlIgMnwAADYCkHLQWqHDslZAADYA0HLSRg6BADAVghaDmI965CcBQCALRC0HIR7DgEAsBeCloNw1yEAAPZC0HIQhg4BALAXgpaD1A4dkrMAALAHgpaT1A4d8rBDAABsgaDlINbQYYTbAQAADiNoOYixxg6JWgAA2AFBy0FqV4Zn5BAAAHsgaDmI9axDBg8BALAFgpaDGB4qDQCArRC0HIWhQwAA7ISg5SAMHQIAYC8ELQcx1thhZNsBAAAOI2g5SO3qDjzrEAAAeyBoOUiADi0AAGyFoOUghodKAwBgKxENWtnZ2br00kuVmJiolJQUDRs2TJs2bQqqMcZo8uTJ8vl8iouLU79+/fT5558H1VRUVGjMmDFKTk5WQkKChg4dqh07dgTVlJaWKjMzUx6PRx6PR5mZmSorKwuqKSws1PXXX6+EhAQlJydr7NixqqysDKrJz89XRkaG4uLi1Lp1a02ZMuXo3CibYOgQAAB7iGjQWr58uUaPHq1Vq1YpJydH1dXVGjhwoPbv32/VzJgxQzNnztTs2bO1du1aeb1eDRgwQHv37rVqxo8fr4ULF2revHlauXKl9u3bpyFDhqimpsaqufXWW7V+/XotXrxYixcv1vr165WZmWntr6mp0eDBg7V//36tXLlS8+bN0/z58zVx4kSrpry8XAMGDJDP59PatWv1/PPP65lnntHMmTPDfKXqJ0CPFgAA9mJspKSkxEgyy5cvN8YYEwgEjNfrNdOnT7dqDh06ZDwej3nhhReMMcaUlZWZmJgYM2/ePKtm586dJioqyixevNgYY8zGjRuNJLNq1SqrJjc310gyX375pTHGmPfee89ERUWZnTt3WjVvvfWWcbvdxu/3G2OMmTNnjvF4PObQoUNWTXZ2tvH5fCYQCNTrM/r9fiPJOmYoDX8x17Sb9K752/qdP10MAADq7WS/v201R8vv90uSkpKSJElbtmxRcXGxBg4caNW43W5lZGTok08+kSTl5eWpqqoqqMbn8yktLc2qyc3NlcfjUc+ePa2aXr16yePxBNWkpaXJ5/NZNYMGDVJFRYXy8vKsmoyMDLnd7qCaXbt2aevWrcf9TBUVFSovLw96hYvVoxW2MwAAgIawTdAyxmjChAnq27ev0tLSJEnFxcWSpNTU1KDa1NRUa19xcbFiY2PVvHnzE9akpKTUOWdKSkpQzbHnad68uWJjY09YU/tzbc2xsrOzrXlhHo9Hbdu2/YkrcfJ4BA8AAPZim6CVlZWlDRs26K233qqzz3VMcjDG1Nl2rGNrjlcfihpjzYs6fnsefvhh+f1+67V9+/YTtvtUsI4WAAD2YougNWbMGC1atEgffvih2rRpY233er2S6vYWlZSUWD1JXq9XlZWVKi0tPWHN7t2765z322+/Dao59jylpaWqqqo6YU1JSYmkur1utdxut5o2bRr0ChfD0CEAALYS0aBljFFWVpYWLFigDz74QB06dAja36FDB3m9XuXk5FjbKisrtXz5cvXp00eSlJ6erpiYmKCaoqIiFRQUWDW9e/eW3+/XmjVrrJrVq1fL7/cH1RQUFKioqMiqWbJkidxut9LT062aFStWBC35sGTJEvl8PrVv3z5EV+XkMXQIAIC9RDRojR49Wq+//rrefPNNJSYmqri4WMXFxTp48KCkw8Nx48eP17Rp07Rw4UIVFBRo5MiRio+P16233ipJ8ng8uvvuuzVx4kQtW7ZMn332mW677TZ17dpVV199tSTpggsu0DXXXKN77rlHq1at0qpVq3TPPfdoyJAhOv/88yVJAwcOVJcuXZSZmanPPvtMy5Yt0/3336977rnH6oW69dZb5Xa7NXLkSBUUFGjhwoWaNm2aJkyY8JNDmadD7dChHdoCAAAU2eUddDgb1Hm98sorVk0gEDBPPPGE8Xq9xu12myuuuMLk5+cHHefgwYMmKyvLJCUlmbi4ODNkyBBTWFgYVLNnzx4zYsQIk5iYaBITE82IESNMaWlpUM22bdvM4MGDTVxcnElKSjJZWVlBSzkYY8yGDRvMz372M+N2u43X6zWTJ0+u99IOxoR3eYdhv19p2k1617xfUBTyYwMAcDY72e9vlzE2W9bc4crLy+XxeOT3+0M+X2vY7z/W+u1leun2HhrQ5fhzxgAAQMOd7Pe3LSbDIzSO3nUY0WYAAIAjCFoOYngEDwAAtkLQchDrrkMWeAAAwBYIWg5iRI8WAAB2QtBykEDg8D9Z3gEAAHsgaDmItY5WRFsBAABqNYp0AxA6xhj1jvpc7Td8LO2Ij3RzAACIjIyHpGh7RBx7tAIhYYz0h5iZalpwMNJNAQAgcq54MNItsBC0nMTUqKnrSMjqfofUqHFk2wMAQCS47DMziqDlIFGm5ugPA38tNfZErjEAAIDJ8E7i+mHQiiJDAwAQaQQtB4nSD4KWKzpyDQEAAJIIWo4SZQI/+IEeLQAAIo2g5SAuU330hyh6tAAAiDSCloPUToY3rmiewwMAgA0QtBwkujZo0ZsFAIAtELQcxPXDHi0AABBxBC0HcdVOhncxER4AADsgaDlItBg6BADATghaDhJ15K5DQ48WAAC2QNByEGsdrSj+WgEAsAO+kR3EWkeLHi0AAGyBoOUgLmuOFkELAAA7IGg5iCtw5FmHTIYHAMAWCFoOUrsyPM85BADAHghaDmIFLRYsBQDAFghaDuKiRwsAAFshaDnI0aBFjxYAAHZA0HKQKNGjBQCAnRC0HCQqQNACAMBOCFoOcrRHi6FDAADsgKDlEMaYHzyCh6AFAIAdELQcwhgp+kiPlouhQwAAbIFvZIeoMUaNXAwdAkCtmpoaVVVVRboZOEPExMQoOjr0358ELYcIGKNoHRk6jI6JbGMAIIKMMSouLlZZWVmkm4IzTLNmzeT1euVyuUJ2TIKWQwQCUiOGDgHAClkpKSmKj48P6ZcmnMkYowMHDqikpESS1KpVq5Adm29kh/hhj5Yrmr9WAGenmpoaK2S1aNEi0s3BGSQuLk6SVFJSopSUlJANIzIZ3iFqjFEjVR/+gR4tAGep2jlZ8fHxEW4JzkS1vzehnNtH0HIIE5Aa1fZoEbQAnOUYLsTJCMfvDUHLIWqMObq8A5PhAQCwBYKWQ9QEzNEeLeZoAQBgCwQthzDGKNrFsw4B4EyVnZ2tSy+9VImJiUpJSdGwYcO0adOm03LuV199Vc2aNTst5zrbELQc4vBkeIIWAJypli9frtGjR2vVqlXKyclRdXW1Bg4cqP3790e6aTgFBC2HCBgdXbCUleEBwGKM0YHK6oi8jDH1bufixYs1cuRIXXjhherWrZteeeUVFRYWKi8v74Tvq6io0NixY5WSkqLGjRurb9++Wrt2rbX/o48+ksvl0t///nd169ZNjRs3Vs+ePZWfn2/tv/POO+X3++VyueRyuTR58uSTutaoi64PhwgEjGKt5R2YDA8AtQ5W1ajL4+9H5NwbpwxSfOzJfdX6/X5JUlJS0gnrHnzwQc2fP1+vvfaa2rVrpxkzZmjQoEH6+uuvg977wAMP6Nlnn5XX69UjjzyioUOHavPmzerTp49mzZqlxx9/3BqqbNKkyUm1GXXRo+UQAWPk1pF1Pxo1jmxjAACnxBijCRMmqG/fvkpLS/vRuv3792vu3Ll6+umnde2116pLly566aWXFBcXp5dffjmo9oknntCAAQPUtWtXvfbaa9q9e7cWLlyo2NhYeTweuVwueb1eeb1eglYI0aPlEDUBI7erNmi5I9sYALCRuJhobZwyKGLnPhlZWVnasGGDVq5caW2bNm2apk2bZv28ceNGlZWVqaqqSpdffrm1PSYmRpdddpm++OKLoGP27t3b+nNSUpLOP//8OjUIPYKWQwSMFEuPFgDU4XK5Tnr4LhLGjBmjRYsWacWKFWrTpo21fdSoUbrpppusn30+n0pLSyXVXWjTGFOvxTdZ2DX8GDp0iOChw9jINgYA0GDGGGVlZWnBggX64IMP1KFDh6D9SUlJ6tSpk/Vq1KiROnXqpNjY2KCer6qqKn366ae64IILgt6/atUq68+lpaXavHmzOnfuLEmKjY1VTU1NGD/d2evMifg4oYAxaqzKwz/QowUAZ5zRo0frzTff1N/+9jclJiaquLhYkuTxeKwHHh8rISFB9957rx544AElJSXpnHPO0YwZM3TgwAHdfffdQbVTpkxRixYtlJqaqkcffVTJyckaNmyYJKl9+/bat2+fli1bpm7duik+Pp7nRYYIPVoOURMwauw6ErRijv8vJADAvubOnSu/369+/fqpVatW1uvtt98+4fumT5+uX/ziF8rMzFT37t319ddf6/3331fz5s3r1I0bN07p6ekqKirSokWLFBt7eASkT58+GjVqlG6++Wa1bNlSM2bMCNvnPNvQo+UQgYB+0KNF0AKAM01D1tz6ocaNG+u5557Tc889d8K6vn37qqCg4Ef3z507V3Pnzj2pNuDH0aPlEFWBwNGgRY8WAAC2QNByiJqAIWgBAGAzDB06RFVNQHHM0QIAHKNfv34nPSyJU0ePlkME9WgxRwsAAFsgaDlEdY1RY1Uc/iGG5R0AALADgpZD1FRXKdZ1ZLG5GNY+AQDADghaDhGoPHD0BxYsBQDAFghaTlF1OGgF5CJoAQBgEwQth4iq2CtJOuiKl6L4awUAwA74RnaKinJJ0sGohAg3BAAA1CJoOUR05eGgdYigBQBnpOzsbF166aVKTExUSkqKhg0bpk2bNp2Wc7/66qtq1qxZ2M/z0UcfyeVyWa8WLVroqquu0scffyzp8MOtf7j/2Fe/fv3q1MXFxal9+/a66aab9MEHHwSdb+vWrXK5XFq/fn3YP9uPIWg5hOtIj9ah6CYRbgkA4GQsX75co0eP1qpVq5STk6Pq6moNHDhQ+/fvj3TTftTkyZM1cuTIBr9v06ZNKioq0kcffaSWLVtq8ODBKikp0dq1a1VUVKSioiLNnz8/qLaoqEgLFiywjjFlyhQVFRVp06ZN+uMf/6hmzZrp6quv1tSpU0P18UKCoOUUR4JWRSOCFgAEMUaq3B+ZVwNWZF+8eLFGjhypCy+8UN26ddMrr7yiwsJC5eXlnfB9FRUVGjt2rFJSUtS4cWP17dtXa9eutfbX9iL9/e9/V7du3dS4cWP17NlT+fn51v4777xTfr/f6iWaPHnySV3q+kpJSZHX61XXrl312GOPye/3a/Xq1WrZsqW8Xq+8Xq+SkpKCan+4TZISExPl9Xp1zjnn6IorrtCLL76o//f//p8ef/zx09YTWB88gschoo4ErapGiRFuCQDYTNUBaZovMud+ZJcUe3JTOvx+vyQFhYvjefDBBzV//ny99tprateunWbMmKFBgwbp66+/DnrvAw88oGeffVZer1ePPPKIhg4dqs2bN6tPnz6aNWtWUEBp0uT0/E/7gQMH9Morr0iSYmJiTvl448aN069//Wv97W9/04MPPnjKxwsFerROwpw5c9ShQwc1btxY6enp+uc//xnpJllztKpi6NECgDOdMUYTJkxQ3759lZaW9qN1+/fv19y5c/X000/r2muvVZcuXfTSSy8pLi5OL7/8clDtE088oQEDBqhr16567bXXtHv3bi1cuFCxsbHyeDxyuVxWz1G4g1abNm3UpEkTNWnSRL/73e+Unp6u/v37n/Jxk5KSlJKSoq1bt556I0OEHq0GevvttzV+/HjNmTNHl19+uf7whz/o2muv1caNG3XOOedErF3RVYeXdwjENo1YGwDAlmLiD/csRercJyErK0sbNmzQypUrrW3Tpk3TtGnTrJ83btyosrIyVVVV6fLLLz96ypgYXXbZZfriiy+Cjtm7d2/rz0lJSTr//PPr1PyUf/7zn7r22mutnysrK2WM0V/+8hdr2yOPPKJHHnnkJ4+TkJCgzz77TJMmTdKrr74akh4t6XBIdblcITlWKBC0GmjmzJm6++679d///d+SpFmzZun999/X3LlzlZ2dHbF2xRzaI0lyxTePWBsAwJZcrpMevouEMWPGaNGiRVqxYoXatGljbR81apRuuukm62efz6fS0lJJqhMs6hs2GhpIevToEXQH33PPPaedO3fqqaeesrb91FCnJHXo0EHNmjXTeeedp0OHDunnP/+5CgoK5Ha7G9SeY+3Zs0fffvutOnTocErHCSWGDhugsrJSeXl5GjhwYND2gQMH6pNPPjnueyoqKlReXh70CrUDe3aq097DEx+jWp4f8uMDAMLPGKOsrCwtWLBAH3zwQZ2wkJSUpE6dOlmvRo0aqVOnToqNjQ3q+aqqqtKnn36qCy64IOj9q1atsv5cWlqqzZs3q3PnzpKk2NhY1dTU/GQb4+LigtqQlJSkxMTEOtsaIjMzU4FAQHPmzGnQ+47n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7969Vs1f/vIXde3aVXFxcWrRooWuvvpq7d+/P0xXE8DJImgBcKRnn31WvXv31j333KOioiIVFRWpbdu2KioqUkZGhi6++GJ9+umnWrx4sXbv3q2bbrop6P2vvfaaGjVqpI8//lh/+MMfJElRUVF67rnnVFBQoNdee00ffPCBHnzwQUlSnz59NGvWLDVt2tQ63/3331+nXcYYDRs2TN9//72WL1+unJwc/fvf/9bNN98cVPfvf/9bf/3rX/Xuu+/q3Xff1fLlyzV9+nRJUlFRkYYPH6677rpLX3zxhT766CPdcMMNMsaE41ICOAUMHQJwJI/Ho9jYWMXHx8vr9Vrb586dq+7du2vatGnWtv/7v/9T27ZttXnzZp133nmSpE6dOmnGjBlBx/zhfK8OHTro17/+te69917NmTNHsbGx8ng8crlcQec71tKlS7VhwwZt2bJFbdu2lST96U9/0oUXXqi1a9fq0ksvlSQFAgG9+uqrSkxMlCRlZmZq2bJlmjp1qoqKilRdXa0bbrhB7dq1kyR17dr1FK4WgHChRwvAWSUvL08ffvihmjRpYr06d+4s6XAvUq0ePXrUee+HH36oAQMGqHXr1kpMTNTtt9+uPXv2NGjI7osvvlDbtm2tkCVJXbp0UbNmzfTFF19Y29q3b2+FLElq1aqVSkpKJEndunVT//791bVrV91444166aWXVFpaWv+LAOC0IWgBOKsEAgFdf/31Wr9+fdDrq6++0hVXXGHVJSQkBL1v27Ztuu6665SWlqb58+crLy9Pv//97yVJVVVV9T6/MUYul+snt8fExATtd7lcCgQCkqTo6Gjl5OToH//4h7p06aLnn39e559/vrZs2VLvdgA4PQhaABwrNjZWNTU1Qdu6d++uzz//XO3bt1enTp2CXseGqx/69NNPVV1drd/+9rfq1auXzjvvPO3atesnz3esLl26qLCwUNu3b7e2bdy4UX6/XxdccEG9P5vL5dLll1+uJ598Up999pliY2O1cOHCer8fwOlB0ALgWO3bt9fq1au1detWfffddwoEAho9erS+//57DR8+XGvWrNE333yjJUuW6K677jphSPqP//gPVVdX6/nnn9c333yjP/3pT3rhhRfqnG/fvn1atmyZvvvuOx04cKDOca6++mpddNFFGjFihNatW6c1a9bo9ttvV0ZGxnGHK49n9erVmjZtmj799FMVFhZqwYIF+vbbbxsU1ACcHgQtAI51//33Kzo6Wl26dFHLli1VWFgon8+njz/+WDU1NRo0aJDS0tI0btw4eTweRUX9+H8SL774Ys2cOVNPPfWU0tLS9MYbbyg7Ozuopk+fPho1apRuvvlmtWzZss5keulwT9Rf//pXNW/eXFdccYWuvvpqdezYUW+//Xa9P1fTpk21YsUKXXfddTrvvPP02GOP6be//a2uvfba+l8cAKeFy3A/MAAAQFjQowUAABAmBC0AAIAwIWgBAACECUELAAAgTAhaAAAAYULQAgAACBOCFgAAQJgQtAAAAMKEoAUAABAmBC0AAIAwIWgBAACEyf8HK6pFA+FTuGUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.nancumsum(np.nanmean(logger_orig.sum_attempts, axis = 0)), label = '2-opt')\n",
    "plt.plot(np.nancumsum(np.nanmean(logger_rtdl.sum_attempts, axis = 0)), label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "#ax.set_ylim([0, 60])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Trials')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "000b40dc-f6f0-40d8-9e3e-caebbca87640",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850.])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.nanmax(logger_orig.sum_attempts, axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fd8442ee-0258-4bc9-b829-b7cac7c56a03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850.])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.nanmax(logger_rtdl.sum_attempts, axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9b8183e6-b849-400f-9f63-eede54d5cab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_113752/2171339728.py:1: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
      "/tmp/ipykernel_113752/2171339728.py:2: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
    "plt.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "#ax.set_ylim([0, 60])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Trials')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
