{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "import torch\n",
    "from torch.distributions import Categorical, kl\n",
    "from d2l.torch import Animator\n",
    "\n",
    "from rcpsp_inst import RCPSPInstance, load_dataset\n",
    "from net import Net\n",
    "from aco import ACO_RCPSP\n",
    "import random\n",
    "\n",
    "# torch.manual_seed(1234)\n",
    "\n",
    "lr = 3e-4\n",
    "EPS = 1e-10\n",
    "ALPHA = 0.05\n",
    "T=5\n",
    "device = 'cpu'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_instance(model, optimizer, rcpsp: RCPSPInstance, n_ants):\n",
    "    model.train()\n",
    "    pyg_data = rcpsp.to_pyg_data()\n",
    "    phe_vec, heu_vec = model(pyg_data, require_phe=True, require_heu=True)\n",
    "    heu_mat = model.reshape(pyg_data, heu_vec) + EPS\n",
    "    \n",
    "    aco = ACO_RCPSP(\n",
    "        rcpsp,\n",
    "        n_ants=n_ants,\n",
    "        pheromone=None,\n",
    "        heuristic=heu_mat,\n",
    "        device=device,\n",
    "        train = True\n",
    "    )\n",
    "    \n",
    "    costs, log_probs = aco.sample()\n",
    "    assert log_probs is not None\n",
    "    assert pyg_data.num_nodes is not None\n",
    "    baseline = costs.mean()\n",
    "    reinforce_loss = torch.sum((costs - baseline) * log_probs.sum(dim=0)) / aco.n_ants \n",
    "    # k_sparse = pyg_data.num_edges // pyg_data.num_nodes\n",
    "    # entropy_loss = ALPHA * (-torch.sum(Categorical(phe_mat).entropy()) / k_sparse)\n",
    "    # print(reinforce_loss.item(), entropy_loss.item())\n",
    "    loss = reinforce_loss / rcpsp.n\n",
    "    optimizer.zero_grad()\n",
    "    loss.backward()\n",
    "    torch.nn.utils.clip_grad_norm_(parameters=model.parameters(), max_norm=1.0, norm_type=2)\n",
    "    optimizer.step()\n",
    "    return loss.item()\n",
    "\n",
    "def infer_instance(model, rcpsp, n_ants):\n",
    "    model.eval()\n",
    "    pyg_data = rcpsp.to_pyg_data()\n",
    "    phe_vec, heu_vec = model(pyg_data, require_phe=True, require_heu=True)\n",
    "    heu_mat = model.reshape(pyg_data, heu_vec) + EPS\n",
    "    aco = ACO_RCPSP(\n",
    "        rcpsp,\n",
    "        n_ants=n_ants,\n",
    "        pheromone=None,\n",
    "        heuristic=heu_mat,\n",
    "        device=device,\n",
    "        train = True\n",
    "    )\n",
    "    costs, log_probs = aco.sample()\n",
    "    result = aco.run(n_iterations=T)\n",
    "    baseline = costs.mean()\n",
    "    best_sample_cost = torch.min(costs)\n",
    "    best_aco_cost = result.cost\n",
    "    return baseline.item(), best_sample_cost.item(), best_aco_cost"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_epoch(trainset,\n",
    "                n_ants, \n",
    "                steps_per_epoch, \n",
    "                net, \n",
    "                optimizer\n",
    "                ):\n",
    "    losses = []\n",
    "    for _ in range(steps_per_epoch):\n",
    "        data = trainset[random.randint(0,len(trainset)-1)]\n",
    "        loss = train_instance(net, optimizer, data, n_ants)\n",
    "        losses.append(loss)\n",
    "    return losses\n",
    "\n",
    "@torch.no_grad()\n",
    "def validation(n_ants, epoch, net, val_dataset, animator=None):\n",
    "    sum_bl, sum_sample_best, sum_aco_best = 0, 0, 0\n",
    "    \n",
    "    for instance in val_dataset:\n",
    "        bl, sample_best, aco_best = infer_instance(net, instance, n_ants)\n",
    "        sum_bl += bl; sum_sample_best += sample_best; sum_aco_best += aco_best\n",
    "    \n",
    "    n_val = len(val_dataset)\n",
    "    avg_bl, avg_sample_best, avg_aco_best = sum_bl/n_val, sum_sample_best/n_val, sum_aco_best/n_val\n",
    "    if animator:\n",
    "        animator.add(epoch+1, (avg_bl, avg_sample_best, avg_aco_best))\n",
    "    \n",
    "    return avg_bl, avg_sample_best, avg_aco_best"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(n_node, n_ants, steps_per_epoch, epochs):\n",
    "    net = Net().to(device)\n",
    "    trainset, testset = load_dataset(f\"../data/rcpsp/j{n_node}rcp\")\n",
    "    testset = testset[:20]\n",
    "    optimizer = torch.optim.AdamW(net.parameters(), lr=lr)\n",
    "    animator = Animator(xlabel='epoch', xlim=[0, epochs],\n",
    "                        legend=[\"Avg. sample obj.\", \"Best sample obj.\", \"Best ACO obj.\"])\n",
    "    \n",
    "    avg_bl, avg_best, avg_aco_best = validation(n_ants, -1, net, testset, animator)\n",
    "    val_results = [(avg_bl, avg_best, avg_aco_best)]\n",
    "    loss_list = []\n",
    "    \n",
    "    sum_time = 0\n",
    "    for epoch in range(0, epochs):\n",
    "        start = time.time()\n",
    "        losses = train_epoch(trainset, n_ants, steps_per_epoch, net, optimizer)\n",
    "        sum_time += time.time() - start\n",
    "        avg_bl, avg_sample_best, avg_aco_best = validation(n_ants, epoch, net, testset, animator)\n",
    "        val_results.append((avg_bl, avg_sample_best, avg_aco_best))\n",
    "        loss_list.append(sum(losses))\n",
    "        \n",
    "    print('total training duration:', sum_time)\n",
    "    # for epoch in range(epochs):\n",
    "    #     print(f'[epoch {epoch}] loss:', loss_list[epoch], \"val:\", val_results[epoch])\n",
    "\n",
    "    torch.save(net.state_dict(), f'../pretrained/rcpsp/rcpsp{n_node}-{net.emb_net.feats}.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total training duration: 114.71200823783875\n"
     ]
    },
    {
     "data": {
      "image/svg+xml": "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"238.96875pt\" height=\"183.35625pt\" viewBox=\"0 0 238.96875 183.35625\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n <metadata>\n  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n   <cc:Work>\n    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n    <dc:date>2023-03-09T13:54:56.399266</dc:date>\n    <dc:format>image/svg+xml</dc:format>\n    <dc:creator>\n     <cc:Agent>\n      <dc:title>Matplotlib v3.5.2, https://matplotlib.org/</dc:title>\n     </cc:Agent>\n    </dc:creator>\n   </cc:Work>\n  </rdf:RDF>\n </metadata>\n <defs>\n  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n </defs>\n <g id=\"figure_1\">\n  <g id=\"patch_1\">\n   <path d=\"M 0 183.35625 \nL 238.96875 183.35625 \nL 238.96875 0 \nL 0 0 \nz\n\" style=\"fill: #ffffff\"/>\n  </g>\n  <g id=\"axes_1\">\n   <g id=\"patch_2\">\n    <path d=\"M 26.925 145.8 \nL 222.225 145.8 \nL 222.225 7.2 \nL 26.925 7.2 \nz\n\" style=\"fill: #ffffff\"/>\n   </g>\n   <g id=\"matplotlib.axis_1\">\n    <g id=\"xtick_1\">\n     <g id=\"line2d_1\">\n      <path d=\"M 26.925 145.8 \nL 26.925 7.2 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_2\">\n      <defs>\n       <path id=\"m063e1cc905\" d=\"M 0 0 \nL 0 3.5 \n\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </defs>\n      <g>\n       <use xlink:href=\"#m063e1cc905\" x=\"26.925\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_1\">\n      <!-- 0 -->\n      <g transform=\"translate(23.74375 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \nQ 1547 4250 1301 3770 \nQ 1056 3291 1056 2328 \nQ 1056 1369 1301 889 \nQ 1547 409 2034 409 \nQ 2525 409 2770 889 \nQ 3016 1369 3016 2328 \nQ 3016 3291 2770 3770 \nQ 2525 4250 2034 4250 \nz\nM 2034 4750 \nQ 2819 4750 3233 4129 \nQ 3647 3509 3647 2328 \nQ 3647 1150 3233 529 \nQ 2819 -91 2034 -91 \nQ 1250 -91 836 529 \nQ 422 1150 422 2328 \nQ 422 3509 836 4129 \nQ 1250 4750 2034 4750 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-30\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_2\">\n     <g id=\"line2d_3\">\n      <path d=\"M 65.985 145.8 \nL 65.985 7.2 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_4\">\n      <g>\n       <use xlink:href=\"#m063e1cc905\" x=\"65.985\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_2\">\n      <!-- 20 -->\n      <g transform=\"translate(59.6225 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \nL 3431 531 \nL 3431 0 \nL 469 0 \nL 469 531 \nQ 828 903 1448 1529 \nQ 2069 2156 2228 2338 \nQ 2531 2678 2651 2914 \nQ 2772 3150 2772 3378 \nQ 2772 3750 2511 3984 \nQ 2250 4219 1831 4219 \nQ 1534 4219 1204 4116 \nQ 875 4013 500 3803 \nL 500 4441 \nQ 881 4594 1212 4672 \nQ 1544 4750 1819 4750 \nQ 2544 4750 2975 4387 \nQ 3406 4025 3406 3419 \nQ 3406 3131 3298 2873 \nQ 3191 2616 2906 2266 \nQ 2828 2175 2409 1742 \nQ 1991 1309 1228 531 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_3\">\n     <g id=\"line2d_5\">\n      <path d=\"M 105.045 145.8 \nL 105.045 7.2 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_6\">\n      <g>\n       <use xlink:href=\"#m063e1cc905\" x=\"105.045\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_3\">\n      <!-- 40 -->\n      <g transform=\"translate(98.6825 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \nL 825 1625 \nL 2419 1625 \nL 2419 4116 \nz\nM 2253 4666 \nL 3047 4666 \nL 3047 1625 \nL 3713 1625 \nL 3713 1100 \nL 3047 1100 \nL 3047 0 \nL 2419 0 \nL 2419 1100 \nL 313 1100 \nL 313 1709 \nL 2253 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-34\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_4\">\n     <g id=\"line2d_7\">\n      <path d=\"M 144.105 145.8 \nL 144.105 7.2 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_8\">\n      <g>\n       <use xlink:href=\"#m063e1cc905\" x=\"144.105\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_4\">\n      <!-- 60 -->\n      <g transform=\"translate(137.7425 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \nQ 1688 2584 1439 2293 \nQ 1191 2003 1191 1497 \nQ 1191 994 1439 701 \nQ 1688 409 2113 409 \nQ 2538 409 2786 701 \nQ 3034 994 3034 1497 \nQ 3034 2003 2786 2293 \nQ 2538 2584 2113 2584 \nz\nM 3366 4563 \nL 3366 3988 \nQ 3128 4100 2886 4159 \nQ 2644 4219 2406 4219 \nQ 1781 4219 1451 3797 \nQ 1122 3375 1075 2522 \nQ 1259 2794 1537 2939 \nQ 1816 3084 2150 3084 \nQ 2853 3084 3261 2657 \nQ 3669 2231 3669 1497 \nQ 3669 778 3244 343 \nQ 2819 -91 2113 -91 \nQ 1303 -91 875 529 \nQ 447 1150 447 2328 \nQ 447 3434 972 4092 \nQ 1497 4750 2381 4750 \nQ 2619 4750 2861 4703 \nQ 3103 4656 3366 4563 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-36\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_5\">\n     <g id=\"line2d_9\">\n      <path d=\"M 183.165 145.8 \nL 183.165 7.2 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_10\">\n      <g>\n       <use xlink:href=\"#m063e1cc905\" x=\"183.165\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_5\">\n      <!-- 80 -->\n      <g transform=\"translate(176.8025 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \nQ 1584 2216 1326 1975 \nQ 1069 1734 1069 1313 \nQ 1069 891 1326 650 \nQ 1584 409 2034 409 \nQ 2484 409 2743 651 \nQ 3003 894 3003 1313 \nQ 3003 1734 2745 1975 \nQ 2488 2216 2034 2216 \nz\nM 1403 2484 \nQ 997 2584 770 2862 \nQ 544 3141 544 3541 \nQ 544 4100 942 4425 \nQ 1341 4750 2034 4750 \nQ 2731 4750 3128 4425 \nQ 3525 4100 3525 3541 \nQ 3525 3141 3298 2862 \nQ 3072 2584 2669 2484 \nQ 3125 2378 3379 2068 \nQ 3634 1759 3634 1313 \nQ 3634 634 3220 271 \nQ 2806 -91 2034 -91 \nQ 1263 -91 848 271 \nQ 434 634 434 1313 \nQ 434 1759 690 2068 \nQ 947 2378 1403 2484 \nz\nM 1172 3481 \nQ 1172 3119 1398 2916 \nQ 1625 2713 2034 2713 \nQ 2441 2713 2670 2916 \nQ 2900 3119 2900 3481 \nQ 2900 3844 2670 4047 \nQ 2441 4250 2034 4250 \nQ 1625 4250 1398 4047 \nQ 1172 3844 1172 3481 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-38\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_6\">\n     <g id=\"line2d_11\">\n      <path d=\"M 222.225 145.8 \nL 222.225 7.2 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_12\">\n      <g>\n       <use xlink:href=\"#m063e1cc905\" x=\"222.225\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_6\">\n      <!-- 100 -->\n      <g transform=\"translate(212.68125 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-31\" d=\"M 794 531 \nL 1825 531 \nL 1825 4091 \nL 703 3866 \nL 703 4441 \nL 1819 4666 \nL 2450 4666 \nL 2450 531 \nL 3481 531 \nL 3481 0 \nL 794 0 \nL 794 531 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"text_7\">\n     <!-- epoch -->\n     <g transform=\"translate(109.346875 174.076563)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \nL 3597 1613 \nL 953 1613 \nQ 991 1019 1311 708 \nQ 1631 397 2203 397 \nQ 2534 397 2845 478 \nQ 3156 559 3463 722 \nL 3463 178 \nQ 3153 47 2828 -22 \nQ 2503 -91 2169 -91 \nQ 1331 -91 842 396 \nQ 353 884 353 1716 \nQ 353 2575 817 3079 \nQ 1281 3584 2069 3584 \nQ 2775 3584 3186 3129 \nQ 3597 2675 3597 1894 \nz\nM 3022 2063 \nQ 3016 2534 2758 2815 \nQ 2500 3097 2075 3097 \nQ 1594 3097 1305 2825 \nQ 1016 2553 972 2059 \nL 3022 2063 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-70\" d=\"M 1159 525 \nL 1159 -1331 \nL 581 -1331 \nL 581 3500 \nL 1159 3500 \nL 1159 2969 \nQ 1341 3281 1617 3432 \nQ 1894 3584 2278 3584 \nQ 2916 3584 3314 3078 \nQ 3713 2572 3713 1747 \nQ 3713 922 3314 415 \nQ 2916 -91 2278 -91 \nQ 1894 -91 1617 61 \nQ 1341 213 1159 525 \nz\nM 3116 1747 \nQ 3116 2381 2855 2742 \nQ 2594 3103 2138 3103 \nQ 1681 3103 1420 2742 \nQ 1159 2381 1159 1747 \nQ 1159 1113 1420 752 \nQ 1681 391 2138 391 \nQ 2594 391 2855 752 \nQ 3116 1113 3116 1747 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6f\" d=\"M 1959 3097 \nQ 1497 3097 1228 2736 \nQ 959 2375 959 1747 \nQ 959 1119 1226 758 \nQ 1494 397 1959 397 \nQ 2419 397 2687 759 \nQ 2956 1122 2956 1747 \nQ 2956 2369 2687 2733 \nQ 2419 3097 1959 3097 \nz\nM 1959 3584 \nQ 2709 3584 3137 3096 \nQ 3566 2609 3566 1747 \nQ 3566 888 3137 398 \nQ 2709 -91 1959 -91 \nQ 1206 -91 779 398 \nQ 353 888 353 1747 \nQ 353 2609 779 3096 \nQ 1206 3584 1959 3584 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-63\" d=\"M 3122 3366 \nL 3122 2828 \nQ 2878 2963 2633 3030 \nQ 2388 3097 2138 3097 \nQ 1578 3097 1268 2742 \nQ 959 2388 959 1747 \nQ 959 1106 1268 751 \nQ 1578 397 2138 397 \nQ 2388 397 2633 464 \nQ 2878 531 3122 666 \nL 3122 134 \nQ 2881 22 2623 -34 \nQ 2366 -91 2075 -91 \nQ 1284 -91 818 406 \nQ 353 903 353 1747 \nQ 353 2603 823 3093 \nQ 1294 3584 2113 3584 \nQ 2378 3584 2631 3529 \nQ 2884 3475 3122 3366 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-68\" d=\"M 3513 2113 \nL 3513 0 \nL 2938 0 \nL 2938 2094 \nQ 2938 2591 2744 2837 \nQ 2550 3084 2163 3084 \nQ 1697 3084 1428 2787 \nQ 1159 2491 1159 1978 \nL 1159 0 \nL 581 0 \nL 581 4863 \nL 1159 4863 \nL 1159 2956 \nQ 1366 3272 1645 3428 \nQ 1925 3584 2291 3584 \nQ 2894 3584 3203 3211 \nQ 3513 2838 3513 2113 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-65\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"61.523438\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"125\"/>\n      <use xlink:href=\"#DejaVuSans-63\" x=\"186.181641\"/>\n      <use xlink:href=\"#DejaVuSans-68\" x=\"241.162109\"/>\n     </g>\n    </g>\n   </g>\n   <g id=\"matplotlib.axis_2\">\n    <g id=\"ytick_1\">\n     <g id=\"line2d_13\">\n      <path d=\"M 26.925 131.567913 \nL 222.225 131.567913 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_14\">\n      <defs>\n       <path id=\"m68c1ddd9c0\" d=\"M 0 0 \nL -3.5 0 \n\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </defs>\n      <g>\n       <use xlink:href=\"#m68c1ddd9c0\" x=\"26.925\" y=\"131.567913\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_8\">\n      <!-- 60 -->\n      <g transform=\"translate(7.2 135.367132)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-36\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_2\">\n     <g id=\"line2d_15\">\n      <path d=\"M 26.925 107.531286 \nL 222.225 107.531286 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_16\">\n      <g>\n       <use xlink:href=\"#m68c1ddd9c0\" x=\"26.925\" y=\"107.531286\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_9\">\n      <!-- 65 -->\n      <g transform=\"translate(7.2 111.330505)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-35\" d=\"M 691 4666 \nL 3169 4666 \nL 3169 4134 \nL 1269 4134 \nL 1269 2991 \nQ 1406 3038 1543 3061 \nQ 1681 3084 1819 3084 \nQ 2600 3084 3056 2656 \nQ 3513 2228 3513 1497 \nQ 3513 744 3044 326 \nQ 2575 -91 1722 -91 \nQ 1428 -91 1123 -41 \nQ 819 9 494 109 \nL 494 744 \nQ 775 591 1075 516 \nQ 1375 441 1709 441 \nQ 2250 441 2565 725 \nQ 2881 1009 2881 1497 \nQ 2881 1984 2565 2268 \nQ 2250 2553 1709 2553 \nQ 1456 2553 1204 2497 \nQ 953 2441 691 2322 \nL 691 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-36\"/>\n       <use xlink:href=\"#DejaVuSans-35\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_3\">\n     <g id=\"line2d_17\">\n      <path d=\"M 26.925 83.494659 \nL 222.225 83.494659 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_18\">\n      <g>\n       <use xlink:href=\"#m68c1ddd9c0\" x=\"26.925\" y=\"83.494659\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_10\">\n      <!-- 70 -->\n      <g transform=\"translate(7.2 87.293878)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-37\" d=\"M 525 4666 \nL 3525 4666 \nL 3525 4397 \nL 1831 0 \nL 1172 0 \nL 2766 4134 \nL 525 4134 \nL 525 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-37\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_4\">\n     <g id=\"line2d_19\">\n      <path d=\"M 26.925 59.458032 \nL 222.225 59.458032 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_20\">\n      <g>\n       <use xlink:href=\"#m68c1ddd9c0\" x=\"26.925\" y=\"59.458032\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_11\">\n      <!-- 75 -->\n      <g transform=\"translate(7.2 63.257251)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-37\"/>\n       <use xlink:href=\"#DejaVuSans-35\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_5\">\n     <g id=\"line2d_21\">\n      <path d=\"M 26.925 35.421405 \nL 222.225 35.421405 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_22\">\n      <g>\n       <use xlink:href=\"#m68c1ddd9c0\" x=\"26.925\" y=\"35.421405\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_12\">\n      <!-- 80 -->\n      <g transform=\"translate(7.2 39.220624)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-38\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_6\">\n     <g id=\"line2d_23\">\n      <path d=\"M 26.925 11.384778 \nL 222.225 11.384778 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_24\">\n      <g>\n       <use xlink:href=\"#m68c1ddd9c0\" x=\"26.925\" y=\"11.384778\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_13\">\n      <!-- 85 -->\n      <g transform=\"translate(7.2 15.183997)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-38\"/>\n       <use xlink:href=\"#DejaVuSans-35\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n   </g>\n   <g id=\"line2d_25\">\n    <path d=\"M 26.925 13.5 \nL 28.878 31.503434 \nL 30.831 63.616369 \nL 32.784 67.882872 \nL 34.737 70.310567 \nL 36.69 70.442769 \nL 38.643 68.832317 \nL 40.596 72.678176 \nL 42.549 70.358646 \nL 44.502 69.913964 \nL 46.455 71.175886 \nL 48.408 71.800839 \nL 50.361 72.557996 \nL 52.314 71.368183 \nL 54.267 72.3657 \nL 56.22 75.538532 \nL 58.173 74.180467 \nL 60.126 73.255058 \nL 62.079 73.807897 \nL 64.032 75.995229 \nL 65.985 76.644221 \nL 67.938 75.959177 \nL 69.891 74.43285 \nL 71.844 78.63926 \nL 73.797 80.694393 \nL 75.75 78.759445 \nL 77.703 79.552652 \nL 79.656 81.042923 \nL 81.609 77.653759 \nL 83.562 81.860171 \nL 85.515 79.829077 \nL 87.468 81.367421 \nL 89.421 81.295308 \nL 91.374 78.43495 \nL 93.327 79.119997 \nL 95.28 78.531093 \nL 97.233 84.432087 \nL 99.186 84.167683 \nL 101.139 81.535675 \nL 103.092 84.119608 \nL 105.045 82.376956 \nL 106.998 83.134111 \nL 108.951 84.528234 \nL 110.904 82.280809 \nL 112.857 86.427127 \nL 114.81 79.480546 \nL 116.763 82.569249 \nL 118.716 83.086039 \nL 120.669 85.249332 \nL 122.622 86.090614 \nL 124.575 86.306945 \nL 126.528 83.518694 \nL 128.481 76.704312 \nL 130.434 91.15033 \nL 132.387 86.318961 \nL 134.34 88.145749 \nL 136.293 77.088896 \nL 138.246 70.911485 \nL 140.199 83.013928 \nL 142.152 86.451164 \nL 144.105 85.898321 \nL 146.058 89.167305 \nL 148.011 78.350823 \nL 149.964 85.417591 \nL 151.917 93.001147 \nL 153.87 88.10969 \nL 155.823 92.292066 \nL 157.776 94.287101 \nL 159.729 90.741702 \nL 161.682 84.936856 \nL 163.635 93.109307 \nL 165.588 89.599963 \nL 167.541 92.917013 \nL 169.494 90.489316 \nL 171.447 90.092714 \nL 173.4 95.512972 \nL 175.353 95.849487 \nL 177.306 95.500953 \nL 179.259 95.272607 \nL 181.212 89.587945 \nL 183.165 92.856925 \nL 185.118 91.619034 \nL 187.071 93.974631 \nL 189.024 90.405187 \nL 190.977 92.195918 \nL 192.93 94.239029 \nL 194.883 94.791876 \nL 196.836 95.537009 \nL 198.789 98.361312 \nL 200.742 92.19592 \nL 202.695 94.888022 \nL 204.648 94.190955 \nL 206.601 86.210799 \nL 208.554 90.789773 \nL 210.507 95.284624 \nL 212.46 90.621519 \nL 214.413 90.164825 \nL 216.366 94.647651 \nL 218.319 96.330221 \nL 220.272 96.95517 \nL 222.225 96.991225 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square\"/>\n   </g>\n   <g id=\"line2d_26\">\n    <path d=\"M 26.925 76.764403 \nL 28.878 91.18638 \nL 30.831 112.338611 \nL 32.784 113.540443 \nL 34.737 118.347768 \nL 36.69 118.828501 \nL 38.643 116.905571 \nL 40.596 116.905571 \nL 42.549 116.905571 \nL 44.502 118.347768 \nL 46.455 119.789966 \nL 48.408 115.223007 \nL 50.361 117.386303 \nL 52.314 120.751431 \nL 54.267 117.867036 \nL 56.22 124.356925 \nL 58.173 120.030332 \nL 60.126 124.356925 \nL 62.079 115.944106 \nL 64.032 120.991797 \nL 65.985 121.232163 \nL 67.938 121.232163 \nL 69.891 120.511065 \nL 71.844 118.347768 \nL 73.797 119.789966 \nL 75.75 118.588134 \nL 77.703 121.47253 \nL 79.656 121.47253 \nL 81.609 123.635826 \nL 83.562 121.712896 \nL 85.515 119.068867 \nL 87.468 117.145937 \nL 89.421 125.078024 \nL 91.374 119.789966 \nL 93.327 118.347768 \nL 95.28 117.867036 \nL 97.233 122.433995 \nL 99.186 124.116559 \nL 101.139 121.953262 \nL 103.092 121.232163 \nL 105.045 119.789966 \nL 106.998 123.155094 \nL 108.951 120.030332 \nL 110.904 118.828501 \nL 112.857 124.356925 \nL 114.81 116.905571 \nL 116.763 122.433995 \nL 118.716 120.270698 \nL 120.669 127.000954 \nL 122.622 123.155094 \nL 124.575 123.635826 \nL 126.528 115.223007 \nL 128.481 113.780809 \nL 130.434 125.799123 \nL 132.387 121.47253 \nL 134.34 124.116559 \nL 136.293 114.98264 \nL 138.246 110.656048 \nL 140.199 120.030332 \nL 142.152 120.270698 \nL 144.105 124.597291 \nL 146.058 123.876192 \nL 148.011 123.39546 \nL 149.964 124.116559 \nL 151.917 125.31839 \nL 153.87 121.232163 \nL 155.823 127.000954 \nL 157.776 121.953262 \nL 159.729 122.433995 \nL 161.682 115.223007 \nL 163.635 122.674361 \nL 165.588 127.24132 \nL 167.541 124.356925 \nL 169.494 124.597291 \nL 171.447 122.433995 \nL 173.4 127.24132 \nL 175.353 124.356925 \nL 177.306 126.760588 \nL 179.259 124.356925 \nL 181.212 121.232163 \nL 183.165 127.24132 \nL 185.118 128.443152 \nL 187.071 127.481686 \nL 189.024 121.232163 \nL 190.977 124.837658 \nL 192.93 124.837658 \nL 194.883 127.000954 \nL 196.836 123.635826 \nL 198.789 122.914727 \nL 200.742 120.030332 \nL 202.695 127.722053 \nL 204.648 127.962419 \nL 206.601 114.742274 \nL 208.554 120.991797 \nL 210.507 130.366082 \nL 212.46 123.876192 \nL 214.413 122.674361 \nL 216.366 128.923884 \nL 218.319 129.404617 \nL 220.272 126.760588 \nL 222.225 129.885349 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #bf00bf; stroke-width: 1.5\"/>\n   </g>\n   <g id=\"line2d_27\">\n    <path d=\"M 26.925 102.243228 \nL 28.878 110.415681 \nL 30.831 126.279855 \nL 32.784 129.16425 \nL 34.737 131.087181 \nL 36.69 131.808279 \nL 38.643 130.606448 \nL 40.596 131.087181 \nL 42.549 129.644983 \nL 44.502 130.125715 \nL 46.455 130.846814 \nL 48.408 131.567913 \nL 50.361 130.125715 \nL 52.314 133.971576 \nL 54.267 132.529378 \nL 56.22 133.010111 \nL 58.173 132.529378 \nL 60.126 132.289012 \nL 62.079 131.087181 \nL 64.032 134.452308 \nL 65.985 133.010111 \nL 67.938 133.010111 \nL 69.891 133.490843 \nL 71.844 131.567913 \nL 73.797 134.933041 \nL 75.75 131.327547 \nL 77.703 135.413773 \nL 79.656 134.933041 \nL 81.609 132.529378 \nL 83.562 132.048646 \nL 85.515 134.933041 \nL 87.468 131.327547 \nL 89.421 134.452308 \nL 91.374 130.846814 \nL 93.327 132.289012 \nL 95.28 129.885349 \nL 97.233 132.048646 \nL 99.186 132.048646 \nL 101.139 132.769744 \nL 103.092 131.567913 \nL 105.045 130.366082 \nL 106.998 136.134872 \nL 108.951 132.769744 \nL 110.904 135.894506 \nL 112.857 136.615605 \nL 114.81 128.923884 \nL 116.763 134.692675 \nL 118.716 133.490843 \nL 120.669 135.65414 \nL 122.622 133.490843 \nL 124.575 131.808279 \nL 126.528 129.404617 \nL 128.481 129.644983 \nL 130.434 135.894506 \nL 132.387 135.413773 \nL 134.34 133.971576 \nL 136.293 130.846814 \nL 138.246 123.39546 \nL 140.199 131.327547 \nL 142.152 134.211942 \nL 144.105 133.490843 \nL 146.058 134.933041 \nL 148.011 131.327547 \nL 149.964 133.73121 \nL 151.917 136.855971 \nL 153.87 132.048646 \nL 155.823 134.933041 \nL 157.776 131.567913 \nL 159.729 131.087181 \nL 161.682 127.722053 \nL 163.635 133.73121 \nL 165.588 135.413773 \nL 167.541 133.250477 \nL 169.494 136.375238 \nL 171.447 131.327547 \nL 173.4 138.057802 \nL 175.353 133.010111 \nL 177.306 135.173407 \nL 179.259 139.5 \nL 181.212 134.211942 \nL 183.165 133.010111 \nL 185.118 137.817436 \nL 187.071 135.894506 \nL 189.024 134.211942 \nL 190.977 134.933041 \nL 192.93 131.327547 \nL 194.883 135.894506 \nL 196.836 130.606448 \nL 198.789 130.366082 \nL 200.742 134.692675 \nL 202.695 137.096337 \nL 204.648 136.134872 \nL 206.601 125.558756 \nL 208.554 131.087181 \nL 210.507 136.855971 \nL 212.46 134.452308 \nL 214.413 131.567913 \nL 216.366 139.259634 \nL 218.319 137.817436 \nL 220.272 137.817436 \nL 222.225 136.615605 \n\" clip-path=\"url(#p206898ca9c)\" style=\"fill: none; stroke-dasharray: 9.6,2.4,1.5,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n   </g>\n   <g id=\"patch_3\">\n    <path d=\"M 26.925 145.8 \nL 26.925 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_4\">\n    <path d=\"M 222.225 145.8 \nL 222.225 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_5\">\n    <path d=\"M 26.925 145.8 \nL 222.225 145.8 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_6\">\n    <path d=\"M 26.925 7.2 \nL 222.225 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"legend_1\">\n    <g id=\"patch_7\">\n     <path d=\"M 99.94375 59.234375 \nL 215.225 59.234375 \nQ 217.225 59.234375 217.225 57.234375 \nL 217.225 14.2 \nQ 217.225 12.2 215.225 12.2 \nL 99.94375 12.2 \nQ 97.94375 12.2 97.94375 14.2 \nL 97.94375 57.234375 \nQ 97.94375 59.234375 99.94375 59.234375 \nz\n\" style=\"fill: #ffffff; opacity: 0.8; stroke: #cccccc; stroke-linejoin: miter\"/>\n    </g>\n    <g id=\"line2d_28\">\n     <path d=\"M 101.94375 20.298438 \nL 111.94375 20.298438 \nL 121.94375 20.298438 \n\" style=\"fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square\"/>\n    </g>\n    <g id=\"text_14\">\n     <!-- Avg. sample obj. -->\n     <g transform=\"translate(129.94375 23.798438)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-41\" d=\"M 2188 4044 \nL 1331 1722 \nL 3047 1722 \nL 2188 4044 \nz\nM 1831 4666 \nL 2547 4666 \nL 4325 0 \nL 3669 0 \nL 3244 1197 \nL 1141 1197 \nL 716 0 \nL 50 0 \nL 1831 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-76\" d=\"M 191 3500 \nL 800 3500 \nL 1894 563 \nL 2988 3500 \nL 3597 3500 \nL 2284 0 \nL 1503 0 \nL 191 3500 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-67\" d=\"M 2906 1791 \nQ 2906 2416 2648 2759 \nQ 2391 3103 1925 3103 \nQ 1463 3103 1205 2759 \nQ 947 2416 947 1791 \nQ 947 1169 1205 825 \nQ 1463 481 1925 481 \nQ 2391 481 2648 825 \nQ 2906 1169 2906 1791 \nz\nM 3481 434 \nQ 3481 -459 3084 -895 \nQ 2688 -1331 1869 -1331 \nQ 1566 -1331 1297 -1286 \nQ 1028 -1241 775 -1147 \nL 775 -588 \nQ 1028 -725 1275 -790 \nQ 1522 -856 1778 -856 \nQ 2344 -856 2625 -561 \nQ 2906 -266 2906 331 \nL 2906 616 \nQ 2728 306 2450 153 \nQ 2172 0 1784 0 \nQ 1141 0 747 490 \nQ 353 981 353 1791 \nQ 353 2603 747 3093 \nQ 1141 3584 1784 3584 \nQ 2172 3584 2450 3431 \nQ 2728 3278 2906 2969 \nL 2906 3500 \nL 3481 3500 \nL 3481 434 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-2e\" d=\"M 684 794 \nL 1344 794 \nL 1344 0 \nL 684 0 \nL 684 794 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-73\" d=\"M 2834 3397 \nL 2834 2853 \nQ 2591 2978 2328 3040 \nQ 2066 3103 1784 3103 \nQ 1356 3103 1142 2972 \nQ 928 2841 928 2578 \nQ 928 2378 1081 2264 \nQ 1234 2150 1697 2047 \nL 1894 2003 \nQ 2506 1872 2764 1633 \nQ 3022 1394 3022 966 \nQ 3022 478 2636 193 \nQ 2250 -91 1575 -91 \nQ 1294 -91 989 -36 \nQ 684 19 347 128 \nL 347 722 \nQ 666 556 975 473 \nQ 1284 391 1588 391 \nQ 1994 391 2212 530 \nQ 2431 669 2431 922 \nQ 2431 1156 2273 1281 \nQ 2116 1406 1581 1522 \nL 1381 1569 \nQ 847 1681 609 1914 \nQ 372 2147 372 2553 \nQ 372 3047 722 3315 \nQ 1072 3584 1716 3584 \nQ 2034 3584 2315 3537 \nQ 2597 3491 2834 3397 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \nQ 1497 1759 1228 1600 \nQ 959 1441 959 1056 \nQ 959 750 1161 570 \nQ 1363 391 1709 391 \nQ 2188 391 2477 730 \nQ 2766 1069 2766 1631 \nL 2766 1759 \nL 2194 1759 \nz\nM 3341 1997 \nL 3341 0 \nL 2766 0 \nL 2766 531 \nQ 2569 213 2275 61 \nQ 1981 -91 1556 -91 \nQ 1019 -91 701 211 \nQ 384 513 384 1019 \nQ 384 1609 779 1909 \nQ 1175 2209 1959 2209 \nL 2766 2209 \nL 2766 2266 \nQ 2766 2663 2505 2880 \nQ 2244 3097 1772 3097 \nQ 1472 3097 1187 3025 \nQ 903 2953 641 2809 \nL 641 3341 \nQ 956 3463 1253 3523 \nQ 1550 3584 1831 3584 \nQ 2591 3584 2966 3190 \nQ 3341 2797 3341 1997 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6d\" d=\"M 3328 2828 \nQ 3544 3216 3844 3400 \nQ 4144 3584 4550 3584 \nQ 5097 3584 5394 3201 \nQ 5691 2819 5691 2113 \nL 5691 0 \nL 5113 0 \nL 5113 2094 \nQ 5113 2597 4934 2840 \nQ 4756 3084 4391 3084 \nQ 3944 3084 3684 2787 \nQ 3425 2491 3425 1978 \nL 3425 0 \nL 2847 0 \nL 2847 2094 \nQ 2847 2600 2669 2842 \nQ 2491 3084 2119 3084 \nQ 1678 3084 1418 2786 \nQ 1159 2488 1159 1978 \nL 1159 0 \nL 581 0 \nL 581 3500 \nL 1159 3500 \nL 1159 2956 \nQ 1356 3278 1631 3431 \nQ 1906 3584 2284 3584 \nQ 2666 3584 2933 3390 \nQ 3200 3197 3328 2828 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \nL 1178 4863 \nL 1178 0 \nL 603 0 \nL 603 4863 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \nQ 3116 2381 2855 2742 \nQ 2594 3103 2138 3103 \nQ 1681 3103 1420 2742 \nQ 1159 2381 1159 1747 \nQ 1159 1113 1420 752 \nQ 1681 391 2138 391 \nQ 2594 391 2855 752 \nQ 3116 1113 3116 1747 \nz\nM 1159 2969 \nQ 1341 3281 1617 3432 \nQ 1894 3584 2278 3584 \nQ 2916 3584 3314 3078 \nQ 3713 2572 3713 1747 \nQ 3713 922 3314 415 \nQ 2916 -91 2278 -91 \nQ 1894 -91 1617 61 \nQ 1341 213 1159 525 \nL 1159 0 \nL 581 0 \nL 581 4863 \nL 1159 4863 \nL 1159 2969 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6a\" d=\"M 603 3500 \nL 1178 3500 \nL 1178 -63 \nQ 1178 -731 923 -1031 \nQ 669 -1331 103 -1331 \nL -116 -1331 \nL -116 -844 \nL 38 -844 \nQ 366 -844 484 -692 \nQ 603 -541 603 -63 \nL 603 3500 \nz\nM 603 4863 \nL 1178 4863 \nL 1178 4134 \nL 603 4134 \nL 603 4863 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-41\"/>\n      <use xlink:href=\"#DejaVuSans-76\" x=\"62.533203\"/>\n      <use xlink:href=\"#DejaVuSans-67\" x=\"121.712891\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"185.189453\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"216.976562\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"248.763672\"/>\n      <use xlink:href=\"#DejaVuSans-61\" x=\"300.863281\"/>\n      <use xlink:href=\"#DejaVuSans-6d\" x=\"362.142578\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"459.554688\"/>\n      <use xlink:href=\"#DejaVuSans-6c\" x=\"523.03125\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"550.814453\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"612.337891\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"644.125\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"705.306641\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"768.783203\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"796.566406\"/>\n     </g>\n    </g>\n    <g id=\"line2d_29\">\n     <path d=\"M 101.94375 34.976563 \nL 111.94375 34.976563 \nL 121.94375 34.976563 \n\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #bf00bf; stroke-width: 1.5\"/>\n    </g>\n    <g id=\"text_15\">\n     <!-- Best sample obj. -->\n     <g transform=\"translate(129.94375 38.476563)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-42\" d=\"M 1259 2228 \nL 1259 519 \nL 2272 519 \nQ 2781 519 3026 730 \nQ 3272 941 3272 1375 \nQ 3272 1813 3026 2020 \nQ 2781 2228 2272 2228 \nL 1259 2228 \nz\nM 1259 4147 \nL 1259 2741 \nL 2194 2741 \nQ 2656 2741 2882 2914 \nQ 3109 3088 3109 3444 \nQ 3109 3797 2882 3972 \nQ 2656 4147 2194 4147 \nL 1259 4147 \nz\nM 628 4666 \nL 2241 4666 \nQ 2963 4666 3353 4366 \nQ 3744 4066 3744 3513 \nQ 3744 3084 3544 2831 \nQ 3344 2578 2956 2516 \nQ 3422 2416 3680 2098 \nQ 3938 1781 3938 1306 \nQ 3938 681 3513 340 \nQ 3088 0 2303 0 \nL 628 0 \nL 628 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-74\" d=\"M 1172 4494 \nL 1172 3500 \nL 2356 3500 \nL 2356 3053 \nL 1172 3053 \nL 1172 1153 \nQ 1172 725 1289 603 \nQ 1406 481 1766 481 \nL 2356 481 \nL 2356 0 \nL 1766 0 \nQ 1100 0 847 248 \nQ 594 497 594 1153 \nL 594 3053 \nL 172 3053 \nL 172 3500 \nL 594 3500 \nL 594 4494 \nL 1172 4494 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-42\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"68.603516\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"130.126953\"/>\n      <use xlink:href=\"#DejaVuSans-74\" x=\"182.226562\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"221.435547\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"253.222656\"/>\n      <use xlink:href=\"#DejaVuSans-61\" x=\"305.322266\"/>\n      <use xlink:href=\"#DejaVuSans-6d\" x=\"366.601562\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"464.013672\"/>\n      <use xlink:href=\"#DejaVuSans-6c\" x=\"527.490234\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"555.273438\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"616.796875\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"648.583984\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"709.765625\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"773.242188\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"801.025391\"/>\n     </g>\n    </g>\n    <g id=\"line2d_30\">\n     <path d=\"M 101.94375 49.654688 \nL 111.94375 49.654688 \nL 121.94375 49.654688 \n\" style=\"fill: none; stroke-dasharray: 9.6,2.4,1.5,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n    </g>\n    <g id=\"text_16\">\n     <!-- Best ACO obj. -->\n     <g transform=\"translate(129.94375 53.154688)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-43\" d=\"M 4122 4306 \nL 4122 3641 \nQ 3803 3938 3442 4084 \nQ 3081 4231 2675 4231 \nQ 1875 4231 1450 3742 \nQ 1025 3253 1025 2328 \nQ 1025 1406 1450 917 \nQ 1875 428 2675 428 \nQ 3081 428 3442 575 \nQ 3803 722 4122 1019 \nL 4122 359 \nQ 3791 134 3420 21 \nQ 3050 -91 2638 -91 \nQ 1578 -91 968 557 \nQ 359 1206 359 2328 \nQ 359 3453 968 4101 \nQ 1578 4750 2638 4750 \nQ 3056 4750 3426 4639 \nQ 3797 4528 4122 4306 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-4f\" d=\"M 2522 4238 \nQ 1834 4238 1429 3725 \nQ 1025 3213 1025 2328 \nQ 1025 1447 1429 934 \nQ 1834 422 2522 422 \nQ 3209 422 3611 934 \nQ 4013 1447 4013 2328 \nQ 4013 3213 3611 3725 \nQ 3209 4238 2522 4238 \nz\nM 2522 4750 \nQ 3503 4750 4090 4092 \nQ 4678 3434 4678 2328 \nQ 4678 1225 4090 567 \nQ 3503 -91 2522 -91 \nQ 1538 -91 948 565 \nQ 359 1222 359 2328 \nQ 359 3434 948 4092 \nQ 1538 4750 2522 4750 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-42\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"68.603516\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"130.126953\"/>\n      <use xlink:href=\"#DejaVuSans-74\" x=\"182.226562\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"221.435547\"/>\n      <use xlink:href=\"#DejaVuSans-41\" x=\"253.222656\"/>\n      <use xlink:href=\"#DejaVuSans-43\" x=\"319.880859\"/>\n      <use xlink:href=\"#DejaVuSans-4f\" x=\"389.705078\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"468.416016\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"500.203125\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"561.384766\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"624.861328\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"652.644531\"/>\n     </g>\n    </g>\n   </g>\n  </g>\n </g>\n <defs>\n  <clipPath id=\"p206898ca9c\">\n   <rect x=\"26.925\" y=\"7.2\" width=\"195.3\" height=\"138.6\"/>\n  </clipPath>\n </defs>\n</svg>\n",
      "text/plain": [
       "<Figure size 350x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# j30\n",
    "n_node, n_ants = 30, 20\n",
    "steps_per_epoch = 32\n",
    "epochs = 100\n",
    "train(n_node, n_ants, steps_per_epoch, epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total training duration: 207.69052577018738\n"
     ]
    },
    {
     "data": {
      "image/svg+xml": "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"245.33125pt\" height=\"183.35625pt\" viewBox=\"0 0 245.33125 183.35625\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n <metadata>\n  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n   <cc:Work>\n    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n    <dc:date>2023-03-09T14:05:30.864663</dc:date>\n    <dc:format>image/svg+xml</dc:format>\n    <dc:creator>\n     <cc:Agent>\n      <dc:title>Matplotlib v3.5.2, https://matplotlib.org/</dc:title>\n     </cc:Agent>\n    </dc:creator>\n   </cc:Work>\n  </rdf:RDF>\n </metadata>\n <defs>\n  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n </defs>\n <g id=\"figure_1\">\n  <g id=\"patch_1\">\n   <path d=\"M 0 183.35625 \nL 245.33125 183.35625 \nL 245.33125 0 \nL 0 0 \nz\n\" style=\"fill: #ffffff\"/>\n  </g>\n  <g id=\"axes_1\">\n   <g id=\"patch_2\">\n    <path d=\"M 33.2875 145.8 \nL 228.5875 145.8 \nL 228.5875 7.2 \nL 33.2875 7.2 \nz\n\" style=\"fill: #ffffff\"/>\n   </g>\n   <g id=\"matplotlib.axis_1\">\n    <g id=\"xtick_1\">\n     <g id=\"line2d_1\">\n      <path d=\"M 33.2875 145.8 \nL 33.2875 7.2 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_2\">\n      <defs>\n       <path id=\"mf9ee863a79\" d=\"M 0 0 \nL 0 3.5 \n\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </defs>\n      <g>\n       <use xlink:href=\"#mf9ee863a79\" x=\"33.2875\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_1\">\n      <!-- 0 -->\n      <g transform=\"translate(30.10625 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \nQ 1547 4250 1301 3770 \nQ 1056 3291 1056 2328 \nQ 1056 1369 1301 889 \nQ 1547 409 2034 409 \nQ 2525 409 2770 889 \nQ 3016 1369 3016 2328 \nQ 3016 3291 2770 3770 \nQ 2525 4250 2034 4250 \nz\nM 2034 4750 \nQ 2819 4750 3233 4129 \nQ 3647 3509 3647 2328 \nQ 3647 1150 3233 529 \nQ 2819 -91 2034 -91 \nQ 1250 -91 836 529 \nQ 422 1150 422 2328 \nQ 422 3509 836 4129 \nQ 1250 4750 2034 4750 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-30\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_2\">\n     <g id=\"line2d_3\">\n      <path d=\"M 72.3475 145.8 \nL 72.3475 7.2 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_4\">\n      <g>\n       <use xlink:href=\"#mf9ee863a79\" x=\"72.3475\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_2\">\n      <!-- 20 -->\n      <g transform=\"translate(65.985 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \nL 3431 531 \nL 3431 0 \nL 469 0 \nL 469 531 \nQ 828 903 1448 1529 \nQ 2069 2156 2228 2338 \nQ 2531 2678 2651 2914 \nQ 2772 3150 2772 3378 \nQ 2772 3750 2511 3984 \nQ 2250 4219 1831 4219 \nQ 1534 4219 1204 4116 \nQ 875 4013 500 3803 \nL 500 4441 \nQ 881 4594 1212 4672 \nQ 1544 4750 1819 4750 \nQ 2544 4750 2975 4387 \nQ 3406 4025 3406 3419 \nQ 3406 3131 3298 2873 \nQ 3191 2616 2906 2266 \nQ 2828 2175 2409 1742 \nQ 1991 1309 1228 531 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_3\">\n     <g id=\"line2d_5\">\n      <path d=\"M 111.4075 145.8 \nL 111.4075 7.2 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_6\">\n      <g>\n       <use xlink:href=\"#mf9ee863a79\" x=\"111.4075\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_3\">\n      <!-- 40 -->\n      <g transform=\"translate(105.045 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \nL 825 1625 \nL 2419 1625 \nL 2419 4116 \nz\nM 2253 4666 \nL 3047 4666 \nL 3047 1625 \nL 3713 1625 \nL 3713 1100 \nL 3047 1100 \nL 3047 0 \nL 2419 0 \nL 2419 1100 \nL 313 1100 \nL 313 1709 \nL 2253 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-34\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_4\">\n     <g id=\"line2d_7\">\n      <path d=\"M 150.4675 145.8 \nL 150.4675 7.2 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_8\">\n      <g>\n       <use xlink:href=\"#mf9ee863a79\" x=\"150.4675\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_4\">\n      <!-- 60 -->\n      <g transform=\"translate(144.105 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \nQ 1688 2584 1439 2293 \nQ 1191 2003 1191 1497 \nQ 1191 994 1439 701 \nQ 1688 409 2113 409 \nQ 2538 409 2786 701 \nQ 3034 994 3034 1497 \nQ 3034 2003 2786 2293 \nQ 2538 2584 2113 2584 \nz\nM 3366 4563 \nL 3366 3988 \nQ 3128 4100 2886 4159 \nQ 2644 4219 2406 4219 \nQ 1781 4219 1451 3797 \nQ 1122 3375 1075 2522 \nQ 1259 2794 1537 2939 \nQ 1816 3084 2150 3084 \nQ 2853 3084 3261 2657 \nQ 3669 2231 3669 1497 \nQ 3669 778 3244 343 \nQ 2819 -91 2113 -91 \nQ 1303 -91 875 529 \nQ 447 1150 447 2328 \nQ 447 3434 972 4092 \nQ 1497 4750 2381 4750 \nQ 2619 4750 2861 4703 \nQ 3103 4656 3366 4563 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-36\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_5\">\n     <g id=\"line2d_9\">\n      <path d=\"M 189.5275 145.8 \nL 189.5275 7.2 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_10\">\n      <g>\n       <use xlink:href=\"#mf9ee863a79\" x=\"189.5275\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_5\">\n      <!-- 80 -->\n      <g transform=\"translate(183.165 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \nQ 1584 2216 1326 1975 \nQ 1069 1734 1069 1313 \nQ 1069 891 1326 650 \nQ 1584 409 2034 409 \nQ 2484 409 2743 651 \nQ 3003 894 3003 1313 \nQ 3003 1734 2745 1975 \nQ 2488 2216 2034 2216 \nz\nM 1403 2484 \nQ 997 2584 770 2862 \nQ 544 3141 544 3541 \nQ 544 4100 942 4425 \nQ 1341 4750 2034 4750 \nQ 2731 4750 3128 4425 \nQ 3525 4100 3525 3541 \nQ 3525 3141 3298 2862 \nQ 3072 2584 2669 2484 \nQ 3125 2378 3379 2068 \nQ 3634 1759 3634 1313 \nQ 3634 634 3220 271 \nQ 2806 -91 2034 -91 \nQ 1263 -91 848 271 \nQ 434 634 434 1313 \nQ 434 1759 690 2068 \nQ 947 2378 1403 2484 \nz\nM 1172 3481 \nQ 1172 3119 1398 2916 \nQ 1625 2713 2034 2713 \nQ 2441 2713 2670 2916 \nQ 2900 3119 2900 3481 \nQ 2900 3844 2670 4047 \nQ 2441 4250 2034 4250 \nQ 1625 4250 1398 4047 \nQ 1172 3844 1172 3481 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-38\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_6\">\n     <g id=\"line2d_11\">\n      <path d=\"M 228.5875 145.8 \nL 228.5875 7.2 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_12\">\n      <g>\n       <use xlink:href=\"#mf9ee863a79\" x=\"228.5875\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_6\">\n      <!-- 100 -->\n      <g transform=\"translate(219.04375 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-31\" d=\"M 794 531 \nL 1825 531 \nL 1825 4091 \nL 703 3866 \nL 703 4441 \nL 1819 4666 \nL 2450 4666 \nL 2450 531 \nL 3481 531 \nL 3481 0 \nL 794 0 \nL 794 531 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"text_7\">\n     <!-- epoch -->\n     <g transform=\"translate(115.709375 174.076563)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \nL 3597 1613 \nL 953 1613 \nQ 991 1019 1311 708 \nQ 1631 397 2203 397 \nQ 2534 397 2845 478 \nQ 3156 559 3463 722 \nL 3463 178 \nQ 3153 47 2828 -22 \nQ 2503 -91 2169 -91 \nQ 1331 -91 842 396 \nQ 353 884 353 1716 \nQ 353 2575 817 3079 \nQ 1281 3584 2069 3584 \nQ 2775 3584 3186 3129 \nQ 3597 2675 3597 1894 \nz\nM 3022 2063 \nQ 3016 2534 2758 2815 \nQ 2500 3097 2075 3097 \nQ 1594 3097 1305 2825 \nQ 1016 2553 972 2059 \nL 3022 2063 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-70\" d=\"M 1159 525 \nL 1159 -1331 \nL 581 -1331 \nL 581 3500 \nL 1159 3500 \nL 1159 2969 \nQ 1341 3281 1617 3432 \nQ 1894 3584 2278 3584 \nQ 2916 3584 3314 3078 \nQ 3713 2572 3713 1747 \nQ 3713 922 3314 415 \nQ 2916 -91 2278 -91 \nQ 1894 -91 1617 61 \nQ 1341 213 1159 525 \nz\nM 3116 1747 \nQ 3116 2381 2855 2742 \nQ 2594 3103 2138 3103 \nQ 1681 3103 1420 2742 \nQ 1159 2381 1159 1747 \nQ 1159 1113 1420 752 \nQ 1681 391 2138 391 \nQ 2594 391 2855 752 \nQ 3116 1113 3116 1747 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6f\" d=\"M 1959 3097 \nQ 1497 3097 1228 2736 \nQ 959 2375 959 1747 \nQ 959 1119 1226 758 \nQ 1494 397 1959 397 \nQ 2419 397 2687 759 \nQ 2956 1122 2956 1747 \nQ 2956 2369 2687 2733 \nQ 2419 3097 1959 3097 \nz\nM 1959 3584 \nQ 2709 3584 3137 3096 \nQ 3566 2609 3566 1747 \nQ 3566 888 3137 398 \nQ 2709 -91 1959 -91 \nQ 1206 -91 779 398 \nQ 353 888 353 1747 \nQ 353 2609 779 3096 \nQ 1206 3584 1959 3584 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-63\" d=\"M 3122 3366 \nL 3122 2828 \nQ 2878 2963 2633 3030 \nQ 2388 3097 2138 3097 \nQ 1578 3097 1268 2742 \nQ 959 2388 959 1747 \nQ 959 1106 1268 751 \nQ 1578 397 2138 397 \nQ 2388 397 2633 464 \nQ 2878 531 3122 666 \nL 3122 134 \nQ 2881 22 2623 -34 \nQ 2366 -91 2075 -91 \nQ 1284 -91 818 406 \nQ 353 903 353 1747 \nQ 353 2603 823 3093 \nQ 1294 3584 2113 3584 \nQ 2378 3584 2631 3529 \nQ 2884 3475 3122 3366 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-68\" d=\"M 3513 2113 \nL 3513 0 \nL 2938 0 \nL 2938 2094 \nQ 2938 2591 2744 2837 \nQ 2550 3084 2163 3084 \nQ 1697 3084 1428 2787 \nQ 1159 2491 1159 1978 \nL 1159 0 \nL 581 0 \nL 581 4863 \nL 1159 4863 \nL 1159 2956 \nQ 1366 3272 1645 3428 \nQ 1925 3584 2291 3584 \nQ 2894 3584 3203 3211 \nQ 3513 2838 3513 2113 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-65\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"61.523438\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"125\"/>\n      <use xlink:href=\"#DejaVuSans-63\" x=\"186.181641\"/>\n      <use xlink:href=\"#DejaVuSans-68\" x=\"241.162109\"/>\n     </g>\n    </g>\n   </g>\n   <g id=\"matplotlib.axis_2\">\n    <g id=\"ytick_1\">\n     <g id=\"line2d_13\">\n      <path d=\"M 33.2875 140.493971 \nL 228.5875 140.493971 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_14\">\n      <defs>\n       <path id=\"m9ab521b445\" d=\"M 0 0 \nL -3.5 0 \n\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </defs>\n      <g>\n       <use xlink:href=\"#m9ab521b445\" x=\"33.2875\" y=\"140.493971\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_8\">\n      <!-- 90 -->\n      <g transform=\"translate(13.5625 144.29319)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-39\" d=\"M 703 97 \nL 703 672 \nQ 941 559 1184 500 \nQ 1428 441 1663 441 \nQ 2288 441 2617 861 \nQ 2947 1281 2994 2138 \nQ 2813 1869 2534 1725 \nQ 2256 1581 1919 1581 \nQ 1219 1581 811 2004 \nQ 403 2428 403 3163 \nQ 403 3881 828 4315 \nQ 1253 4750 1959 4750 \nQ 2769 4750 3195 4129 \nQ 3622 3509 3622 2328 \nQ 3622 1225 3098 567 \nQ 2575 -91 1691 -91 \nQ 1453 -91 1209 -44 \nQ 966 3 703 97 \nz\nM 1959 2075 \nQ 2384 2075 2632 2365 \nQ 2881 2656 2881 3163 \nQ 2881 3666 2632 3958 \nQ 2384 4250 1959 4250 \nQ 1534 4250 1286 3958 \nQ 1038 3666 1038 3163 \nQ 1038 2656 1286 2365 \nQ 1534 2075 1959 2075 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-39\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_2\">\n     <g id=\"line2d_15\">\n      <path d=\"M 33.2875 112.094804 \nL 228.5875 112.094804 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_16\">\n      <g>\n       <use xlink:href=\"#m9ab521b445\" x=\"33.2875\" y=\"112.094804\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_9\">\n      <!-- 100 -->\n      <g transform=\"translate(7.2 115.894023)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_3\">\n     <g id=\"line2d_17\">\n      <path d=\"M 33.2875 83.695638 \nL 228.5875 83.695638 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_18\">\n      <g>\n       <use xlink:href=\"#m9ab521b445\" x=\"33.2875\" y=\"83.695638\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_10\">\n      <!-- 110 -->\n      <g transform=\"translate(7.2 87.494856)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-31\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_4\">\n     <g id=\"line2d_19\">\n      <path d=\"M 33.2875 55.296471 \nL 228.5875 55.296471 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_20\">\n      <g>\n       <use xlink:href=\"#m9ab521b445\" x=\"33.2875\" y=\"55.296471\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_11\">\n      <!-- 120 -->\n      <g transform=\"translate(7.2 59.09569)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-32\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_5\">\n     <g id=\"line2d_21\">\n      <path d=\"M 33.2875 26.897304 \nL 228.5875 26.897304 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_22\">\n      <g>\n       <use xlink:href=\"#m9ab521b445\" x=\"33.2875\" y=\"26.897304\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_12\">\n      <!-- 130 -->\n      <g transform=\"translate(7.2 30.696523)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \nQ 3050 2419 3304 2112 \nQ 3559 1806 3559 1356 \nQ 3559 666 3084 287 \nQ 2609 -91 1734 -91 \nQ 1441 -91 1130 -33 \nQ 819 25 488 141 \nL 488 750 \nQ 750 597 1062 519 \nQ 1375 441 1716 441 \nQ 2309 441 2620 675 \nQ 2931 909 2931 1356 \nQ 2931 1769 2642 2001 \nQ 2353 2234 1838 2234 \nL 1294 2234 \nL 1294 2753 \nL 1863 2753 \nQ 2328 2753 2575 2939 \nQ 2822 3125 2822 3475 \nQ 2822 3834 2567 4026 \nQ 2313 4219 1838 4219 \nQ 1578 4219 1281 4162 \nQ 984 4106 628 3988 \nL 628 4550 \nQ 988 4650 1302 4700 \nQ 1616 4750 1894 4750 \nQ 2613 4750 3031 4423 \nQ 3450 4097 3450 3541 \nQ 3450 3153 3228 2886 \nQ 3006 2619 2597 2516 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-33\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n   </g>\n   <g id=\"line2d_23\">\n    <path d=\"M 33.2875 13.5 \nL 35.2405 20.329999 \nL 37.1935 64.675295 \nL 39.1465 68.360084 \nL 41.0995 69.581252 \nL 43.0525 67.678507 \nL 45.0055 67.884402 \nL 46.9585 68.502084 \nL 48.9115 70.184734 \nL 50.8645 68.118692 \nL 52.8175 68.793175 \nL 54.7705 72.250774 \nL 56.7235 73.713333 \nL 58.6765 74.10382 \nL 60.6295 74.835096 \nL 62.5825 75.381782 \nL 64.5355 78.030006 \nL 66.4885 78.129401 \nL 68.4415 78.796784 \nL 70.3945 80.252237 \nL 72.3475 80.727926 \nL 74.3005 82.715865 \nL 76.2535 80.493631 \nL 78.2065 79.883049 \nL 80.1595 76.872734 \nL 82.1125 82.360878 \nL 84.0655 83.411646 \nL 86.0185 81.849693 \nL 87.9715 79.55646 \nL 89.9245 79.819153 \nL 91.8775 83.24125 \nL 93.8305 84.781906 \nL 95.7835 79.272468 \nL 97.7365 82.644868 \nL 99.6895 82.978558 \nL 101.6425 80.053445 \nL 103.5955 83.624639 \nL 105.5485 85.243394 \nL 107.5015 87.06804 \nL 109.4545 87.572125 \nL 111.4075 87.721218 \nL 113.3605 86.223164 \nL 115.3135 86.478757 \nL 117.2665 84.732208 \nL 119.2195 86.897646 \nL 121.1725 87.707018 \nL 123.1255 85.293092 \nL 125.0785 87.778017 \nL 127.0315 86.855047 \nL 128.9845 87.117738 \nL 130.9375 83.454246 \nL 132.8905 87.323632 \nL 134.8435 82.474475 \nL 136.7965 81.5302 \nL 138.7495 87.955515 \nL 140.7025 86.791146 \nL 142.6555 85.790076 \nL 144.6085 84.299119 \nL 146.5615 88.118808 \nL 148.5145 89.212179 \nL 150.4675 86.414857 \nL 152.4205 85.264692 \nL 154.3735 86.443254 \nL 156.3265 88.743589 \nL 158.2795 84.625711 \nL 160.2325 87.621823 \nL 162.1855 84.242322 \nL 164.1385 86.72725 \nL 166.0915 87.018339 \nL 168.0445 87.834814 \nL 169.9975 84.732207 \nL 171.9505 82.943058 \nL 173.9035 86.933144 \nL 175.8565 86.400659 \nL 177.8095 84.540514 \nL 179.7625 87.841916 \nL 181.7155 87.344931 \nL 183.6685 87.621824 \nL 185.6215 88.509297 \nL 187.5745 87.380428 \nL 189.5275 88.3389 \nL 191.4805 86.890545 \nL 193.4335 87.195834 \nL 195.3865 88.771989 \nL 197.3395 86.713051 \nL 199.2925 89.11988 \nL 201.2455 86.997045 \nL 203.1985 91.782301 \nL 205.1515 91.562205 \nL 207.1045 91.100722 \nL 209.0575 86.201863 \nL 211.0105 86.833744 \nL 212.9635 87.664422 \nL 214.9165 89.595567 \nL 216.8695 89.055984 \nL 218.8225 88.168506 \nL 220.7755 88.502196 \nL 222.7285 85.917873 \nL 224.6815 87.316534 \nL 226.6345 87.09644 \nL 228.5875 89.645263 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square\"/>\n   </g>\n   <g id=\"line2d_24\">\n    <path d=\"M 33.2875 74.465909 \nL 35.2405 78.441792 \nL 37.1935 108.118921 \nL 39.1465 110.390854 \nL 41.0995 115.502704 \nL 43.0525 109.680875 \nL 45.0055 114.082746 \nL 46.9585 114.082746 \nL 48.9115 110.958838 \nL 50.8645 114.224742 \nL 52.8175 114.650729 \nL 54.7705 117.064658 \nL 56.7235 123.880458 \nL 58.6765 121.750521 \nL 60.6295 121.608525 \nL 62.5825 124.732433 \nL 64.5355 124.448442 \nL 66.4885 125.300417 \nL 68.4415 122.744492 \nL 70.3945 122.4605 \nL 72.3475 122.176508 \nL 74.3005 122.602496 \nL 76.2535 122.034513 \nL 78.2065 120.330563 \nL 80.1595 116.780667 \nL 82.1125 122.744492 \nL 84.0655 119.194596 \nL 86.0185 122.318504 \nL 87.9715 121.750521 \nL 89.9245 122.176508 \nL 91.8775 123.170479 \nL 93.8305 123.880458 \nL 95.7835 117.206654 \nL 97.7365 124.16445 \nL 99.6895 124.306446 \nL 101.6425 121.892517 \nL 103.5955 121.466529 \nL 105.5485 120.046571 \nL 107.5015 127.430354 \nL 109.4545 124.022454 \nL 111.4075 123.880458 \nL 113.3605 125.016425 \nL 115.3135 125.8684 \nL 117.2665 123.738463 \nL 119.2195 122.176508 \nL 121.1725 124.306446 \nL 123.1255 123.170479 \nL 125.0785 123.312475 \nL 127.0315 123.170479 \nL 128.9845 125.016425 \nL 130.9375 119.904575 \nL 132.8905 126.436383 \nL 134.8435 119.478588 \nL 136.7965 120.330563 \nL 138.7495 119.904575 \nL 140.7025 118.484617 \nL 142.6555 121.324533 \nL 144.6085 119.0526 \nL 146.5615 120.330563 \nL 148.5145 125.584408 \nL 150.4675 122.176508 \nL 152.4205 123.596467 \nL 154.3735 123.596467 \nL 156.3265 125.442413 \nL 158.2795 121.750521 \nL 160.2325 121.608525 \nL 162.1855 118.626613 \nL 164.1385 120.472558 \nL 166.0915 122.318504 \nL 168.0445 122.318504 \nL 169.9975 122.176508 \nL 171.9505 122.034513 \nL 173.9035 122.318504 \nL 175.8565 124.16445 \nL 177.8095 118.200625 \nL 179.7625 120.614554 \nL 181.7155 119.336592 \nL 183.6685 125.726404 \nL 185.6215 124.022454 \nL 187.5745 121.892517 \nL 189.5275 122.602496 \nL 191.4805 124.448442 \nL 193.4335 123.028483 \nL 195.3865 126.152392 \nL 197.3395 121.040542 \nL 199.2925 123.738463 \nL 201.2455 121.750521 \nL 203.1985 122.4605 \nL 205.1515 128.282329 \nL 207.1045 127.288358 \nL 209.0575 119.336592 \nL 211.0105 123.454471 \nL 212.9635 121.466529 \nL 214.9165 125.016425 \nL 216.8695 126.010396 \nL 218.8225 125.300417 \nL 220.7755 123.170479 \nL 222.7285 125.584408 \nL 224.6815 122.4605 \nL 226.6345 124.732433 \nL 228.5875 125.8684 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #bf00bf; stroke-width: 1.5\"/>\n   </g>\n   <g id=\"line2d_25\">\n    <path d=\"M 33.2875 95.481292 \nL 35.2405 99.599171 \nL 37.1935 123.170479 \nL 39.1465 126.436383 \nL 41.0995 129.418296 \nL 43.0525 128.850313 \nL 45.0055 130.838254 \nL 46.9585 128.566321 \nL 48.9115 127.714346 \nL 50.8645 128.708317 \nL 52.8175 131.406238 \nL 54.7705 130.270271 \nL 56.7235 131.974221 \nL 58.6765 134.38815 \nL 60.6295 134.530146 \nL 62.5825 135.808108 \nL 64.5355 134.530146 \nL 66.4885 136.660083 \nL 68.4415 133.962163 \nL 70.3945 135.524117 \nL 72.3475 134.672142 \nL 74.3005 134.104158 \nL 76.2535 133.678171 \nL 78.2065 134.530146 \nL 80.1595 133.394179 \nL 82.1125 138.506029 \nL 84.0655 133.536175 \nL 86.0185 136.0921 \nL 87.9715 135.524117 \nL 89.9245 133.536175 \nL 91.8775 136.802079 \nL 93.8305 134.38815 \nL 95.7835 135.240125 \nL 97.7365 135.382121 \nL 99.6895 135.382121 \nL 101.6425 135.382121 \nL 103.5955 136.376092 \nL 105.5485 135.666113 \nL 107.5015 137.938046 \nL 109.4545 136.944075 \nL 111.4075 139.5 \nL 113.3605 134.672142 \nL 115.3135 136.660083 \nL 117.2665 137.370063 \nL 119.2195 137.79605 \nL 121.1725 137.370063 \nL 123.1255 138.648025 \nL 125.0785 137.79605 \nL 127.0315 137.228067 \nL 128.9845 135.098129 \nL 130.9375 130.838254 \nL 132.8905 134.38815 \nL 134.8435 131.974221 \nL 136.7965 128.708317 \nL 138.7495 132.542204 \nL 140.7025 131.974221 \nL 142.6555 134.956133 \nL 144.6085 131.406238 \nL 146.5615 136.0921 \nL 148.5145 135.382121 \nL 150.4675 132.116217 \nL 152.4205 130.98025 \nL 154.3735 134.814138 \nL 156.3265 135.808108 \nL 158.2795 134.104158 \nL 160.2325 133.962163 \nL 162.1855 131.122246 \nL 164.1385 131.406238 \nL 166.0915 136.0921 \nL 168.0445 132.6842 \nL 169.9975 134.38815 \nL 171.9505 134.104158 \nL 173.9035 132.116217 \nL 175.8565 134.246154 \nL 177.8095 133.962163 \nL 179.7625 132.6842 \nL 181.7155 134.38815 \nL 183.6685 134.814138 \nL 185.6215 136.518088 \nL 187.5745 137.228067 \nL 189.5275 136.0921 \nL 191.4805 137.086071 \nL 193.4335 134.956133 \nL 195.3865 135.524117 \nL 197.3395 135.524117 \nL 199.2925 136.518088 \nL 201.2455 136.660083 \nL 203.1985 136.518088 \nL 205.1515 139.358004 \nL 207.1045 136.944075 \nL 209.0575 135.950104 \nL 211.0105 132.968192 \nL 212.9635 137.228067 \nL 214.9165 134.104158 \nL 216.8695 135.240125 \nL 218.8225 133.678171 \nL 220.7755 133.536175 \nL 222.7285 136.518088 \nL 224.6815 134.246154 \nL 226.6345 137.228067 \nL 228.5875 133.536175 \n\" clip-path=\"url(#p7b551a8965)\" style=\"fill: none; stroke-dasharray: 9.6,2.4,1.5,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n   </g>\n   <g id=\"patch_3\">\n    <path d=\"M 33.2875 145.8 \nL 33.2875 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_4\">\n    <path d=\"M 228.5875 145.8 \nL 228.5875 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_5\">\n    <path d=\"M 33.2875 145.8 \nL 228.5875 145.8 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_6\">\n    <path d=\"M 33.2875 7.2 \nL 228.5875 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"legend_1\">\n    <g id=\"patch_7\">\n     <path d=\"M 106.30625 59.234375 \nL 221.5875 59.234375 \nQ 223.5875 59.234375 223.5875 57.234375 \nL 223.5875 14.2 \nQ 223.5875 12.2 221.5875 12.2 \nL 106.30625 12.2 \nQ 104.30625 12.2 104.30625 14.2 \nL 104.30625 57.234375 \nQ 104.30625 59.234375 106.30625 59.234375 \nz\n\" style=\"fill: #ffffff; opacity: 0.8; stroke: #cccccc; stroke-linejoin: miter\"/>\n    </g>\n    <g id=\"line2d_26\">\n     <path d=\"M 108.30625 20.298438 \nL 118.30625 20.298438 \nL 128.30625 20.298438 \n\" style=\"fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square\"/>\n    </g>\n    <g id=\"text_13\">\n     <!-- Avg. sample obj. -->\n     <g transform=\"translate(136.30625 23.798438)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-41\" d=\"M 2188 4044 \nL 1331 1722 \nL 3047 1722 \nL 2188 4044 \nz\nM 1831 4666 \nL 2547 4666 \nL 4325 0 \nL 3669 0 \nL 3244 1197 \nL 1141 1197 \nL 716 0 \nL 50 0 \nL 1831 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-76\" d=\"M 191 3500 \nL 800 3500 \nL 1894 563 \nL 2988 3500 \nL 3597 3500 \nL 2284 0 \nL 1503 0 \nL 191 3500 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-67\" d=\"M 2906 1791 \nQ 2906 2416 2648 2759 \nQ 2391 3103 1925 3103 \nQ 1463 3103 1205 2759 \nQ 947 2416 947 1791 \nQ 947 1169 1205 825 \nQ 1463 481 1925 481 \nQ 2391 481 2648 825 \nQ 2906 1169 2906 1791 \nz\nM 3481 434 \nQ 3481 -459 3084 -895 \nQ 2688 -1331 1869 -1331 \nQ 1566 -1331 1297 -1286 \nQ 1028 -1241 775 -1147 \nL 775 -588 \nQ 1028 -725 1275 -790 \nQ 1522 -856 1778 -856 \nQ 2344 -856 2625 -561 \nQ 2906 -266 2906 331 \nL 2906 616 \nQ 2728 306 2450 153 \nQ 2172 0 1784 0 \nQ 1141 0 747 490 \nQ 353 981 353 1791 \nQ 353 2603 747 3093 \nQ 1141 3584 1784 3584 \nQ 2172 3584 2450 3431 \nQ 2728 3278 2906 2969 \nL 2906 3500 \nL 3481 3500 \nL 3481 434 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-2e\" d=\"M 684 794 \nL 1344 794 \nL 1344 0 \nL 684 0 \nL 684 794 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-73\" d=\"M 2834 3397 \nL 2834 2853 \nQ 2591 2978 2328 3040 \nQ 2066 3103 1784 3103 \nQ 1356 3103 1142 2972 \nQ 928 2841 928 2578 \nQ 928 2378 1081 2264 \nQ 1234 2150 1697 2047 \nL 1894 2003 \nQ 2506 1872 2764 1633 \nQ 3022 1394 3022 966 \nQ 3022 478 2636 193 \nQ 2250 -91 1575 -91 \nQ 1294 -91 989 -36 \nQ 684 19 347 128 \nL 347 722 \nQ 666 556 975 473 \nQ 1284 391 1588 391 \nQ 1994 391 2212 530 \nQ 2431 669 2431 922 \nQ 2431 1156 2273 1281 \nQ 2116 1406 1581 1522 \nL 1381 1569 \nQ 847 1681 609 1914 \nQ 372 2147 372 2553 \nQ 372 3047 722 3315 \nQ 1072 3584 1716 3584 \nQ 2034 3584 2315 3537 \nQ 2597 3491 2834 3397 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \nQ 1497 1759 1228 1600 \nQ 959 1441 959 1056 \nQ 959 750 1161 570 \nQ 1363 391 1709 391 \nQ 2188 391 2477 730 \nQ 2766 1069 2766 1631 \nL 2766 1759 \nL 2194 1759 \nz\nM 3341 1997 \nL 3341 0 \nL 2766 0 \nL 2766 531 \nQ 2569 213 2275 61 \nQ 1981 -91 1556 -91 \nQ 1019 -91 701 211 \nQ 384 513 384 1019 \nQ 384 1609 779 1909 \nQ 1175 2209 1959 2209 \nL 2766 2209 \nL 2766 2266 \nQ 2766 2663 2505 2880 \nQ 2244 3097 1772 3097 \nQ 1472 3097 1187 3025 \nQ 903 2953 641 2809 \nL 641 3341 \nQ 956 3463 1253 3523 \nQ 1550 3584 1831 3584 \nQ 2591 3584 2966 3190 \nQ 3341 2797 3341 1997 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6d\" d=\"M 3328 2828 \nQ 3544 3216 3844 3400 \nQ 4144 3584 4550 3584 \nQ 5097 3584 5394 3201 \nQ 5691 2819 5691 2113 \nL 5691 0 \nL 5113 0 \nL 5113 2094 \nQ 5113 2597 4934 2840 \nQ 4756 3084 4391 3084 \nQ 3944 3084 3684 2787 \nQ 3425 2491 3425 1978 \nL 3425 0 \nL 2847 0 \nL 2847 2094 \nQ 2847 2600 2669 2842 \nQ 2491 3084 2119 3084 \nQ 1678 3084 1418 2786 \nQ 1159 2488 1159 1978 \nL 1159 0 \nL 581 0 \nL 581 3500 \nL 1159 3500 \nL 1159 2956 \nQ 1356 3278 1631 3431 \nQ 1906 3584 2284 3584 \nQ 2666 3584 2933 3390 \nQ 3200 3197 3328 2828 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \nL 1178 4863 \nL 1178 0 \nL 603 0 \nL 603 4863 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \nQ 3116 2381 2855 2742 \nQ 2594 3103 2138 3103 \nQ 1681 3103 1420 2742 \nQ 1159 2381 1159 1747 \nQ 1159 1113 1420 752 \nQ 1681 391 2138 391 \nQ 2594 391 2855 752 \nQ 3116 1113 3116 1747 \nz\nM 1159 2969 \nQ 1341 3281 1617 3432 \nQ 1894 3584 2278 3584 \nQ 2916 3584 3314 3078 \nQ 3713 2572 3713 1747 \nQ 3713 922 3314 415 \nQ 2916 -91 2278 -91 \nQ 1894 -91 1617 61 \nQ 1341 213 1159 525 \nL 1159 0 \nL 581 0 \nL 581 4863 \nL 1159 4863 \nL 1159 2969 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6a\" d=\"M 603 3500 \nL 1178 3500 \nL 1178 -63 \nQ 1178 -731 923 -1031 \nQ 669 -1331 103 -1331 \nL -116 -1331 \nL -116 -844 \nL 38 -844 \nQ 366 -844 484 -692 \nQ 603 -541 603 -63 \nL 603 3500 \nz\nM 603 4863 \nL 1178 4863 \nL 1178 4134 \nL 603 4134 \nL 603 4863 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-41\"/>\n      <use xlink:href=\"#DejaVuSans-76\" x=\"62.533203\"/>\n      <use xlink:href=\"#DejaVuSans-67\" x=\"121.712891\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"185.189453\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"216.976562\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"248.763672\"/>\n      <use xlink:href=\"#DejaVuSans-61\" x=\"300.863281\"/>\n      <use xlink:href=\"#DejaVuSans-6d\" x=\"362.142578\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"459.554688\"/>\n      <use xlink:href=\"#DejaVuSans-6c\" x=\"523.03125\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"550.814453\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"612.337891\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"644.125\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"705.306641\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"768.783203\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"796.566406\"/>\n     </g>\n    </g>\n    <g id=\"line2d_27\">\n     <path d=\"M 108.30625 34.976563 \nL 118.30625 34.976563 \nL 128.30625 34.976563 \n\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #bf00bf; stroke-width: 1.5\"/>\n    </g>\n    <g id=\"text_14\">\n     <!-- Best sample obj. -->\n     <g transform=\"translate(136.30625 38.476563)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-42\" d=\"M 1259 2228 \nL 1259 519 \nL 2272 519 \nQ 2781 519 3026 730 \nQ 3272 941 3272 1375 \nQ 3272 1813 3026 2020 \nQ 2781 2228 2272 2228 \nL 1259 2228 \nz\nM 1259 4147 \nL 1259 2741 \nL 2194 2741 \nQ 2656 2741 2882 2914 \nQ 3109 3088 3109 3444 \nQ 3109 3797 2882 3972 \nQ 2656 4147 2194 4147 \nL 1259 4147 \nz\nM 628 4666 \nL 2241 4666 \nQ 2963 4666 3353 4366 \nQ 3744 4066 3744 3513 \nQ 3744 3084 3544 2831 \nQ 3344 2578 2956 2516 \nQ 3422 2416 3680 2098 \nQ 3938 1781 3938 1306 \nQ 3938 681 3513 340 \nQ 3088 0 2303 0 \nL 628 0 \nL 628 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-74\" d=\"M 1172 4494 \nL 1172 3500 \nL 2356 3500 \nL 2356 3053 \nL 1172 3053 \nL 1172 1153 \nQ 1172 725 1289 603 \nQ 1406 481 1766 481 \nL 2356 481 \nL 2356 0 \nL 1766 0 \nQ 1100 0 847 248 \nQ 594 497 594 1153 \nL 594 3053 \nL 172 3053 \nL 172 3500 \nL 594 3500 \nL 594 4494 \nL 1172 4494 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-42\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"68.603516\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"130.126953\"/>\n      <use xlink:href=\"#DejaVuSans-74\" x=\"182.226562\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"221.435547\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"253.222656\"/>\n      <use xlink:href=\"#DejaVuSans-61\" x=\"305.322266\"/>\n      <use xlink:href=\"#DejaVuSans-6d\" x=\"366.601562\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"464.013672\"/>\n      <use xlink:href=\"#DejaVuSans-6c\" x=\"527.490234\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"555.273438\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"616.796875\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"648.583984\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"709.765625\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"773.242188\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"801.025391\"/>\n     </g>\n    </g>\n    <g id=\"line2d_28\">\n     <path d=\"M 108.30625 49.654688 \nL 118.30625 49.654688 \nL 128.30625 49.654688 \n\" style=\"fill: none; stroke-dasharray: 9.6,2.4,1.5,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n    </g>\n    <g id=\"text_15\">\n     <!-- Best ACO obj. -->\n     <g transform=\"translate(136.30625 53.154688)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-43\" d=\"M 4122 4306 \nL 4122 3641 \nQ 3803 3938 3442 4084 \nQ 3081 4231 2675 4231 \nQ 1875 4231 1450 3742 \nQ 1025 3253 1025 2328 \nQ 1025 1406 1450 917 \nQ 1875 428 2675 428 \nQ 3081 428 3442 575 \nQ 3803 722 4122 1019 \nL 4122 359 \nQ 3791 134 3420 21 \nQ 3050 -91 2638 -91 \nQ 1578 -91 968 557 \nQ 359 1206 359 2328 \nQ 359 3453 968 4101 \nQ 1578 4750 2638 4750 \nQ 3056 4750 3426 4639 \nQ 3797 4528 4122 4306 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-4f\" d=\"M 2522 4238 \nQ 1834 4238 1429 3725 \nQ 1025 3213 1025 2328 \nQ 1025 1447 1429 934 \nQ 1834 422 2522 422 \nQ 3209 422 3611 934 \nQ 4013 1447 4013 2328 \nQ 4013 3213 3611 3725 \nQ 3209 4238 2522 4238 \nz\nM 2522 4750 \nQ 3503 4750 4090 4092 \nQ 4678 3434 4678 2328 \nQ 4678 1225 4090 567 \nQ 3503 -91 2522 -91 \nQ 1538 -91 948 565 \nQ 359 1222 359 2328 \nQ 359 3434 948 4092 \nQ 1538 4750 2522 4750 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-42\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"68.603516\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"130.126953\"/>\n      <use xlink:href=\"#DejaVuSans-74\" x=\"182.226562\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"221.435547\"/>\n      <use xlink:href=\"#DejaVuSans-41\" x=\"253.222656\"/>\n      <use xlink:href=\"#DejaVuSans-43\" x=\"319.880859\"/>\n      <use xlink:href=\"#DejaVuSans-4f\" x=\"389.705078\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"468.416016\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"500.203125\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"561.384766\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"624.861328\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"652.644531\"/>\n     </g>\n    </g>\n   </g>\n  </g>\n </g>\n <defs>\n  <clipPath id=\"p7b551a8965\">\n   <rect x=\"33.2875\" y=\"7.2\" width=\"195.3\" height=\"138.6\"/>\n  </clipPath>\n </defs>\n</svg>\n",
      "text/plain": [
       "<Figure size 350x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# j60\n",
    "n_node, n_ants = 60, 20\n",
    "steps_per_epoch = 32\n",
    "epochs = 100\n",
    "train(n_node, n_ants, steps_per_epoch, epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total training duration: 454.07165265083313\n"
     ]
    },
    {
     "data": {
      "image/svg+xml": "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"245.33125pt\" height=\"183.35625pt\" viewBox=\"0 0 245.33125 183.35625\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n <metadata>\n  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n   <cc:Work>\n    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n    <dc:date>2023-03-09T14:38:20.836270</dc:date>\n    <dc:format>image/svg+xml</dc:format>\n    <dc:creator>\n     <cc:Agent>\n      <dc:title>Matplotlib v3.5.2, https://matplotlib.org/</dc:title>\n     </cc:Agent>\n    </dc:creator>\n   </cc:Work>\n  </rdf:RDF>\n </metadata>\n <defs>\n  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n </defs>\n <g id=\"figure_1\">\n  <g id=\"patch_1\">\n   <path d=\"M 0 183.35625 \nL 245.33125 183.35625 \nL 245.33125 0 \nL 0 0 \nz\n\" style=\"fill: #ffffff\"/>\n  </g>\n  <g id=\"axes_1\">\n   <g id=\"patch_2\">\n    <path d=\"M 33.2875 145.8 \nL 228.5875 145.8 \nL 228.5875 7.2 \nL 33.2875 7.2 \nz\n\" style=\"fill: #ffffff\"/>\n   </g>\n   <g id=\"matplotlib.axis_1\">\n    <g id=\"xtick_1\">\n     <g id=\"line2d_1\">\n      <path d=\"M 33.2875 145.8 \nL 33.2875 7.2 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_2\">\n      <defs>\n       <path id=\"m2a9e3e9732\" d=\"M 0 0 \nL 0 3.5 \n\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </defs>\n      <g>\n       <use xlink:href=\"#m2a9e3e9732\" x=\"33.2875\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_1\">\n      <!-- 0 -->\n      <g transform=\"translate(30.10625 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \nQ 1547 4250 1301 3770 \nQ 1056 3291 1056 2328 \nQ 1056 1369 1301 889 \nQ 1547 409 2034 409 \nQ 2525 409 2770 889 \nQ 3016 1369 3016 2328 \nQ 3016 3291 2770 3770 \nQ 2525 4250 2034 4250 \nz\nM 2034 4750 \nQ 2819 4750 3233 4129 \nQ 3647 3509 3647 2328 \nQ 3647 1150 3233 529 \nQ 2819 -91 2034 -91 \nQ 1250 -91 836 529 \nQ 422 1150 422 2328 \nQ 422 3509 836 4129 \nQ 1250 4750 2034 4750 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-30\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_2\">\n     <g id=\"line2d_3\">\n      <path d=\"M 72.3475 145.8 \nL 72.3475 7.2 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_4\">\n      <g>\n       <use xlink:href=\"#m2a9e3e9732\" x=\"72.3475\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_2\">\n      <!-- 20 -->\n      <g transform=\"translate(65.985 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \nL 3431 531 \nL 3431 0 \nL 469 0 \nL 469 531 \nQ 828 903 1448 1529 \nQ 2069 2156 2228 2338 \nQ 2531 2678 2651 2914 \nQ 2772 3150 2772 3378 \nQ 2772 3750 2511 3984 \nQ 2250 4219 1831 4219 \nQ 1534 4219 1204 4116 \nQ 875 4013 500 3803 \nL 500 4441 \nQ 881 4594 1212 4672 \nQ 1544 4750 1819 4750 \nQ 2544 4750 2975 4387 \nQ 3406 4025 3406 3419 \nQ 3406 3131 3298 2873 \nQ 3191 2616 2906 2266 \nQ 2828 2175 2409 1742 \nQ 1991 1309 1228 531 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_3\">\n     <g id=\"line2d_5\">\n      <path d=\"M 111.4075 145.8 \nL 111.4075 7.2 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_6\">\n      <g>\n       <use xlink:href=\"#m2a9e3e9732\" x=\"111.4075\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_3\">\n      <!-- 40 -->\n      <g transform=\"translate(105.045 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \nL 825 1625 \nL 2419 1625 \nL 2419 4116 \nz\nM 2253 4666 \nL 3047 4666 \nL 3047 1625 \nL 3713 1625 \nL 3713 1100 \nL 3047 1100 \nL 3047 0 \nL 2419 0 \nL 2419 1100 \nL 313 1100 \nL 313 1709 \nL 2253 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-34\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_4\">\n     <g id=\"line2d_7\">\n      <path d=\"M 150.4675 145.8 \nL 150.4675 7.2 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_8\">\n      <g>\n       <use xlink:href=\"#m2a9e3e9732\" x=\"150.4675\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_4\">\n      <!-- 60 -->\n      <g transform=\"translate(144.105 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \nQ 1688 2584 1439 2293 \nQ 1191 2003 1191 1497 \nQ 1191 994 1439 701 \nQ 1688 409 2113 409 \nQ 2538 409 2786 701 \nQ 3034 994 3034 1497 \nQ 3034 2003 2786 2293 \nQ 2538 2584 2113 2584 \nz\nM 3366 4563 \nL 3366 3988 \nQ 3128 4100 2886 4159 \nQ 2644 4219 2406 4219 \nQ 1781 4219 1451 3797 \nQ 1122 3375 1075 2522 \nQ 1259 2794 1537 2939 \nQ 1816 3084 2150 3084 \nQ 2853 3084 3261 2657 \nQ 3669 2231 3669 1497 \nQ 3669 778 3244 343 \nQ 2819 -91 2113 -91 \nQ 1303 -91 875 529 \nQ 447 1150 447 2328 \nQ 447 3434 972 4092 \nQ 1497 4750 2381 4750 \nQ 2619 4750 2861 4703 \nQ 3103 4656 3366 4563 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-36\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_5\">\n     <g id=\"line2d_9\">\n      <path d=\"M 189.5275 145.8 \nL 189.5275 7.2 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_10\">\n      <g>\n       <use xlink:href=\"#m2a9e3e9732\" x=\"189.5275\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_5\">\n      <!-- 80 -->\n      <g transform=\"translate(183.165 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \nQ 1584 2216 1326 1975 \nQ 1069 1734 1069 1313 \nQ 1069 891 1326 650 \nQ 1584 409 2034 409 \nQ 2484 409 2743 651 \nQ 3003 894 3003 1313 \nQ 3003 1734 2745 1975 \nQ 2488 2216 2034 2216 \nz\nM 1403 2484 \nQ 997 2584 770 2862 \nQ 544 3141 544 3541 \nQ 544 4100 942 4425 \nQ 1341 4750 2034 4750 \nQ 2731 4750 3128 4425 \nQ 3525 4100 3525 3541 \nQ 3525 3141 3298 2862 \nQ 3072 2584 2669 2484 \nQ 3125 2378 3379 2068 \nQ 3634 1759 3634 1313 \nQ 3634 634 3220 271 \nQ 2806 -91 2034 -91 \nQ 1263 -91 848 271 \nQ 434 634 434 1313 \nQ 434 1759 690 2068 \nQ 947 2378 1403 2484 \nz\nM 1172 3481 \nQ 1172 3119 1398 2916 \nQ 1625 2713 2034 2713 \nQ 2441 2713 2670 2916 \nQ 2900 3119 2900 3481 \nQ 2900 3844 2670 4047 \nQ 2441 4250 2034 4250 \nQ 1625 4250 1398 4047 \nQ 1172 3844 1172 3481 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-38\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"xtick_6\">\n     <g id=\"line2d_11\">\n      <path d=\"M 228.5875 145.8 \nL 228.5875 7.2 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_12\">\n      <g>\n       <use xlink:href=\"#m2a9e3e9732\" x=\"228.5875\" y=\"145.8\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_6\">\n      <!-- 100 -->\n      <g transform=\"translate(219.04375 160.398438)scale(0.1 -0.1)\">\n       <defs>\n        <path id=\"DejaVuSans-31\" d=\"M 794 531 \nL 1825 531 \nL 1825 4091 \nL 703 3866 \nL 703 4441 \nL 1819 4666 \nL 2450 4666 \nL 2450 531 \nL 3481 531 \nL 3481 0 \nL 794 0 \nL 794 531 \nz\n\" transform=\"scale(0.015625)\"/>\n       </defs>\n       <use xlink:href=\"#DejaVuSans-31\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"text_7\">\n     <!-- epoch -->\n     <g transform=\"translate(115.709375 174.076563)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \nL 3597 1613 \nL 953 1613 \nQ 991 1019 1311 708 \nQ 1631 397 2203 397 \nQ 2534 397 2845 478 \nQ 3156 559 3463 722 \nL 3463 178 \nQ 3153 47 2828 -22 \nQ 2503 -91 2169 -91 \nQ 1331 -91 842 396 \nQ 353 884 353 1716 \nQ 353 2575 817 3079 \nQ 1281 3584 2069 3584 \nQ 2775 3584 3186 3129 \nQ 3597 2675 3597 1894 \nz\nM 3022 2063 \nQ 3016 2534 2758 2815 \nQ 2500 3097 2075 3097 \nQ 1594 3097 1305 2825 \nQ 1016 2553 972 2059 \nL 3022 2063 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-70\" d=\"M 1159 525 \nL 1159 -1331 \nL 581 -1331 \nL 581 3500 \nL 1159 3500 \nL 1159 2969 \nQ 1341 3281 1617 3432 \nQ 1894 3584 2278 3584 \nQ 2916 3584 3314 3078 \nQ 3713 2572 3713 1747 \nQ 3713 922 3314 415 \nQ 2916 -91 2278 -91 \nQ 1894 -91 1617 61 \nQ 1341 213 1159 525 \nz\nM 3116 1747 \nQ 3116 2381 2855 2742 \nQ 2594 3103 2138 3103 \nQ 1681 3103 1420 2742 \nQ 1159 2381 1159 1747 \nQ 1159 1113 1420 752 \nQ 1681 391 2138 391 \nQ 2594 391 2855 752 \nQ 3116 1113 3116 1747 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6f\" d=\"M 1959 3097 \nQ 1497 3097 1228 2736 \nQ 959 2375 959 1747 \nQ 959 1119 1226 758 \nQ 1494 397 1959 397 \nQ 2419 397 2687 759 \nQ 2956 1122 2956 1747 \nQ 2956 2369 2687 2733 \nQ 2419 3097 1959 3097 \nz\nM 1959 3584 \nQ 2709 3584 3137 3096 \nQ 3566 2609 3566 1747 \nQ 3566 888 3137 398 \nQ 2709 -91 1959 -91 \nQ 1206 -91 779 398 \nQ 353 888 353 1747 \nQ 353 2609 779 3096 \nQ 1206 3584 1959 3584 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-63\" d=\"M 3122 3366 \nL 3122 2828 \nQ 2878 2963 2633 3030 \nQ 2388 3097 2138 3097 \nQ 1578 3097 1268 2742 \nQ 959 2388 959 1747 \nQ 959 1106 1268 751 \nQ 1578 397 2138 397 \nQ 2388 397 2633 464 \nQ 2878 531 3122 666 \nL 3122 134 \nQ 2881 22 2623 -34 \nQ 2366 -91 2075 -91 \nQ 1284 -91 818 406 \nQ 353 903 353 1747 \nQ 353 2603 823 3093 \nQ 1294 3584 2113 3584 \nQ 2378 3584 2631 3529 \nQ 2884 3475 3122 3366 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-68\" d=\"M 3513 2113 \nL 3513 0 \nL 2938 0 \nL 2938 2094 \nQ 2938 2591 2744 2837 \nQ 2550 3084 2163 3084 \nQ 1697 3084 1428 2787 \nQ 1159 2491 1159 1978 \nL 1159 0 \nL 581 0 \nL 581 4863 \nL 1159 4863 \nL 1159 2956 \nQ 1366 3272 1645 3428 \nQ 1925 3584 2291 3584 \nQ 2894 3584 3203 3211 \nQ 3513 2838 3513 2113 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-65\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"61.523438\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"125\"/>\n      <use xlink:href=\"#DejaVuSans-63\" x=\"186.181641\"/>\n      <use xlink:href=\"#DejaVuSans-68\" x=\"241.162109\"/>\n     </g>\n    </g>\n   </g>\n   <g id=\"matplotlib.axis_2\">\n    <g id=\"ytick_1\">\n     <g id=\"line2d_13\">\n      <path d=\"M 33.2875 132.808934 \nL 228.5875 132.808934 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_14\">\n      <defs>\n       <path id=\"mea9b6bc95e\" d=\"M 0 0 \nL -3.5 0 \n\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </defs>\n      <g>\n       <use xlink:href=\"#mea9b6bc95e\" x=\"33.2875\" y=\"132.808934\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_8\">\n      <!-- 200 -->\n      <g transform=\"translate(7.2 136.608153)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_2\">\n     <g id=\"line2d_15\">\n      <path d=\"M 33.2875 96.641012 \nL 228.5875 96.641012 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_16\">\n      <g>\n       <use xlink:href=\"#mea9b6bc95e\" x=\"33.2875\" y=\"96.641012\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_9\">\n      <!-- 220 -->\n      <g transform=\"translate(7.2 100.440231)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-32\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_3\">\n     <g id=\"line2d_17\">\n      <path d=\"M 33.2875 60.47309 \nL 228.5875 60.47309 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_18\">\n      <g>\n       <use xlink:href=\"#mea9b6bc95e\" x=\"33.2875\" y=\"60.47309\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_10\">\n      <!-- 240 -->\n      <g transform=\"translate(7.2 64.272309)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-34\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n    <g id=\"ytick_4\">\n     <g id=\"line2d_19\">\n      <path d=\"M 33.2875 24.305168 \nL 228.5875 24.305168 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #b0b0b0; stroke-width: 0.8; stroke-linecap: square\"/>\n     </g>\n     <g id=\"line2d_20\">\n      <g>\n       <use xlink:href=\"#mea9b6bc95e\" x=\"33.2875\" y=\"24.305168\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n      </g>\n     </g>\n     <g id=\"text_11\">\n      <!-- 260 -->\n      <g transform=\"translate(7.2 28.104387)scale(0.1 -0.1)\">\n       <use xlink:href=\"#DejaVuSans-32\"/>\n       <use xlink:href=\"#DejaVuSans-36\" x=\"63.623047\"/>\n       <use xlink:href=\"#DejaVuSans-30\" x=\"127.246094\"/>\n      </g>\n     </g>\n    </g>\n   </g>\n   <g id=\"line2d_21\">\n    <path d=\"M 33.2875 13.5 \nL 35.2405 16.497419 \nL 37.1935 55.192574 \nL 39.1465 55.368894 \nL 41.0995 58.3211 \nL 43.0525 59.767817 \nL 45.0055 58.312056 \nL 46.9585 60.179224 \nL 48.9115 62.304091 \nL 50.8645 58.226159 \nL 52.8175 58.863616 \nL 54.7705 60.53186 \nL 56.7235 63.063621 \nL 58.6765 63.239935 \nL 60.6295 64.25716 \nL 62.5825 65.238216 \nL 64.5355 67.137032 \nL 66.4885 72.896771 \nL 68.4415 71.549519 \nL 70.3945 70.808076 \nL 72.3475 73.900431 \nL 74.3005 67.779012 \nL 76.2535 72.887731 \nL 78.2065 77.820126 \nL 80.1595 72.684285 \nL 82.1125 76.753174 \nL 84.0655 74.045105 \nL 86.0185 75.437567 \nL 87.9715 81.228958 \nL 89.9245 80.216257 \nL 91.8775 78.728848 \nL 93.8305 81.382666 \nL 95.7835 81.839286 \nL 97.7365 80.3338 \nL 99.6895 83.471367 \nL 101.6425 81.694618 \nL 103.5955 81.242522 \nL 105.5485 83.462323 \nL 107.5015 86.17492 \nL 109.4545 82.341121 \nL 111.4075 85.166735 \nL 113.3605 83.389987 \nL 115.3135 85.239077 \nL 117.2665 84.777933 \nL 119.2195 83.982235 \nL 121.1725 89.398387 \nL 123.1255 85.306891 \nL 125.0785 84.258023 \nL 127.0315 88.887513 \nL 128.9845 89.4662 \nL 130.9375 91.568458 \nL 132.8905 87.409151 \nL 134.8435 84.710123 \nL 136.7965 85.727343 \nL 138.7495 88.693111 \nL 140.7025 90.976213 \nL 142.6555 89.936383 \nL 144.6085 90.347793 \nL 146.5615 90.732075 \nL 148.5145 89.601829 \nL 150.4675 87.526697 \nL 152.4205 88.977928 \nL 154.3735 89.922821 \nL 156.3265 85.957911 \nL 158.2795 86.717437 \nL 160.2325 90.931002 \nL 162.1855 91.658885 \nL 164.1385 86.324111 \nL 166.0915 90.686866 \nL 168.0445 88.620779 \nL 169.9975 86.251779 \nL 171.9505 86.446179 \nL 173.9035 88.652416 \nL 175.8565 82.12411 \nL 177.8095 84.791501 \nL 179.7625 84.81862 \nL 181.7155 84.48859 \nL 183.6685 88.905599 \nL 185.6215 86.179441 \nL 187.5745 89.913779 \nL 189.5275 85.306892 \nL 191.4805 84.633261 \nL 193.4335 87.671365 \nL 195.3865 86.373843 \nL 197.3395 81.857374 \nL 199.2925 86.125187 \nL 201.2455 87.228307 \nL 203.1985 88.923681 \nL 205.1515 80.555323 \nL 207.1045 84.475029 \nL 209.0575 89.457162 \nL 211.0105 84.475024 \nL 212.9635 88.634338 \nL 214.9165 90.903872 \nL 216.8695 89.72842 \nL 218.8225 90.415604 \nL 220.7755 85.135092 \nL 222.7285 88.146069 \nL 224.6815 87.142411 \nL 226.6345 88.001397 \nL 228.5875 88.060175 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square\"/>\n   </g>\n   <g id=\"line2d_22\">\n    <path d=\"M 33.2875 65.35576 \nL 35.2405 69.062972 \nL 37.1935 96.008074 \nL 39.1465 98.539828 \nL 41.0995 94.290097 \nL 43.0525 100.348224 \nL 45.0055 98.178149 \nL 46.9585 97.997309 \nL 48.9115 98.630248 \nL 50.8645 97.997309 \nL 52.8175 99.263187 \nL 54.7705 94.561357 \nL 56.7235 105.682993 \nL 58.6765 101.885361 \nL 60.6295 107.853068 \nL 62.5825 101.885361 \nL 64.5355 106.315931 \nL 66.4885 107.943488 \nL 68.4415 110.656082 \nL 70.3945 106.85845 \nL 72.3475 109.842304 \nL 74.3005 109.028526 \nL 76.2535 105.863832 \nL 78.2065 114.453714 \nL 80.1595 108.576427 \nL 82.1125 115.357912 \nL 84.0655 111.198601 \nL 86.0185 111.56028 \nL 87.9715 115.267492 \nL 89.9245 115.357912 \nL 91.8775 112.554898 \nL 93.8305 114.453714 \nL 95.7835 118.703445 \nL 97.7365 116.895049 \nL 99.6895 118.613025 \nL 101.6425 118.160926 \nL 103.5955 115.086653 \nL 105.5485 117.618407 \nL 107.5015 119.426803 \nL 109.4545 114.905813 \nL 111.4075 121.868138 \nL 113.3605 116.985468 \nL 115.3135 118.884284 \nL 117.2665 120.692681 \nL 119.2195 120.331001 \nL 121.1725 120.602261 \nL 123.1255 121.05436 \nL 125.0785 119.245964 \nL 127.0315 124.038213 \nL 128.9845 125.846609 \nL 130.9375 123.224435 \nL 132.8905 121.506459 \nL 134.8435 119.155544 \nL 136.7965 119.517223 \nL 138.7495 124.128633 \nL 140.7025 126.298708 \nL 142.6555 121.596879 \nL 144.6085 126.027449 \nL 146.5615 125.937029 \nL 148.5145 126.208289 \nL 150.4675 118.613025 \nL 152.4205 123.947793 \nL 154.3735 125.846609 \nL 156.3265 121.235199 \nL 158.2795 119.426803 \nL 160.2325 125.032831 \nL 162.1855 127.926265 \nL 164.1385 120.96394 \nL 166.0915 124.309473 \nL 168.0445 122.501077 \nL 169.9975 118.793865 \nL 171.9505 119.336383 \nL 173.9035 120.692681 \nL 175.8565 117.799247 \nL 177.8095 120.421421 \nL 179.7625 120.87352 \nL 181.7155 118.884284 \nL 183.6685 122.139397 \nL 185.6215 118.884284 \nL 187.5745 123.586114 \nL 189.5275 118.613025 \nL 191.4805 121.506459 \nL 193.4335 122.953176 \nL 195.3865 117.799247 \nL 197.3395 121.506459 \nL 199.2925 121.416039 \nL 201.2455 122.681916 \nL 203.1985 122.501077 \nL 205.1515 113.911195 \nL 207.1045 119.607643 \nL 209.0575 123.857374 \nL 211.0105 117.527987 \nL 212.9635 121.868138 \nL 214.9165 127.474166 \nL 216.8695 124.219053 \nL 218.8225 124.580732 \nL 220.7755 118.251346 \nL 222.7285 123.857374 \nL 224.6815 119.517223 \nL 226.6345 119.517223 \nL 228.5875 123.043595 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #bf00bf; stroke-width: 1.5\"/>\n   </g>\n   <g id=\"line2d_23\">\n    <path d=\"M 33.2875 80.727127 \nL 35.2405 83.349301 \nL 37.1935 107.03929 \nL 39.1465 111.108181 \nL 41.0995 108.124328 \nL 43.0525 111.289021 \nL 45.0055 114.815393 \nL 46.9585 111.017761 \nL 48.9115 112.554898 \nL 50.8645 108.666846 \nL 52.8175 111.921959 \nL 54.7705 112.374058 \nL 56.7235 114.996233 \nL 58.6765 115.086653 \nL 60.6295 119.065124 \nL 62.5825 113.368676 \nL 64.5355 117.347148 \nL 66.4885 121.596879 \nL 68.4415 122.862756 \nL 70.3945 120.96394 \nL 72.3475 123.947793 \nL 74.3005 124.128633 \nL 76.2535 119.969322 \nL 78.2065 125.846609 \nL 80.1595 122.953176 \nL 82.1125 127.202906 \nL 84.0655 125.213671 \nL 86.0185 125.48493 \nL 87.9715 126.027449 \nL 89.9245 126.117869 \nL 91.8775 126.479548 \nL 93.8305 127.383746 \nL 95.7835 129.372982 \nL 97.7365 127.745425 \nL 99.6895 131.814317 \nL 101.6425 130.09634 \nL 103.5955 129.553821 \nL 105.5485 130.3676 \nL 107.5015 130.458019 \nL 109.4545 130.458019 \nL 111.4075 131.543057 \nL 113.3605 130.00592 \nL 115.3135 134.79817 \nL 117.2665 130.910119 \nL 119.2195 129.553821 \nL 121.1725 130.910119 \nL 123.1255 132.899354 \nL 125.0785 128.287944 \nL 127.0315 136.516146 \nL 128.9845 137.329925 \nL 130.9375 134.436491 \nL 132.8905 130.729279 \nL 134.8435 130.00592 \nL 136.7965 133.441873 \nL 138.7495 135.521529 \nL 140.7025 138.957481 \nL 142.6555 134.436491 \nL 144.6085 135.06943 \nL 146.5615 139.5 \nL 148.5145 132.628095 \nL 150.4675 135.521529 \nL 152.4205 137.329925 \nL 154.3735 134.79817 \nL 156.3265 132.085576 \nL 158.2795 135.340689 \nL 160.2325 136.968245 \nL 162.1855 138.957481 \nL 164.1385 134.074812 \nL 166.0915 133.170614 \nL 168.0445 132.718515 \nL 169.9975 130.09634 \nL 171.9505 128.107105 \nL 173.9035 131.995156 \nL 175.8565 131.995156 \nL 177.8095 133.713132 \nL 179.7625 132.537675 \nL 181.7155 130.09634 \nL 183.6685 132.266416 \nL 185.6215 133.080194 \nL 187.5745 132.447255 \nL 189.5275 129.372982 \nL 191.4805 134.165231 \nL 193.4335 132.266416 \nL 195.3865 134.074812 \nL 197.3395 132.175996 \nL 199.2925 132.718515 \nL 201.2455 134.255651 \nL 203.1985 132.356835 \nL 205.1515 129.825081 \nL 207.1045 131.543057 \nL 209.0575 135.521529 \nL 211.0105 129.463402 \nL 212.9635 134.436491 \nL 214.9165 137.149085 \nL 216.8695 133.441873 \nL 218.8225 133.713132 \nL 220.7755 133.351453 \nL 222.7285 133.441873 \nL 224.6815 132.356835 \nL 226.6345 132.537675 \nL 228.5875 133.532293 \n\" clip-path=\"url(#pcbffed24ed)\" style=\"fill: none; stroke-dasharray: 9.6,2.4,1.5,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n   </g>\n   <g id=\"patch_3\">\n    <path d=\"M 33.2875 145.8 \nL 33.2875 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_4\">\n    <path d=\"M 228.5875 145.8 \nL 228.5875 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_5\">\n    <path d=\"M 33.2875 145.8 \nL 228.5875 145.8 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"patch_6\">\n    <path d=\"M 33.2875 7.2 \nL 228.5875 7.2 \n\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n   </g>\n   <g id=\"legend_1\">\n    <g id=\"patch_7\">\n     <path d=\"M 106.30625 59.234375 \nL 221.5875 59.234375 \nQ 223.5875 59.234375 223.5875 57.234375 \nL 223.5875 14.2 \nQ 223.5875 12.2 221.5875 12.2 \nL 106.30625 12.2 \nQ 104.30625 12.2 104.30625 14.2 \nL 104.30625 57.234375 \nQ 104.30625 59.234375 106.30625 59.234375 \nz\n\" style=\"fill: #ffffff; opacity: 0.8; stroke: #cccccc; stroke-linejoin: miter\"/>\n    </g>\n    <g id=\"line2d_24\">\n     <path d=\"M 108.30625 20.298438 \nL 118.30625 20.298438 \nL 128.30625 20.298438 \n\" style=\"fill: none; stroke: #1f77b4; stroke-width: 1.5; stroke-linecap: square\"/>\n    </g>\n    <g id=\"text_12\">\n     <!-- Avg. sample obj. -->\n     <g transform=\"translate(136.30625 23.798438)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-41\" d=\"M 2188 4044 \nL 1331 1722 \nL 3047 1722 \nL 2188 4044 \nz\nM 1831 4666 \nL 2547 4666 \nL 4325 0 \nL 3669 0 \nL 3244 1197 \nL 1141 1197 \nL 716 0 \nL 50 0 \nL 1831 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-76\" d=\"M 191 3500 \nL 800 3500 \nL 1894 563 \nL 2988 3500 \nL 3597 3500 \nL 2284 0 \nL 1503 0 \nL 191 3500 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-67\" d=\"M 2906 1791 \nQ 2906 2416 2648 2759 \nQ 2391 3103 1925 3103 \nQ 1463 3103 1205 2759 \nQ 947 2416 947 1791 \nQ 947 1169 1205 825 \nQ 1463 481 1925 481 \nQ 2391 481 2648 825 \nQ 2906 1169 2906 1791 \nz\nM 3481 434 \nQ 3481 -459 3084 -895 \nQ 2688 -1331 1869 -1331 \nQ 1566 -1331 1297 -1286 \nQ 1028 -1241 775 -1147 \nL 775 -588 \nQ 1028 -725 1275 -790 \nQ 1522 -856 1778 -856 \nQ 2344 -856 2625 -561 \nQ 2906 -266 2906 331 \nL 2906 616 \nQ 2728 306 2450 153 \nQ 2172 0 1784 0 \nQ 1141 0 747 490 \nQ 353 981 353 1791 \nQ 353 2603 747 3093 \nQ 1141 3584 1784 3584 \nQ 2172 3584 2450 3431 \nQ 2728 3278 2906 2969 \nL 2906 3500 \nL 3481 3500 \nL 3481 434 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-2e\" d=\"M 684 794 \nL 1344 794 \nL 1344 0 \nL 684 0 \nL 684 794 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-73\" d=\"M 2834 3397 \nL 2834 2853 \nQ 2591 2978 2328 3040 \nQ 2066 3103 1784 3103 \nQ 1356 3103 1142 2972 \nQ 928 2841 928 2578 \nQ 928 2378 1081 2264 \nQ 1234 2150 1697 2047 \nL 1894 2003 \nQ 2506 1872 2764 1633 \nQ 3022 1394 3022 966 \nQ 3022 478 2636 193 \nQ 2250 -91 1575 -91 \nQ 1294 -91 989 -36 \nQ 684 19 347 128 \nL 347 722 \nQ 666 556 975 473 \nQ 1284 391 1588 391 \nQ 1994 391 2212 530 \nQ 2431 669 2431 922 \nQ 2431 1156 2273 1281 \nQ 2116 1406 1581 1522 \nL 1381 1569 \nQ 847 1681 609 1914 \nQ 372 2147 372 2553 \nQ 372 3047 722 3315 \nQ 1072 3584 1716 3584 \nQ 2034 3584 2315 3537 \nQ 2597 3491 2834 3397 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \nQ 1497 1759 1228 1600 \nQ 959 1441 959 1056 \nQ 959 750 1161 570 \nQ 1363 391 1709 391 \nQ 2188 391 2477 730 \nQ 2766 1069 2766 1631 \nL 2766 1759 \nL 2194 1759 \nz\nM 3341 1997 \nL 3341 0 \nL 2766 0 \nL 2766 531 \nQ 2569 213 2275 61 \nQ 1981 -91 1556 -91 \nQ 1019 -91 701 211 \nQ 384 513 384 1019 \nQ 384 1609 779 1909 \nQ 1175 2209 1959 2209 \nL 2766 2209 \nL 2766 2266 \nQ 2766 2663 2505 2880 \nQ 2244 3097 1772 3097 \nQ 1472 3097 1187 3025 \nQ 903 2953 641 2809 \nL 641 3341 \nQ 956 3463 1253 3523 \nQ 1550 3584 1831 3584 \nQ 2591 3584 2966 3190 \nQ 3341 2797 3341 1997 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6d\" d=\"M 3328 2828 \nQ 3544 3216 3844 3400 \nQ 4144 3584 4550 3584 \nQ 5097 3584 5394 3201 \nQ 5691 2819 5691 2113 \nL 5691 0 \nL 5113 0 \nL 5113 2094 \nQ 5113 2597 4934 2840 \nQ 4756 3084 4391 3084 \nQ 3944 3084 3684 2787 \nQ 3425 2491 3425 1978 \nL 3425 0 \nL 2847 0 \nL 2847 2094 \nQ 2847 2600 2669 2842 \nQ 2491 3084 2119 3084 \nQ 1678 3084 1418 2786 \nQ 1159 2488 1159 1978 \nL 1159 0 \nL 581 0 \nL 581 3500 \nL 1159 3500 \nL 1159 2956 \nQ 1356 3278 1631 3431 \nQ 1906 3584 2284 3584 \nQ 2666 3584 2933 3390 \nQ 3200 3197 3328 2828 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \nL 1178 4863 \nL 1178 0 \nL 603 0 \nL 603 4863 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \nQ 3116 2381 2855 2742 \nQ 2594 3103 2138 3103 \nQ 1681 3103 1420 2742 \nQ 1159 2381 1159 1747 \nQ 1159 1113 1420 752 \nQ 1681 391 2138 391 \nQ 2594 391 2855 752 \nQ 3116 1113 3116 1747 \nz\nM 1159 2969 \nQ 1341 3281 1617 3432 \nQ 1894 3584 2278 3584 \nQ 2916 3584 3314 3078 \nQ 3713 2572 3713 1747 \nQ 3713 922 3314 415 \nQ 2916 -91 2278 -91 \nQ 1894 -91 1617 61 \nQ 1341 213 1159 525 \nL 1159 0 \nL 581 0 \nL 581 4863 \nL 1159 4863 \nL 1159 2969 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-6a\" d=\"M 603 3500 \nL 1178 3500 \nL 1178 -63 \nQ 1178 -731 923 -1031 \nQ 669 -1331 103 -1331 \nL -116 -1331 \nL -116 -844 \nL 38 -844 \nQ 366 -844 484 -692 \nQ 603 -541 603 -63 \nL 603 3500 \nz\nM 603 4863 \nL 1178 4863 \nL 1178 4134 \nL 603 4134 \nL 603 4863 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-41\"/>\n      <use xlink:href=\"#DejaVuSans-76\" x=\"62.533203\"/>\n      <use xlink:href=\"#DejaVuSans-67\" x=\"121.712891\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"185.189453\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"216.976562\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"248.763672\"/>\n      <use xlink:href=\"#DejaVuSans-61\" x=\"300.863281\"/>\n      <use xlink:href=\"#DejaVuSans-6d\" x=\"362.142578\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"459.554688\"/>\n      <use xlink:href=\"#DejaVuSans-6c\" x=\"523.03125\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"550.814453\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"612.337891\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"644.125\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"705.306641\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"768.783203\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"796.566406\"/>\n     </g>\n    </g>\n    <g id=\"line2d_25\">\n     <path d=\"M 108.30625 34.976563 \nL 118.30625 34.976563 \nL 128.30625 34.976563 \n\" style=\"fill: none; stroke-dasharray: 5.55,2.4; stroke-dashoffset: 0; stroke: #bf00bf; stroke-width: 1.5\"/>\n    </g>\n    <g id=\"text_13\">\n     <!-- Best sample obj. -->\n     <g transform=\"translate(136.30625 38.476563)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-42\" d=\"M 1259 2228 \nL 1259 519 \nL 2272 519 \nQ 2781 519 3026 730 \nQ 3272 941 3272 1375 \nQ 3272 1813 3026 2020 \nQ 2781 2228 2272 2228 \nL 1259 2228 \nz\nM 1259 4147 \nL 1259 2741 \nL 2194 2741 \nQ 2656 2741 2882 2914 \nQ 3109 3088 3109 3444 \nQ 3109 3797 2882 3972 \nQ 2656 4147 2194 4147 \nL 1259 4147 \nz\nM 628 4666 \nL 2241 4666 \nQ 2963 4666 3353 4366 \nQ 3744 4066 3744 3513 \nQ 3744 3084 3544 2831 \nQ 3344 2578 2956 2516 \nQ 3422 2416 3680 2098 \nQ 3938 1781 3938 1306 \nQ 3938 681 3513 340 \nQ 3088 0 2303 0 \nL 628 0 \nL 628 4666 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-74\" d=\"M 1172 4494 \nL 1172 3500 \nL 2356 3500 \nL 2356 3053 \nL 1172 3053 \nL 1172 1153 \nQ 1172 725 1289 603 \nQ 1406 481 1766 481 \nL 2356 481 \nL 2356 0 \nL 1766 0 \nQ 1100 0 847 248 \nQ 594 497 594 1153 \nL 594 3053 \nL 172 3053 \nL 172 3500 \nL 594 3500 \nL 594 4494 \nL 1172 4494 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-42\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"68.603516\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"130.126953\"/>\n      <use xlink:href=\"#DejaVuSans-74\" x=\"182.226562\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"221.435547\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"253.222656\"/>\n      <use xlink:href=\"#DejaVuSans-61\" x=\"305.322266\"/>\n      <use xlink:href=\"#DejaVuSans-6d\" x=\"366.601562\"/>\n      <use xlink:href=\"#DejaVuSans-70\" x=\"464.013672\"/>\n      <use xlink:href=\"#DejaVuSans-6c\" x=\"527.490234\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"555.273438\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"616.796875\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"648.583984\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"709.765625\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"773.242188\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"801.025391\"/>\n     </g>\n    </g>\n    <g id=\"line2d_26\">\n     <path d=\"M 108.30625 49.654688 \nL 118.30625 49.654688 \nL 128.30625 49.654688 \n\" style=\"fill: none; stroke-dasharray: 9.6,2.4,1.5,2.4; stroke-dashoffset: 0; stroke: #008000; stroke-width: 1.5\"/>\n    </g>\n    <g id=\"text_14\">\n     <!-- Best ACO obj. -->\n     <g transform=\"translate(136.30625 53.154688)scale(0.1 -0.1)\">\n      <defs>\n       <path id=\"DejaVuSans-43\" d=\"M 4122 4306 \nL 4122 3641 \nQ 3803 3938 3442 4084 \nQ 3081 4231 2675 4231 \nQ 1875 4231 1450 3742 \nQ 1025 3253 1025 2328 \nQ 1025 1406 1450 917 \nQ 1875 428 2675 428 \nQ 3081 428 3442 575 \nQ 3803 722 4122 1019 \nL 4122 359 \nQ 3791 134 3420 21 \nQ 3050 -91 2638 -91 \nQ 1578 -91 968 557 \nQ 359 1206 359 2328 \nQ 359 3453 968 4101 \nQ 1578 4750 2638 4750 \nQ 3056 4750 3426 4639 \nQ 3797 4528 4122 4306 \nz\n\" transform=\"scale(0.015625)\"/>\n       <path id=\"DejaVuSans-4f\" d=\"M 2522 4238 \nQ 1834 4238 1429 3725 \nQ 1025 3213 1025 2328 \nQ 1025 1447 1429 934 \nQ 1834 422 2522 422 \nQ 3209 422 3611 934 \nQ 4013 1447 4013 2328 \nQ 4013 3213 3611 3725 \nQ 3209 4238 2522 4238 \nz\nM 2522 4750 \nQ 3503 4750 4090 4092 \nQ 4678 3434 4678 2328 \nQ 4678 1225 4090 567 \nQ 3503 -91 2522 -91 \nQ 1538 -91 948 565 \nQ 359 1222 359 2328 \nQ 359 3434 948 4092 \nQ 1538 4750 2522 4750 \nz\n\" transform=\"scale(0.015625)\"/>\n      </defs>\n      <use xlink:href=\"#DejaVuSans-42\"/>\n      <use xlink:href=\"#DejaVuSans-65\" x=\"68.603516\"/>\n      <use xlink:href=\"#DejaVuSans-73\" x=\"130.126953\"/>\n      <use xlink:href=\"#DejaVuSans-74\" x=\"182.226562\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"221.435547\"/>\n      <use xlink:href=\"#DejaVuSans-41\" x=\"253.222656\"/>\n      <use xlink:href=\"#DejaVuSans-43\" x=\"319.880859\"/>\n      <use xlink:href=\"#DejaVuSans-4f\" x=\"389.705078\"/>\n      <use xlink:href=\"#DejaVuSans-20\" x=\"468.416016\"/>\n      <use xlink:href=\"#DejaVuSans-6f\" x=\"500.203125\"/>\n      <use xlink:href=\"#DejaVuSans-62\" x=\"561.384766\"/>\n      <use xlink:href=\"#DejaVuSans-6a\" x=\"624.861328\"/>\n      <use xlink:href=\"#DejaVuSans-2e\" x=\"652.644531\"/>\n     </g>\n    </g>\n   </g>\n  </g>\n </g>\n <defs>\n  <clipPath id=\"pcbffed24ed\">\n   <rect x=\"33.2875\" y=\"7.2\" width=\"195.3\" height=\"138.6\"/>\n  </clipPath>\n </defs>\n</svg>\n",
      "text/plain": [
       "<Figure size 350x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# j120\n",
    "n_node, n_ants = 120, 20\n",
    "steps_per_epoch = 32\n",
    "epochs = 100\n",
    "train(n_node, n_ants, steps_per_epoch, epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch",
   "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.9.13 (main, Oct 13 2022, 21:15:33) \n[GCC 11.2.0]"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "a93e3d9460341b3566123144586be69108c80018542c7977bec35f4a26a80b82"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
