{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c78646a5-1243-4cf2-9ff0-be144d5743b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import trange\n",
    "from tsp_rtdl_fast import plot_tour, two_opt_rtdl, two_opt, Logger, calculate_total_distance\n",
    "from tsp_rtdl_util import create_problem, create_problem_nonmetric\n",
    "from christofides_tsp import christofides_tsp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c3d17b1a-02d5-4427-a9c0-3cf4f9b3f6d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "N_CITIES = 300\n",
    "TRIALS = 100\n",
    "MAX_ITER = 10**5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "63310ac1-ea30-4f01-8ba8-745feb625a2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_problem_noneuc(seed, N):\n",
    "    np.random.seed(seed)\n",
    "    distance_matrix = np.random.random((N, N))\n",
    "    #np.fill_diagonal(distance_matrix, 0)\n",
    "    distance_matrix[np.triu_indices(N, k = 0)] = 0\n",
    "    distance_matrix = (distance_matrix + distance_matrix.T) / 2\n",
    "\n",
    "    return distance_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9de731cc-3545-4018-aa53-211481923129",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:03<06:04,  3.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1195 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:08<07:27,  4.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1249 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [00:14<07:51,  4.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1122 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:17<07:10,  4.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1193 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [00:23<07:47,  4.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1250 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [00:27<07:19,  4.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1220 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [00:31<06:57,  4.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1154 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:36<06:56,  4.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1183 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [00:41<06:51,  4.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1135 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:46<07:08,  4.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1179 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:51<07:05,  4.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1245 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [00:56<07:19,  5.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1152 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [01:02<07:46,  5.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1264 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [01:06<06:53,  4.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1238 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [01:11<06:53,  4.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1222 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [01:16<06:44,  4.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1154 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [01:21<06:44,  4.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1183 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [01:25<06:36,  4.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1242 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [01:30<06:16,  4.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1191 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [01:35<06:18,  4.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1126 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [01:39<06:08,  4.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1128 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [01:43<05:53,  4.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1163 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [01:49<06:11,  4.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1181 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [01:54<06:10,  4.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1255 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [01:59<06:06,  4.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1190 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [02:03<05:54,  4.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1132 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [02:08<05:54,  4.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1187 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [02:13<05:46,  4.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1253 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [02:17<05:27,  4.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1168 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [02:21<05:01,  4.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1164 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [02:26<05:08,  4.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1164 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [02:30<04:58,  4.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1203 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [02:35<05:04,  4.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1246 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [02:40<05:09,  4.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1200 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [02:44<04:57,  4.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1164 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [02:49<05:04,  4.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1208 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [02:54<04:55,  4.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1231 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [02:58<04:45,  4.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1211 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [03:03<04:48,  4.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1165 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [03:08<04:43,  4.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1216 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [03:13<04:40,  4.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1219 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [03:17<04:29,  4.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1179 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [03:22<04:25,  4.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1159 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [03:28<04:43,  5.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1269 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [03:32<04:24,  4.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1178 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [03:36<04:15,  4.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1214 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [03:42<04:19,  4.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1242 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [03:46<04:01,  4.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1215 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [03:50<03:48,  4.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1124 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [03:54<03:38,  4.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1149 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [03:59<03:36,  4.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1252 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [04:03<03:32,  4.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1150 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [04:07<03:23,  4.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1194 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [04:12<03:24,  4.44s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1218 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [04:17<03:25,  4.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1187 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [04:20<03:10,  4.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1198 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [04:25<03:12,  4.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1226 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [04:31<03:19,  4.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1170 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [04:35<03:07,  4.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1157 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [04:39<02:54,  4.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1230 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [04:44<03:02,  4.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1215 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [04:49<02:56,  4.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1150 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [04:53<02:49,  4.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1164 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [04:57<02:42,  4.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1266 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [05:01<02:32,  4.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1184 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [05:05<02:23,  4.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1207 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [05:09<02:16,  4.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1182 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [05:13<02:12,  4.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1177 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [05:17<02:04,  4.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1205 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [05:21<01:59,  3.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1124 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [05:25<01:52,  3.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1151 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [05:29<01:48,  3.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1190 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [05:34<01:54,  4.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1224 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [05:39<01:57,  4.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1119 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [05:43<01:52,  4.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1213 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [05:47<01:43,  4.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1148 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [05:53<01:46,  4.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1151 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [05:56<01:35,  4.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1145 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [06:00<01:30,  4.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1157 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [06:04<01:21,  4.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1183 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [06:08<01:18,  4.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1241 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [06:13<01:20,  4.45s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1251 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [06:18<01:15,  4.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1111 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [06:23<01:14,  4.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1137 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [06:27<01:08,  4.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1220 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [06:31<01:00,  4.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1137 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [06:36<00:58,  4.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1270 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [06:41<00:54,  4.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1189 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [06:45<00:50,  4.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1288 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [06:49<00:42,  4.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1250 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [06:53<00:39,  4.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1279 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [06:58<00:35,  4.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1213 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [07:02<00:29,  4.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1157 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [07:06<00:24,  4.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1264 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [07:10<00:20,  4.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1194 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [07:15<00:17,  4.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1165 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [07:20<00:13,  4.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1164 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 98/100 [07:25<00:09,  4.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1171 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [07:29<00:04,  4.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1174 44550\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [07:35<00:00,  4.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1194 44550\n",
      "CPU times: user 7min 33s, sys: 1.29 s, total: 7min 35s\n",
      "Wall time: 7min 35s\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",
    "    distance_matrix = create_problem_noneuc(t, N_CITIES)\n",
    "    initial_tour = list(range(distance_matrix.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": 5,
   "id": "2e35dbfa-b771-42a3-ac14-b9537cdb5914",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2.7326340412446384, 0.015044095846334603)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(data_orig), np.std(data_orig) / np.sqrt(TRIALS-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "95003323-c3b7-4d8e-9ddc-8baeae08aa7d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "455.00707030296326"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logger_orig.time_end - logger_orig.time_start"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:33<55:55, 33.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1272 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n",
      "iter 1410 calc rtdl\n",
      "iter 1440 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [01:11<58:49, 36.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1450 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [01:43<55:33, 34.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1191 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [02:20<56:29, 35.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1311 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [02:57<56:38, 35.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1322 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [03:34<56:49, 36.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1309 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [04:10<56:14, 36.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1323 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [04:46<55:29, 36.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1314 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [05:20<53:34, 35.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1313 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [05:53<52:05, 34.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1252 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [06:27<51:01, 34.40s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1370 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [07:00<50:05, 34.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1294 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [07:35<49:37, 34.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1390 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [08:09<49:13, 34.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1354 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [08:41<47:34, 33.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1339 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [09:13<46:08, 32.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1325 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [09:45<45:24, 32.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1272 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [10:17<44:29, 32.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1241 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [10:51<44:34, 33.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1386 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [11:23<43:35, 32.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1280 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [11:57<43:32, 33.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1332 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [12:27<41:49, 32.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1210 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [13:00<41:23, 32.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1247 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [13:33<41:07, 32.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1299 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [14:05<40:32, 32.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1324 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [14:36<39:40, 32.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1293 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [15:11<39:52, 32.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1403 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [15:41<38:27, 32.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1302 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [16:11<37:08, 31.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1228 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [16:43<36:59, 31.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1326 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [17:15<36:30, 31.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1244 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [17:48<36:14, 31.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1258 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [18:19<35:27, 31.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1320 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [18:48<34:10, 31.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1232 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [19:19<33:39, 31.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1229 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [19:51<33:27, 31.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1292 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [20:25<33:39, 32.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1380 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [20:58<33:24, 32.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1291 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [21:31<33:01, 32.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1346 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [22:04<32:44, 32.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1282 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [22:37<32:09, 32.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1274 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [23:10<31:47, 32.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1295 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [23:43<31:20, 33.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1370 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [24:17<30:55, 33.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1383 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [24:48<29:54, 32.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1285 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [25:22<29:37, 32.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1355 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [25:55<29:07, 32.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1295 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [26:26<28:03, 32.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1295 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [27:01<28:10, 33.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1376 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [27:33<27:15, 32.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1316 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [28:06<26:57, 33.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1329 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [28:37<25:47, 32.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1253 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [29:11<25:39, 32.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1342 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [29:43<24:52, 32.44s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1308 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [30:13<23:59, 31.99s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1302 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [30:45<23:20, 31.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1284 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [31:18<23:04, 32.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1337 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [31:53<23:02, 32.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1348 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [32:27<22:44, 33.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1381 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [32:57<21:36, 32.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1278 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [33:30<21:10, 32.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1379 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [34:04<20:55, 33.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1349 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [34:37<20:25, 33.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1291 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [35:10<19:47, 32.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1317 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n",
      "iter 1380 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [35:45<19:38, 33.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1409 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [36:17<18:41, 32.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1325 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [36:48<17:48, 32.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1198 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [37:21<17:19, 32.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1295 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [37:56<17:17, 33.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1315 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [38:28<16:25, 32.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1290 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [39:00<15:49, 32.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1257 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [39:34<15:23, 32.99s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1311 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [40:07<14:55, 33.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1359 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [40:41<14:25, 33.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1265 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [41:14<13:52, 33.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1362 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [41:45<13:03, 32.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1311 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [42:18<12:30, 32.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1308 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [42:50<11:53, 32.45s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1303 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [43:26<11:46, 33.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1354 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [43:59<11:04, 33.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1289 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [44:32<10:31, 33.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1263 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [45:03<09:47, 32.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1307 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [45:34<09:07, 32.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1310 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [46:05<08:28, 31.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1288 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [46:38<08:01, 32.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1333 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [47:12<07:37, 32.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1298 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [47:46<07:07, 32.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1358 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [48:17<06:28, 32.40s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1373 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [48:46<05:45, 31.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1274 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [49:20<05:21, 32.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1326 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [49:54<04:54, 32.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1316 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [50:26<04:20, 32.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1377 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [50:59<03:50, 32.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1286 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [51:32<03:17, 32.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1334 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [52:03<02:41, 32.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1276 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [52:38<02:12, 33.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1268 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [53:13<01:40, 33.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1314 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n",
      "iter 1320 calc rtdl\n",
      "iter 1350 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 98/100 [53:48<01:07, 33.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1377 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [54:18<00:32, 32.84s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1255 44550\n",
      "iter 0 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 210 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 270 calc rtdl\n",
      "iter 300 calc rtdl\n",
      "iter 330 calc rtdl\n",
      "iter 360 calc rtdl\n",
      "iter 390 calc rtdl\n",
      "iter 420 calc rtdl\n",
      "iter 450 calc rtdl\n",
      "iter 480 calc rtdl\n",
      "iter 510 calc rtdl\n",
      "iter 540 calc rtdl\n",
      "iter 570 calc rtdl\n",
      "iter 600 calc rtdl\n",
      "iter 630 calc rtdl\n",
      "iter 660 calc rtdl\n",
      "iter 690 calc rtdl\n",
      "iter 720 calc rtdl\n",
      "iter 750 calc rtdl\n",
      "iter 780 calc rtdl\n",
      "iter 810 calc rtdl\n",
      "iter 840 calc rtdl\n",
      "iter 870 calc rtdl\n",
      "iter 900 calc rtdl\n",
      "iter 930 calc rtdl\n",
      "iter 960 calc rtdl\n",
      "iter 990 calc rtdl\n",
      "iter 1020 calc rtdl\n",
      "iter 1050 calc rtdl\n",
      "iter 1080 calc rtdl\n",
      "iter 1110 calc rtdl\n",
      "iter 1140 calc rtdl\n",
      "iter 1170 calc rtdl\n",
      "iter 1200 calc rtdl\n",
      "iter 1230 calc rtdl\n",
      "iter 1260 calc rtdl\n",
      "iter 1290 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [54:50<00:00, 32.91s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 1310 44550\n",
      "CPU times: user 1h 9min 13s, sys: 9.78 s, total: 1h 9min 23s\n",
      "Wall time: 54min 50s\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",
    "    distance_matrix = create_problem_noneuc(t, N_CITIES)\n",
    "    initial_tour = list(range(distance_matrix.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, progressive = True)\n",
    "    logger_rtdl.problem_solved()\n",
    "    data_rtdl.append(optimized_distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "94402bb9-9a8b-4afc-aa71-23d6f88359a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2.061489191245718, 0.009040921251224996)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(data_rtdl), np.std(data_rtdl) / np.sqrt(TRIALS-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "149a038c-1f5b-44f8-9251-a5b08b0c93cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3290.7151033878326"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logger_rtdl.time_end - logger_rtdl.time_start"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c874aafe-f8d7-4967-ac89-c5b6dc571073",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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DN0uK2GcNxC5uMK906DePXhYcpnuPoG9v3/LzDVxZlcmIiIixcx5AxGAqzvc9ynU7oaXJYeP3d9j388fsHhngtmViYiISDFy7kAE4OYBvedgNHkIN0s+Y90/Ye/8V9kUd9rsykRERKSYKBABuHlg6fEh+R3/DcDTrt+wc/ZI9p9IN7kwERERKQ4KRBdYLLjc8hLZt1s38hvI9+yZPpCk1HMmFyYiIiJFTYHoIh7th3G260TycOGevN/48aOXSTufY3ZZIiIiUoQUiC6jTJtHSe40DoAHM77gvzO+IjNbCzeKiJQm48aNo2XLlvj5+REcHEzPnj2JjY0tls+eNWtWsUzLX7lyJRaLxfYoV64ct956K2vWrAGse6r9/fWLH506dbrkOG9vb6pVq0bv3r1Zvnx5gc87dOgQFouFrVu3FvnPZm+mBqJ/uhDDhg0DrDsRjx49mrCwMLy9venUqRO7du0qltrKdxjM2bB2+FqyGHXqVV6atZjs3Pxi+WwRESl6UVFRDBs2jPXr17N06VJyc3Pp0qUL58457lCJ0aNHM3DgwEK/LzY2loSEBFauXEmFChW46667SEpKIjo6moSEBBISEvj2228LHJuQkMCCBQts53jjjTdISEggNjaWOXPmEBgYyO23385bb71lrx/PVKYGor9fiISEBJYuXQrAAw88AMA777zDhAkTmDx5MtHR0YSGhtK5c2fS04thsLOLK2X6f05mQA0qWs7w9NFRvP75MvK0mrWISKmwePFiBg4cSIMGDWjcuDEzZ84kPj6emJiYK74vKyuLp59+muDgYLy8vGjfvj3R0dG21y/0yvz00080btwYLy8vWrVqxY4dO2yvP/roo6Smpto6AkaPHl2UPyrBwcGEhobSsGFDXn31VVJTU9mwYQMVKlQgNDSU0NBQgoKCChz79zYAPz8/QkNDqVKlCh06dGD69Om89tpr/Oc//ym2nrWiZGog+vuFCA0N5ccff6RGjRp07NgRwzCYOHEir7zyCr169SIyMpLZs2eTkZHBvHnziqdA77J4P7qI876VqO6SSP8D/+KNr9dRyvfDFRG5MYYB2efMedzA38+pqakABULA5bzwwgt8++23zJ49m82bN1OzZk26du3KmTNnChz3/PPP83//939ER0cTHBxM9+7dycnJoW3btkycOBF/f39bh8Bzzz133XUXRkZG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",
      "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, 1000])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Tour length')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9b8183e6-b849-400f-9f63-eede54d5cab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_83407/2171339728.py:1: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
      "/tmp/ipykernel_83407/2171339728.py:2: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n"
     ]
    },
    {
     "data": {
      "image/png": "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PSJx7oE8TBpMBCeEEEIIsQFFEyGEEEKIDSiamgEJCQn429/+hoSEhKYeyknlVJ03cOrOnfPmvE8FTtV5A81/7kwEJ4QQQgixAT1NhBBCCCE2oGgihBBCCLEBRRMhhBBCiA0omgghhBBCbEDR1Ax48cUX0blzZyQmJqJ///745ptvmnpI9WbOnDk4++yzkZqaioyMDEyYMAE7d+402CiKglmzZiE7OxtJSUkYMWIEtm3bZrCprq7G7bffjjZt2iAlJQXjx4/HgQMHTuZUGsScOXPgcDgwffp0/Vi0zvvgwYP44x//iNatWyM5ORlnnXUWNm3apJ+P1nnX1dXhL3/5Czp37oykpCScfvrpeOihh+DxeHSbaJj7119/jUsuuQTZ2dlwOBz48MMPDefDNceioiLk5eXB5XLB5XIhLy8PJ06caOTZWRNo3rW1tbjnnnvQq1cvpKSkIDs7G9dccw0OHTpkaCPa5m3mpptugsPhwNy5cw3Hm+O8dRQS0SxatEiJj49X5s+fr2zfvl254447lJSUFGXv3r1NPbR6MWbMGOW1115Ttm7dquTn5ytjx45VOnTooJSVlek2jzzyiJKamqq89957ypYtW5QrrrhCadeunVJSUqLb3Hzzzcppp52mLFu2TNm8ebNy/vnnK3369FHq6uqaYlohsX79eqVTp05K7969lTvuuEM/Ho3zPn78uNKxY0dl8uTJyrp165Tdu3cry5cvV3766SfdJhrnrSiK8ve//11p3bq18sknnyi7d+9W/vOf/ygtWrRQ5s6dq9tEw9w/++wz5f7771fee+89BYDywQcfGM6Ha44XXnihkpubq6xevVpZvXq1kpubq4wbN+5kTdOPQPM+ceKEMnLkSOWdd95RfvjhB2XNmjXKwIEDlf79+xvaiLZ5i3zwwQdKnz59lOzsbOXpp582nGuO89agaIpwzjnnHOXmm282HOvevbty7733NtGIwsuRI0cUAMrKlSsVRVEUj8ejZGVlKY888ohuU1VVpbhcLuWll15SFEX9QIqPj1cWLVqk2xw8eFCJiYlRlixZcnInECKlpaVK165dlWXLlinDhw/XRVO0zvuee+5Rhg0bZnk+WuetKIoyduxY5frrrzccu/TSS5U//vGPiqJE59zNN9FwzXH79u0KAGXt2rW6zZo1axQAyg8//NDIswpOIPGgsX79egWA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
    "plt.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "#ax.set_ylim([0, 60])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Trials')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4ca35f96-9d0c-4252-b039-3da9fbe0b92e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_rtdl():\n",
    "    logger_rtdl = Logger(MAX_ITER)\n",
    "    data_rtdl = []\n",
    "    \n",
    "    for t in trange(TRIALS):\n",
    "        distance_matrix = create_problem_noneuc(t, N_CITIES)\n",
    "        initial_tour = list(range(distance_matrix.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",
    "        logger_rtdl.problem_solved()\n",
    "        data_rtdl.append(optimized_distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "01a68eec-abd7-40c2-b484-fb3a625be858",
   "metadata": {},
   "outputs": [],
   "source": [
    "#import cProfile\n",
    "#from pstats import SortKey\n",
    "\n",
    "#cProfile.run('test_rtdl()', sort = SortKey.CUMULATIVE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4ff08686-8a04-4bfe-a732-10527802635f",
   "metadata": {},
   "outputs": [],
   "source": [
    "tour = [0, 1, 2, 3, 4, 5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2aca1ca8-4a3b-4e56-b15b-4600c1de90ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "06b33de2-c9bb-4a43-8c63-bce284c17791",
   "metadata": {},
   "outputs": [],
   "source": [
    "def two_opt_swap(tour, i, k):\n",
    "    \"\"\"\n",
    "    Perform a 2-opt swap by reversing the segment between i and k\n",
    "    i < k.\n",
    "    Edges (i-1, i), (k, k+1) are swaped with (i-1, k), (i, k+1)\n",
    "    \"\"\"\n",
    "    new_tour = tour[:i] + tour[i:k+1][::-1] + tour[k+1:]\n",
    "\n",
    "    return new_tour\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "4f85e688-57f9-455b-9ffa-3ef2a94a3948",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[4, 3, 2, 1, 0, 5]"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "two_opt_swap(tour, 0, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ff9b1a64-ae98-437d-81de-8c88c9f0b5d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "distance_matrix = create_problem_noneuc(0, 5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2989a03a-6955-4200-be95-9dc8c11f66ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "tour = list(range(5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "df0caf27-6cde-4a07-9035-493d14acc004",
   "metadata": {},
   "outputs": [],
   "source": [
    "def delta_two_opt_swap(d, tour, i, k):\n",
    "    \"\"\"\n",
    "    Perform a 2-opt swap by reversing the segment between i and k\n",
    "    i < k.\n",
    "    Edges (i-1, i), (k, k+1) are swaped with (i-1, k), (i, k+1)\n",
    "    \"\"\"\n",
    "\n",
    "    return d[tour[i-1],tour[k]] + d[tour[i],tour[k+1]] - d[tour[i-1],tour[i]] - d[tour[k],tour[k+1]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "f269c437-dd19-4bea-8bef-cb9df05de38a",
   "metadata": {},
   "outputs": [
    {
     "ename": "IndexError",
     "evalue": "list index out of range",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[30], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m delta_two_opt_swap(distance_matrix, tour, \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m4\u001b[39m)\n",
      "Cell \u001b[0;32mIn[28], line 8\u001b[0m, in \u001b[0;36mdelta_two_opt_swap\u001b[0;34m(d, tour, i, k)\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mdelta_two_opt_swap\u001b[39m(d, tour, i, k):\n\u001b[1;32m      2\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;124;03m    Perform a 2-opt swap by reversing the segment between i and k\u001b[39;00m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;124;03m    i < k.\u001b[39;00m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;124;03m    Edges (i-1, i), (k, k+1) are swaped with (i-1, k), (i, k+1)\u001b[39;00m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m----> 8\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m d[tour[i\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m],tour[k]] \u001b[38;5;241m+\u001b[39m d[tour[i],tour[k\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m]] \u001b[38;5;241m-\u001b[39m d[tour[i\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m],tour[i]] \u001b[38;5;241m-\u001b[39m d[tour[k],tour[k\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m]]\n",
      "\u001b[0;31mIndexError\u001b[0m: list index out of range"
     ]
    }
   ],
   "source": [
    "delta_two_opt_swap(distance_matrix, tour, 0, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67a0535e-3db6-483a-be99-6f0870168dde",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "570b572d-f9f9-4490-9cf8-2a0760953d98",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b44d2da-8191-4be6-90aa-eeaee2caf4af",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aee4565b-6b0b-440e-9a81-67fb60b2d1b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c68963b3-5361-4c8e-80b1-1e09bbbfe2f2",
   "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
}
