{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "034835bc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABTYAAAETCAYAAAAMBFmuAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAA/3lJREFUeJzs3Xd8FGX+wPHPzPbd9E4CJBB67yBFmooVC4piOTh71/P8We5U9Kx3enr23j0Vu2A9UZrSe28hBEJI72XrzO+PIUM2m0ASQrJJnvfrFWVmZ2af2dnvzsx3niKpqqoiCIIgCIIgCIIgCIIgCILQhsitXQBBEARBEARBEARBEARBEITGEolNQRAEQRAEQRAEQRAEQRDaHJHYFARBEARBEARBEARBEAShzRGJTUEQBEEQBEEQBEEQBEEQ2hyR2BQEQRAEQRAEQRAEQRAEoc0RiU1BEARBEARBEARBEARBENockdgUBEEQBEEQBEEQBEEQBKHNMbZ2AQThZPN4PHg8ntYuhiAIgiAIgiAIgiC0KJPJhMlkau1iCMJJIxKbQrtVUVHB4cOHKSsra+2iCIIgCIIgCIIgCEKrCA0NpVOnTjgcjtYuiiA0O0lVVbW1CyEIzc3lcrFr1y7MZjNxcXFYrdbWLpIgCIIgCIIgCIIgtCin00lubi5ut5vevXtjsVhau0iC0KxEYlNol9LT06msrKRPnz4YDIbWLo4gCIIgCIIgCIIgtAqfz8fOnTux2+1069attYsjCM1KDB4ktDuqqlJWVkZUVJRIagqCIAiCIAiCIAgdmsFgICoqirKyMkTdNqG9EYlNod1xu934fD7Rf4ggCIIgCIIgCIIgAA6HA5/Ph9vtbu2iCEKzEolNod3x+XwAGI1ibCxBEARBEARBEARBqL4/rr5fFoT2QiQ2BUEQBEEQBEEQBEEQBEFoc0RiUxAEQRAEQRAEQRAEQRCENkckNgWhg5EkqcF/33zzTb3bKSoq4vnnn+eCCy6gW7duhIWFYTQaCQ8Pp0+fPpx//vn885//ZOfOnQHrzpkzJ+C95s2bF7Dc/v37/ZZJSUlp0D4uXry4UftZ82/SpEkN/CRPzKRJk/zed//+/S3yvkJw6QjxmJ2djclk0teTZZmMjIxjrjNr1iy/97r77rsb9F71efjhh/229957753Q9oTW0xFipilqf8eP9TdkyJBjbuuXX37hxhtvZNCgQcTExGAymQgNDaVfv35cddVVfPrppzidznrXz8vLw2w2B7zvd99916R9S0lJafI5vSXOre+9957fez788MMn/T2F4CR+n+rWnn+fzj33XL/t/OMf/zjm8j///LPf8p06dcLr9TbpvSHwOLbUfYwgBBuR2BQEoVFUVeXpp5+mS5cu3HnnnXz77bfs37+fsrIyfD4fpaWl7Nq1i/nz53PffffRt29f9u3bd9ztPvjggyd0YheEjqgtxGNCQgLTpk3zK/NHH31U7/JlZWV8++23fvPmzJnTLGURhLYQM61l586djBw5kjPOOIPXX3+dLVu2UFBQgNfrpby8nB07dvDRRx8xa9Ys/va3v9W7nY8++giPxxMwXzxQEIRjE79P9QvW36fa1yfHur4B+PDDD/2mr7jiCjEuhCA0AxFFgtDBnXXWWdjt9jpfS0pK8ptWVZXLL7+cTz/91G++wWBg0KBBdO7cGbfbTUZGBrt370ZRFAD9/8eyZ88e3n33Xa677rom7slRsbGxzJgxI2D+jz/+SGVlpT596qmnEhsb67dM//79T/j9G2LixInExMTo0w6Ho0XeVwhu7TEeQbvw//777/XpDz/8kL///e91LvvFF19QVVWlTw8fPpwBAwY0SzmE9qe9xsyJSk5OZsSIEXW+1q1bt4B5q1atYurUqVRUVPjN7969O3369EFRFNLS0tizZw9w7M/k/fffr3P+ggULKCwsJCoqqqG7AcDZZ59Nbm6u37zt27ezY8cOfbq+/W2Jc2tKSorfNUe/fv1O+nsKbYP4fapbe/p9mj59OlFRURQWFgLaZ71y5UrGjBkTsGx5eTlff/213zzx4FYQmokqCO1MRUWFun79erWioqK1ixKUAL+/9PT0Bq/76KOPBqx/xRVXqFlZWQHLFhQUqG+88Ybar18/dc+ePX6vzZ49O2A7gJqUlKRWVVXpy6Wnp/u9npyc3NTdVlVVVZOTk/22t2jRohPaniCcqI4Sjy6XS42OjvZbf/Xq1XUuO3nyZL/lXnzxxQa/T33mzp3rt8133333hLcptI6OEDM115s7d26D1qn9HZ89e3aD1lNVbV9jY2MD9uXXX38NWHbfvn3q7bffrt599911bmv9+vV+2zGZTM0ez6p6YvsrCCeL+H2qW3v/fbr11lv9tnPzzTfXudz777/vt9zw4cOb9H411T6OEydOPOby4j5ZaK9EU3RBEBokLy+Pp556ym/eVVddxUcffUSnTp0Clo+KiuK6665jy5YtDe6359ChQ7z00kvNUdwmq6vvyy+//JJJkyYRERGBJEksXrwYgN9//52//OUvTJ48mdTUVCIjI/U+kAYOHMhNN93Epk2bGvw+1erqL8flcvHMM88wePBgbDYb4eHhnHnmmaxcubIFPhUh2LS1eDSbzcyaNctvXu3mWAAHDx7U46t6vcsvvxzQ4uLBBx/kvPPOo3fv3sTFxWE2mwkJCSE1NZWZM2c2uY8sof1razHTkp566iny8vL0abvdzsKFC5kyZUrAst26deP555/nscceq3NbtZtz1u5vsiWbo9fV92V6ejpz5swhKSkJo9Go15YqKCjg0UcfZcaMGfTv35+EhAQsFgt2u52uXbsyffp0/vvf/9ZZE+x4fWzWdb7/7bffOOecc4iKisJqtdK/f3+ee+45VFVtgU9GCDbi96l+beH3qXaty3nz5tXZ3L32dU/N9V588UVmz57NsGHD6Ny5Mw6HA4vFQnx8PBMnTuRf//oXZWVlTSqfIHQEoim60KFUeepvmiBLEhaj1KBlJUnC2sRlnR4VlbovXCUkrCb/ZWtOt6Zvv/3WrwmIyWTiX//613HXk2UZWT72M5SJEyeyZMkSQLuAuf766wkLCzuxAjeThx56qM4EDMCnn37Kyy+/HDC/tLSUrVu3snXrVt58803eeOMNrr766iaXoaCggLFjx7J+/Xp9ntPp5Oeff2bx4sUsWbKE0aNHN3n7rUFVVZzetnkDZzVqN6etqS3G45w5c/xuqj799FOeffZZv76l/vvf//rd2J933nl6s7C1a9fWebPi8XjYt28f+/bt4/PPP+fqq6/m7bffPuHyBivVdYx+0mQJyWRo2LKShGRu4rJuL/WcxkACyRx8l5dtMWZayieffOI3fe2119KnT59jrmOxWALmeTwePv74Y33a4XBw5513Mn/+fFatWgXAunXr2Lp1a6t0L7Fhwwaee+45SktLA15LT0/noYceqnO9gwcPcvDgQRYsWMCHH37IggULMJlMTS7H3Llz+eCDD/zmbd++nbvuuouMjAz+85//NHnbrUVVVXD7WrsYTWM2iHN6EGsLv0/Dhw9n4MCBbNmyBdCu23/44QfOP/98fZlDhw7x22+/6dM1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id+nurXX36c5c+bo1zeg1dK84YYbAmpr1n5wu3PnTiZOnEhubm6D3qc9X+MIQlOJM5AgCA0yduxY3n33XX163bp15OfnExNztFZpdZ89ixcvZvLkyY1+jylTpnD66afzyy+/4Ha7mTt37okX/AQlJibWOf/LL78MSGoOHDiQbt26YTKZAi48T2Sk0+jo6IB59d2cCR1DW47Hui78ExMT/S7ohw8f7te0/PDhw9x7771+2+nSpQsDBw7EZrMBWkxWEyMLC7UFa8xMnDjRrwwAlZWVeu2ivn370q9fv4D1HA5Ho8tXl65du9K5c2e/fux++OGHgNpEx/P+++/7TX/++ef88MMP+nTtEYIXLFhAYWFhQB9zJ1N953O3281NN93kl/iIjY1l2LBhenPPH3/8kcrKuvuVbaza53RxPhfE71Pd2trv07nnnkt0dLTeJ+Yff/zBnj17/AYtgsAHt3fffbffNZDNZmP06NFERUUhSRJr1671a7ovrnEEIZBIbAqC0CDTp0/njjvu0C/s3W43Dz30kF/n583hiSeeYOHChaiqeszmLy2lvtEmly1b5jf9z3/+k3vuuUef/uSTT5r0RF0QGqItx+N5551HTEyM3on/smXL8Pn8B7ipfdG/cuVKv6TDOeecw4IFC/SuPg4fPuyX2BSE2oI1Zupqxrl//366desGwMyZM3n44YebtYy1zZo1i6efflqffvvtt7n55puPWSvK5XLpzbjXrVvn18wSoLi4mOLi4nrXd7vdfPzxx3pf1C2hvvP5tm3bKCws1KeHDBnCypUr9f3zer119qUtCM1F/D7Vry39PpnNZq644gpeeOEFfd4111xDdna2Pl37wS3431NYLBZ27txJ165d9XnTpk2rt09SQRA0DW8/KwhChxYXF8f//d//+c179dVXufXWW495cdBYI0aMYMaMGc22vZOl9tPdmqNeZmdn89hjj7V0kYQOpC3Ho8lk0jvtB63mQc0BEcxms9/rEBhvVqtVT2q6XK4GN1EXOq62HDMn23333Uds7NG+wisrKznttNP47bffApZNT0/n9ttv54EHHtDnNaRJaV2aul5zq/37Yjab9WaqiqJw//33N1ttTUGoi/h9ql9b+32q/WC2dkWI2q+D/2+QLMt6SxSAr7/+moULFzapLILQkYgam4LQwd18881+SbmaZs6cycyZM/Xp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85//5MCBA03e37p+c8xmM9nZ2XUu73Q6iY2NDVhnzpw5TS5De9be4k9RFJYuXcoTTzzBOeecQ//+/YmNjcVkMhEZGcno0aOZO3cuOTk5TSr7pEmT6v18zGYz8fHxTJ06lRdeeIGKiopjbsvn8/HVV18xZ84c+vbtS2RkJEajkfDwcAYPHsx1113HggUL8Pl89W5j+/bt3HvvvYwbN46EhAQsFgt2u51u3boxffp0XnzxRfLy8pq0r1D3701cXBwul6vO5Q8fPozZbA5Y5+GHH25yGYRA7S1ua2qpa9fmPI9s3bqVm266if79+xMaGorJZCI2NpbevXtz+umnc9ddd9X5edV3jVnXX0RERJP2XWh+7TH+Wvq6tTnPI8uXL2f27Nn07NlTvw9MSEigb9++nH322dx77718/fXXAesd65629t+QIUOavP9C82tvMdga166DBg2qd/l169bV+VnWt88//vgjM2fOJCUlBZvNhtVqJTExkQEDBnDBBRfw4IMP8uuvvx73MznW3wUXXNCkfW8UtY0DGvz39ddfN8t7zp0712+77777bqPWnz17tt/6ixYtCljm1VdfVY1GY7374nA41O++++6Ey36sv5CQEPWLL76oczuHDh1SzzjjjAZt58ILLwxY3+fzqY899phqtVobtI3i4uJG76uqquq7775b5/b+9Kc/1bn8woUL61x+4sSJTXr/jqA9xmB935umvt+x3vtYf7GxseqyZcvq3M6OHTvUESNGNGg7f/nLXwLWdzqd6u23337M35nqv8jIyCbvb32/OQ899FCdy7/11lt1Lj979uwml6E9a2/xl5eX16B9iYiIUBcuXNjosk+cOLHBn1e3bt3UHTt21Lmd5cuXqz169GjQdp5//vmA9YuLi9VZs2apkiQdd/2hQ4c2ej+r1fd7884779S5/AMPPFDn8nPnzm1yGYRA7S1uq7X0tWtznEdeeeWVBp0HDQZDwLrHu1ao+RceHt7o/RZOjvYYf61x3doc55H777+/QcchNTU1YN3G3NMOHjy4yfsvNL/2FoOtde3622+/1bn8lVde2aDfAa/Xq1511VUNKvvUqVOP+5kc6+/8889v9H43lpF25qyzzsJut9f5WlJSUguXpmm+//57brrpJn3aZDJx6qmn4nK5+OOPP1BVlYqKCi666CLWrl3LwIEDm/xeycnJjBgxAoDc3FxWrVqF2+0GoLy8nFmzZrF582b69Omjr5OWlsa4ceMCnjokJiYycOBADAYDBw4cYPv27SiKgqIofsspisJll13G559/7jffarUyYsQIoqKiKCwsZOPGjZSXlwOgqmqT97Eu8+bN4+mnnyYuLs5v/vPPP9+s79MRtYcYrMlkMmGxWPTvYnPr27cv/fr1AyAzM5PVq1fr3/e8vDymT5/Onj17iI6O1tdZtWoVU6dODahR1r17d/r06YOiKKSlpbFnzx6AgBh0Op2cfvrp/P77737zQ0NDGTFiBCEhIeTm5rJp0yacTmfA+s3h9ddf5+9//ztms9lvvojBE9Oe4k+WZQYPHkxiYiLp6els375df624uJgZM2awe/fugN/xxhgxYgTJycmoqsq+ffvYuHGj/lp6ejrnnXce27Zt8/uefvPNN1xyySV4vV6/bfXt25fU1FRcLhe7du3SazrXjp+CggLGjRvHrl27/OZHR0czbNgwLBYLWVlZbN68Ga/Xe1Li78UXX+TPf/6z3zyXy8Xrr7/e7O8lHF97iNuWvHatdqLnkQ0bNnDrrbf6xVj//v1JTk4GtHPyzp079evi44mJiWHixIl1vuZwOBq0DaHltYf4q+lkX7dWO9HzyPz583nyySf1aUmSGDp0KElJSXg8Hvbv38+ePXuO2eqhppr3tLV169atQdsQWkd7isGWuHat9sILLzB58mS/ednZ2Xz22WcNWv/ll1/mww8/1KeNRqPeCtfpdJKWlsa+ffsanIepeU9b26hRoxq0jRPR7hKbr7zyCikpKa1djCZTFIXbbrtNn5ZlmV9++UW/UProo4+46qqrAHC73dx55511Vg1uqEmTJvlVS960aROnnHIKVVVVAHg8Hl544QVeeeUVffrcc8/1S2qGhYXx1ltvcckll/htOzs7m1dffZW9e/f6zX/iiScCkpo33ngjTz31FOHh4fo8r9fLN998w9y5c5u8f/WpPvE++OCD+ry0tDS+//77Zn+vjqatxyBoNzYvvfQSI0eOZPDgwdxwww28//77J+W9Zs6c6dc856effuLss8/WTyJFRUW8/fbb3HPPPQAUFhZy3nnn+SU1k5KS+OCDD5gyZYrfttPT0/nPf/6DyWTym3/rrbf6JTUlSeKhhx7ivvvuw2q16vOrqqr45JNP+M9//tNcu6vLyclh3rx5+u8ZwKJFi9iyZUuzv1dH0h7iLyIigr/+9a9cf/31fhd+77//vl9T0pKSEj755BPuuOOOJr/XLbfc4rfNN954gxtuuEGf3rt3L9988w0zZ84EYPfu3Vx++eV+Sc1+/frx4YcfMmzYML9tb9myhaeffhpZ9u/159JLL/VLaprNZp577jluuOEGDAaDPr+4uJh3332X7777rsn7V58NGzawbNkyJkyYoM/7+OOPT6jZu9B0bT1uW/ratdqJnkfee+89v6Tm559/zsUXX+y3TGVlJb/++iv//e9/j7u9/v3788UXXzSw9EKwaOvxBy173VrtRM8jb7/9tv5vSZJYuXJlQPKjuLiYn3/+mUWLFh13e7XvaYW2oz3EYEteu1ZbsGABGRkZ+sM4gFdffbXBD+NqxmBYWBjr168nNTXVb5nc3Fy+++67gHxOXWrf07a0Nt/H5olQFIWvvvqKGTNm0LVrV2w2G3a7ne7du3P55ZezcOHCJm/74MGDXHPNNXqfdT169OD+++8/7tOzRYsWkZ6erk9PnDjR7+nvlVde6Rf4v/32G/v27WtyOWsbPHhwQIJy9erV+r/ffPNNdu7cqU/Lssz8+fMD1gFISEjgkUce4Z133tHn5eXl8dRTT/ktd/XVV/Pqq6/6JTVBe2pw8cUXs2nTJsLCwk5ov6rVfOrz2muv4fF49OkXX3xRv8Bta0+H2qpgjEGAkSNHcssttzBq1CgsFkuTy9AUZ555pt9FIvjH4FNPPeV30Wi321m4cGFAUhO0J9TPP/88jz32mD5v69atvPvuu37LPfLIIzz88MN+SU0Am83G1VdfzZo1a05on2qqGVsvvPCC32s1a9mIGDz5gjH+wsLC2LNnDw888EDA0+zZs2czbtw4v3k1z0fN4frrr6dr165+82rG3wMPPKA/+APtPLd48eKApCZo/TV/8MEHfonSH374ISCh89Zbb3HzzTf7JTVBu0j+y1/+wg8//HBC+1STiL+2LxjjtqWvXZvre7x7926/6alTpwYsY7fbOe+88/j000+bUlShnQnG+IOWvW49GfEXHh7OyJEjA5aJiIjg0ksv5bXXXmtqcYV2JhhjsKWvXatjy+fz8dJLL+nzXS6XX6w0JgZTUlICkpoAcXFxXH311TzxxBMnVOaW0GETm0VFRZx22mnMmDGDr776ioMHD+J0OqmqqiI9PZ1PPvmE008/ncsuu6zBWe9qW7ZsYdiwYbzzzjscPnwYl8tFWloaTz31FKNHjz7mk6ylS5f6TddVbbf2vGXLljWqfMcTHx/vN11z8J9PPvnE77Vzzz233mY31WqeYOfPn+9X08xkMh03UIxGY0CNl6aaOnUqvXr1AiArK0uvOVpaWuqXgL355pub5f2E+gVrDAaDxsTgtdde69dVRF1qxuC8efP8aqjExsbqtUEbsv6JmjVrlj6Iwtq1a1m+fDkA+/btY8GCBQAYDAauv/76ZntPIVCwxp/ZbCYmJqbe1zt16uQ3XfuBWHOoL/4qKyuZP3++32v33HMPsbGxx9xezfipHb+DBg3yq212vPVP1HXXXacnUL/++mt9kMDFixezadMmQLuRnDVrVrO9p9B8gjVuW/ratbnOI7WbsF900UUsWLCA4uLiJpdNaL+CNf5aWnOdR2rGX3FxMRdffDELFy487sB9QscVrDHY0teuNbt9eeutt6isrAS0a8zc3FwAevXqVefDuppqxuDmzZu54YYb+P333+sdGCzYtbum6DfffHOdfTTExcXpzakBLrnkEr9q7VarlVGjRuF2u1m7dq3ezGzevHmEhoby5ptvNuj9vV4vM2fOJD8/X59nt9sZPXo0JSUlrF+/3q+vhdpqZ/DryrTXntfcNVZqjxheHYyKorBy5Uq/184+++xGbfuPP/7wmx4+fHjATeTJJEkSt912m95k6oUXXuDyyy/n3Xff1W9eR4wYwdixY1usTO1NW4/B1qYoil8/f3A0Bg8cOEBmZqbfaycag1OnTm3RWqkOh4NrrrmGf//734AWg2PHjvWrMX3hhRcG1JoTGqY9x19FRUXASLB11VQ+EeXl5QG1uKrjb+3atQEXeycaf41d/0QlJydzwQUX8OWXX+Lz+Xj55Zd56qmn/GrZXHvttaI/wBbW1uO2pa9dm+s8MmHCBL+HFYsXL9Z/Y7p168bo0aOZOnUqM2bMIDIy8rjl2rZtW0BT9mozZ87Uu7QQgktbj7+W1lznkQkTJrB582Z9+quvvuKrr75ClmV69uzJmDFjOOOMMzj//PMbdE5avHhxvfF36623MmnSpIbtoNDi2nMMnoxr13HjxjF8+HDWrVtHcXExH3zwATfeeKNfDN5+++3HbXE3YcIEv2743njjDd544w2MRiP9+vXjlFNO4ayzzuKss84KeBBYl88++4ytW7fW+dojjzxC//79G7iHTXTShyc6yWjgSEzJycn6Oj/99JPfa5GRkeq2bdv01xctWqQaDAb9dUmS/EZGPdaoWl988YXfa9HR0equXbv011977bWAstUcVav2SONvv/12wD7XHm3uhhtuaPDnVbvsNUeIzM3NVf/xj38ElO+pp57SX6/92k8//dTg91ZVVT377LP91r/ssssatX5j1R4lcPbs2WpZWZkaHh6uz1uxYoWampqqT3/44YfqokWL/NYTo6LXr73FYF1qj/rWnKNL1hwlMjMzU73xxhsDyvfpp5+qqqqqq1evDnht586djXr/fv36+a1/3333NXlfGqL2sZo7d66anp6uyrKsAqrRaFR37typhoWF6cssW7asztgVAnWE+FNVVfX5fOqsWbP81hs/fryqKEqjPq/aI0tWl11RFHXv3r3qhRdeGFC+lStXqqqqqp999lnAa06ns1Hvb7fb/dZ/7bXXGrV+Y9X127V06VK/47Nt2zY9Hg0Gg7p///4641ZoPu0tblv62rW5ziNlZWUB58S6/kJCQtRnnnkmoFyNGRVdxFDwaG/xV5eTed3aXOeRzMxMtVOnTsc9DjExMeqHH34YUK7GjIp+IvsvNL+OEIOqevKuXRctWqR+8MEH+nS/fv3UxYsX69Ph4eFqWVnZcX8HNm3apIaEhBz3OHTt2lX9+eefA8rVmFHRG/J5nagO2RS9dlOy66+/3m8Ep0mTJnHRRRfp06qqNrjz/l9++cVv+rrrrtObPle/V8+ePRtcVrWOUajqmtdU77//PpIkIUkScXFxPPTQQ36v9+jRg1tuuaVR5WuM5tyXhgoJCeHqq6/Wp6+88krS0tIArb808UT95GtLMXiyPfLII3oMdu7cOaAfobFjx9bZh221thiDKSkpnH/++YD2lPScc86htLQUgGHDhjF+/PgWL1NH0tbiz+12c8UVV/g14+7ZsydffvklkiQ1alu1/fnPf0aSJGRZpkePHnz99dd+r1922WWMHj263vXbYvxNmDCBoUOHAtoI7dOnT9druZ1//vl+ndALwaMtxe3JvnaF5jmPhISE8Pvvv3PDDTcE9DFdU3l5OXfffXeDR3sW2p+2FH8toTnOI0lJSaxevZqZM2diNNbfiDQ/P58//elP/PTTT81TeKFNamsxeDKvXUEbiLK61ev27du55ppr9NeuueYaQkJCjruNQYMGsWrVKqZNm3bMMh04cIDzzjvPr4Z1MGp3ic309HRUVQ34279/v75MzX+D1sF/bYMHDw7YbkNkZGQcc9uSJB2zGm51n0HVqvtMqKl23yMNaR7TFJMnT+a3337TAyM6OjrgxFP7szye2s3OG7t+c7n11lv1fjurk5qg9VnRkKrWQv3aegwGk4svvpjvvvtO/67W1W1DW43BmqMB1ozB5hglsCNrb/FXUlLCtGnT/AbuGDhwIEuWLAnooL05ybLMTTfd5DfCqog/4WRp63HbWteuzfE9joyM5LXXXiM7O5uvvvqKu+66izFjxtSZaKlu+l6fiRMn1nkcVVVt1ZFihWNr6/HXWpoj/jp37sy8efPIysrik08+4ZZbbmHIkCEBSRZVVXn22WePua3Zs2fXG381R6UWgk97i8GWuHY1m81+fW1Wx6Asy9x6660N3k6/fv346aefyMjI4N133+Xaa6+lb9++Acu53W6/gYrqMnfu3HpjsCW6gmh3ic2GqP3UuDmy5s2l9iAgtfvTAzh06NAx12mM5ORkZsyYwYwZM5g5cybXXnst//znP1m3bh2//fYbXbp00ZeVZZkxY8b4rd/Y0Vprjwq2fv16cnJymlz+purevTvnnnuu3zyz2ew3eq1w8gRzDLa0vn376jF46aWXcv311/Pcc8+xc+dOPv/8c7+bv65du9K5c2e/9U80Bn/99ddW6SR64sSJARcgcXFxXHbZZS1elo6mrcRfZmYm48eP9+ubaOrUqSxbtiygI/amGjFihB5/s2bN4uabb+aVV14hIyODV155xa//2eHDhwf0R3ui8decI543xmWXXRZwcT1kyBBOPfXUVimPcHzBHLctfe1arTnPI+Hh4Vx44YX8+9//ZsWKFeTl5QXcHO7Zs0fvw03oWII5/lpLc55HYmNjueyyy3jppZfYsGEDWVlZAf1l7tix44TKK7RtbSUGW+LatdqNN94YUCHrvPPOo1u3bo3eVpcuXZgzZw5vvvkm27dvZ+/evQEDRAd7DHbIxGbtg71ly5aAZWpXtW3oF6R2R+V1daB6rM5na58MVq1aFbDM6tWr/aYnTJjQoLLVZdKkSXzxxRd88cUXzJs3jzfffJN77rmHYcOG1bl87RHuvv/+e5YsWXLM96iZNJk+fbpfB9Aej4e//e1vx1zf6/X6jeLcXGo/UbzssstadCCjjiyYY7ClzZw5U4/BTz/9lNdff50777yT3r1717l87Rh8++23jzsIQ80YvPTSS/UaoKA18fnXv/7V4PWb0+233+43XdcJWmh+bSH+tm7dyimnnOK3/uzZs/nxxx+bdST0W265RY+/jz/+mJdffpmbbrop4AECaAOWTJ8+3W/e008/fdzRamvGT+343bJlCx9++GGD128uFosl4EFe7XgUgkswx21LX7vWdCLnkaysrHpfi4iI4PHHH/ebZzAY9NGghY4lmOOvtZzoeeRY8ZeQkMCDDz7oN89kMjWugEK70hZisKWuXavFx8dz6aWX+s1rTI3pY8Vgamoqd911l9+8YI/BDpnYrF1T74033vBLDCxbtoyvvvpKn5YkiXPOOadB2z7ttNP8pt9880327t2rT7/11lsBI67WNHnyZL8gXLp0qd/oX++//75fdekpU6bQvXv3BpWtOVx33XV+T9kVReH888/niy++CFg2Ozubhx56yK8/y9jYWO69916/5d555x1uvvlmSkpK/OZ7vV4+//xzBg0apPeb1JymTJnCKaecQnR0NNHR0aIJXgsK5hgMdvfddx+xsbH6dGVlJaeddhq//fZbwLLp6encfvvtPPDAA/q8AQMGBDTJmTt3Lo888ghOp9NvflVVFW+//TYjR45s3p044vLLL6dHjx5ER0cTHx/v16RCOHmCPf4WL17M+PHj/Wp9Pfzww7z33nutflH12GOP+fXFl52dzeTJk9mwYUPAslu2bOGqq67y65fv7LPPDhgN89prr+XVV1/F5/P5zS8uLubZZ589aSOn33TTTcTHxxMdHU2PHj0Ckq5CcAnmuG3Na9cTOY889NBDjBo1irfeeovCwsKA1z/77DO/6b59+wZtLSHh5Arm+GtNJ3IemT17Nqeddhqffvop5eXlfq+pqsrnn3/uNy8Ym+MLLSfYY7C1rl3vuOMOPZcxduxYJk+e3OB1J0+ezEUXXcSCBQsCHqL7fD6+/PJLv3nBHoP199Tbjp111llMmjRJryJcWFjIsGHDGDlyJB6PhzVr1vg1NZkzZ06dfQ3U5cILL6RXr176lz8/P58hQ4YwevRoSkpKWLdu3THXl2WZF154gfPOOw/QftinTZvGqaeeisvl4o8//tCXNZvN/Oc//2nEnp84k8nEggULGD9+vN6EvKSkhEsu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",
      "text/plain": [
       "<Figure size 1400x300 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#!/usr/bin/env python3\n",
    "# -*- coding: utf-8 -*-\n",
    "\n",
    "from pathlib import Path\n",
    "from typing import Optional\n",
    "import re\n",
    "import os\n",
    "import datetime\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import font_manager as fm\n",
    "\n",
    "\n",
    "matplotlib.rcParams.update({\n",
    "    \"axes.titlesize\": 16,\n",
    "    \"axes.labelsize\": 16,\n",
    "    \"xtick.labelsize\": 16,\n",
    "    \"ytick.labelsize\": 16,\n",
    "    \"legend.fontsize\": 16,\n",
    "    \"lines.linewidth\": 6,   \n",
    "    \"savefig.bbox\": \"tight\",\n",
    "    \"font.weight\": \"bold\",\n",
    "    \"axes.labelweight\": \"bold\",\n",
    "    \"axes.titleweight\": \"bold\",\n",
    "})\n",
    "\n",
    "STANDARD_COLOR = \"#3494E6\"  # EGN\n",
    "ECA_COLOR      = \"#EC6EAD\"  # EGN+ECA\n",
    "STANDARD_GRAY  = \"#444444\"\n",
    "ECA_GRAY       = \"#111111\"\n",
    "\n",
    "def _sanitize_for_filename(s: str) -> str:\n",
    "    s = re.sub(r\"\\s+\", \"_\", s.strip())\n",
    "    return re.sub(r\"[^\\w\\-\\.]+\", \"\", s)\n",
    "\n",
    "def _normalize_columns(df: pd.DataFrame) -> pd.DataFrame:\n",
    "    rename = {c: c.strip() for c in df.columns}\n",
    "    df = df.rename(columns=rename)\n",
    "    col_map = {}\n",
    "    for c in list(df.columns):\n",
    "        lc = c.lower()\n",
    "        if lc == \"mse\":\n",
    "            col_map[c] = \"MSE\"\n",
    "        elif lc == \"pcc_f\":\n",
    "            col_map[c] = \"PCC_F\"\n",
    "        elif lc == \"pcc_s\":\n",
    "            col_map[c] = \"PCC_S\"\n",
    "        elif lc == \"pcc_m\":\n",
    "            col_map[c] = \"PCC_M\"\n",
    "        elif lc == \"epoch\":\n",
    "            col_map[c] = \"epoch\"\n",
    "        elif lc == \"split\":\n",
    "            col_map[c] = \"split\"\n",
    "        elif lc == \"when\":\n",
    "            col_map[c] = \"when\"\n",
    "    df = df.rename(columns=col_map)\n",
    "    if \"split\" in df.columns:\n",
    "        df[\"split\"] = (\n",
    "            df[\"split\"]\n",
    "            .astype(str)\n",
    "            .str.lower()\n",
    "            .str.strip()\n",
    "            .replace({\"valid\": \"val\", \"validation\": \"val\"})\n",
    "        )\n",
    "    return df\n",
    "\n",
    "def _load_and_pivot(csv_path: str):\n",
    "\n",
    "    df = pd.read_csv(csv_path)\n",
    "    df = _normalize_columns(df)\n",
    "    needed = [\"epoch\", \"split\", \"PCC_F\", \"PCC_S\", \"PCC_M\", \"MSE\"]\n",
    "    for col in needed:\n",
    "        if col not in df.columns:\n",
    "            raise ValueError(f\"{csv_path} is missing column: {col}\")\n",
    "\n",
    "    df = (\n",
    "        df.sort_values(\"epoch\")\n",
    "          .groupby([\"epoch\", \"split\"], as_index=False)\n",
    "          .tail(1)\n",
    "    )\n",
    "    df = df[df[\"split\"].isin([\"train\", \"val\"])]\n",
    "\n",
    "    pf  = df.pivot(index=\"epoch\", columns=\"split\", values=\"PCC_F\").sort_index()\n",
    "    ps  = df.pivot(index=\"epoch\", columns=\"split\", values=\"PCC_S\").sort_index()\n",
    "    pm  = df.pivot(index=\"epoch\", columns=\"split\", values=\"PCC_M\").sort_index()\n",
    "    mse = df.pivot(index=\"epoch\", columns=\"split\", values=\"MSE\").sort_index()\n",
    "    return pf, ps, pm, mse\n",
    "\n",
    "\n",
    "def _plot_mse_only(ax, std_mse, eca_mse,\n",
    "                   std_color=STANDARD_COLOR,\n",
    "                   eca_color=ECA_COLOR,\n",
    "                   lw_val=2, lw_train=2):\n",
    "    def _one(ax, df, color, label_prefix):\n",
    "        if df is None or df.empty:\n",
    "            return\n",
    "        if \"train\" in df.columns:\n",
    "            ax.plot(df.index, df[\"train\"], linestyle=\"--\", linewidth=lw_train,\n",
    "                    color=color, label=f\"{label_prefix} Train\")\n",
    "        if \"val\" in df.columns:\n",
    "            ax.plot(df.index, df[\"val\"], linestyle=\"-\", linewidth=lw_val,\n",
    "                    color=color, label=f\"{label_prefix} Val\")\n",
    "\n",
    "    _one(ax, std_mse, std_color, \"EGN\")\n",
    "    _one(ax, eca_mse, eca_color, \"EGN+ECA\")\n",
    "\n",
    "    ax.set_xlabel(\"Epoch\")\n",
    "    ax.set_ylabel(\"MSE\")\n",
    "    ax.grid(True, which=\"both\", linestyle=\"--\", alpha=0.4)\n",
    "    ax.legend(ncol=2, frameon=True, framealpha=0.9, loc=\"upper right\")\n",
    "\n",
    "def _plot_pcc_only(ax, std_pcc, eca_pcc,\n",
    "                   std_color=STANDARD_COLOR,\n",
    "                   eca_color=ECA_COLOR,\n",
    "                   lw_val=1.5, lw_train=1.5):\n",
    "    def _one(ax, df, color, label_prefix):\n",
    "        if df is None or df.empty:\n",
    "            return\n",
    "        if \"train\" in df.columns:\n",
    "            ax.plot(df.index, df[\"train\"], linestyle=\"--\", linewidth=lw_train,\n",
    "                    color=color, label=f\"{label_prefix} Train\")\n",
    "        if \"val\" in df.columns:\n",
    "            ax.plot(df.index, df[\"val\"], linestyle=\"-\", linewidth=lw_val,\n",
    "                    color=color, label=f\"{label_prefix} Val\")\n",
    "\n",
    "    _one(ax, std_pcc, std_color, \"EGN\")\n",
    "    _one(ax, eca_pcc, eca_color, \"EGN+ECA\")\n",
    "\n",
    "    ax.set_xlabel(\"Epoch\")\n",
    "    ax.set_ylabel(\"PCC\")\n",
    "    ax.set_ylim(0.0, 1.0)\n",
    "    ax.grid(True, which=\"both\", linestyle=\"--\", alpha=0.4)\n",
    "    ax.legend(ncol=2, frameon=True, framealpha=0.9, loc=\"lower right\")\n",
    "\n",
    "def plot_pcc_mse_two_figures(standard_csv: str,\n",
    "                             eca_csv: str,\n",
    "                             pcc_metric: str = \"PCC_M\",\n",
    "                             title_prefix: str = \"Curves\",\n",
    "                             save_dir: Optional[str] = None,\n",
    "                             fig_size=(3.4, 2.2),\n",
    "                             dpi_png: int = 400,\n",
    "                             save_pdf: bool = True,\n",
    "                             use_grayscale: bool = False,\n",
    "                             title_pad: float = 8.0):\n",
    "    std_pf, std_ps, std_pm, std_mse = _load_and_pivot(standard_csv)\n",
    "    eca_pf, eca_ps, eca_pm, eca_mse = _load_and_pivot(eca_csv)\n",
    "\n",
    "    pcc_map_std = {\"PCC_F\": std_pf, \"PCC_S\": std_ps, \"PCC_M\": std_pm}\n",
    "    pcc_map_eca = {\"PCC_F\": eca_pf, \"PCC_S\": eca_ps, \"PCC_M\": eca_pm}\n",
    "    if pcc_metric not in pcc_map_std:\n",
    "        raise ValueError(f\"Unknown pcc_metric: {pcc_metric}. Use one of PCC_F/PCC_S/PCC_M.\")\n",
    "\n",
    "    if use_grayscale:\n",
    "        std_c, eca_c = STANDARD_GRAY, ECA_GRAY\n",
    "    else:\n",
    "        std_c, eca_c = STANDARD_COLOR, ECA_COLOR\n",
    "\n",
    "    fig_mse, ax_mse = plt.subplots(figsize=fig_size)\n",
    "    _plot_mse_only(ax_mse, std_mse, eca_mse, std_color=std_c, eca_color=eca_c)\n",
    "    ax_mse.set_title(f\"{title_prefix} — MSE\", pad=title_pad)\n",
    "    fig_mse.tight_layout()\n",
    "\n",
    "    fig_pcc, ax_pcc = plt.subplots(figsize=fig_size)\n",
    "    _plot_pcc_only(ax_pcc, pcc_map_std[pcc_metric], pcc_map_eca[pcc_metric],\n",
    "                   std_color=std_c, eca_color=eca_c)\n",
    "    ax_pcc.set_title(f\"{title_prefix} — {pcc_metric}\", pad=title_pad)\n",
    "    fig_pcc.tight_layout()\n",
    "\n",
    "    if save_dir:\n",
    "        save_path = Path(save_dir)\n",
    "        save_path.mkdir(parents=True, exist_ok=True)\n",
    "        ts = datetime.datetime.now().strftime(\"%Y_%m_%d_%H_%M_%S\")\n",
    "        base = f\"{ts}_{_sanitize_for_filename(title_prefix)}\"\n",
    "        fig_mse.savefig(save_path / f\"{base}_mse.png\", dpi=dpi_png)\n",
    "        fig_pcc.savefig(save_path / f\"{base}_{pcc_metric.lower()}.png\", dpi=dpi_png)\n",
    "        if save_pdf:\n",
    "            fig_mse.savefig(save_path / f\"{base}_mse.pdf\")\n",
    "            fig_pcc.savefig(save_path / f\"{base}_{pcc_metric.lower()}.pdf\")\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "def _collect_min_max_from_mse(dfs):\n",
    "    vals = []\n",
    "    for df in dfs:\n",
    "        if df is None or df.empty:\n",
    "            continue\n",
    "        for col in [\"train\", \"val\"]:\n",
    "            if col in df.columns:\n",
    "                v = pd.to_numeric(df[col], errors=\"coerce\").dropna().values\n",
    "                if v.size:\n",
    "                    vals.append(v.min()); vals.append(v.max())\n",
    "    if not vals:\n",
    "        return 0.0, 1.0\n",
    "    lo, hi = float(np.min(vals)), float(np.max(vals))\n",
    "    if not np.isfinite(lo) or not np.isfinite(hi) or lo == hi:\n",
    "        lo, hi = max(0.0, lo - 1e-6), hi + 1e-6\n",
    "    pad = 0.05 * (hi - lo if hi > lo else 1.0)\n",
    "    return max(0.0, lo - pad), hi + pad\n",
    "\n",
    "def _plot_pair_on_ax(ax, std_df, eca_df, std_color, eca_color,\n",
    "                     lw_val=1.5, lw_train=1.5,\n",
    "                     label_std=\"EGN\", label_eca=\"EGN+ECA\",\n",
    "                     return_handles=False):\n",
    "    handles = []\n",
    "    if std_df is not None and not std_df.empty:\n",
    "        if \"train\" in std_df.columns:\n",
    "            h, = ax.plot(std_df.index, std_df[\"train\"], linestyle=\"--\", linewidth=lw_train,\n",
    "                         color=std_color, label=f\"{label_std} Train\")\n",
    "            handles.append(h)\n",
    "        if \"val\" in std_df.columns:\n",
    "            h, = ax.plot(std_df.index, std_df[\"val\"], linestyle=\"-\", linewidth=lw_val,\n",
    "                         color=std_color, label=f\"{label_std} Val\")\n",
    "            handles.append(h)\n",
    "    if eca_df is not None and not eca_df.empty:\n",
    "        if \"train\" in eca_df.columns:\n",
    "            h, = ax.plot(eca_df.index, eca_df[\"train\"], linestyle=\"--\", linewidth=lw_train,\n",
    "                         color=eca_color, label=f\"{label_eca} Train\")\n",
    "            handles.append(h)\n",
    "        if \"val\" in eca_df.columns:\n",
    "            h, = ax.plot(eca_df.index, eca_df[\"val\"], linestyle=\"-\", linewidth=lw_val,\n",
    "                         color=eca_color, label=f\"{label_eca} Val\")\n",
    "            handles.append(h)\n",
    "    ax.grid(True, which=\"both\", linestyle=\"--\", alpha=0.4)\n",
    "    ax.set_xlabel(\"Epoch\")\n",
    "    return handles if return_handles else None\n",
    "\n",
    "def plot_six_in_one_row(standard_csvs, eca_csvs,\n",
    "                        pcc_metric=\"PCC_M\",\n",
    "                        save_dir: Optional[str] = None,\n",
    "                        file_prefix: str = \"sixpan\",\n",
    "                        fig_size=(14, 2.6),\n",
    "                        dpi_png=400,\n",
    "                        save_pdf=True,\n",
    "                        use_grayscale=False,\n",
    "                        legend_y=0.98):\n",
    "    assert len(standard_csvs) == 3 and len(eca_csvs) == 3, \"need 3 csv path\"\n",
    "    if use_grayscale:\n",
    "        std_c, eca_c = STANDARD_GRAY, ECA_GRAY\n",
    "    else:\n",
    "        std_c, eca_c = STANDARD_COLOR, ECA_COLOR\n",
    "\n",
    "    std_pcc_list, eca_pcc_list = [], []\n",
    "    std_mse_list, eca_mse_list = [], []\n",
    "\n",
    "    for sc, ec in zip(standard_csvs, eca_csvs):\n",
    "        spf, sps, spm, smse = _load_and_pivot(sc)\n",
    "        epf, eps, epm, emse = _load_and_pivot(ec)\n",
    "        pcc_map_std = {\"PCC_F\": spf, \"PCC_S\": sps, \"PCC_M\": spm}\n",
    "        pcc_map_eca = {\"PCC_F\": epf, \"PCC_S\": eps, \"PCC_M\": epm}\n",
    "        if pcc_metric not in pcc_map_std:\n",
    "            raise ValueError(f\"Unknown pcc_metric: {pcc_metric}. Use one of PCC_F/PCC_S/PCC_M.\")\n",
    "        std_pcc_list.append(pcc_map_std[pcc_metric])\n",
    "        eca_pcc_list.append(pcc_map_eca[pcc_metric])\n",
    "        std_mse_list.append(smse)\n",
    "        eca_mse_list.append(emse)\n",
    "\n",
    "    mse_lo, mse_hi = _collect_min_max_from_mse(std_mse_list + eca_mse_list)\n",
    "\n",
    "    fig, axes = plt.subplots(1, 6, figsize=fig_size, constrained_layout=False)\n",
    "\n",
    "    legend_handles = None\n",
    "    for i in range(3):\n",
    "        ax = axes[i]\n",
    "        return_handles = (i == 0)\n",
    "        h = _plot_pair_on_ax(ax, std_pcc_list[i], eca_pcc_list[i],\n",
    "                             std_c, eca_c, return_handles=return_handles)\n",
    "        ax.set_ylim(0.0, 1.0)\n",
    "        title = \"@\".join(pcc_metric.split(\"_\"))\n",
    "        ax.set_title(f\"Fold{i} {title}\")\n",
    "        if return_handles:\n",
    "            legend_handles = h\n",
    "\n",
    "    for i in range(3):\n",
    "        ax = axes[3 + i]\n",
    "        _plot_pair_on_ax(ax, std_mse_list[i], eca_mse_list[i], std_c, eca_c)\n",
    "        mse_hi = 0.135\n",
    "        ax.set_ylim(mse_lo, mse_hi)\n",
    "        ax.set_title(f\"Fold{i} MSE\")\n",
    "\n",
    "    if legend_handles:\n",
    "        labels = [h.get_label() for h in legend_handles]\n",
    "        fig.legend(legend_handles, labels,\n",
    "                   loc=\"upper center\", bbox_to_anchor=(0.5, legend_y),\n",
    "                   ncol=len(labels), frameon=True, framealpha=0.95,\n",
    "                   borderpad=0.3, handlelength=2.0)\n",
    "\n",
    "    fig.tight_layout(rect=[0.02, 0.06, 0.98, 0.86])\n",
    "\n",
    "    if save_dir:\n",
    "        save_path = Path(save_dir)\n",
    "        save_path.mkdir(parents=True, exist_ok=True)\n",
    "        ts = datetime.datetime.now().strftime(\"%Y_%m_%d_%H_%M_%S\")\n",
    "        base = f\"{ts}_{file_prefix}\"\n",
    "        fig.savefig(save_path / f\"{base}.png\", dpi=dpi_png)\n",
    "        if save_pdf:\n",
    "            fig.savefig(save_path / f\"{base}.pdf\")\n",
    "    plt.show()\n",
    "\n",
    "def _read_best_val(csv_path, metric_cols=(\"PCC_F\",\"PCC_S\",\"PCC_M\"), mse_col=\"MSE\"):\n",
    "    df = pd.read_csv(csv_path)\n",
    "    df = _normalize_columns(df)\n",
    "    if \"split\" not in df.columns or \"when\" not in df.columns:\n",
    "        return None\n",
    "    df = df[(df[\"split\"].str.lower()==\"val\") & (df[\"when\"]==\"end\")].copy()\n",
    "    if df.empty:\n",
    "        return None\n",
    "    needed_cols = [\"epoch\", *metric_cols, mse_col]\n",
    "    for c in needed_cols:\n",
    "        if c in df.columns:\n",
    "            df[c] = pd.to_numeric(df[c], errors=\"coerce\")\n",
    "        else:\n",
    "            return None\n",
    "    df = df.dropna(subset=needed_cols)\n",
    "    if df.empty:\n",
    "        return None\n",
    "    df_sorted = df.sort_values(by=[\"PCC_M\", mse_col, \"epoch\"],\n",
    "                               ascending=[False, True, False])\n",
    "    best_row = df_sorted.iloc[0]\n",
    "    epoch = int(best_row[\"epoch\"])\n",
    "    out = {m: float(best_row[m]) for m in metric_cols}\n",
    "    out[mse_col] = float(best_row[mse_col])\n",
    "    out[\"epoch\"] = epoch\n",
    "    return out\n",
    "\n",
    "def _read_at_epoch(csv_path, target_epoch: int,\n",
    "                   metric_cols=(\"PCC_F\",\"PCC_S\",\"PCC_M\"),\n",
    "                   mse_col=\"MSE\",\n",
    "                   split=\"val\", when=\"end\",\n",
    "                   allow_nearest: bool = False,\n",
    "                   nearest_mode: str = \"closest\"):\n",
    "    try:\n",
    "        df = pd.read_csv(csv_path)\n",
    "    except Exception:\n",
    "        return None\n",
    "    df = _normalize_columns(df)\n",
    "    if \"split\" not in df.columns or \"when\" not in df.columns:\n",
    "        return None\n",
    "    df = df[(df[\"split\"].str.lower() == split.lower()) & (df[\"when\"] == when)].copy()\n",
    "    if df.empty:\n",
    "        return None\n",
    "    need = [\"epoch\", *metric_cols, mse_col]\n",
    "    for c in need:\n",
    "        if c not in df.columns:\n",
    "            return None\n",
    "        df[c] = pd.to_numeric(df[c], errors=\"coerce\")\n",
    "    df = df.dropna(subset=need)\n",
    "    if df.empty:\n",
    "        return None\n",
    "    hit = df[df[\"epoch\"].astype(int) == int(target_epoch)]\n",
    "    if hit.empty and allow_nearest:\n",
    "        if nearest_mode == \"down\":\n",
    "            cand = df[df[\"epoch\"] <= target_epoch]\n",
    "            if not cand.empty:\n",
    "                hit = cand.sort_values(\"epoch\", ascending=False).head(1)\n",
    "        elif nearest_mode == \"up\":\n",
    "            cand = df[df[\"epoch\"] >= target_epoch]\n",
    "            if not cand.empty:\n",
    "                hit = cand.sort_values(\"epoch\", ascending=True).head(1)\n",
    "        else:\n",
    "            idx = (df[\"epoch\"] - target_epoch).abs().astype(float).idxmin()\n",
    "            hit = df.loc[[idx]]\n",
    "    if hit.empty:\n",
    "        return None\n",
    "    r = hit.iloc[0]\n",
    "    out = {\"epoch\": int(r[\"epoch\"]), \"csv\": csv_path}\n",
    "    for m in metric_cols:\n",
    "        out[m] = float(r[m])\n",
    "    out[mse_col] = float(r[mse_col])\n",
    "    return out\n",
    "\n",
    "def compute_threefold_summary_fixed_epoch(standard_csvs, eca_csvs,\n",
    "                                          fixed_epoch: int = 49,\n",
    "                                          metric_cols=(\"PCC_F\",\"PCC_S\",\"PCC_M\"),\n",
    "                                          mse_col=\"MSE\",\n",
    "                                          split=\"val\", when=\"end\",\n",
    "                                          allow_nearest: bool = False,\n",
    "                                          nearest_mode: str = \"closest\",\n",
    "                                          print_report: bool = True,\n",
    "                                          return_details_df: bool = False):\n",
    "    assert len(standard_csvs) == 3 and len(eca_csvs) == 3, \"need 3 csv path\"\n",
    "    std_rows, eca_rows = [], []\n",
    "    details = []\n",
    "    for i, (sc, ec) in enumerate(zip(standard_csvs, eca_csvs)):\n",
    "        s = _read_at_epoch(sc, fixed_epoch, metric_cols, mse_col, split, when,\n",
    "                           allow_nearest=allow_nearest, nearest_mode=nearest_mode)\n",
    "        e = _read_at_epoch(ec, fixed_epoch, metric_cols, mse_col, split, when,\n",
    "                           allow_nearest=allow_nearest, nearest_mode=nearest_mode)\n",
    "        if s is None or e is None:\n",
    "            raise ValueError(f\"fail to find epoch={fixed_epoch}(allow_nearest={allow_nearest}):{sc} or {ec}\")\n",
    "        std_rows.append([s[m] for m in [*metric_cols, mse_col]])\n",
    "        eca_rows.append([e[m] for m in [*metric_cols, mse_col]])\n",
    "        details.append({\"model\":\"EGN\",\"fold\":i,\"epoch\":s[\"epoch\"],\n",
    "                        **{m:s[m] for m in metric_cols}, mse_col:s[mse_col], \"csv\":sc})\n",
    "        details.append({\"model\":\"EGN+ECA\",\"fold\":i,\"epoch\":e[\"epoch\"],\n",
    "                        **{m:e[m] for m in metric_cols}, mse_col:e[mse_col], \"csv\":ec})\n",
    "    std_arr = np.array(std_rows); eca_arr = np.array(eca_rows)\n",
    "    std_mean = std_arr.mean(axis=0); std_std = std_arr.std(axis=0, ddof=0)\n",
    "    eca_mean = eca_arr.mean(axis=0); eca_std = eca_arr.std(axis=0, ddof=0)\n",
    "    header = [*metric_cols, mse_col]\n",
    "    improvement = []\n",
    "    for j, m in enumerate(header):\n",
    "        if m == mse_col:\n",
    "            imp = (std_mean[j] - eca_mean[j]) / max(std_mean[j], 1e-12) * 100.0\n",
    "        else:\n",
    "            imp = (eca_mean[j] - std_mean[j]) / max(std_mean[j], 1e-12) * 100.0\n",
    "        improvement.append(imp)\n",
    "    summary_df = pd.DataFrame({\n",
    "        \"metric\": header,\n",
    "        \"EGN_mean\": std_mean, \"EGN_std\": std_std,\n",
    "        \"EGN+ECA_mean\": eca_mean, \"EGN+ECA_std\": eca_std,\n",
    "        \"improvement_%\": improvement\n",
    "    })\n",
    "    details_df = pd.DataFrame(details).sort_values([\"model\", \"fold\"]).reset_index(drop=True)\n",
    "    if print_report:\n",
    "        print(f\"\\n=== Per-fold values at epoch={fixed_epoch} (val • end) ===\")\n",
    "        for model in [\"EGN\",\"EGN+ECA\"]:\n",
    "            sub = details_df[details_df[\"model\"] == model]\n",
    "            print(f\"\\n[{model}]\")\n",
    "            for _, r in sub.iterrows():\n",
    "                print(f\"Fold {int(r['fold'])}: epoch={int(r['epoch'])} | \"\n",
    "                      f\"PCC_F={r['PCC_F']:.4f}, PCC_S={r['PCC_S']:.4f}, PCC_M={r['PCC_M']:.4f}, {mse_col}={r[mse_col]:.6f}\")\n",
    "        print(f\"\\n=== Three-Fold Summary @ epoch={fixed_epoch} ===\")\n",
    "        for m, sm, ss, em, es, imp in zip(summary_df[\"metric\"], summary_df[\"EGN_mean\"], summary_df[\"EGN_std\"],\n",
    "                                          summary_df[\"EGN+ECA_mean\"], summary_df[\"EGN+ECA_std\"], summary_df[\"improvement_%\"]):\n",
    "            print(f\"{m}:  EGN {sm:.4f} ± {ss:.4f} | EGN+ECA {em:.4f} ± {es:.4f} | Δ% = {imp:+.2f}%\")\n",
    "    if return_details_df:\n",
    "        return summary_df, details_df\n",
    "    return summary_df\n",
    "\n",
    "def compute_threefold_summary(standard_csvs, eca_csvs, metric_cols=(\"PCC_F\",\"PCC_S\",\"PCC_M\"), mse_col=\"MSE\",\n",
    "                              print_report=True, return_details_df: bool=False):\n",
    "    assert len(standard_csvs)==3 and len(eca_csvs)==3, \"need 3 csv path\"\n",
    "    std_rows, eca_rows = [], []; details = []\n",
    "    for i, (sc, ec) in enumerate(zip(standard_csvs, eca_csvs)):\n",
    "        s = _read_best_val(sc, metric_cols, mse_col)\n",
    "        e = _read_best_val(ec, metric_cols, mse_col)\n",
    "        if s is None or e is None:\n",
    "            raise ValueError(f\"fail to read {sc} or {ec}\")\n",
    "        std_rows.append([s[m] for m in [*metric_cols, mse_col]])\n",
    "        eca_rows.append([e[m] for m in [*metric_cols, mse_col]])\n",
    "        details.append({\"model\":\"EGN\",\"fold\":i,\"epoch\":s[\"epoch\"],\n",
    "                        **{m:s[m] for m in metric_cols}, mse_col:s[mse_col], \"csv\":sc})\n",
    "        details.append({\"model\":\"EGN+ECA\",\"fold\":i,\"epoch\":e[\"epoch\"],\n",
    "                        **{m:e[m] for m in metric_cols}, mse_col:e[mse_col], \"csv\":ec})\n",
    "    std_arr = np.array(std_rows); eca_arr = np.array(eca_rows)\n",
    "    std_mean = std_arr.mean(axis=0); std_std  = std_arr.std(axis=0, ddof=0)\n",
    "    eca_mean = eca_arr.mean(axis=0); eca_std  = eca_arr.std(axis=0, ddof=0)\n",
    "    improvement = []\n",
    "    header = [*metric_cols, mse_col]\n",
    "    for i, m in enumerate(header):\n",
    "        if m == mse_col:\n",
    "            imp = (std_mean[i] - eca_mean[i]) / max(std_mean[i], 1e-12) * 100.0\n",
    "        else:\n",
    "            imp = (eca_mean[i] - std_mean[i]) / max(std_mean[i], 1e-12) * 100.0\n",
    "        improvement.append(imp)\n",
    "    summary_df = pd.DataFrame({\n",
    "        \"metric\": header,\n",
    "        \"EGN_mean\": std_mean, \"EGN_std\": std_std,\n",
    "        \"EGN+ECA_mean\": eca_mean, \"EGN+ECA_std\": eca_std,\n",
    "        \"improvement_%\": improvement\n",
    "    })\n",
    "    details_df = pd.DataFrame(details).sort_values([\"model\", \"fold\"]).reset_index(drop=True)\n",
    "    if print_report:\n",
    "        print(\"\\n=== Per-fold chosen epoch & values (val • end) ===\")\n",
    "        for model in [\"EGN\",\"EGN+ECA\"]:\n",
    "            sub = details_df[details_df[\"model\"] == model]\n",
    "            print(f\"\\n[{model}]\")\n",
    "            for _, r in sub.iterrows():\n",
    "                print(f\"Fold {int(r['fold'])}: epoch={int(r['epoch'])} | \"\n",
    "                      f\"PCC_F={r['PCC_F']:.4f}, PCC_S={r['PCC_S']:.4f}, PCC_M={r['PCC_M']:.4f}, {mse_col}={r[mse_col]:.6f}\")\n",
    "        print(\"\\n=== Three-Fold Summary (best val epoch per CSV) ===\")\n",
    "        for m, sm, ss, em, es, imp in zip(summary_df[\"metric\"], summary_df[\"EGN_mean\"], summary_df[\"EGN_std\"],\n",
    "                                          summary_df[\"EGN+ECA_mean\"], summary_df[\"EGN+ECA_std\"], summary_df[\"improvement_%\"]):\n",
    "            print(f\"{m}:  EGN {sm:.4f} ± {ss:.4f} | EGN+ECA {em:.4f} ± {es:.4f} | Δ% = {imp:+.2f}%\")\n",
    "    if return_details_df:\n",
    "        return summary_df, details_df\n",
    "    return summary_df\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    # Fold 0/1/2 CSV\n",
    "    standard_csv0 = \"EGN/v1/results/0/metrics.csv\"\n",
    "    standard_csv1 = \"EGN/v1/results/1/metrics.csv\"\n",
    "    standard_csv2 = \"EGN/v1/results/2/metrics.csv\"\n",
    "    \n",
    "    #Replace with results csv. Here is the example csv we provided\n",
    "    eca_csv0      = \"EGN/v1/eca_results/paper_reported_results/0/metrics.csv\"\n",
    "    eca_csv1      = \"EGN/v1/eca_results/paper_reported_results/1/metrics.csv\"\n",
    "    eca_csv2      = \"EGN/v1/eca_results/paper_reported_results/2/metrics.csv\"\n",
    "\n",
    "    standard_csvs = [standard_csv0, standard_csv1, standard_csv2]\n",
    "    eca_csvs      = [eca_csv0,      eca_csv1,      eca_csv2]\n",
    "\n",
    "    plot_six_in_one_row(\n",
    "        standard_csvs,\n",
    "        eca_csvs,\n",
    "        pcc_metric=\"PCC_M\",         \n",
    "        save_dir=\"EGN/figure_results\",\n",
    "        file_prefix=\"fold012_pccM_mse_row\",\n",
    "        fig_size=(14, 3),\n",
    "        dpi_png=400,\n",
    "        save_pdf=True,\n",
    "        use_grayscale=False,\n",
    "        legend_y=1\n",
    "    )\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "eca",
   "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.10.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
