{
 "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 import plot_tour, two_opt_rtdl, two_opt, Logger, calculate_total_distance\n",
    "from tsp_rtdl_util import create_problem"
   ]
  },
  {
   "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\n",
    "DIM = 2"
   ]
  },
  {
   "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:37,  1.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 357 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:02<01:50,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 416 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [00:03<01:54,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:05<02:09,  1.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 397 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [00:06<02:10,  1.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 346 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [00:08<02:15,  1.44s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 439 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [00:09<02:03,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 394 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:10<01:50,  1.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [00:11<01:58,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 421 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:12<01:50,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 334 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:13<01:47,  1.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 375 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [00:14<01:43,  1.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 389 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [00:16<01:39,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [00:17<01:37,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 399 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [00:18<01:40,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 393 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [00:19<01:38,  1.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 414 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [00:21<01:47,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 425 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [00:22<01:39,  1.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 382 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [00:23<01:43,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 412 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [00:24<01:37,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 411 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [00:26<01:41,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 377 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [00:27<01:37,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 404 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [00:28<01:41,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 419 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [00:30<01:46,  1.41s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 433 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [00:31<01:34,  1.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [00:32<01:36,  1.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [00:34<01:36,  1.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 410 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [00:35<01:30,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 390 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [00:36<01:23,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [00:37<01:25,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [00:38<01:29,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 409 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [00:40<01:27,  1.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 407 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [00:41<01:23,  1.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 374 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [00:42<01:15,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 386 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [00:43<01:07,  1.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [00:44<01:15,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 425 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [00:45<01:14,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 403 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [00:46<01:10,  1.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 377 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [00:47<01:09,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 389 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [00:49<01:09,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [00:50<01:08,  1.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [00:51<01:11,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 408 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [00:53<01:15,  1.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 442 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [00:54<01:07,  1.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 352 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [00:55<01:02,  1.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 411 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [00:56<01:10,  1.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 384 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [00:57<01:05,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 408 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [00:59<01:05,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 364 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [01:00<01:00,  1.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [01:01<01:02,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 424 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [01:02<01:00,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 365 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [01:04<00:59,  1.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 393 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [01:04<00:51,  1.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [01:05<00:48,  1.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 397 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [01:06<00:45,  1.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 400 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [01:07<00:40,  1.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 371 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [01:08<00:42,  1.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [01:09<00:37,  1.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 375 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [01:10<00:38,  1.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 372 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [01:11<00:45,  1.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [01:13<00:45,  1.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [01:13<00:40,  1.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [01:14<00:38,  1.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 404 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [01:15<00:36,  1.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [01:17<00:36,  1.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 338 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [01:18<00:35,  1.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 389 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [01:18<00:30,  1.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 354 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [01:19<00:31,  1.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 414 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [01:20<00:31,  1.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 395 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [01:22<00:31,  1.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [01:22<00:29,  1.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 371 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [01:23<00:27,  1.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 333 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [01:25<00:29,  1.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 382 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [01:26<00:31,  1.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 447 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [01:28<00:31,  1.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 376 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [01:29<00:29,  1.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 386 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [01:30<00:31,  1.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 403 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [01:32<00:29,  1.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 419 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [01:33<00:29,  1.41s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 390 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [01:34<00:26,  1.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [01:36<00:24,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [01:37<00:25,  1.41s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 401 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [01:38<00:22,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 333 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [01:40<00:21,  1.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 444 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [01:41<00:19,  1.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 380 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [01:42<00:16,  1.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 351 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [01:43<00:15,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 390 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [01:44<00:12,  1.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 330 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [01:44<00:10,  1.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 354 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [01:46<00:09,  1.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 398 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [01:47<00:09,  1.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [01:49<00:10,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 459 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [01:50<00:08,  1.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 403 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [01:50<00:06,  1.08s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 381 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [01:52<00:05,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 410 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [01:53<00:04,  1.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 409 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [01:54<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:55<00:02,  1.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [01:56<00:01,  1.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 368 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:57<00:00,  1.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 379 4850\n",
      "CPU times: user 1min 56s, sys: 1.29 s, total: 1min 57s\n",
      "Wall time: 1min 57s\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, dim = DIM)\n",
    "    initial_tour = list(range(cities.shape[0]))\n",
    "\n",
    "    logger_orig.problem_started()\n",
    "    optimized_tour, optimized_distance = two_opt(initial_tour, distance_matrix, max_iterations = MAX_ITER, logger = logger_orig)\n",
    "    logger_orig.problem_solved()\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": [
       "117.79853200912476"
      ]
     },
     "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": [
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:02<03:36,  2.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "stat 317 4850\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": [
      "  2%|▏         | 2/100 [00:04<03:28,  2.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "stat 344 4850\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": [
      "  3%|▎         | 3/100 [00:06<03:25,  2.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 335 4850\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",
      "stat 372 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:08<03:30,  2.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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": [
      "  5%|▌         | 5/100 [00:10<03:26,  2.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 331 4850\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": [
      "  6%|▌         | 6/100 [00:12<03:23,  2.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\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 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": [
      "  7%|▋         | 7/100 [00:15<03:26,  2.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 361 4850\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 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",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:17<03:30,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 367 4850\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": [
      "  9%|▉         | 9/100 [00:19<03:19,  2.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 323 4850\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 359 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:22<03:20,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 0 calc rtdl\n",
      "iter 10 calc rtdl\n",
      "iter 20 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": [
      " 11%|█         | 11/100 [00:24<03:13,  2.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "stat 310 4850\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 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": [
      " 12%|█▏        | 12/100 [00:26<03:15,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\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",
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [00:28<03:12,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 338 4850\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": [
      " 14%|█▍        | 14/100 [00:30<03:09,  2.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "stat 347 4850\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": [
      " 15%|█▌        | 15/100 [00:33<03:09,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 362 4850\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": [
      " 16%|█▌        | 16/100 [00:35<03:07,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n",
      "stat 351 4850\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 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",
      "stat 309 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [00:37<03:03,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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 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 300 calc rtdl\n",
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [00:39<03:04,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 347 4850\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 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": [
      " 19%|█▉        | 19/100 [00:42<03:01,  2.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 323 4850\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 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": [
      " 20%|██        | 20/100 [00:44<03:04,  2.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 379 4850\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": [
      " 21%|██        | 21/100 [00:46<02:59,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 338 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [00:48<02:48,  2.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 280 calc rtdl\n",
      "iter 290 calc rtdl\n",
      "stat 296 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [00:50<02:51,  2.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "stat 363 4850\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": [
      " 24%|██▍       | 24/100 [00:53<02:52,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\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",
      "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": [
      " 25%|██▌       | 25/100 [00:55<02:55,  2.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 370 calc rtdl\n",
      "stat 372 4850\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": [
      " 26%|██▌       | 26/100 [00:58<02:53,  2.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 363 4850\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": [
      " 27%|██▋       | 27/100 [01:00<02:51,  2.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 351 4850\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": [
      " 28%|██▊       | 28/100 [01:02<02:47,  2.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 358 4850\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",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [01:04<02:41,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 328 4850\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 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": [
      " 30%|███       | 30/100 [01:07<02:38,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 327 4850\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": [
      " 31%|███       | 31/100 [01:09<02:35,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\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 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": [
      " 32%|███▏      | 32/100 [01:11<02:35,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 355 4850\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 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": [
      " 33%|███▎      | 33/100 [01:14<02:37,  2.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 380 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "stat 395 4850\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",
      "iter 300 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [01:16<02:28,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "stat 316 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [01:18<02:23,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 328 4850\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",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [01:20<02:22,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 341 4850\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": [
      " 37%|███▋      | 37/100 [01:23<02:21,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 358 4850\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",
      "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": [
      " 38%|███▊      | 38/100 [01:25<02:20,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 364 4850\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",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [01:27<02:24,  2.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 370 calc rtdl\n",
      "stat 377 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [01:30<02:17,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "iter 320 calc rtdl\n",
      "stat 325 4850\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": [
      " 41%|████      | 41/100 [01:32<02:15,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 351 4850\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",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [01:34<02:16,  2.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 360 4850\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": [
      " 43%|████▎     | 43/100 [01:37<02:12,  2.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 351 4850\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 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 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": [
      " 44%|████▍     | 44/100 [01:39<02:12,  2.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 369 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [01:41<02:05,  2.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 305 4850\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": [
      " 46%|████▌     | 46/100 [01:43<02:03,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 352 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [01:46<02:00,  2.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 337 4850\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 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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [01:48<01:53,  2.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 290 calc rtdl\n",
      "stat 291 4850\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": [
      " 49%|████▉     | 49/100 [01:50<01:54,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 359 4850\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",
      "stat 317 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [01:52<01:50,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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": [
      " 51%|█████     | 51/100 [01:54<01:48,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "stat 344 4850\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": [
      " 52%|█████▏    | 52/100 [01:57<01:48,  2.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 370 calc rtdl\n",
      "stat 371 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [01:59<01:48,  2.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 352 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [02:02<01:48,  2.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 361 4850\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 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": [
      " 55%|█████▌    | 55/100 [02:04<01:47,  2.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 356 4850\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 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 324 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [02:06<01:42,  2.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [02:09<01:42,  2.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 390 calc rtdl\n",
      "stat 396 4850\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",
      "iter 350 calc rtdl\n",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [02:11<01:40,  2.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 367 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [02:13<01:35,  2.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 329 4850\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": [
      " 60%|██████    | 60/100 [02:16<01:32,  2.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "stat 320 4850\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": [
      " 61%|██████    | 61/100 [02:18<01:29,  2.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 344 4850\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 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:20<01:26,  2.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 335 4850\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": [
      " 63%|██████▎   | 63/100 [02:22<01:21,  2.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 323 4850\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 [02:25<01:20,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 360 4850\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 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": [
      " 65%|██████▌   | 65/100 [02:27<01:17,  2.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "stat 333 4850\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 344 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [02:29<01:15,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [02:31<01:12,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 328 4850\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": [
      " 68%|██████▊   | 68/100 [02:33<01:11,  2.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 340 calc rtdl\n",
      "stat 346 4850\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 [02:35<01:07,  2.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "stat 310 4850\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",
      "iter 320 calc rtdl\n",
      "stat 327 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [02:38<01:06,  2.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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": [
      " 71%|███████   | 71/100 [02:40<01:03,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 336 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [02:42<01:01,  2.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 330 4850\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": [
      " 73%|███████▎  | 73/100 [02:44<01:00,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 365 4850\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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [02:47<00:59,  2.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 350 calc rtdl\n",
      "stat 351 4850\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": [
      " 75%|███████▌  | 75/100 [02:49<00:57,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 364 4850\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": [
      " 76%|███████▌  | 76/100 [02:51<00:54,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 337 4850\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": [
      " 77%|███████▋  | 77/100 [02:54<00:51,  2.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "iter 340 calc rtdl\n",
      "stat 342 4850\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",
      "iter 320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [02:56<00:49,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 330 calc rtdl\n",
      "stat 331 4850\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",
      "iter 340 calc rtdl\n",
      "iter 350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [02:58<00:48,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 351 4850\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 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": [
      " 80%|████████  | 80/100 [03:01<00:46,  2.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 346 4850\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",
      "stat 320 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [03:03<00:44,  2.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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 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": [
      " 82%|████████▏ | 82/100 [03:05<00:41,  2.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 330 4850\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",
      "iter 340 calc rtdl\n",
      "stat 345 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [03:07<00:38,  2.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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",
      "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 354 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [03:10<00:36,  2.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [03:12<00:34,  2.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 384 4850\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": [
      " 86%|████████▌ | 86/100 [03:14<00:30,  2.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 297 4850\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",
      "iter 360 calc rtdl\n",
      "iter 370 calc rtdl\n",
      "iter 380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [03:17<00:30,  2.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 383 4850\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",
      "stat 354 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [03:19<00:27,  2.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [03:21<00:25,  2.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 329 4850\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 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 [03:23<00:22,  2.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 338 4850\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",
      "stat 379 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [03:26<00:21,  2.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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 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",
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [03:29<00:19,  2.44s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 384 4850\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 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",
      "iter 360 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [03:31<00:17,  2.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 362 4850\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 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": [
      " 94%|█████████▍| 94/100 [03:33<00:14,  2.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 321 4850\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 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",
      "stat 344 4850\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [03:36<00:11,  2.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [03:38<00:09,  2.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 310 calc rtdl\n",
      "stat 315 4850\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 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": [
      " 97%|█████████▋| 97/100 [03:40<00:06,  2.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 360 calc rtdl\n",
      "stat 362 4850\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 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 [03:42<00:04,  2.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 320 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "stat 334 4850\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 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": [
      " 99%|█████████▉| 99/100 [03:45<00:02,  2.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 349 4850\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 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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [03:47<00:00,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 290 calc rtdl\n",
      "stat 295 4850\n",
      "CPU times: user 3min 46s, sys: 1.42 s, total: 3min 47s\n",
      "Wall time: 3min 47s\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, dim = DIM)\n",
    "    initial_tour = list(range(cities.shape[0]))\n",
    "\n",
    "    logger_rtdl.problem_started()\n",
    "    optimized_tour, optimized_distance = two_opt_rtdl(initial_tour, distance_matrix, max_iterations = MAX_ITER, logger = logger_rtdl,\\\n",
    "                                                      progressive = True)\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.226460727443603, 0.027666074323507872)"
      ]
     },
     "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": [
       "227.1739022731781"
      ]
     },
     "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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F+TsMW81YcIECgoK+OKLL9zG7733XtfPWVlZDBo0iLS0ND799NMm/7jO5Ml/m5EjR7p+7tu3L9dccw3dunVj9uzZrp0tL+W19uR1Ptubb77JyJEjSU5Odo354mt9Pq3x+p5reW/4W9TV1XHffffR2NjI73//e7d5jz76qOvnrKwsunfvzqBBg1i7di0DBgwAvG+9W+t97W3rfaa33nqLBx98kNDQULdxb369z/eZBZ7z79snvzLr1KkTgYGBTZphaWlpkybqjZ588knmz5/P0qVLSUlJueCySUlJpKWlsWPHDgASExOpra2lrKzMbTlv+ttERETQt29fduzY4Tra7EKvtbev8969e/nss8945JFHLricL77WrfX6JiYmcujQoSaPf/jwYY/+W9TV1XHPPfdQWFhIXl6e29ahcxkwYADBwcFu7wFvXO8zXcr72pvX+/PPP2fbtm0X/fcO3vN6n+8zy9P+fftkIQoJCWHgwIGuzYin5eXlkZOTY1Gqy2eaJhMmTGDu3LksWbKEjIyMi97n6NGj7Nu3j6SkJAAGDhxIcHCw29+muLiYjRs3es3fpqamhi1btpCUlOTafHzm+tTW1pKfn+9aH29f57fffpv4+Hhuv/32Cy7ni691a72+11xzDQ6Hg2+++ca1zNdff43D4fDYv8XpMrRjxw4+++wzOnbseNH7bNq0ibq6Otd7wBvX+2yX8r725vV+8803GThwINnZ2Rdd1tNf74t9Znncv+/m7x/uXd5//30zODjYfPPNN83NmzebEydONCMiIsw9e/ZYHe2SPf7446bdbjeXLVtmFhcXu6aqqirTNE2zoqLCfPbZZ80VK1aYhYWF5tKlS81rrrnG7Ny5s1leXu56nMcee8xMSUkxP/vsM3Pt2rXmsGHDzOzsbLO+vt6qVbugZ5991ly2bJm5e/duc+XKleYdd9xhRkVFuV7LV155xbTb7ebcuXPNDRs2mPfff7+ZlJTk1et8WkNDg9mlSxfzxz/+sdu4L73WFRUV5rp168x169aZgDl9+nRz3bp1rqOpWuv1vfXWW81+/fqZX331lfnVV1+Zffv2Ne+44452X9/TLrTedXV15qhRo8yUlBRz/fr1bv/ea2pqTNM0zZ07d5ovv/yyuWrVKrOwsND89NNPzV69eplXXnml1653a76vvWm9T3M4HGZ4eLj5+uuvN7m/N77eF/vMMk3P+vfts4XINE3zd7/7nZmWlmaGhISYAwYMcDs83RsB55zefvtt0zRNs6qqyhwxYoQZFxdnBgcHm126dDEfeughs6ioyO1xTp48aU6YMMGMjY01w8LCzDvuuKPJMp7k3nvvNZOSkszg4GAzOTnZHDNmjLlp0ybX/MbGRvOll14yExMTTZvNZt5www3mhg0b3B7D29b5tIULF5qAuW3bNrdxX3qtly5des739UMPPWSaZuu9vkePHjUffPBBMyoqyoyKijIffPBBs6ysrJ3WsqkLrXdhYeF5/70vXbrUNE3TLCoqMm+44QYzNjbWDAkJMbt162Y+9dRT5tGjR92ex5vWuzXf19603qf98Y9/NMPCwszjx483ub83vt4X+8wyTc/6922cCi0iIiLit3xyHyIRERGRllAhEhEREb+nQiQiIiJ+T4VIRERE/J4KkYiIiPg9FSIRERHxeypEIiIi4vdUiERERMTvqRCJiM9JT09nxowZVscQES+iQiQil2XcuHGMHj0agNzcXCZOnNhuzz1r1ixiYmKajK9atYof/vCH7ZZDRLxfkNUBRETOVltbS0hIyCXfPy4urhXTiIg/0BYiEWkV48aNIz8/n9deew3DMDAMgz179gCwefNmbrvtNiIjI0lISGDs2LEcOXLEdd/c3FwmTJjAM888Q6dOnRg+fDgA06dPp2/fvkRERJCamsoTTzzBiRMnAFi2bBnf//73cTgcruebPHky0PQrs6KiIu666y4iIyOJjo7mnnvu4dChQ675kydPpn///vzlL38hPT0du93OfffdR0VFhWuZv//97/Tt25ewsDA6duzIzTffTGVlZRv9NUWkvakQiUireO2117jmmmt49NFHKS4upri4mNTUVIqLixk6dCj9+/dn9erVLFiwgEOHDnHPPfe43X/27NkEBQXx5Zdf8sc//hGAgIAAfvOb37Bx40Zmz57NkiVLmDRpEgA5OTnMmDGD6Oho1/M999xzTXKZpsno0aM5duwY+fn55OXlsWvXLu6991635Xbt2sVHH33EJ598wieffEJ+fj6vvPIKAMXFxdx///08/PDDbNmyhWXLljFmzBh0bWwR36GvzESkVdjtdkJCQggPDycxMdE1/vrrrzNgwACmTJniGnvrrbdITU1l+/bt9OjRA4DMzEymTZvm9phn7o+UkZHB//zP//D444/z+9//npCQEOx2O4ZhuD3f2T777DMKCgooLCwkNTUVgL/85S/06dOHVatWMXjwYAAaGxuZNWsWUVFRAIwdO5bFixfzy1/+kuLiYurr6xkzZgxpaWkA9O3b9zL+WiLiabSFSETa1Jo1a1i6dCmRkZGuqVevXoBzq8xpgwYNanLfpUuXMnz4cDp37kxUVBTf+973OHr0aIu+qtqyZQupqamuMgTQu3dvYmJi2LJli2ssPT3dVYYAkpKSKC0tBSA7O5ubbrqJvn378t3vfpc33niDsrKy5v8RRMTjqRCJSJtqbGzkzjvvZP369W7Tjh07uOGGG1zLRUREuN1v79693HbbbWRlZfHhhx+yZs0afve73wFQV1fX7Oc3TRPDMC46Hhwc7DbfMAwaGxsBCAwMJC8vj3/961/07t2b3/72t/Ts2ZPCwsJm5xARz6ZCJCKtJiQkhIaGBrexAQMGsGnTJtLT08nMzHSbzi5BZ1q9ejX19fX8+te/5uqrr6ZHjx4cPHjwos93tt69e1NUVMS+fftcY5s3b8bhcHDFFVc0e90Mw+Daa6/l5ZdfZt26dYSEhDBv3rxm319EPJsKkYi0mvT0dL7++mv27NnDkSNHaGxsZPz48Rw7doz777+fb775ht27d7No0SIefvjhC5aZbt26UV9fz29/+1t2797NX/7yF/7whz80eb4TJ06wePFijhw5QlVVVZPHufnmm+nXrx8PPvgga9eu5ZtvvuF73/seQ4cOPefXdOfy9ddfM2XKFFavXk1RURFz587l8OHDLSpUIuLZVIhEpNU899xzBAYG0rt3b+Li4igqKiI5OZkvv/yShoYGbrnlFrKysnj66aex2+0EBJz/P0H9+/dn+vTp/OpXvyIrK4v33nuPqVOnui2Tk5PDY489xr333ktcXFyTnbLBuWXno48+okOHDtxwww3cfPPNdO3alQ8++KDZ6xUdHc3y5cu57bbb6NGjB//93//Nr3/9a0aOHNn8P46IeDTD1HGjIiIi4ue0hUhERET8ngqRiIiI+D0VIhEREfF7KkQiIiLi91SIRERExO+pEImIiIjfUyESERERv6dCJCIiIn5PhUhERET8ngqRiIiI+D0VIhEREfF7/x+ZTREqHPiNjAAAAABJRU5ErkJggg==",
      "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_137558/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_137558/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": "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bVKHDh24ziHQp0+fWsuTbNu2TW3btpXE73MoHTp0SFFRwbfI6Ohoa3kHrnXo2e2a9urVSytXrgxa8mHp0qXy+Xy1hhRPqs7T5mFbNcs7vPzyy2bLli1mwoQJJj4+3uzYsSPSTYu4e++913g8HvPRRx+ZwsJC63Xo0CGrZsaMGcbj8ZiFCxeavLw8M2LEiBN+nbh169Zm2bJlZsOGDebqq68+4deJL7nkEpOTk2NycnJMly5dTvh14v79+5sNGzaYZcuWmdatW5+VX9Guix9+69AYrnMorFu3zjRo0MBMmzbNfPHFF+aNN94wjRo1Mq+//rpVw3UOjTvuuMO0atXKWt5h4cKFJikpyTz44INWDde6/vbv3282btxoNm7caCSZWbNmmY0bN1rLEdnpmpaWlpqUlBQzYsQIk5eXZxYuXGiaNGnC8g7nqt///vembdu2JjY21nTr1s1avuBcJ+mEr1deecWqCQQC5oknnjBer9e43W5z5ZVXmry8vKDjHD582GRmZprExEQTFxdnhgwZYgoKCoJq9u3bZ0aOHGkSEhJMQkKCGTlypCkpKQmq2blzpxk8eLCJi4sziYmJJjMzM+irw05yfNDiOofGO++8Y1JTU43b7TadOnUyL774YtB+rnNolJWVmfHjx5vzzjvPNGzY0HTo0ME8+uijpry83KrhWtffhx9+eMJ/k++44w5jjP2u6ebNm83PfvYz43a7jdfrNVOmTKnX0g7GGOMypr5LnAIAAKAumKMFAAAQJgQtAACAMCFoAQAAhAlBCwAAIEwIWgAAAGFC0AIAAAgTghYAAECYELQAAADChKAFAGHWrl07zZ49O9LNABABBC0AjjJq1CgNGzZMktSvXz9NmDDhjJ371VdfVdOmTWttX79+vX75y1+esXYAsI8GkW4AANhdRUWFYmNjT/n9LVq0CGFrAJxN6NEC4EijRo3SihUr9Oyzz8rlcsnlcmnHjh2SpC1btuj6669X48aNlZKSooyMDH377bfWe/v166fMzExNnDhRSUlJGjBggCRp1qxZ6tKli+Lj49WmTRvdd999OnDggCTpo48+0p133im/32+db8qUKZJqDx0WFBToP//zP9W4cWM1adJEw4cP1969e639U6ZM0aWXXqo//elPateunTwej2655Rbt37/fqvnLX/6iLl26KC4uTs2bN9c111yjgwcPhulqAjhVBC0AjvTss8+qV69euueee1RYWKjCwkK1adNGhYWFSk9P16WXXqpPPvlES5Ys0d69ezV8+PCg97/22mtq0KCBPv74Y/3hD3+QJEVFRem5555Tfn6+XnvtNX3wwQd68MEHJUm9e/fW7Nmz1aRJE+t8999/f612GWM0bNgwfffdd1qxYoWys7P173//WzfffHNQ3b///W/99a9/1bvvvqt3331XK1as0IwZMyRJhYWFGjFihO666y599tln+uijj3TjjTfKGBOOSwngNDB0CMCRPB6PYmNj1ahRI3m9Xmv7vHnz1K1bN02fPt3a9n//939q06aNtm3bpgsuuECS1LFjR82cOTPomD+c79W+fXv9+te/1r333qu5c+cqNjZWHo9HLpcr6HzHW7ZsmTZv3qzt27erTZs2kqQ//elPuvjii7V+/XpdfvnlkqRAIKBXX31VCQkJkqSMjAwtX75c06ZNU2FhoaqqqnTjjTeqbdu2kqQuXbqcxtUCEC70aAE4p+Tm5urDDz9U48aNrVenTp0kHe1FqtG9e/da7/3www81YMAAtWrVSgkJCbr99tu1b9++eg3ZffbZZ2rTpo0VsiSpc+fOatq0qT777DNrW7t27ayQJUktW7ZUcXGxJKlr167q37+/unTpoptuukkvvfSSSkpK6n4RAJwxBC0A55RAIKAbbrhBmzZtCnp98cUXuvLKK626+Pj4oPft3LlT119/vVJTU7VgwQLl5ubq97//vSSpsrKyzuc3xsjlcv3k9piYmKD9LpdLgUBAkhQdHa3s7Gz94x//UOfOnfX888/rwgsv1Pbt2+vcDgBnBkELgGPFxsaquro6aFu3bt306aefql27durYsWPQ6/hw9UOffPKJqqqq9Nvf/lY9e/bUBRdcoD179vzk+Y7XuXNnFRQUaNeuXda2LVu2yO/366KLLqrzZ3O5XOrTp4+efPJJbdy4UbGxsVq0aFGd3w/gzCBoAXCsdu3aae3atdqxY4e+/fZbBQIBjRkzRt99951GjBihdevW6auvvtLSpUt11113nTQk/cd//Ieqqqr0/PPP66uvvtKf/vQnvfDCC7XOd+DAAS1fvlzffvutDh06VOs411xzjS655BKNHDlSGzZs0Lp163T77bcrPT39hMOVJ7J27VpNnz5dn3zyiQoKCrRw4UJ988039QpqAM4MghYAx7r//vsVHR2tzp07q0WLFiooKJDP59PHH3+s6upqDRo0SKmpqRo/frw8Ho+ion78n8RLL71Us2bN0lNPPaXU1FS98cYbysrKCqrp3bu3Ro8erZtvvlktWrSoNZleOtoT9de//lXNmjXTlVdeqWuuuUYdOnTQ22+/XefP1aRJE61cuVLXX3+9LrjgAj322GP67W9/q+uuu67uFwfAGeEyfB8YAAAgLOjRAgAACBOCFgAAQJgQtAAAAMKEoAUAABAmBC0AAIAwIWgBAACECUELAAAgTAhaAAAAYULQAgAACBOCFgAAQJgQtAAAAMLk/wOINkG3QjFo4QAAAABJRU5ErkJggg==",
      "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": 22,
   "id": "9b8183e6-b849-400f-9f63-eede54d5cab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_137558/557587510.py:4: RuntimeWarning: Mean of empty slice\n",
      "  ax.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
      "/tmp/ipykernel_137558/557587510.py:5: RuntimeWarning: Mean of empty slice\n",
      "  ax.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 500x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=(5, 2.5))\n",
    "\n",
    "plt.style.use('seaborn-v0_8')\n",
    "ax.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
    "ax.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n",
    "\n",
    "#ax.set_ylim([0, 60])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Trials')\n",
    "#ax.set_yscale('log')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d09f464-6d6f-462d-a568-24baece12616",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b154553-cc83-4319-bc23-cb858d5dc058",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
