{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "c78646a5-1243-4cf2-9ff0-be144d5743b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import trange\n",
    "from tsp_rtdl import plot_tour, two_opt_rtdl, two_opt, Logger, calculate_total_distance\n",
    "from tsp_rtdl_util import create_problem\n",
    "import scipy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "8fc3df33-e7a9-4f1b-b325-4c85f7c49186",
   "metadata": {},
   "outputs": [],
   "source": [
    "def add_points(X, c, r, nc, depth = 1, max_depth = 3):\n",
    "\n",
    "    d_list = []\n",
    "\n",
    "    for _ in range(1000):\n",
    "        d = 2 * np.random.random(2) - 1\n",
    "        d = d / np.linalg.norm(d)\n",
    "        good_d = True\n",
    "        \n",
    "        for d_prev in d_list:\n",
    "            #print(d @ d_prev)\n",
    "            if d @ d_prev > .8:\n",
    "                good_d = False\n",
    "                break\n",
    "\n",
    "        if good_d:\n",
    "            d_list.append(d)\n",
    "\n",
    "        if len(d_list) == nc:\n",
    "            break\n",
    "    \n",
    "    for d in d_list:\n",
    "        #print(depth)\n",
    "        r1 = r * max(min(np.random.normal(1, 0.2), 1.2), 0.2)\n",
    "        X.append(c + r1 * d)\n",
    "\n",
    "        if depth <= max_depth and nc > 1:\n",
    "            add_points(X, c + r1 * d, r / 5, nc // 2, depth + 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "bbb440eb-e727-47cd-ac31-9f8b0e24bf5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_problem_cluster(t):\n",
    "    np.random.seed(t)\n",
    "    \n",
    "    X = []\n",
    "    c = np.array([0, 0])\n",
    "    add_points(X, c, r = 1, nc = 10, max_depth = 1)\n",
    "    \n",
    "    X = np.array(X)\n",
    "\n",
    "    return X, scipy.spatial.distance.cdist(X, X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "a96abb48-26a0-4975-b955-dac4319eea7a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f95283fd850>"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGdCAYAAADaPpOnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABKJklEQVR4nO3df3hU5Zk//vckTBISyYQkhZlYhAlQNASUwMbECFYtELIFWnp1VYRL+21ZwOXbRddvJS1bkooL9mO17YWAuKyuG7V+Pkss8DFNxRXF4sSIgUKIv0gGoTIjJiEzGMgPZs73j3hCJpkf58ycM3POzPt1Xbkuc3LO5GGczLnnee7nvg2CIAggIiIi0omkWA+AiIiISA4GL0RERKQrDF6IiIhIVxi8EBERka4weCEiIiJdYfBCREREusLghYiIiHSFwQsRERHpyqhYD0BpXq8X586dw5gxY2AwGGI9HCIiIpJAEARcvHgReXl5SEoKPrcSd8HLuXPnMGHChFgPg4iIiMJw9uxZfPOb3wx6TtwFL2PGjAEw8I/PzMyM8WiIiIhICrfbjQkTJgzex4OJu+BFXCrKzMxk8EJERKQzUlI+mLBLREREusLghYiIiHSFwQsRERHpCoMXIiIi0hUGL0RERKQrDF6IiIhIVxi8EBERka4weCEiIiJdibsidUSJyOMV0GjvxPmLPRg3Jg3F1mwkJ7G3FxHFJwYvRDpX3+xA1b4WON09g8fMmWmoWlKA8kJLDEdGRKQOLhsR6Vh9swNrapp8AhcAcLp7sKamCfXNjhiNjIhIPQxeiHTK4xWwofZE0HMqa0/A4xWiNCIiouhg8EKkUw1tHei61B/0nAuX+tHQ1hGlERERRQeDFyKdere1XdJ5tlYGL0QUXxi8EOlQfbMDzx8+LfFsLhsRUXzhbiMinalvdmBtTZPkkKQ0P1fV8RARRRuDFyI/+q548V+20/is8xImZqdjZekkpIyK3USlWMfF6e7Bo//3pOTAJSvdiJLJOaqOjYgo2hi8EA2zpa4Fz75jx9BNOo/VfYhVc62orCiI+njqjp/Dxr3N6OwOnpzrz9ZlM1isjojiDoMXSlj+qtL+uv5DPHPIPuJcr4DB49EMYLbUtfgdTyim0aPw+A9mskgdEcUlBi+UkAaq0p6E0907eGzcNUZ8GWJ249l37PiXBddHZQmp7rgjrMAFALYvn42yqcx1IaL4xN1GlHCuVqXt9Tl+/qt+CCGSSbwC8F+20+oN7mser4CNe5tlX2cAYDGlMc+FiOIagxdKKFKq0obyWeclhUYTWKO9E53dfbKuETNbNi0uYJ4LEcU1LhtRQmloDV2VNpSJ2ekKjSaw8xd7Qp80jNmUhk2L2YyRiOIfgxdKKLY2aVVpA0kyACtLJykzmCDGjUmTdF5m2ihUL5kOs2k0iq3ZnHEhooTA4IUSTGQ391VzrVFJ1i22ZsNiSoPDFXwGZuuyGaiYmaf6eIiItIQ5L5RQSsNMZE0yAKvnqVPnxeMVYGvtwN5jn8PW2gGPV0BykgGbFhcEDbVWz7MycCGihMSZF0ooJfk5yEo3ys57+c/7izF32jcUH099swPV+1t8ZlgsQ3JXdqwoGvHznIwUPLq0EBUzmdtCRImJwQsllOQkA7Yum4E1NU2yruu8LG/njxSBehQ5XT1YW9OEHSuKUF5owfwC84hiesxtIaJExmUjSjjlhRbsXFEEc6a0pFhAegKtVB6vgOr9LX57FInHqve3DC4hlU7OwdKbrkXp5BwGLkSU8DjzQglJnNFoaOvAP73YhK7L/peRDBjYglxszVb09zfaO4Mm4woAHK4eNNo7w87TIYo1j1dAQ2vH17v8BoLwkvzwA3CPV0BDWwdsrR0ABJTm56KEAX1CYvBCCSs5yYCyKbnY+oMZWPv1MtLQmRA1i75JreMSTr0XIi2ob3ZgQ+0Jn/yybQdPISvdiK3LZsiuR+T/8VrDfjzSNy4bUcITE2PNJt+lIbMpbTDvRGlSl6GUXq4iffO3My3W/I1JbMHhLzG+61I/1tQ0ob7ZIfl3KP14pH+ceSECAibGAsDhU+2KT1OLdVycrh6/eS9qLVeRfvnbmZadYcTmpYUBt8z765yu5CyivzGZM1Nxud8T8trq/S2YX2AOOR6PV0DVvpaQj1e176Skx6P4wOCF6GtiYqxIzWlqsY7L2pomGBC95SrSp0A70zq7+/HAS0ex+m9dPjWIPF4B2948hecO233yuSwKtpAIuFtuWMPTQKTmdDXaO+F0h14+dbp7mSOWQLhsRORHNKapY7FcRfoTbGea6JlDdtQdH3g91jc7MHvzATz1xicjEtHFbfiRvnaljEkKKTldcvK+mCOWODjzQjSMnGnqMalGtHf3hj0lzzouFEqonWmif93bDAB44KXANYwEDMzsSV2yiXRMoUjJ6cq9JlXRx6P4wOCFaBg509T37n5v8Ptwp+SHL1cRDSV1NqGjuw8bvw5gglFiG74SMxwWqTldEqd3stONzBFLIFw2Ihom3DdmpabkiYaSM5vQ2S29EnQkAYgSMxxSc7qkjvN7s67ljGUCYfBCNEy4b8zDK+MSKaHYmo3sDKPijxtJACLulgvH2HQjdkrM6ao77sAv952U9LjzC8xhjYf0icEL0TDF1mxZrQOGGjolT6SE5CQDNi8tVPQxJS/ZBCDulpNjQcE4vPiTm3Fk43xJgcuWuhY88FITLvZcCXlupP8e0h8GL0TDJCcZULVE3hvzcNz1QEqqmJmH1fOsijyWAcpswy8vtODB70yVfP6PyvJRNiVX0u+tO34OzxyyS3pcpf49pC8MXoj8EJs3ZqWHN10/fEre4xVw+FQ7nvjzx3jizx/h8KftXFoiWSorCrB9eRGuSU0O+zHGphsV3Ya/7o6pkmYpzZmpkmdGPF5BUuIxMFCkj2UFEpOqwcuhQ4ewePFi5OXlwWAw4I9//GPIa95++23Mnj0baWlpyM/Px86dO9UcIlFA5YUWfLBxPl78yc0ony59PX34FLZYd+Pef38P2w6ewraDrbh393uYvfkAk3tJloqZFjyzYo7s67JGG/Hgd6ZKXrKRSuosZdWS6ZJnRhrtnejs9t8odbh//e50Bi4JStXgpbu7GzfeeCO2bdsm6Xy73Y6KigrMnTsXR48exc9//nP89Kc/xZ49e9QcJlFAyUkGlOTnoPG09ByWoVPY7MlCSiuZnAOLKQ2BQgEDBmY6XvzJzfjd3Tfh5VUl+OBf5+Ofv/MtVZZWgs1SZslIzhXJWXINNzeN9E/VOi+LFi3CokWLJJ+/c+dOXHfddfjtb38LALjhhhtw5MgRPPHEE/jBD36g0iiJghv4JChtC+qPyyYNvlGzJwupQUpriaol01E2JTdqYxKLLTa0dUTcB0zqLqicjBQm6SYwTeW82Gw2LFiwwOfYwoULceTIEfT3S5tGJFKanE+C3xmyXVNuTxYiqbTYWiI5yYCyKbl4eOE0PLzwepRNlZacO5zUbdiPLi1kwJ/ANFVh1+l0Yvz48T7Hxo8fjytXrqC9vR0Wy8g/yN7eXvT2Xm0E5na7VR8nJRapnwSzM3wrfLInC6kpXltLDJ1ZCpTSvnqeFRUzmeuSyDQ18wIABoPvH54gCH6Pi7Zs2QKTyTT4NWHCBNXHSIlF6ifBzcM+CcopAhbsXI9XgK21A3uPfQ5bawd3KdEgsbXE0puuRWkYSzRaJc4sDf+7y84wYvvyWT4dtCkxaWrmxWw2w+l0+hw7f/48Ro0ahZwc/z04Kisr8dBDDw1+73a7GcCQoqR/EszzOSYWuwu1dBRsG2l9swNV+1p8HsOcmYaqJfJ7KBHpSbzOLJEyNDXzUlpaigMHDvgce/311zFnzhwYjf7rbaSmpiIzM9Pni0hpgT4J5mSkYPvyIr+fBJOTDFh6U+gAI9A2UnGn0vDgx+nu4S4lSgjxOrNEkVN15uWrr77CqVOnBr+32+04duwYsrOzcd1116GyshKff/45XnjhBQDAmjVrsG3bNjz00ENYtWoVbDYbdu/ejZdfflnNYRJJIveToMcrYN9fgwcYWelGvz1ZPF4BG2pPBL22svYExqQa0d7dy0+lRJRQVA1ejhw5gttvv33we3F557777sPzzz8Ph8OBM2fODP7carWirq4ODz74IJ5++mnk5eXh97//PbdJk2aInwSD8XgFNNo7cfhUOxyu4EtGXZf60WjvHPGYDW0dfmvDDHXhUj/u3f3e4PcWUxo2LeZyEhHFP4MgZsTGCbfbDZPJBJfLxSUkirq64+ewcW+z5AqhAPC7u2/C0puu9Tn2xJ8/xraDpwJc4Z8458Jy6USkR3Lu35rKeSHSs4EuuEdlBS5AoJ1G8j9TiFdU72/hjiQiimsMXogUUHfcIbkLrsiAkX2QRKX54VVHFQA4XD0sekeq4vZ9ijVNbZUm0iM5XXBF4hLP0D5IQ5VMzkFWujFk3ksg73x6HodPfQlgIEenJJ87NUgZ9c0OVO9v8cnnYr4VRRtzXogiZGvtwD3PNsi6RsqbvbhVWglZ6UZsXTaDNxeKSH2zw2+9I+ZbkRKY80IURXJK+6+7fTJeXlWCvzxyR8g3ebFbrzkz1ed4OPMn7GBNkfJ4BVTvb/GbjcV8K4o2LhsRRUhO76MH50+TtXzjr7bMhe5e/NNLRwHIT+ut3t/CDtYUlkZ7Z9Ct/0PzrUKVEyCKFIMXogiJvY9C1XQZ3vtIKn+1ZXYkGUbkHUjBmwuFS+oMI5uMUjQweCGKULi9jyIxfEbm0y++klwXhjcXCofUGUY5DUkjIRaDZN+jxMTghUgBYu+j4bMhORkpeHRpISpmKp/EOHRGxtbaITl4idbNheKLOMPodPX4DdINAMwBtv4rjTueiMELkUJi2QV3oIN1Kpzu3qDnBaorQxTK0BlGA3zzrUJt/VdSoB1PTlcP1tY0ccdTguBuIyIFxaoLbnKSAVVLpoc8Lxo3F4pf4gyjeVh3dbMpLSpBQ6gdTwKADXtO4PCpdu56inOs80IUR+qbHdhQe2JEcbux6UZsYZ0XUkis8k3k1FQyZ6aiasl0vuZ1RM79m8ELUZzxeAU0tHbA1tYOVtileCAGS39qduAF22eyrt3JZSTdkHP/Zs4LUZxJTjKgbGouyqaG1x+JSEvqmx2o2ncyZD5XIBtqT7C2URxizgsREWmS2CIj3MAFGKgu3dDaoeCoSAsYvBARkeZ4vAI21J5Q5LEGllApnjB4ISIizWlo7Qi7q/pIXDKKNwxeiIhIc5ScLWE7jPjD4IWIiDRI2mxJ6qjg541NN6Ikn8FLvGHwQkREmiN1tmTtbZOD/nzLshncaRSHGLwQEZHmlOTnICvdGPScselG/L93fgs7VxTBnOlb9ddiSmONlzjGOi9ERBQzYgE6p+syOrv7kH1NKsyZA1V7ty6bgTU1TQGvFWdVYtlXjGKDFXaJiCgm/HWHFoldogGgal8LnG52kI53bA/A4IWISNMCdYceygBgx4oizqokCLYHICIizQrWHXq46v0tmF9g5nZn8sGEXSIiiqqGtg6/S0XDCQAcrh402jvVHxTpCoMXIiKKmvpmB1a9cETWNecvhg50KLFw2YiIiKJCbLQo1+n2bhVGQ3rGmRciIlKdxyugal9LWNc+9canqG92KDwi0jMGL0REpLpGe6fPdmc5DBhI3PV442pzLEWAwQsREakukrwVJu7ScAxeiIhIdePGpIU+KQQm7pKIwQsREamu2Jo9ov+QXEoEQBQfGLwQEZHqkpMMqFpSENa1Bgy0BCi2Zis7KNItBi9ERBQV5YUW7FxR5LdbdEZKMoCBQGUo8ftNiwvYEoAGsc4LERFFjdgBuqGtA7bWDgACSvNzUTI5BwdanCMaNZrZhJH8YGNGIiLSDI9XYBPGBMXGjEREpEvJSQY2YaSQmPNCREREusLghYiIiHSFwQsRERHpCnNeSBYm0xERUawxeCHJ6psdqNp3Ek537+Axc2YqqpZM5zZGIiKKGi4bkST1zQ6sqWnyCVwAwOnuxZqaJrarJyKiqGHwQiF5vAI21J4Ies6G2hNsV09ERFHB4IVCamjtQNel/qDndF3qR0NrR5RGREREiYzBC4Vka2tX9DwiIqJIMHghCaTuJuKuIyIiUh+DFwpJaqlulvQmIqJoYPBCIZXk5/htYT+UwQC4LvVFaURERJTIGLxQSMlJBmxdNiPoOYIA/NNLR7llmoiIVMfghSQpL7Rg+/IihCqmW72/hVumiYhIVQxeSLKxGSkIFpcIAByuHjTaO6M2JiIiSjxsD0CSnb/YI+m85w63wSsIKMnPYd8jIiJSHIMXkmzcmDRJ573ech6vt5xHVroRW5fNYN8jIiJSVFSWjbZv3w6r1Yq0tDTMnj0b77zzTsBz33rrLRgMhhFfH330UTSGSkEUW7NhMaVJrubSdamffY+IiEhxqgcvr7zyCtavX49f/OIXOHr0KObOnYtFixbhzJkzQa/7+OOP4XA4Br+mTp2q9lAphOQkAzYtLgAgrxwdk3iJiEhJqgcvTz75JH784x/jJz/5CW644Qb89re/xYQJE7Bjx46g140bNw5ms3nwKzk5We2hkgTlhRbsWFEEs0naEhLAJF4iIlKWqsFLX18fPvjgAyxYsMDn+IIFC/Duu+8GvXbWrFmwWCy48847cfDgwYDn9fb2wu12+3yRusoLLfjLI3dg3e1TJF8jNdmXiIgoFFWDl/b2dng8HowfP97n+Pjx4+F0Ov1eY7FYsGvXLuzZswe1tbWYNm0a7rzzThw6dMjv+Vu2bIHJZBr8mjBhguL/DhopOcmAsim5ks+XmuxLREQUSlR2GxkMvhkSgiCMOCaaNm0apk2bNvh9aWkpzp49iyeeeALz5s0bcX5lZSUeeuihwe/dbjcDmCgptmbDnJkKp7s36HkWUxqKrdlRGhUREcU7VWdecnNzkZycPGKW5fz58yNmY4IpKSnBp59+6vdnqampyMzM9Pmi6EhOMqBqyfSQ521aXMB6L0REpBhVg5eUlBTMnj0bBw4c8Dl+4MAB3HLLLZIf5+jRo7BYWCtEi8oLLdi5oshv48ax6UbsXFHEOi9ERKQo1ZeNHnroIaxcuRJz5sxBaWkpdu3ahTNnzmDNmjUABpZ9Pv/8c7zwwgsAgN/+9reYNGkSpk+fjr6+PtTU1GDPnj3Ys2eP2kOlMJUXWjC/wIyG1g7Y2toBGFA6OYcVdomISBWqBy933XUXOjo68Ktf/QoOhwOFhYWoq6vDxIkTAQAOh8On5ktfXx8efvhhfP755xg9ejSmT5+O1157DRUVFWoPlSKQnGRA2dRclE2VnsRLREQUDoMgCHFVPcztdsNkMsHlcsVd/ovHK6DR3onzF3swbsxAEixnNoiIKB7IuX+zt5FO1Dc7UL2/BQ7X1XopFlMaNi0uYE4JEREllKj0NqLI1Dc7sLamySdwAQCnqwdr2TuIiIgSDGdeNGjo8lDuNamo2ncS/tb2BAz0GKre34L5BWYuIRERUUJg8KIxdccd2Li3GZ3dfZLOF3C1d1Dp5Bx1B0dERKQBDF40ZEtdC545ZA/rWvYOIiKiRMGcF42oO34u7MAFYO8gIiJKHAxeNMDjFbBxb3PY12eNHsXeQURElDAYvGhAo70Tnd39YV/fdfkKfl3/oYIjIiIi0i4GLxqgRL7KM4fsqDt+ToHREBERaRsTdjVAqXyVjXubsbDQEnDLtJIVelntl4iIYoXBiwYUW7NhMaWNKEInV2d3f8At0/XNDlTtOwmnu3fwmDkzFVVLpmN+gVlWIBKNar8er4CGtg7YWjsACCjNz0XJZDZ6JCIi9jbSDLGKbqT/M353901YetO1Ix57TU1TwGuy0o3ounQ15yZYIBJonGJIsWNFUcQBTH2zAxtqT/iMSRzn1mUz2A6BiCgOybl/M+dFI8oLLdixoggWk+8SUnaGEdvunoXsjBRJjzN8CcrjFbCh9kTQa4YHCY4AbQc8XgHV+1sCVvsFBqr9erzhh2BioDV8TOI417AdAhFRwuOykYaUF1oCLuEkJRnwwEuBZ0+AgRmT4VumG1o7/AYCoQgY2Xag0d4ZdGkr0mq/Hq+Aqn0tIc+r2neS7RCIiBIYZ140JjnJgNLJOVh607UoHZLjUTHTgtXzrAGvMwDYtLhgxA3d1tYe9ljEQEQkdVdUuLunGu2dcLpDX+t09/qMi4iIEguDFx2prCjA9uWzkJ1h9DluMaUFyTWJbHbC6bo8+N9Sd0WFu3tKTtDDdghERImLy0Y6UzEzDwsLLZJ3B5VOzsG2g6fC/n1DG0SKu6Kcrh6/eS8GAGY/S1fBDN1y3X6xN/QFX2M7BCLSE5aXUBaDFx0Sl5akKMnPGbGbSI7sa1J9fu+mxQVYW9MEA+ATwIh/gv6WrgIZ2L7dImmpaChzZirbIRCRbvh7rzNnpqFqiXLlJRINl43iXHKSAT+6JXCuTCjmTN8ZDnFXlHnYrihz0KWrkcRdRXIDFwC4p3giP7EQkS4Eeq9zunu4ezICnHlJAJNy08O6zt/uJSD4rigppGzfDibcfw8RUTRJea+rrD2hmd2TelraYvCSAOTmh0hZApKzdDVcQ1t427dFzHchIj2Q8l534VI/Gto6UDYlN0qj8q/uuAMb9zb75DlmZ6TgezflYX6BeTCQ0UqAw+AlAYRKtB3OrHCp/+EGSv7LF05CMBFRrEh9r7O1xjZ42VLXgmcO2Ucc7+zuw38cPo3/OHwaFlMaltxowd5jDk3k7jB4SQChEm0FAA9+Zyom5WZEKZKWX4E3nIRgIqLYkvZe1/blRZXHEVjd8XN+A5fhHK4ev+eJuTs7FWgNIwcTdhNEsETbnSuK8M/f+daIwnhqKc2X/wlDbkIwEVGsSX2vq2v+IiaJux6vgI17mxV5rMraExG1hpGLMy8JJNJEW6WUTA69fTsr3Yin7ylCe3ev5hPHiIj8kfJeJxrejiUaGu2d6OwOP/9wqGjn7nDmJcEEaj8Q7TFsXTYj6Dlbl81A2dTcmI6TiChSP7plkqTzhrdjiQalK5WHm88YDgYvFBPlhRbsXFEEc2aqz3FzZmrU106JiJRW3+zArY+/iafe+FTyNdFue6L8zk0uG1EC0MoyFhGRkuqbHVhb0yT7Vh7tMhDiTlSHS5mgKZx8xnAxeKGYiqReDBGR1ni8Aqr3t8gKXGJVBmLoTtRI50yy0o0oieJ7OZeNiIiIFNJo75Q1kxHrMhDiTlTLsJ2ow0eSlW4M+jhbl82I6vg580Ixo5VKjURESpGbt6J2UVAp/C3hz544Fh98dsHn/flAixNV+07C6e69Ov7MVFQtmc4idZQY6psdqN7f4vMJxaKBP2IiokjIyVtZd/sUPDj/W5r40OZvCX/491rKU2TwQlEXKJnN6erB2pomFqMjIt0qtmYjO8MoqX5K2ZRcTQQucmglT5E5LxRVwZLZxGPV+1uiWqmRiEgpyUkGbF5aGPI8C/u0RYTBC0VVQ2tH0GQ2AQPFmp4/bMfeY5/D1trBQIaIdKViZh5Wz7MG/LkB7NMWKYMgCHF1Z3C73TCZTHC5XMjMzIz1cGiI+mYHHvrff8WlPo+s62KVEEZEFIm64w5s3NuMzu6+wWPM7QtMzv2bwQtFRX2zA2tqmiJ6DFbeJSK94a5K6eTcv5mwS6rzeAVU7TsZ8eNsqD0R9cZlRESR0EqCa7xhzguprtHe6VMXIFxdl/rREMXGX0REpE0MXkh1SjYbs7W1K/ZYRESkTwxeSHXKNhvjkhERUaJj8EKqK7Zmw5yZqshjce2YiIgYvJDqkpMMqFoyPeR56SnJQX8+Nt2IknwGL0REUni8AmytHXFZM4u7jSgqygst2LmiCBtqT6Drkm/Z7LHpRmxZNgMAgm6n3hLlrqVERHoV7/3jWOeFosrjFdDQ2vF14u3AFsKS/JzBoKS+2YGqfS1wuuPzD46I4oOW67cE6h8njk6r/eNYpI7Bi65p+U2BiEjLsxoer4BbH38zYBsWAwCzKQ1/eeQOzb2vskgd6RqLOhGR1ni8AhraOlDT8Bn+1Owc8XOHqwdraprw4HemYt0dU2MWGDTaOyX1j2u0d+r6fZbBCxERURD1zQ6/+Xr+PPXGp3i58SyqlsRmFkZqXS0l62/FAncbERERBSD2ZZMSuIic7oFZmPpmh4oj809qXS1l629FH4MXIiIiPwb6srWEfX1l7Ymob08utmbDYkoLWM7TgIH8nGJrdjSHpTgGL0RERH4M9GULf3nlwqV+NLRFtx9bcpIBmxYXABhZj1z8ftPiAs0l68rF4IWIiMgPJfJCbAo1k5VTcK680IIdK4pgNvkuDZlNaZrdJi0XE3aJiIj8UCYvJPJlo4H6VyfhdPcOHjNnpqJqyfSAgUh5oQXzC8xxW3aCwQsREZEfA33Z0iJaOirNz41oDGLC8HBOdy/W1DRhZ5CZlHguO8FlIyIiIj8G+rIVhH19VroRJREEDx6vgA21J4KesyEGScFaEJXgZfv27bBarUhLS8Ps2bPxzjvvBD3/7bffxuzZs5GWlob8/Hzs3LkzGsMkIiLyIfZly0o3jvhZqGayWyPsx9bQ2hFyi3bXpX40KJRXoyeqLxu98sorWL9+PbZv346ysjI888wzWLRoEVpaWnDdddeNON9ut6OiogKrVq1CTU0NDh8+jAceeADf+MY38IMf/EDt4RIREfkQ80ca2jq+TsAVUJqfi5LJOTjQ4pSdjyKFxyvg/3xwVtK5trZ2lE2NbHlKb1TvbXTzzTejqKgIO3bsGDx2ww034Hvf+x62bNky4vxHHnkE+/btw4cffjh4bM2aNfjrX/8Km80W8vextxEREUWT0v3Y/PVOCmbd7VPw8MJpYf8+rdBMb6O+vj588MEH2LBhg8/xBQsW4N133/V7jc1mw4IFC3yOLVy4ELt370Z/fz+MRt+pu97eXvT2Xo143W63QqMnIiIKTcnE2EAdoYOJ16TcYFTNeWlvb4fH48H48eN9jo8fPx5O58jGVgDgdDr9nn/lyhW0t7ePOH/Lli0wmUyDXxMmTFDuH0BERBQlHq+A6v0tsgKXrNGjUJLP4EUVBoPv9JkgCCOOhTrf33EAqKyshMvlGvw6e1baGiEREZGWhOoI7U+fR8CBFv+TAfFM1eAlNzcXycnJI2ZZzp8/P2J2RWQ2m/2eP2rUKOTkjIwuU1NTkZmZ6fNFRESkN+FU9L3U54lZE8hYUjV4SUlJwezZs3HgwAGf4wcOHMAtt9zi95rS0tIR57/++uuYM2fOiHwXIiKieBFJRd+qfSdVqfcipy1BNKm+Vfqhhx7CypUrMWfOHJSWlmLXrl04c+YM1qxZA2Bg2efzzz/HCy+8AGBgZ9G2bdvw0EMPYdWqVbDZbNi9ezdefvlltYdKREQUM2JHaKerR3ZTAae7F432TkWTd/3tesrOSMHmpYWomBnb/kiqBy933XUXOjo68Ktf/QoOhwOFhYWoq6vDxIkTAQAOhwNnzpwZPN9qtaKurg4PPvggnn76aeTl5eH3v/89a7wQEVFcEztCr61pggHyuyIp0UhSFGjXU2d3Hx54qQmr/2ZFZUX41YcjpXqdl2hjnRciItIzuXVeRC+vKlFk5sXjFXDr42+G/P3bl89Cxcy8iH+fSDN1XoiIiEieoR2hna7LePS1D9HZ3Rf0GnNmKoqt2WH9vuFF9ryCIClw2ri3GQsLLTHpVM3ghYiISGOGFr4bnZLst7P0UFVLpocVRPib5ckaLW1zTGd3v+J5NlKxqzQREZGGBWsOmZVuxM4VRWH1URLzWobPsnRdDt4Mcigl82zk4MwLERGRxgVrDhnOjEs41Xz9iWR7dyQYvBAREelAcpIBZVNyUTYl8g7S4VTzHc5iSgs7zyZSXDYiIiJKMJEu9xgAbFpcEJNkXYAzL0RERAknkuUeiykNmxYXhJVnoxQGL0RERAkmnGq+P7plEhZMN6PYmh2zGRcRl42IiIgSjFjNV459fz2nicAFYPBCRESUkMoLLdixokhyXZeO7j402jtVHpU0DF6IiIgSVHmhBU/fWyT5/FjVdRmOwQsREVECK8nPQXaGtNmXWNV1GY7BCxERUQJLTjJg89LCkOfFsq7LcAxeiIiIElzFzDysnmcN+PNY13UZjsELERERobKiANuXFyE7I8XnuMWUhh1h9k9SC+u8EBEREQCgYqYFCwvNaLR34vzFHowbk6aZ7dFDMXghIiKiQclJBpROzon1MILishERERHpCoMXIiIi0hUGL0RERKQrDF6IiIhIVxi8EBERka4weCEiIiJdYfBCREREusLghYiIiHSFwQsRERHpCoMXIiIi0hW2B4gyj1fQfM8IIiIiLWPwEkX1zQ5U72+Bw9UzeCxrtBE/KpuEdXdMZRBDREQkgUEQBCHWg1CS2+2GyWSCy+VCZmZmrIczONNyoMWJ/zh8OuB5WelGbF02Q1Mtx4mIiKJFzv2bMy8q8jfTEkjXpX6srWnCjhVFDGCIiIiCYPCiMHGm5Y0WJ3YHmWnxRwBQvb8F8wvMIZeQPF4BDW0dsLV2ABBQmp+Lksk5XHoiIqK4x+BFQfXNDlTta4HTHXqmJRCHqweN9k6UTs4J+ns21J5A16X+wWPbDrYiK92If/veDIzNSGFCMBERxS0GLwqpb3ZgTU2TIo91/mLg4CfY7+m61I8HXvL9mcWUhk2LC7gURUREcYN1XhTg8QrYUHtCsccbNyYt4O+p2tci67Gcrh6srWlCfbNDiaERERHFHIMXBTS0dfgs4YTLgIGZkmJrtt+fN9o7ZS9JiVvJqve3wOONq41lRESUoBi8KGAgaTYyYlbKpsUFAXNUgi0nBSNgIJemQYFxEhERxRqDF0XIn9HISEn2+d5sSgu5TTrQcpJUD7zE5SMiItI/JuwqoDQ/F9sOtko6V0ygnV9glt0moNiaDXNmWti7mVyX+7Gmpgk7WUuGiIh0jMGLAkom5yAr3Rg07yU9JRnPrpzjU4sl2HZof5KTDKhaUhDxrqbK2hOSaskQERFpEZeNFJCcZMDWZTOCnvPkP9yIsqm5EQcM5YUW7FxRhKx0Y9iPceFSPxrapOW/eLwCbK0d2Hvsc9haO5j0S0REMceZF4WIQUXVvpNwunsHj5szU1G1ZLqiyzTlhRbMLzCPqLDrutyH/2/PcXT3ekI+hq21A2VTcoOeU3fcgY17m9HZ3Td4jHVjiIgo1hi8KEgMKuTmsoQjOcmAsim5IwKQkw43npaUfxN8BmVLXQueOWQfcdzxdd0Y9mAiIqJY4bKRwpKTDCidnIOlN12L0hj0GrolP/hsiqg0yHl1x8/5DVxEYg8mLiEREVEsMHiJM2LycDBZ6UaUBEgW9ngFbNzbHPL3iD2YiIiIoo3BS5yRkjy8ddmMgDNCDW0d6OyWVi043KJ5REREkWDwogNyd/yIycPmzFSf4+bMVOxcUYT5BWa/j1ff7MA/vSh9G3akRfOIiIjCwYRdjatvdqB6fwscrquzHFJ2/ARKHv5zsxN/99gbI3YQLbnRgl2H7JJrBedkpATswURERKQmgyAIcZV16Xa7YTKZ4HK5kJmZGevhRKS+2YG1NU0jAgpxwUfujp9AO4jCsX15ESpmcrcREREpQ879m8tGGuXxCqje3+J3JiScTtGhdhDJsXqelYELERHFDIMXjWq0d/osFQ0ndoqWsuNH6g6iUDJSk7F9+SxUVhRE/FhEREThYs6LRkndySPlvEZ7p+QdRMHsWjEHZVOl1ZEhIiJSC4MXjZK6k0fKeZFuaTYAMJvSAtaGISIiiiYuG2lUsTUbFlMaAtXnNWBgl5CUHT+RbGkWf/+mxQXsQk1ERJqgavBy4cIFrFy5EiaTCSaTCStXrkRXV1fQa+6//34YDAafr5KSEjWHqUnJSQZsWjyQWzI8ZJAbUIiBUCir5lpHnGc2pbGPERERaYqqW6UXLVqEv/3tb9i1axcA4B//8R8xadIk7N+/P+A1999/P7744gs899xzg8dSUlKQnS2tpkg8bZUGwq/z4u9x/G27Fq2eZ0VlRQE8XiEqjSWJiIiGknP/Vi14+fDDD1FQUICGhgbcfPPNAICGhgaUlpbio48+wrRp0/xed//996Orqwt//OMfw/q98Ra8AFAsoPAXCGVnGLF5aSEqZuYpOWQiItUEek/khy99k3P/Vi1h12azwWQyDQYuAFBSUgKTyYR33303YPACAG+99RbGjRuHrKws3HbbbXjssccwbtw4v+f29vait7d38Hu3263cP0IjxE7VkQpUdZd/3ESkF4Fmo5fcaMHeY+fgdF+9H5gzU1G1ZDqXveOQajkvTqfTb8Axbtw4OJ3OgNctWrQIL774It5880385je/wfvvv4877rjDJ0AZasuWLYM5NSaTCRMmTFDs3xCPxEBo6U3XonRyDgMXItINcfl7eA0sh6sHzxyy+wQuAOB092JNTRPqmx3RHCZFgezgpaqqakRC7fCvI0eOAAAMhpE3RkEQ/B4X3XXXXfj7v/97FBYWYvHixfjTn/6ETz75BK+99prf8ysrK+FyuQa/zp49K/efREREGubxCjh8qh0b9pyQ3H9tqA21JyRXIyd9kL1stG7dOtx9991Bz5k0aRKOHz+OL774YsTPvvzyS4wfP17y77NYLJg4cSI+/fRTvz9PTU1Famqq358REZG+1R13YOPeZp9msnJ1XepHQ2sHi2zGEdnBS25uLnJzQ78ASktL4XK50NjYiOLiYgDAe++9B5fLhVtuuUXy7+vo6MDZs2dhsXDNkogokSjZTNbW1s7gJY6olvNyww03oLy8HKtWrUJDQwMaGhqwatUqfPe73/VJ1r3++uvx6quvAgC++uorPPzww7DZbDh9+jTeeustLF68GLm5ufj+97+v1lCJiEhjlGwmO4D5ffFE1fYAL774In76059iwYIFAIAlS5Zg27ZtPud8/PHHcLlcAIDk5GScOHECL7zwArq6umCxWHD77bfjlVdewZgxY9QcqiK0uE1Pi2MiIgpGqWayQ0WyY9PjFdDQ2gFbWzuAgU0PJfnc8BBLqhapi4VY1Xnxty4bTjE5pXi8Ara9eQrPHbaj6/LVpoxZo434UZkV6+6Ywj88ItIkW2sH7nm2QbHHG5tuxJGN88Ouj7Wh9gS6Lvk2t81KN2Lrshnchq0gOfdv9jZSwJa6FjzwUtOIhDKHqwdrY7BNr77ZgdmbD+CpNz7xCVwAoOtyP5564xPM3nyA2weJSJPkNpPNSjcG/fmWZTNkBS4erwBbawd+tf8k1tQ0jQhcgIEkYG7Djh0GLxEKtS4rAKje3xK1bXr1zY6Af2xD8Q+PiLRKajPZa1KT8eKPb8YHG+dj54oimDN9r7OY0rBTZm+2+mYHbn38TdzzbAP+4/DpkOdH8/2drlI15yXeSV2Xdbh60GjvVKRKbqjxVO9vkXVN9f4WzC8wcwmJiDRDbCY7vBjdcL/+wY2DO4iUqCAeqgecP9F6fydfnHmJQKO9E53dwWc4RHKnQcPRaO8M+cc+nMPVg+cP2/nJgYg0IznJgE2LC4LuD1o9z4qKmb4zKpFUEBc//IXzThiN93fyxeAlAnJesFKnQSMR7h/Qo699iLKtb3IJiYg0o7zQgh0rimAx+b53ZmcYsX35LFRWFCj6+8L58CeKxvs7+eKykUT+tsrlXiOtsm9ORgqKrdnqDhCR/QE53T1YU9Mke32YiEgt0WwmG+6Hv6x0Y1Te38kXgxcJ/G2V23bwFEyjR8FgAEJtNq9aMj0qOSXiOrHT1RPW1CcAVNaeYA4MEfmIZb0ocSlIbeF++OM7ZWwweAlB3L3jj+vyFUmPIXWGJlLiOvHamiYYgLACmAuX+tHQ1oGyKSyjTUQD74FV+076dGw2Z6aiasn0uJqlDffD34VL/UzYjQHmvATh8Qqo2ncy4seJZjKXuE5sHrZOLOfTga21Q9lBEZEuiR/ehgYuAOB098ZdqQXxwx8gfzaFCbvRx5mXIBrtnSP+aMMR7WQuf+vEsyeOxc/++6/447FzEh6BO4+IEp3HK2BD7Ymg5zz8f47jcp8HZtPouGg9In74q97fIit5lwm70cfgJYhIo2kDALMpLSbJXP7WiX84e4Kk4KU0n0tGRImuobUjZLHLr3qv4MH//VcAsW2HoiTxw9/zh+149LUPQ56fncGE3VjgslEQkUTT4uePTYsLNPNppGRyTsgy2lnpRpQk+NqtWBp877HPYWvtYA0cSkgDOyulc8aoHYoakpMMuL/MOmKbtj+blxZq5j0+kTB4CaLYmg1zZuhk27HpxhHnmU1p2KGxbcfJSQZsXTYj6DlbZfYAiTdDS4P/8x+O4Z5nG/B3j72BuuP6f0Mmkkfe+4AY4sdLuXzphfLyojYmuopdpUMItttItHNFUdRqESghUXYPyBWqNPjqeVbFC2MRadXhU+2499/fC+val1eVxM3um/pmx4gcmJyMFDy6tHBEhV+KjJz7N4MXCQK1RB+bbsQWnbZEj2XdBi3yeAXc+vibIZP0ti+fxU9alBA8XgGzNx8Imffiz+/uvglLb7pWhVHFBt8vo0PO/ZsJuxKICVzDK+yW5MvrnaEl0Sr8pBdSS4Nv3NuMhYUW3f5/J5JKXGYONfPsT7ztvuH7pfYweJEoOcmAsqm5gx1MKb5I3VnW2c0ifpQ4ygst2L68COteboKUNJZY7rCkxMKEXSLI+6T4Ty/Gx44KIinGZqRIClyAgaRdLe2wpPjF4IUIAzvLsjNSJJ3bdbk/braEEoUip97Vg9+ZqsscQNIfBi9EGFgW3Ly0UNY18bIllCgYObOSk3IzVBwJ0VUMXoi+VjHTgtXzrJLOFQA4XD1otHeqOyiiGBuYlQxe3FIUb4m6pF0MXoiGqKwowPbls5CRkizp/OcOt+HwqfaYzsCwIjCpSeqspCUGibp87Scu7jYiGqZiZh5Mo1Nw7+7QBbpebzmP11vOIyvdiK0q1/zxV2viz80ObNzbjM7uq7U44qXHDGlHxcw8rP5bF545ZPf7cwOin6jrr3gcX/uJg0XqiPwQi9Y5XT2yemzvVKklhL836vSUZFzq8/g93wBorj0F6V/dcTFY7hs8FouAIVA1bDF04mtfn1hhl8ELKUB8gwQgOYCxmNLwl0fuUPQTaKi2BdEcC1Gsq82GqoYt1prha19/5Ny/mfNCFEB5oQU7VhTBLKGzrEjpJF6PV0D1/hbZgYsaYyECrlabXXrTtSidHP0q46GqYTOZPjEweCEKorzQgr88cgfW3T5F8jVy6mKEIrVtQTTGQqQFUl/TfO3HNwYvFHeU3oGQnGSQ1Q5Aye2ikb4Bc+sqxRupr2m+9uMbdxuRLgVad1drB0KxNRvmzFQ43b1Bz1N6u2gkb8DZGUb2mKG4U2zNhsWUFjCZnv2VEgODF9KdQDseltxowa5D9hFvaE5XD9bWNEW0AyE5yYCqJdNDdthVeruo1KDJn81LC5mwSHEnOcmATYsLsLamCQb4JtOLr3b2V4p/XDYiXdlS14IHXmryCVyAgQS9Z/wELsDVN7dIy/mXF1qwc0URstJHVhsdm25UZZt0cpIB9xRfJ/u61fOsqJiZp+hYiLQiUDK92ZTGbdIJgjMvpBt1x88FLJIVytAdCKWTc8IeQ3mhBfMLzGho7YCtrR3AwM6Lknz1dl3I6ReTmTYKW5fNRMVMvnlTfBP/FmO5bZtih8EL6YLHK2Dj3uaIH0eJHQjJSQaUTc1F2VTpSbyRkJP3Ur20kIELJQxx2zYlHi4bkS402jt9SuCHq+3LbgVGE11yGuOZM7nDgojiH4MX0gWlajb87n8+xZa6FkUeK1q03BiPiCgWGLyQLihZs+GZQ3bUHXco9njRUDEzD6vnWQP+PBaN8YiIYoXBC+mCWNshlL+fYZb0eP+6tzni4nXRVllRgO3Li5CdkeJz3MIdFkRhU7qoJUUHE3ZJF4bWdgj01rJ6nhUFeSa8dsIZ8vE6uvsi3nkUCxUzLVhYyB0WROEaWuDydHs3Xm4841NHKRZdskk+Bi+kG2Jth+EVdLMzjNi8tBAVM/Nga+2Q/Hh67X3CHRZE4fFX4HI4p6sHa2qa8OB3pmJSbgY/IGgUgxfSlVC1HcSdOVJ2JrH3Camp74oX/2U7jc86L2FidjpWlk5Cyqj4X6kP1Loj1rbUtUiqEyXO7D71xqeDx4Z+QCJtMAiCEFcLfG63GyaTCS6XC5mZmbEeDsVA3fFzeOClo0HPsZjS8JdH7tDEmyrFny11LXj2HTuGpk8kGYBVc62orCiI3cBUplZvsUhJeU+QYvW8+P7/F2ty7t/x/zGAEg535lAsiZ/wh+d9eoWBnW5626ovVX2zA2trmnwCF+Bqb7H65tjs8FOqwCWgz52K8YrBC8Ul7syhWOi74sWz7wRfmnj2HTv6rnijNCL1eLwCDp9qxxN//hj/688fobL2uKq9xcKlVIFLkR53KsYj5rxQ3OLOHIoWMc/jlffPjJhxGc4rAP9lO40fz82PzuBUUN/swIbaE+i6JC0oUKq3WDiUTszX607FeMPgheKamjtztJqYSNHlL88jlM86L6k4InXVNzuwpqYprGtjscNPjcR8ve5UjCcMXojCoNXExESgpaBRzPOQu4gwMTtdlfGozeMVULUv/Jyd0+3RD9rEApdygstQuFMx9hi8EMkU6IYlJiYypyZ8oQITf3U6YhU0erwCqve3yA5ckgzAytJJagxJdY32Tjjd4QcBT73xCaaZr4nq/yspBS6/O9OC+QXj0fZlN373P58GOGsAe4hpA4MXIhmC3bAEDOxkqt7fgvkFZi4hBeEvSDnQ4gw6mxWoTocjRkFjo70zrE/zq+ZadVvvRYnlksraE1H/+5BS4FLU038lYD0Y7lTUDgYvRDKEumHFMjFRL+qOn/t69uRqsmdWutFv8qc4m/WTuZPw7DunAz6mgOgHjXJv5PFQ50WJ5ZILl/rR0NaBsim5CoxIulAFLkWVFQW48ZtjNTPDR/4xeCGSQeoNiwl9/gWaPQm0a0Wc4fr3IIGLKNpBo9wb+TWpyZh13ViVRhMdxdZsmDPTIlo6AgBba/SDF0B6Aj93KmqfPucuiWJE6g2LCX0j1R13SCrP7o/UvJJoBo1iIqjU25m7x4M1MSzWpoTkJAOqligxc6T9OilioLP0pmtROjmHgYvGMHghkiHUDcsAJvT5o2SV02CiGTSKiaAAJAcwQOyKtSmlvNCCnSuKkJVuHPGz9BRpt5TS/OjPulB8YfBCJEOwG5b4PRP6Rhqochq4k68ScjJSoh40iomgZpP0oElc3tKz8kILPtg4Hy/+5Gasu30K1t0+GS/++GYc++VCv0HNUFnpRpQwH4wixOCFSKZANywzWw8EFOlyjpRY8NGlhTEJGssLLfjLI3dg3e1TJF8TDzlRyUkGlE3JxcMLp+HhhdejbGouUkYlYeuyGUGv27psBoN7ihgTdonCIHXnAg0IdzlHfDZXzbVi1yF7wEyJ1fOsqJgZu6BRvJFvO3hK0vnxnBMlLitV7TsJp7t38Lg5MxVVS6YzuCdFqBq8PPbYY3jttddw7NgxpKSkoKurK+Q1giCguroau3btwoULF3DzzTfj6aefxvTp09UcKpFsarYeiDdSq5yaRo+C6/KVwe/NQ7anzrpurKQ6HbEysBMn1eeG7U8i5EQxuCe1qRq89PX14Yc//CFKS0uxe/duSdf8+te/xpNPPonnn38e3/rWt7B582bMnz8fH3/8McaMGaPmcIlIJVKqnK6eZ8XPym8IeMPT+g1xYCfO9JB9fxIlJ4rBPanJIAiC6mnvzz//PNavXx9y5kUQBOTl5WH9+vV45JFHAAC9vb0YP348Hn/8caxevTrk73K73TCZTHC5XMjMzFRi+ESkEH89oXIyUvDo0sKYLvsoKVDH5bHpRmxZNoPLJkQByLl/ayrnxW63w+l0YsGCBYPHUlNTcdttt+Hdd9/1G7z09vait/fqNK3b7Y7KWIm0RCy373T3oPOrXmRnpMBsGq2pmQlA+7MnShD/jQ2tHbC1tQMYmIEoyWetECKlaCp4cTqdAIDx48f7HB8/fjw+++wzv9ds2bIF1dXVqo+NSEuG9gY63X4JLzee8Vv1VIslzRNhOSE5yYCyqbkom8p6JkRqkL1VuqqqCgaDIejXkSNHIhqUweD76UQQhBHHRJWVlXC5XINfZ8+ejeh3E2ldfbMDtz7+Ju55tgH//IdjeOqNTwKWaxebFuq5qisR0XCyZ17WrVuHu+++O+g5kyZNCmswZrMZwMAMjMVy9ZPi+fPnR8zGiFJTU5GamhrW7yPSm/pmR9CkV39i0bSQiEhNsoOX3Nxc5OaqMxVqtVphNptx4MABzJo1C8DAjqW3334bjz/+uCq/k0gvPF4B1ftbwuoKw07XRBRPVK2we+bMGRw7dgxnzpyBx+PBsWPHcOzYMXz11VeD51x//fV49dVXAQwsF61fvx7/9m//hldffRXNzc24//77kZ6ejuXLl6s5VCLNa7R3hqyTEkw8VHUlIgJUTtj95S9/if/8z/8c/F6cTTl48CC+/e1vAwA+/vhjuFyuwXN+9rOf4fLly3jggQcGi9S9/vrrrPFCCS/S4COeq7oSUWKJSp2XaGKdF4pXttYO3PNsQ1jXWkxp+MsjdzDnhYg0S879m40ZiXRCLLEvlwGJU9WViBIDgxeKOx6vgMOn2vHEnz/GE3/+CIc/bYfHq/8JRrHEvhzmzFR2uiaiuKOpInVEkfJXmn3bwVZkpRuxNQ5Ks5cXWvDjsknYffi0pPN/8w83oWwKC6WFMrToXzxW/SWKNwxeKG7UNzsCNsXrutSPNTVN2BkHsxDfKTBLDl7avwre4Zj891vSYmViIrqKy0YUFzxeAVX7WkKeV7XvJPqueGFr7cDeY5/D1tqhuyWlYms2sjOMks7lDqPgxKJ/w7egO1mZmEjTOPNCcUFsShiK092Lki1voLP76rKS3j5lJycZsHlpIR546WjQ8yymgeUP8i9Y0T8BA4nOrExMpE2ceaG4IKcGytDABdDnp+yKmXlYPc8a8OfcYRRaqKJ/Aq5WJiYibWHwQnEhkuUR8ZN39f4WXS0hVVYUYPvyImRnpPgct5jSuMNIAqkBLysTE2kPl40oLhRbs2HOTJO0dOSP+Cn7P/7Shv/n1nzdzFhUzLRgYaGZO2XCIDXgZd4Qkfawwi7FjWC7jeSIl23VFJzHK+DWx9+E09XjN+/FAMCscGVij1dAQ2sHbG3tAAwonZyDkvwcBptEkHf/ZvBCccVfnRcAuCZ1FL7qvSLrseJhWzUFJ+42AuATwIihhJLLb4FemwyWiQYweGHwktA8XgENbR2wtXYAEFCan4u/s2bjtv91MOCnbH/Mmak4vOFOfiqOc9Go8yJlVpDBMiU6Bi8MXsgP8VO2nBf8y6tKUDo5R7UxkTaoWWHX4xVQtvV/4HQHLxjI5pmU6OTcv5mwSwmjvNCCHSuKsGHPCXRd7g99AbjTJNaiVbY/OcmgSJDqb7wDNYhCVzoWt2UzWCYKjcELJZTyQgvGpBlx77+/J+l87jSJnuE3/o6Lvfjl/mZdFBT0eAVse/NTPHf4tE9gbDGlocAyRvLjMFgmkobBCyWckvwcSduqzZmprFAbJf7yTvxxfF1QUEt1bAIl4gID4w31bxqKwTKRNCxSRwknOcmAqiUFIc+rWjKd+QdREKi/UCACtFNQUBy7v8BFLrZzIJKOwQslpPJCC3auKEJW+sgGh1npRu78iJJg/YWC0ULZ/nDHHgjbORBJx2UjSljlhRbMLzCP2FZdMplFw6IlVH+hYGKdHxLJ2IfKSEnGb/7hRgbLRDIweKGElpxkQNmUXJRNyY31UBJSJAFIrPNDlAqedq2cg7KpfP0RycHghYhiJtwAJDvDGPP8kEiDJ7H9QAm3RhPJxpwXIoqZYms2TKPlf4bavLQw5kt7xdZsWExpCGcU4jXMcyEKD4MXIoqZX9d/CNdleT2nVs+zomJmnkojki45yYBNiwd2rQUKP7LSjVg9zwqLyXeWxmxK09R2byK9YXsAIoqJuuMOPPCS9C7gORkpeHRpISpmauuG769GTVa6ET+6xYp1d0xBcpIhapWCifSMvY0YvBBpmscr4O8eewOd3X0hz113+xSUTclV7IavRiDB4IQocuxtRESa1mjvlBS4AMDU8dco1u/H3yxJdkYKNvuZ0ZETkCjVG4mIpGHwQkRRJ2ebsVJbogN1Fe/s7sMDLzVh9d+sqKwoGDy3at9Jn4aK5sxUVC2ZzjwVIg1gwi4RRZ3UgESpLdFSquE+c8iOuuPnUN/swJqaphGdoJ3uXqypaUJ9syPi8RBRZDjzQkRRJ24zDlWhVqkt0VKr4T6y5ziSk4J/pttQewLzC8zMaSGKIc68EFHUiduMg93+ldwSLXWZ6mKvB12XgzdZ7LrUj4bWDiWGRURhYvBCRDFRXmjBjhVFI2qg5GSkYPvyosH8EyUo3UrA1tau6OMRkTxcNiKimBGbY6q9zbjYmo3sjBTJO5xC45IRUSwxeCGimIrGNuPkJAM2Ly2UVRQvGG6LJootLhsRUUKomGnB6nnWiB9nbLoRJfkMXohiicELESWMyooCbF8+C2PSwp903rJsBncaEcUYgxciSigVM/Pwwcb5yM4wBj1veHxiMaVhJ5spEmkCc16IKOGkjErCv31/BtbWDOTADC1eJ8Ys2+6ZhbEZqexXRKRBDF6IKCGJW7WH9zoym9KwaXEBZ1iINIzBCxElrGht1SYiZTF4IaKExo7QRPrDhF0iIiLSFQYvREREpCsMXoiIiEhXGLwQERGRrjB4ISIiIl1h8EJERES6wuCFiIiIdIXBCxEREekKgxciIiLSlbirsCsIAy3W3G53jEdCREREUon3bfE+HkzcBS8XL14EAEyYMCHGIyEiIiK5Ll68CJPJFPQcgyAlxNERr9eLc+fOYcyYMTAY2FwtELfbjQkTJuDs2bPIzMyM9XDiBp9X9fC5VQefV3XweZVPEARcvHgReXl5SEoKntUSdzMvSUlJ+OY3vxnrYehGZmYm/7BUwOdVPXxu1cHnVR18XuUJNeMiYsIuERER6QqDFyIiItIVBi8JKjU1FZs2bUJqamqshxJX+Lyqh8+tOvi8qoPPq7riLmGXiIiI4htnXoiIiEhXGLwQERGRrjB4ISIiIl1h8EJERES6wuAlgTz22GO45ZZbkJ6ejqysLEnXCIKAqqoq5OXlYfTo0fj2t7+NkydPqjtQnblw4QJWrlwJk8kEk8mElStXoqurK+g1999/PwwGg89XSUlJdAasUdu3b4fVakVaWhpmz56Nd955J+j5b7/9NmbPno20tDTk5+dj586dURqp/sh5bt96660Rr02DwYCPPvooiiPWvkOHDmHx4sXIy8uDwWDAH//4x5DX8DWrHAYvCaSvrw8//OEPsXbtWsnX/PrXv8aTTz6Jbdu24f3334fZbMb8+fMHe0gRsHz5chw7dgz19fWor6/HsWPHsHLlypDXlZeXw+FwDH7V1dVFYbTa9Morr2D9+vX4xS9+gaNHj2Lu3LlYtGgRzpw54/d8u92OiooKzJ07F0ePHsXPf/5z/PSnP8WePXuiPHLtk/vcij7++GOf1+fUqVOjNGJ96O7uxo033oht27ZJOp+vWYUJlHCee+45wWQyhTzP6/UKZrNZ2Lp16+Cxnp4ewWQyCTt37lRxhPrR0tIiABAaGhoGj9lsNgGA8NFHHwW87r777hOWLl0ahRHqQ3FxsbBmzRqfY9dff72wYcMGv+f/7Gc/E66//nqfY6tXrxZKSkpUG6NeyX1uDx48KAAQLly4EIXRxQcAwquvvhr0HL5mlcWZFwrIbrfD6XRiwYIFg8dSU1Nx22234d13343hyLTDZrPBZDLh5ptvHjxWUlICk8kU8jl66623MG7cOHzrW9/CqlWrcP78ebWHq0l9fX344IMPfF5nALBgwYKAz6HNZhtx/sKFC3HkyBH09/erNla9Cee5Fc2aNQsWiwV33nknDh48qOYwEwJfs8pi8EIBOZ1OAMD48eN9jo8fP37wZ4nO6XRi3LhxI46PGzcu6HO0aNEivPjii3jzzTfxm9/8Bu+//z7uuOMO9Pb2qjlcTWpvb4fH45H1OnM6nX7Pv3LlCtrb21Ubq96E89xaLBbs2rULe/bsQW1tLaZNm4Y777wThw4disaQ4xZfs8qKu67SiaaqqgrV1dVBz3n//fcxZ86csH+HwWDw+V4QhBHH4o3U5xUY+fwAoZ+ju+66a/C/CwsLMWfOHEycOBGvvfYali1bFuao9U3u68zf+f6Ok7zndtq0aZg2bdrg96WlpTh79iyeeOIJzJs3T9Vxxju+ZpXD4EXn1q1bh7vvvjvoOZMmTQrrsc1mM4CBTwwWi2Xw+Pnz50d8gog3Up/X48eP44svvhjxsy+//FLWc2SxWDBx4kR8+umnsseqd7m5uUhOTh4xExDsdWY2m/2eP2rUKOTk5Kg2Vr0J57n1p6SkBDU1NUoPL6HwNassBi86l5ubi9zcXFUe22q1wmw248CBA5g1axaAgTX0t99+G48//rgqv1MrpD6vpaWlcLlcaGxsRHFxMQDgvffeg8vlwi233CL593V0dODs2bM+QWKiSElJwezZs3HgwAF8//vfHzx+4MABLF261O81paWl2L9/v8+x119/HXPmzIHRaFR1vHoSznPrz9GjRxPytakkvmYVFstsYYquzz77TDh69KhQXV0tXHPNNcLRo0eFo0ePChcvXhw8Z9q0aUJtbe3g91u3bhVMJpNQW1srnDhxQrjnnnsEi8UiuN3uWPwTNKm8vFyYOXOmYLPZBJvNJsyYMUP47ne/63PO0Of14sWLwr/8y78I7777rmC324WDBw8KpaWlwrXXXpuwz+sf/vAHwWg0Crt37xZaWlqE9evXCxkZGcLp06cFQRCEDRs2CCtXrhw8v62tTUhPTxcefPBBoaWlRdi9e7dgNBqF//7v/47VP0Gz5D63Tz31lPDqq68Kn3zyidDc3Cxs2LBBACDs2bMnVv8ETbp48eLgeygA4cknnxSOHj0qfPbZZ4Ig8DWrNgYvCeS+++4TAIz4Onjw4OA5AITnnntu8Huv1yts2rRJMJvNQmpqqjBv3jzhxIkT0R+8hnV0dAj33nuvMGbMGGHMmDHCvffeO2Kb6dDn9dKlS8KCBQuEb3zjG4LRaBSuu+464b777hPOnDkT/cFryNNPPy1MnDhRSElJEYqKioS333578Gf33XefcNttt/mc/9ZbbwmzZs0SUlJShEmTJgk7duyI8oj1Q85z+/jjjwuTJ08W0tLShLFjxwq33nqr8Nprr8Vg1Nombikf/nXfffcJgsDXrNoMgvB1xhARERGRDnCrNBEREekKgxciIiLSFQYvREREpCsMXoiIiEhXGLwQERGRrjB4ISIiIl1h8EJERES6wuCFiIiIdIXBCxEREekKgxciIiLSFQYvREREpCsMXoiIiEhX/n/YFulbAoXiAQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cities, distance_matrix = create_problem_cluster(1)\n",
    "plt.scatter(x = cities[:, 0], y = cities[:, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "c79db795-83dc-4da7-bd53-86695b9633cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "208"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(cities)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "c3d17b1a-02d5-4427-a9c0-3cf4f9b3f6d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "N_CITIES = 100\n",
    "TRIALS = 100\n",
    "MAX_ITER = 10**5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "6e3894fa-fc61-4b72-a756-4a3dc3618fa2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:03<05:51,  3.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 217 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:08<07:10,  4.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 203 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [00:11<06:21,  3.93s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 212 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:17<07:32,  4.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 289 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [00:20<06:23,  4.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 179 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [00:22<05:08,  3.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 165 11934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [00:25<04:42,  3.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 198 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:30<05:48,  3.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 264 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [00:33<05:35,  3.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 214 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:37<05:23,  3.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 190 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:43<06:28,  4.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 275 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [00:45<05:13,  3.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 152 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [00:50<05:45,  3.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 240 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [00:53<05:26,  3.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 207 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [00:58<05:50,  4.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 251 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [01:02<05:40,  4.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 261 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [01:05<05:15,  3.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 196 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [01:08<04:52,  3.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 213 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [01:13<05:36,  4.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 260 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [01:18<05:53,  4.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 280 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [01:22<05:16,  4.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 217 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [01:25<04:50,  3.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 212 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [01:29<05:03,  3.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 224 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [01:32<04:30,  3.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 207 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [01:37<05:09,  4.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 250 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [01:40<04:39,  3.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 196 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [01:46<05:20,  4.40s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 284 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [01:49<04:45,  3.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 197 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [01:52<04:14,  3.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 180 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [01:58<05:02,  4.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 264 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [02:04<05:30,  4.78s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 305 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [02:06<04:37,  4.08s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 189 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [02:09<04:11,  3.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 212 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [02:11<03:31,  3.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 157 11934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [02:17<04:16,  3.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 276 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [02:20<03:57,  3.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 212 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [02:23<03:42,  3.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 187 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [02:26<03:36,  3.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 211 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [02:31<03:54,  3.84s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 233 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [02:34<03:37,  3.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 207 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [02:36<03:11,  3.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 166 11934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [02:41<03:31,  3.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 220 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [02:45<03:26,  3.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 216 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [02:48<03:16,  3.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 184 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [02:53<03:39,  3.99s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 251 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [02:56<03:17,  3.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 165 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [02:59<03:09,  3.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 232 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [03:04<03:27,  4.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 235 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [03:08<03:18,  3.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 257 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [03:11<03:10,  3.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 238 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [03:14<02:55,  3.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 196 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [03:17<02:38,  3.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 179 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [03:20<02:34,  3.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 197 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [03:24<02:40,  3.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 228 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [03:27<02:27,  3.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 181 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [03:30<02:24,  3.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 195 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [03:35<02:39,  3.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 224 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [03:39<02:39,  3.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 245 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [03:42<02:28,  3.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 201 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [03:46<02:25,  3.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 213 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [03:49<02:15,  3.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 222 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [03:56<02:47,  4.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 261 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [03:59<02:28,  4.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 178 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [04:03<02:21,  3.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 199 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [04:09<02:41,  4.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 303 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [04:12<02:20,  4.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 199 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [04:15<02:08,  3.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 218 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [04:18<01:58,  3.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 211 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [04:21<01:48,  3.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 196 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [04:26<01:57,  3.93s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 244 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [04:31<01:59,  4.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 248 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [04:33<01:42,  3.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 209 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [04:35<01:20,  2.99s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 143 11934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [04:38<01:21,  3.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 266 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [04:43<01:31,  3.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 279 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [04:46<01:24,  3.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 207 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [04:53<01:40,  4.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 286 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [04:58<01:39,  4.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 221 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [05:03<01:39,  4.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 245 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [05:06<01:24,  4.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 236 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [05:07<01:04,  3.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 140 11934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [05:13<01:14,  4.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 250 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [05:18<01:11,  4.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 242 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [05:23<01:11,  4.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 235 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [05:26<01:00,  4.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 203 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [05:32<01:04,  4.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 267 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [05:37<01:01,  4.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 230 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [05:41<00:54,  4.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 213 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [05:45<00:47,  4.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 205 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [05:48<00:41,  4.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 228 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [05:53<00:38,  4.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 238 21320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [05:56<00:30,  3.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 211 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [05:59<00:24,  3.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 178 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [06:02<00:20,  3.45s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 212 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [06:06<00:17,  3.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 223 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [06:08<00:13,  3.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 198 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [06:10<00:08,  2.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 172 11934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 98/100 [06:13<00:05,  2.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 215 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [06:16<00:02,  2.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 218 16289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [06:20<00:00,  3.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 204 16289\n",
      "CPU times: user 6min 19s, sys: 2 s, total: 6min 21s\n",
      "Wall time: 6min 20s\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "logger_orig = Logger(MAX_ITER)\n",
    "data_orig = []\n",
    "\n",
    "for t in trange(TRIALS):\n",
    "\n",
    "    cities, distance_matrix = create_problem_cluster(t)\n",
    "    initial_tour = list(range(cities.shape[0]))\n",
    "\n",
    "    logger_orig.problem_started()\n",
    "    optimized_tour, optimized_distance = two_opt(initial_tour, distance_matrix, max_iterations = MAX_ITER, logger = logger_orig)\n",
    "    logger_orig.problem_solved()\n",
    "    data_orig.append(optimized_distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "c13a431e-377b-4b44-9345-6ddd575bfd1a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(13.302615035083866, 0.09781134690279866)"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(data_orig), np.std(data_orig) / np.sqrt(TRIALS-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "51d03c61-57dd-4486-ba52-f778c87bd401",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "380.0756151676178"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logger_orig.time_end - logger_orig.time_start"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "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 18 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 1/100 [00:05<08:54,  5.40s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 214 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:11<09:16,  5.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 186 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 3/100 [00:16<08:34,  5.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 211 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 4/100 [00:22<09:03,  5.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 221 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 5/100 [00:27<08:25,  5.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 195 16289\n",
      "iter 0 calc rtdl\n",
      "iter 15 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 75 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 135 calc rtdl\n",
      "iter 150 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 6/100 [00:29<06:51,  4.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 165 calc rtdl\n",
      "stat 165 11934\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 7/100 [00:34<06:54,  4.45s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 185 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:41<08:14,  5.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 249 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  9%|▉         | 9/100 [00:46<07:55,  5.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 194 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 10%|█         | 10/100 [00:51<07:36,  5.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 185 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:57<08:10,  5.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 230 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 12/100 [01:02<07:41,  5.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 193 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 13/100 [01:08<07:58,  5.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 239 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 14/100 [01:12<07:15,  5.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 170 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 15%|█▌        | 15/100 [01:19<07:53,  5.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 235 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n",
      "iter 234 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 16/100 [01:24<07:52,  5.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 239 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 17%|█▋        | 17/100 [01:30<07:47,  5.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 199 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 18/100 [01:36<07:55,  5.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 226 32220\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 19%|█▉        | 19/100 [01:43<08:06,  6.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 245 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 20/100 [01:51<08:42,  6.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 279 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██        | 21/100 [01:55<07:47,  5.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 215 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 22/100 [01:59<06:54,  5.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 192 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 23%|██▎       | 23/100 [02:04<06:49,  5.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 230 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▍       | 24/100 [02:08<06:11,  4.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 159 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 25/100 [02:16<07:08,  5.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 271 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 26%|██▌       | 26/100 [02:20<06:34,  5.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 207 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 27/100 [02:27<06:50,  5.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 249 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|██▊       | 28/100 [02:31<06:18,  5.26s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 215 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 29/100 [02:36<06:09,  5.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 216 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|███       | 30/100 [02:42<06:29,  5.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 219 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 280 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 31%|███       | 31/100 [02:50<07:09,  6.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 282 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|███▏      | 32/100 [02:55<06:41,  5.91s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 198 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 33/100 [03:01<06:29,  5.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 210 16289\n",
      "iter 0 calc rtdl\n",
      "iter 15 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 75 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 135 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 34/100 [03:03<05:11,  4.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 146 11934\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 35/100 [03:12<06:27,  5.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 275 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|███▌      | 36/100 [03:17<05:56,  5.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 203 32220\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 37%|███▋      | 37/100 [03:21<05:30,  5.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 177 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 38%|███▊      | 38/100 [03:26<05:12,  5.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 190 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 39/100 [03:33<05:53,  5.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 267 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 40/100 [03:38<05:37,  5.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 203 16289\n",
      "iter 0 calc rtdl\n",
      "iter 15 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 75 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 135 calc rtdl\n",
      "iter 150 calc rtdl\n",
      "iter 165 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 41/100 [03:41<04:42,  4.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 178 11934\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 42%|████▏     | 42/100 [03:47<04:58,  5.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 214 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 43%|████▎     | 43/100 [03:52<04:47,  5.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 207 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 44/100 [03:56<04:21,  4.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 161 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 280 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 45%|████▌     | 45/100 [04:04<05:14,  5.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 286 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 46%|████▌     | 46/100 [04:08<04:45,  5.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 174 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 47/100 [04:13<04:37,  5.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 229 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|████▊     | 48/100 [04:20<04:46,  5.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 233 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▉     | 49/100 [04:25<04:31,  5.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 194 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 50/100 [04:29<04:13,  5.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 185 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 51%|█████     | 51/100 [04:34<04:13,  5.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 221 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 52/100 [04:39<04:04,  5.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 197 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 53/100 [04:45<04:04,  5.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 198 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n",
      "iter 234 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 54%|█████▍    | 54/100 [04:50<03:59,  5.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 236 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 55%|█████▌    | 55/100 [04:55<03:48,  5.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 205 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 56/100 [04:59<03:34,  4.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 184 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n",
      "iter 280 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 57%|█████▋    | 57/100 [05:07<04:13,  5.90s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 286 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 58%|█████▊    | 58/100 [05:13<04:05,  5.85s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 204 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 59/100 [05:17<03:37,  5.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 203 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 60/100 [05:21<03:19,  4.99s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 194 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 61%|██████    | 61/100 [05:26<03:07,  4.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 206 32220\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 62/100 [05:33<03:31,  5.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 257 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 63%|██████▎   | 63/100 [05:39<03:27,  5.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 205 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|██████▍   | 64/100 [05:44<03:18,  5.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 218 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▌   | 65/100 [05:51<03:27,  5.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 267 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 66%|██████▌   | 66/100 [05:56<03:06,  5.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 183 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 67/100 [06:01<02:58,  5.40s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 191 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|██████▊   | 68/100 [06:06<02:49,  5.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 208 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 69%|██████▉   | 69/100 [06:12<02:48,  5.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 221 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|███████   | 70/100 [06:18<02:53,  5.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 252 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 71/100 [06:24<02:51,  5.91s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 221 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n",
      "iter 234 calc rtdl\n",
      "iter 252 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 72/100 [06:31<02:49,  6.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 253 32220\n",
      "iter 0 calc rtdl\n",
      "iter 15 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 75 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 120 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 73/100 [06:33<02:13,  4.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 133 22960\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 74%|███████▍  | 74/100 [06:39<02:11,  5.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 221 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 75%|███████▌  | 75/100 [06:45<02:16,  5.45s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 272 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▌  | 76/100 [06:49<02:01,  5.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 200 32220\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 77%|███████▋  | 77/100 [06:55<02:01,  5.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 217 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 78/100 [07:01<02:00,  5.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 225 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 79%|███████▉  | 79/100 [07:07<02:00,  5.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 235 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 80/100 [07:11<01:43,  5.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 195 16289\n",
      "iter 0 calc rtdl\n",
      "iter 15 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 75 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 135 calc rtdl\n",
      "iter 150 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 81%|████████  | 81/100 [07:13<01:21,  4.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 155 11934\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 82/100 [07:19<01:28,  4.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 247 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 83%|████████▎ | 83/100 [07:27<01:35,  5.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 240 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 84/100 [07:34<01:40,  6.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 264 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 85%|████████▌ | 85/100 [07:40<01:30,  6.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 229 16289\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n",
      "iter 260 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 86%|████████▌ | 86/100 [07:48<01:31,  6.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 265 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 87/100 [07:53<01:21,  6.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 206 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 88/100 [07:59<01:14,  6.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 214 21320\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 89/100 [08:05<01:05,  6.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 186 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n",
      "iter 234 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 90%|█████████ | 90/100 [08:11<01:01,  6.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 240 32220\n",
      "iter 0 calc rtdl\n",
      "iter 20 calc rtdl\n",
      "iter 40 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 80 calc rtdl\n",
      "iter 100 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 140 calc rtdl\n",
      "iter 160 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 200 calc rtdl\n",
      "iter 220 calc rtdl\n",
      "iter 240 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 91%|█████████ | 91/100 [08:19<00:58,  6.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 251 21320\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|█████████▏| 92/100 [08:24<00:49,  6.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 229 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 93/100 [08:29<00:39,  5.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 177 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n",
      "iter 234 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 94/100 [08:34<00:33,  5.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 234 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 95%|█████████▌| 95/100 [08:38<00:26,  5.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 193 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|█████████▌| 96/100 [08:44<00:21,  5.41s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 215 16289\n",
      "iter 0 calc rtdl\n",
      "iter 15 calc rtdl\n",
      "iter 30 calc rtdl\n",
      "iter 45 calc rtdl\n",
      "iter 60 calc rtdl\n",
      "iter 75 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 105 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 120 calc rtdl\n",
      "iter 135 calc rtdl\n",
      "iter 150 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 97%|█████████▋| 97/100 [08:47<00:13,  4.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 163 11934\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 98%|█████████▊| 98/100 [08:51<00:08,  4.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 189 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n",
      "iter 198 calc rtdl\n",
      "iter 216 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████▉| 99/100 [08:57<00:04,  4.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 217 16289\n",
      "iter 0 calc rtdl\n",
      "iter 18 calc rtdl\n",
      "iter 36 calc rtdl\n",
      "iter 54 calc rtdl\n",
      "iter 72 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 90 calc rtdl\n",
      "iter 108 calc rtdl\n",
      "iter 126 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 144 calc rtdl\n",
      "iter 162 calc rtdl\n",
      "iter 180 calc rtdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [09:02<00:00,  5.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stat 195 16289\n",
      "CPU times: user 2h 29min 56s, sys: 10min 50s, total: 2h 40min 46s\n",
      "Wall time: 9min 2s\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "logger_rtdl = Logger(MAX_ITER)\n",
    "data_rtdl = []\n",
    "\n",
    "for t in trange(TRIALS):\n",
    "    cities, distance_matrix = create_problem_cluster(t)\n",
    "    initial_tour = list(range(cities.shape[0]))\n",
    "\n",
    "    logger_rtdl.problem_started()\n",
    "    optimized_tour, optimized_distance = two_opt_rtdl(initial_tour, distance_matrix, max_iterations = MAX_ITER, logger = logger_rtdl,\\\n",
    "                                                      progressive = True)\n",
    "    logger_rtdl.problem_solved()\n",
    "    data_rtdl.append(optimized_distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "94402bb9-9a8b-4afc-aa71-23d6f88359a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(13.219300575520343, 0.08860612530103906)"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(data_rtdl), np.std(data_rtdl) / np.sqrt(TRIALS-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "149a038c-1f5b-44f8-9251-a5b08b0c93cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "542.3192632198334"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logger_rtdl.time_end - logger_rtdl.time_start"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "c874aafe-f8d7-4967-ac89-c5b6dc571073",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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S5di1KhR0Gq1MBgMmDZtGk6ePGl3zKxZsyAIgt3jpptusjumubkZ8+bNQ1RUFEJCQjB16lScP3/enafikMWLF3c5J6PRaNsviiIWL16MuLg4BAUFITMzE8eOHbN7DW87ZwBITk7uct6CIGDu3LkAfOez3rVrF+655x7ExcVBEARs2rTJbr+zPt/q6mrMnDkTOp0OOp0OM2fORE1NjYvPrmdXOm+z2YznnnsO6enpCAkJQVxcHB5++GFcvHjR7jUyMzO7/A488MADdsd403kDzvu99rbz7u7fuiAIeOONN2zHeNvn3Zu/WZ7079tnA9H69evx5JNP4sUXX8ShQ4fw85//HFOmTEFhYaHcpV2znJwczJ07F3v37kV2djZaW1sxadIkNDQ02B13xx13oLi42Pb4v//7P7v9Tz75JDZu3IhPP/0Ue/bsQX19Pe6++260tbW583QcMmTIELtzOnLkiG3f8uXL8eabb+Kdd97Bvn37YDQaMXHiRNTV1dmO8cZz3rdvn905Z2dnAwB++ctf2o7xhc+6oaEBGRkZeOedd7rd76zP98EHH8Thw4exZcsWbNmyBYcPH8bMmTNdfn49udJ5NzY24uDBg3jppZdw8OBBbNiwAXl5eZg6dWqXYx977DG734H333/fbr83nbeVM36vve28O55vcXExPvroIwiCgF/84hd2x3nT592bv1ke9e9b9FGjR48W58yZY9c2aNAg8fnnn5epIucrKysTAYg5OTm2tkceeUS89957e3xOTU2NqFKpxE8//dTWduHCBdHPz0/csmWLK8u9Zq+88oqYkZHR7T6LxSIajUZx2bJltrampiZRp9OJ7733niiK3nnO3VmwYIHYr18/0WKxiKLom581AHHjxo227531+R4/flwEIO7du9d2zHfffScCEH/66ScXn9XVdT7v7vzwww8iALGgoMDWdsstt4gLFizo8TneeN7O+L32xvPu7N577xUnTJhg1+btn3fnv1me9u/bJ3uIWlpacODAAUyaNMmufdKkSfj2229lqsr5TCYTAHRZ+G7nzp0wGAwYMGAAHnvsMZSVldn2HThwAGaz2e5nExcXh6FDh3r0z+bUqVOIi4tDSkoKHnjgAZw9exYAkJ+fj5KSErvz0Wg0uOWWW2zn463n3FFLSws++eQTzJ49G4Ig2Np98bPuyFmf73fffQedTocxY8bYjrnpppug0+m85mdhMpkgCALCw8Pt2v/5z38iKioKQ4YMwTPPPGP3f9beet7X+3vtredtVVpaii+//BK//vWvu+zz5s+7898sT/v37ZOLu1ZUVKCtrQ0xMTF27TExMSgpKZGpKucSRRELFy7EuHHjMHToUFv7lClT8Mtf/hJJSUnIz8/HSy+9hAkTJuDAgQPQaDQoKSmBWq1GRESE3et58s9mzJgx+PjjjzFgwACUlpbiT3/6E8aOHYtjx47Zau7usy4oKAAArzznzjZt2oSamhrMmjXL1uaLn3Vnzvp8S0pKYDAYury+wWDwip9FU1MTnn/+eTz44IN2i3s+9NBDSElJgdFoxNGjR/HCCy/gxx9/tF1e9cbzdsbvtTeed0dr166FVqvF/fffb9fuzZ93d3+zPO3ft08GIquO/ycNSB9I5zZvlZWVhdzcXOzZs8eufcaMGbavhw4dihtvvBFJSUn48ssvu/zj6siTfzZTpkyxfZ2eno6bb74Z/fr1w9q1a22DLa/ls/bkc+7sww8/xJQpUxAXF2dr88XPuifO+Hy7O94bfhZmsxkPPPAALBYL3n33Xbt9jz32mO3roUOHon///rjxxhtx8OBBjBgxAoD3nbezfq+97bw7+uijj/DQQw8hMDDQrt2bP++e/mYBnvPv2ycvmUVFRcHf379LMiwrK+uSRL3RvHnzsHnzZuzYsQPx8fFXPDY2NhZJSUk4deoUAMBoNKKlpQXV1dV2x3nTzyYkJATp6ek4deqU7W6zK33W3n7OBQUF+Prrr/Gb3/zmisf54mftrM/XaDSitLS0y+uXl5d79M/CbDZj+vTpyM/PR3Z2tl3vUHdGjBgBlUpl9zvgjefd0bX8Xnvzee/evRsnT5686r93wHs+757+Znnav2+fDERqtRojR460dSNaZWdnY+zYsTJVdf1EUURWVhY2bNiA7du3IyUl5arPqaysRFFREWJjYwEAI0eOhEqlsvvZFBcX4+jRo17zs2lubsaJEycQGxtr6z7ueD4tLS3IycmxnY+3n/Pq1athMBhw1113XfE4X/ysnfX53nzzzTCZTPjhhx9sx3z//fcwmUwe+7OwhqFTp07h66+/RmRk5FWfc+zYMZjNZtvvgDeed2fX8nvtzef94YcfYuTIkcjIyLjqsZ7+eV/tb5bH/fvu/fhw7/Lpp5+KKpVK/PDDD8Xjx4+LTz75pBgSEiKeO3dO7tKu2RNPPCHqdDpx586dYnFxse3R2NgoiqIo1tXViU8//bT47bffivn5+eKOHTvEm2++WezTp49YW1tre505c+aI8fHx4tdffy0ePHhQnDBhgpiRkSG2trbKdWpX9PTTT4s7d+4Uz549K+7du1e8++67Ra1Wa/ssly1bJup0OnHDhg3ikSNHxF/96ldibGysV5+zVVtbm5iYmCg+99xzdu2+9FnX1dWJhw4dEg8dOiQCEN98803x0KFDtrupnPX53nHHHeINN9wgfvfdd+J3330npqeni3fffbfbz9fqSudtNpvFqVOnivHx8eLhw4ft/r03NzeLoiiKp0+fFl999VVx3759Yn5+vvjll1+KgwYNEocPH+615+3M32tvOm8rk8kkBgcHi6tWreryfG/8vK/2N0sUPevft88GIlEUxb/+9a9iUlKSqFarxREjRtjdnu6NAHT7WL16tSiKotjY2ChOmjRJjI6OFlUqlZiYmCg+8sgjYmFhod3rXLp0SczKyhL1er0YFBQk3n333V2O8SQzZswQY2NjRZVKJcbFxYn333+/eOzYMdt+i8UivvLKK6LRaBQ1Go04fvx48ciRI3av4W3nbLV161YRgHjy5Em7dl/6rHfs2NHt7/UjjzwiiqLzPt/KykrxoYceErVarajVasWHHnpIrK6udtNZdnWl887Pz+/x3/uOHTtEURTFwsJCcfz48aJerxfVarXYr18/cf78+WJlZaXd+3jTeTvz99qbztvq/fffF4OCgsSampouz/fGz/tqf7NE0bP+fQvtRRMREREplk+OISIiIiJyBAMRERERKR4DERERESkeAxEREREpHgMRERERKR4DERERESkeAxEREREpHgMRERERKR4DERH5nOTkZKxYsULuMojIizAQEdF1mTVrFqZNmwYAyMzMxJNPPum2916zZg3Cw8O7tO/btw+//e1v3VYHEXm/ALkLICLqrKWlBWq1+pqfHx0d7cRqiEgJ2ENERE4xa9Ys5OTkYOXKlRAEAYIg4Ny5cwCA48eP484770RoaChiYmIwc+ZMVFRU2J6bmZmJrKwsLFy4EFFRUZg4cSIA4M0330R6ejpCQkKQkJCA3/3ud6ivrwcA7Ny5E48++ihMJpPt/RYvXgyg6yWzwsJC3HvvvQgNDUVYWBimT5+O0tJS2/7Fixdj2LBh+Mc//oHk5GTodDo88MADqKursx3zP//zP0hPT0dQUBAiIyNx++23o6GhwUU/TSJyNwYiInKKlStX4uabb8Zjjz2G4uJiFBcXIyEhAcXFxbjlllswbNgw7N+/H1u2bEFpaSmmT59u9/y1a9ciICAA33zzDd5//30AgJ+fH9566y0cPXoUa9euxfbt2/Hss88CAMaOHYsVK1YgLCzM9n7PPPNMl7pEUcS0adNQVVWFnJwcZGdn48yZM5gxY4bdcWfOnMGmTZvwxRdf4IsvvkBOTg6WLVsGACguLsavfvUrzJ49GydOnMDOnTtx//33g2tjE/kOXjIjIqfQ6XRQq9UIDg6G0Wi0ta9atQojRozAkiVLbG0fffQREhISkJeXhwEDBgAAUlNTsXz5crvX7DgeKSUlBf/5n/+JJ554Au+++y7UajV0Oh0EQbB7v86+/vpr5ObmIj8/HwkJCQCAf/zjHxgyZAj27duHUaNGAQAsFgvWrFkDrVYLAJg5cya2bduG1157DcXFxWhtbcX999+PpKQkAEB6evp1/LSIyNOwh4iIXOrAgQPYsWMHQkNDbY9BgwYBkHplrG688cYuz92xYwcmTpyIPn36QKvV4uGHH0ZlZaVDl6pOnDiBhIQEWxgCgLS0NISHh+PEiRO2tuTkZFsYAoDY2FiUlZUBADIyMnDbbbchPT0dv/zlL/H3v/8d1dXVvf8hEJHHYyAiIpeyWCy45557cPjwYbvHqVOnMH78eNtxISEhds8rKCjAnXfeiaFDh+Kzzz7DgQMH8Ne//hUAYDabe/3+oihCEISrtqtUKrv9giDAYrEAAPz9/ZGdnY1///vfSEtLw9tvv42BAwciPz+/13UQkWdjICIip1Gr1Whra7NrGzFiBI4dO4bk5GSkpqbaPTqHoI7279+P1tZW/OUvf8FNN92EAQMG4OLFi1d9v87S0tJQWFiIoqIiW9vx48dhMpkwePDgXp+bIAj42c9+hldffRWHDh2CWq3Gxo0be/18IvJsDERE5DTJycn4/vvvce7cOVRUVMBisWDu3LmoqqrCr371K/zwww84e/YsvvrqK8yePfuKYaZfv35obW3F22+/jbNnz+If//gH3nvvvS7vV19fj23btqGiogKNjY1dXuf222/HDTfcgIceeggHDx7EDz/8gIcffhi33HJLt5fpuvP9999jyZIl2L9/PwoLC7FhwwaUl5c7FKiIyLMxEBGR0zzzzDPw9/dHWloaoqOjUVhYiLi4OHzzzTdoa2vD5MmTMXToUCxYsAA6nQ5+fj3/J2jYsGF488038frrr2Po0KH45z//iaVLl9odM3bsWMyZMwczZsxAdHR0l0HZgNSzs2nTJkRERGD8+PG4/fbb0bdvX6xfv77X5xUWFoZdu3bhzjvvxIABA/CHP/wBf/nLXzBlypTe/3CIyKMJIu8bJSIiIoVjDxEREREpHgMRERERKR4DERERESkeAxEREREpHgMRERERKR4DERERESkeAxEREREpHgMRERERKR4DERERESkeAxEREREpHgMRERERKd7/Dx8Xc1yQTgrOAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(logger_orig.sum_distances / TRIALS, label = '2-opt')\n",
    "plt.plot(logger_rtdl.sum_distances / TRIALS, label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "ax.set_xlim([0, 2000])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Tour length')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c841d575-56dd-4b9a-8957-058719542b66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0bcbf66f-c80b-441a-8ab8-1ad074730da1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_105060/3112441879.py:1: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nancumsum(np.nanmean(logger_orig.sum_attempts, axis = 0)), label = '2-opt')\n",
      "/tmp/ipykernel_105060/3112441879.py:2: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nancumsum(np.nanmean(logger_rtdl.sum_attempts, axis = 0)), label = '2-opt + RTDL')\n"
     ]
    },
    {
     "data": {
      "image/png": "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ALiKx+NR9+7dlZCQoLq6ulA3B+eJiIiINu3JakTQAgC4Unh4eLtcOIGWYDI8AABAOyFoAQAAtBOCFgAAQDthjtY51rgYWnV1dYhbAgAAmqvxut3SRU0JWufYoUOHJEm9evUKcUsAAEBLHTp0SJZlNbveY3hOwTnV0NCg/fv3KyYmpk0X0auurlavXr20Z88edenSpc2Oi2Cc53OD83zucK7PDc7zudGe59kYo0OHDsnv9yssrPkzr+jROsfCwsLUs2fPdjt+ly5d+If4HOA8nxuc53OHc31ucJ7PjfY6zy3pyWrEZHgAAIB2QtACAABoJwQtl/B6vXr44Yfl9XpD3RRX4zyfG5znc4dzfW5wns8NJ55nJsMDAAC0E3q0AAAA2glBCwAAoJ0QtAAAANoJQQsAAKCdELRcYtmyZerbt686duyolJQU/e1vfwt1kxwhKytLV111lWJiYpSQkKBJkybpgw8+CKoxxmjBggXy+/2KiorSyJEj9e677wbV1NTUaNasWYqPj1d0dLQmTpyovXv3BtVUVlYqPT1dlmXJsiylp6erqqoqqKa0tFQTJkxQdHS04uPjNXv2bNXW1rbLdw+lrKwseTwezZkzx97GeW4b+/bt0+23366LLrpInTp10ne+8x0VFhba+znPbePEiRP66U9/qr59+yoqKkqXXHKJFi5cqIaGBruGc91yGzdu1IQJE+T3++XxePTaa68F7XfaOS0uLlZqaqqioqLUo0cPLVy4sMXPOpTBeS87O9tERESYZ5991uzcudPcc889Jjo62nz66aehblrIjRkzxjz33HOmpKTEFBUVmXHjxpmLL77YHD582K5ZvHixiYmJMStWrDDFxcXmlltuMd27dzfV1dV2zZ133ml69Ohh8vLyzDvvvGO+//3vm0GDBpkTJ07YNWPHjjVJSUlm8+bNZvPmzSYpKcmMHz/e3n/ixAmTlJRkvv/975t33nnH5OXlGb/fbzIzM8/NyThHtm7davr06WOuuOIKc88999jbOc/f3BdffGF69+5tpk+fbrZs2WJ27dpl/vrXv5qPP/7YruE8t41f/OIX5qKLLjKvv/662bVrl/njH/9oOnfubB5//HG7hnPdcqtXrzYPPfSQWbFihZFkcnJygvY76ZwGAgGTmJhobr31VlNcXGxWrFhhYmJizKOPPtqi70zQcoHvfe975s47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w9YAOJ/QowXAlaZPn64NGzboiSeekMfjkcfj0e7duyVJO3fu1A9+8AN17txZiYmJSk9P1+eff26/d+TIkcrMzNTcuXMVHx+v0aNHS5KWLl2q5ORkRUdHq1evXrr77rt1+PBhSdL69ev14x//WIFAwP68BQsWSGo6dFhaWqof/vCH6ty5s7p06aLJkyfrwIED9v4FCxboO9/5jv7whz+oT58+sixLt956qw4dOmTX/OlPf1JycrKioqJ00UUXadSoUTpy5Eg7nU0ArUXQAuBKTzzxhIYNG6aMjAyVlZWprKxMvXr1UllZmVJTU/Wd73xHb7/9tnJzc3XgwAFNnjw56P0vvPCCOnTooL///e/6zW9+I0kKCwvTk08+qZKSEr3wwgtat26d7rvvPknS8OHD9fjjj6tLly72582fP79Ju4wxmjRpkr744gtt2LBBeXl5+sc//qFbbrklqO4f//iHXnvtNb3++ut6/fXXtWHDBi1evFiSVFZWpttuu0133HGH3nvvPa1fv1433XSTjDHtcSoBfAMMHQJwJcuyFBkZqU6dOsnn89nbly9friuvvFKLFi2yt/33f/+3evXqpQ8//FCXXnqpJKlfv35asmRJ0DG/PN+rb9+++o//+A/dddddWrZsmSIjI2VZljweT9Dnne6vf/2rduzYoV27dqlXr16SpD/84Q+6/PLLtW3bNl111VWSpIaGBj3//POKiYmRJKWnp2vt2rV65JFHVFZWphMnTuimm25S7969JUnJycnf4GwBaC/0aAG4oBQWFuqtt95S586d7ddll10m6WQvUqPBgwc3ee9bb72l0aNHq0ePHoqJidGPfvQjHTx4sEVDdu+995569eplhyxJGjhwoLp27ar33nvP3tanTx87ZElS9+7dVVFRIUkaNGiQrr/+eiUnJ+vmm2/Ws88+q8rKyuafBADnDEELwAWloaFBEyZMUFFRUdDro48+0rXXXmvXRUdHB73v008/1Q9+8AMlJSVpxYoVKiws1H/+539Kkurq6pr9+cYYeTyer90eERERtN/j8aihoUGSFB4erry8PP3P//yPBg4cqKeeekr9+/fXrl27mt0OAOcGQQuAa0VGRqq+vj5o25VXXql3331Xffr0Ub9+/YJep4erL3v77bd14sQJ/frXv9bQoUN16aWXav/+/V/7eacbOHCgSktLtWfPHnvbzp07FQgENGDAgGZ/N4/Ho6uvvlo///nPtX37dkVGRionJ6fZ7wdwbhC0ALhWnz59tGXLFu3evVuff/65GhoaNHPmTH3xxRe67bbbtHXrVn3yySdas2aN7rjjjrOGpG9961s6ceKEnnrqKX3yySf6wx/+oGeeeabJ5x0+fFhr167V559/rqNHjzY5zqhRo3TFFVdo6tSpeuedd7R161b96Ec/Umpq6hmHK89ky5YtWrRokd5++22VlpZq5cqV+uyzz1oU1ACcGwQtAK41f/58hYeHa+DAgerWrZtKS0vl9/v197//XfX19RozZoySkpJ0zz33yLIshYV99b8Sv/Od72jp0qX65S9/qaSkJL300kvKysoKqhk+fLjuvPNO3XLLLerWrVuTyfTSyZ6o1157TbGxsbr22ms1atQoXXLJJXr11Veb/b26dOmijRs36gc/+IEuvfRS/fSnP9Wvf/1r3XDDDc0/OQDOCY/hfmAAAIB2QY8WAABAOyFoAQAAtBOCFgAAQDshaAEAALQTghYAAEA7IWgBAAC0E4IWAABAOyFoAQAAtBOCFgAAQDshaAEAALQTghYAAEA7+f8BpnZk9iMp82gAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.nancumsum(np.nanmean(logger_orig.sum_attempts, axis = 0)), label = '2-opt')\n",
    "plt.plot(np.nancumsum(np.nanmean(logger_rtdl.sum_attempts, axis = 0)), label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "#ax.set_ylim([0, 60])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Trials')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "000b40dc-f6f0-40d8-9e3e-caebbca87640",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850.])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.nanmax(logger_orig.sum_attempts, axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fd8442ee-0258-4bc9-b829-b7cac7c56a03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850., 4850.,\n",
       "       4850.])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.nanmax(logger_rtdl.sum_attempts, axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9b8183e6-b849-400f-9f63-eede54d5cab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_105060/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_105060/2171339728.py:2: RuntimeWarning: Mean of empty slice\n",
      "  plt.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.nanmean(logger_orig.sum_attempts, axis = 0), label = '2-opt')\n",
    "plt.plot(np.nanmean(logger_rtdl.sum_attempts, axis = 0), label = '2-opt + RTDL')\n",
    "\n",
    "ax = plt.gca()\n",
    "#ax.set_ylim([0, 60])\n",
    "ax.set_xlabel('Iterations')\n",
    "ax.set_ylabel('Trials')\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2172762-122b-4367-886f-77513bf88455",
   "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
}
