{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "9614dc27-dc96-40e9-bae2-f7e89cf9e9e6",
   "metadata": {},
   "source": [
    "# Filtering measured TESLA data to build principled KIND datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5823283c-2418-4879-ab23-15c80fa508e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# --! include root folder into PYTHONPATH --!\n",
    "\n",
    "import os\n",
    "import sys\n",
    "\n",
    "thisdir = os.getcwd()\n",
    "rootdir = os.path.abspath(os.path.join(thisdir, '..', '..'))\n",
    "sys.path.append(rootdir)\n",
    "\n",
    "# --! import python libraries and kind framework --!\n",
    "\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from scipy.spatial.distance import cdist\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "import utils_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0bf8e1f1-0a33-4603-bd4d-dadf96367556",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inf >> read data shape is torch.Size([1000000, 2])\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAzkAAAEmCAYAAABBDV5+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABeIklEQVR4nO3dd3hTZRsG8Dvdu3RAS2mhLXsUKCB7yh4qIiigDBEVEWV8DkBkyVIRUVRwIC4ERBFFZO9VaqFltLRAKRQ6WR3Q3Z7vj9I0aXaa5CTp/buuXFdzcpK8hdPkPOd93ueRCIIggIiIiIiIyErYiD0AIiIiIiIiQ2KQQ0REREREVoVBDhERERERWRUGOUREREREZFUY5BARERERkVVhkENERERERFaFQQ4REREREVkVBjlERERERGRV7MQegDplZWVITU2Fu7s7JBKJ2MMhIiIiIiKRCIKA3NxcBAQEwMZG/VyNWQc5qampCAoKEnsYRERERERkJm7evInAwEC1+5h1kOPu7g6g/Bfx8PAQeTRERERERCSWnJwcBAUFSWMEdcw6yKlIUfPw8GCQQ0REREREWi1jYeEBIiIiIiKyKgxyiIiIiIjIqjDIISIiIiIiq8Igh4iIiIiIrAqDHCIiIiIisioMcoiIiIiIyKowyCGzkJlbgBc3ROLApQyxh0JEREREFo5BDpmFRTvicCjhNl76MUrsoRARERGRhWOQQ2bhdk6h2EMgIiIiIivBIIeIiIiIiKwKgxwiIiIiIrIqDHKIiIiIiMiqMMghIiIiIiKrwiCHiIiIiIisCoMcIiIiIiKyKgxyiIiIiIjIqjDIISIiIiIiq8Igh4iIiIiIrAqDHBLFg8ISsYdARERERFaKQQ6Z3JeHrqLVgj34KyZF7KEQERERkRVikEMm9/GeBADAnG0XRB4JEREREVkjkwQ5X331FUJCQuDk5IT27dvj2LFjpnhbIiIiIiKqgYwe5GzZsgUzZszAe++9h+joaPTo0QODBw9GcnKysd+aLIgAQewhEBEREZGVMHqQs2rVKrz00kuYPHkymjdvjtWrVyMoKAhr16419lsTEREREVENZNQgp6ioCGfOnMGAAQPktg8YMAAnT55U2L+wsBA5OTlyNyIiIiIiIl0YNci5c+cOSktL4efnJ7fdz88P6enpCvsvX74cnp6e0ltQUJAxh0dERERERFbIJIUHJBKJ3H1BEBS2AcCcOXOQnZ0tvd28edMUwyORKB4BRERERETVZ2fMF/f19YWtra3CrE1mZqbC7A4AODo6wtHR0ZhDIiIiIiIiK2fUmRwHBwe0b98e+/btk9u+b98+dO3a1ZhvTURERERENZRRZ3IAYNasWRg3bhw6dOiALl264JtvvkFycjKmTJli7LcmIiIiIqIayOhBznPPPYe7d+9i8eLFSEtLQ6tWrfDvv/+iQYMGxn5rsiCX0nLFHgIRERERWQmjBzkAMHXqVEydOtUUb0UWRLb4xIPCEhFHQkRERETWxCTV1YiIiIiIiEyFQQ4REREREVkVBjlERERERGRVGOQQEREREZFVYZBDopFo3oWIiIiISGcMcoiIiIiIyKowyCEiIiIiIqvCIIeIiIiIiKwKgxwSTS4bgBIRERGRETDIIVHlFhSLPQQiIiIisjIMckhUdx8UiT0EIiIiIrIyDHKIiIiIiMiqMMghIqJqyy8qFXsIREREUgxyiIioWvqsPIzm83fj19PJYg+FiIgIAIMcIiKqpqQ7DwEAc/+8IPJIiIiIyjHIISIiIiIiq8Igh4iIiIiIrAqDHCIiIiIisioMckhUgpJt9x6ydw4RERER6Y9BDpmdvKISsYdARERERBaMQQ4REREREVkVBjlERERERGRVGOSQqCRiD4CIiIiIrI5Rg5ylS5eia9eucHFxQa1atYz5VkREJIKUrHyxh0BERKTAqEFOUVERRo0ahddee82Yb0NERCK5kpEr9hCIiIgU2BnzxRctWgQA+OGHH4z5NmTBlJWQJiIiIiKqDq7JISIiIiIiq2LUmRxdFRYWorCwUHo/JydHxNEQEZEmmbmFcvez84vh6Wwv0miIiIjK6TyTs3DhQkgkErW3qKgovQazfPlyeHp6Sm9BQUF6vQ5ZNoE5bEQWY+WeBLn7Celco0NEROLTeSZn2rRpGD16tNp9goOD9RrMnDlzMGvWLOn9nJwcBjpERGYsv6hU7n5RSZlIIyEiIqqkc5Dj6+sLX19fY4wFjo6OcHR0NMprExGREbDZFRERmSGjrslJTk7GvXv3kJycjNLSUsTExAAAGjVqBDc3N2O+NVkIXvUlsmxVYxwJgx4iIjIDRq2uNn/+fISHh2PBggV48OABwsPDER4erveaHbI+P566LvYQiMiAuKaOiIjMgVGDnB9++AGCICjcevfubcy3JQuSmVMg9hCIiIiIyMqwTw6JKunOQ7GHQEQGxHQ1IiIyBwxySFSJtxnkEFkTpqsREZE5YJBDRERERERWhUEOERHpjTM3RERkjhjkEBGR3orLWAaeiIjMD4McIiIiIiKyKgxyiIiIiIjIqjDIISIivUnAmtFERMoUl5ZB4MJF0TDIIZPKYPNPIqvGPjlERMCdB4UIW7gH0zfHiD2UGotBDpnU2G8jxB4CERERkVH9FnUTBcVl+PtcqthDqbEY5JBJsfknERERERkbgxwiIjIYZqsREZE5YJBDREQGwyW2RERkDhjkkNlhIRIiIiKyZFHX74s9hBqPQQ4RERnMjbt5Yg+BiEh0N+9VfhbmFBSzlLQIGOQQEZHeqpaMnvvnBVxKy9H6+flFpThx9Q6KS8sMPDIiItMrLRPwzu/ncCXzgXRb64V7Me3XaLn9HhaWYNm/lxBzM8vEI6w5GOQQaXA18wH2x2WIPQwis6Ss0MDgz44ht6BYq+e//utZPP/daazck2DYgRERieCf86n4LeqWwvadF9Lk7q/adxnfHL2G4V+eMNXQahwGOUQa9Ft1BJN/isJ/1++JPRQiixFxTbu/l4PxmQCAn07dMOZwiIhMIitPuws8lzNyjTwSYpBDpEZhSan051V7L4s4EiLz9LCoVPNOREREJsYgh0R3/2GR3P0vDl3R+Jzi0jK8v/0i4tO1z/3Xx+bIm9KfzySzUgqRtnTtlyOw+DQRWbgl/8Thk72GSb0tKS3DlYxchYIFmbkFeH/7RZ3WPtZUDHLMRGFJKQ7GZ+BBYYnYQzG58ynZcvd/i7qFOw8K1T5n5NqT+DniBgatPmbMoSE7X7tpZyKS97Co5n2WEZkLVvIyrD2x6YhLVR9UpGXn47vjScgpqP5n3zdHE9HovV3o/+lRbDydLPfY21vP4+eIGxj8mXHPf6wBgxwzsWJXPCb9EIVXf44SeyhmobBEfaWlc7ey1T5OROLap2OxDp6TERnGoh2x6PHRIeRoWfyD1Dt3Mwuv/nwGQz5XH1QUaThvqUr2M+9qZi5Ky8o3XLv9AMv+jZc+Nm/7RbnnxXEGR2sMcszEpsjySP3E1bsij4SMaX9cBj74Jw4lLJdLVq7iC5uITGvDieu4dT8fm6rMAJB+EkxQIKDfqqN45/fzAIDbueozWUh7DHKI1DDk1eXrdx5i8k9RWH88CdvOphjuhYmIiMhk0rMLcKEaGSV5RSUK6xD/OFtedvrbY0kqn8cLpLoxWpBz/fp1vPTSSwgJCYGzszMaNmyIBQsWoKioSPOTySrlq6jCpOsCZbFUd5wTN0RKf07PKajmqxEZ3817eZi+ORoXU3T/Mt91MV2n/TnvQ0SWovPyA3jii+O4mlk5y5ORo90MzJWMXLSYv0dp5s5fMSnYf0l5qu+GE0loMm8XZ3p0YLQgJz4+HmVlZfj6668RGxuLTz/9FOvWrcPcuXON9ZZk5iKSLDsVT9M6IU2u380z0EiITGPqxrP4KyYVw9Yc1+v5Z26wtxQRWa9zNysvAK0/fk2r56w/rnqmZvrmGKXbN0UmY9GOODALWDd2xnrhQYMGYdCgQdL7oaGhSEhIwNq1a7Fy5Upjva1RJaTnItDLGa6ORvtnIyIyG1czH1Tr+YmZD1GvlgtW7UtAvVoueOPxRrCxUTEnyi9vMqCKzAFnB1uRR0JUfXO2XRB7CBbJpGfr2dnZ8Pb2Vvl4YWEhCgsrp+FycsyngsSxK7cxbn0k6nu74Og7fcQejlUpKat5OaaWkqJHVF0DVx+VlmJvWMcVw1oHiDwisnalZQJaLdyD0jIBV5cOhp0tlx+T+WAlSdMx2V9+YmIi1qxZgylTpqjcZ/ny5fD09JTegoKCTDU8jXacSwUAJN9jypGh3X2guE6LQQCRdZDtNXWDKZtkAtn5xdLqflnsdUZGJJE5WdF2TY4p/X0uVedy/tZE5yBn4cKFkEgkam9RUfK9XlJTUzFo0CCMGjUKkydPVvnac+bMQXZ2tvR28+ZNlftaG0b2VNXJxDt4+qsTGhuQERnSycQ7WHckEYIgKFT/0ZkOVyuq/V5EREZQ9WNMtjx+SWnlzzE3s7R6PVN91t3OLcSbm6Lx8k9RKNNhMc+DwhKraUyvc7ratGnTMHr0aLX7BAcHS39OTU1Fnz590KVLF3zzzTdqn+fo6AhHR0ddh0SkUl5RCRztbGGrah2ASCSS8g+SRX/H4ok2AejZpLbCPmO/PQ0AePGHSJye28/UQ6QaRhAETPrhPxxKuA0ACPF1rfZrVq3KZmld2COu3YW9rQTtG6hOsyYypAeFJXDjul+z9qCgMgC4l6dbxeCHBg4ermbmwt/TWekxI9sMVttP3uLSMrRasKf8ta0g1VPn0fv6+qJZs2Zqb05OTgCAlJQU9O7dG+3atcOGDRtgY2PZ/1hkHMqqlpUZ4GQoO68YLebvweDPjlb7tYxhzYEr2HrmFsZ/H6l2v/sPmW5BxpeSlS8NcIDy8tGyoq7rXintp1M35O6v3HtZZRd2c4t/cgqKMfqbCDyz9hSK2ZuCHtl4+gae+vIE7j4wfGrS2sOJaLVgD7Y96pfy97lUzNwSg4Ji5e0XSHy6nqsYuoBAv1VH0WrBHnyyNwGpWfnVfr2svMrP59wCy5/NMVrUkZqait69eyMoKAgrV67E7du3kZ6ejvR03XonkPXbHq3YGPP0teqXnj117Q4A4HJG9SpEGcstmQ8kfomR2Kp+V1e9P3LdKWQYoL/T71G3qv0appAt82VfqibVI/H2AzboqyGKSsrw3p8Xce5mFt5+1J2+wo27DzHh+0icSlRslXAxJRvHr9zR+Pof7o4HALy19RwA4M1N0fgzOgW/RNxQ2DclKx8bTiQZfGaAdPNXdPl67U2RyVrt//e5VKNc0Flz8KrGC6Y1kdGCnL179+Lq1as4ePAgAgMDUbduXemNSFaRkhOE/z36kBebrrmzOQXF+OFEEjJz1Z8Mrtx7We6qy7ojiSr3La6B1efIuO48KNR4Yi5AQEGx/D637lf/SqHEvDJHq+WPM7fQ95MjePmnKM07kyje3BSNo5dva95RjWu3H2D5v5cw9tsI6baD8Zly+7yxKRpHLt/GGJl9ACArrwjD1hzHC+tP40pGLvRx76FiStTQz49h0Y44tHyUWkSmUVBciuNXKwPW63cfAtBthubmfeMUYKluyf+qzGxyXS9GC3ImTpxYvnBVyY1qJis6t1FwMSUbr288i9YL92Lhjjh0XHoAP526jplbYlReBY5OzpL+rO7DSfZPJjO3QCGNiKrnQWEJhn5+DKv3XxZ7KCYRn56DDkv245l1p9Tud89IaZKqPgfM+ZuhoudKVe/+UX41XzbNj8Qne55xMvFuta9wP7HmOL4+eg1RN+6r3Cc1S/mFrWMyMzh/xaRWaxyyZNOKyHQOxWfi9V/PVus1IgyQqaKrW1oGVhWpkhVSsvLx6+lki8024SIZLUms+hRdXOdvZWveSS/V/z+TDUTUGbbmOHZeSJPbNv+vWPwZnYK9sZpTNLU9weu49AB6fHRILpWGqmdjxA3EpuZg9f4rRn+visX90zdHG/29VNl2tjw99NyjSkDfHr2Gd35XnDlVN7toDKVlAqb9etbgVyMNIfyDfShSsnawhO3HLYYgCGrTDtV5qCLIrfIOGrd+ceiqymevPaz6782aZj8tkUTNf4BEAoOk8RrKd8eu4fytLADyZ0C9Pj6MA5c0l5Jevite7v7g1Ucx988LJvl+NAYGOWaCX5Xm6Ug10xwAINcIOdM37j00+GvWVKZcVH79bh4Oxmfir5hUxKebrjR4Zk7lDODWqMrS/IcSMrH030v4LeoWIq4priWo6u8YxfVzulJ3wvDP+TSMW3+62u9hDOZ0IkO6m/xjFLquOKByVk5WRk6BwbJOtH2divU4mszZdgGvb9R+JiGbfYKqTV1xgYLiMnRadsCEo1Fvyc5LePKLE0of+/GU4toudQRBQM6j4gPVTfkUC4McM6Qs/5Z0Zy5Xv7S6evhoF0EQMOu3GMz/66L63RkVG9WZG/eRaYSTWtkvy7e3nlezp2F1XFY+A5iZU4D7MrOAL274T/pzvhbpCBVfkilZ+fjq8FW9ZhSv3X6AFzdEYtW+y0qvLKZlM5ggwzsQn4mMnEIcu6L+ZG3unxfQadkBLPv3kkHe1xCf1RWZJKVlAjZFJitkDaiyfFc82izaW6ObQRpCZFJletmag6pn48xJQnputc8l35EprmGIirdiYDF2M9Rp2X5cWTpE7GFYPNkYZ8w3EXh/WAu0CPAw+TjmbLuAHee0y8W+dT9fmk5ExlVcWgZ7JT0AzibfxzNrTwIArq8YarT3LywxfY7z9buGWc81cu1JpGUXKK0kpUlFoGRp61gs9Dve6l3JyEXyvTz0be5nkNf79XR5laxvjyXhvaEttH6equNDn8aPqq6LzfotRufXAoDl/15C/xaG+fepiWRTVePSLKM598DV2rfOyMwtwG//3cSzHYLkth+QKa5hqZ9/DHK0FJtmrHUj5WT/iIpLLfRoMmOnrt3F899FIHr+AIO+7gf/xGmVdnRSw8nghUdNE7XNGecRUj1fHb6Kj3Yn4PcpXeS2F5aUyp24FxSXwsne1tTDE4UuHbErZluOaVEWV1+CIKhNbSMCgP6flp/M/Tm1K8Lre4k8GkXqTg7VHeOy1bokEmDHuVSDFi4gqvDyj1E4dysbe2JVz/jpE6ybA6araeliimVE71QuM6cAr/x8Rm7b/bxipGbl63X1WZX1x5Nw4mr1Xy/5Xh6OXL6NbUp6BlUwxwXZlqSsTMDPETcQm5qNj3YnAADmbZdPC2z2/m58vCdBev+f89qlhejD3K6M7dDyd80rMn5fjp3n0xD+wT6cTDReEKUJ4yvLkpCuXXnm00mKla1KSstw7bb+n6+CIOCuitQgVdcO3t9+Eb0+PowHKtZsyvZdOX8rG29s0r9YiZl91FiEn05dx+6L1tnXURAE/Hf9HrLyirB4RxzOPSr+VHGxVRlz7TeoCWdyLFBRSRlibmYhvH4tpek2BHy4O0Hp9q4rDgIAfnu1CzqGeJtySBpN0FDmtN+qI9Kfa3op9uLSMjwoKIGXq4PWz9kek4L3qwQ1VReTV/1nlc1D3hSZjCAvF3Rv7Kv7gM2EuhP3M2rK48pqMd/4fTkqSrSOXx+Jq8uYukuKNkcmY/+lTKWPqft0XH88CRHX7uLxZnXwvwFNAQBTfjmD/Zcy8daAJjqPo6ikDHvUVNBU9Vn986MGn39Gp2DMY0FK96lQ3QI4SXce4lB8Jvo0q1Ot16kpLmfkYv5fsQCMm7JsahUf/1vP3JJbb2PNeIZsgWb/cR7Pfn0KS/6Jk27790IaVu+/bJST37sPCjH/r4u4qCbK14axUk+UpXj9cVZ9V/WoG5VX87Lzi7Hw71hEJ2s+ydPU5NNUcgtqdpfrgauPIvyDfVrX/geUz8be13Lh/PlbWZiz7QJeqGblrxyZSkcCgPsyV38zcwtw8uqdGh/AmitLTdewVrO3XcB+LUriKhObmiO3gLwiWFq5V7deWRtOJKHJvF0qK6OVlQkam0QKgoBSE/zNv/jDf5p3IgDlzZJlWcusbkWw/JcBqmRaCgY5ZkoQBHx56KrSsn0VKU2y5QCnbjyL1fuvGKXJ1Ht/XsRPp25g2Jrj1XqdfCOluXwgE+zp6kpGLkatO4kfTl7H01+d1Lh/748P4/czt9Bl+QFcMuECxKrrJWp6WdBrt8tLaK/S4aQkUUU6ijYpaalZ+Vq/jyrfH0+SO8auZj5A+Af7pF88HZcewNjvTmPj6WSVa7M2RSbjqS+O6xRsW3LQVFImIKegGNN+PYtNkcloNPdfhWZ1xnLfSM1Qa4KTiXe0KkluSGKciC7aUf7dc+u+8s+HQwmZGnspbY2q/vFc8TcuCILCCbosbcpnkyIriXEAAKev3VXa88taMcgxoryiErzyUxT+jFb9IfbxnngEz96psH1fXAY+3pOgc6dmdR9w+pJdWF+dE6Y/jFQ17IeT1wGUBwKxqdko0aLviQQSFJWUof+nR5Xmmv4Vk4KNpxVryucVleKtreeQll2AGZtjqjt0ra3er9sVRlXuPyzCoNVHTd7o0Vi2Radg6c44PP6J8tz21Kx8bIos79asqpxmvIZc/jsPChGXpl2+vzqLVQTjn+6T/7+dt/0iXvkpSm5bbkExZm2JwZxtF3DuVjY+2aPf8XBWy5Q0czLt12j8cz4Nc7ZdQEmZgFm/KTYuNbQDlzIwbVP1uprXJAXFpdK1Wg8LSzD229MY/U2ExXZJr1BUUqb0e0AbZWUC0lWUoa9IVQPUr4PQVkW63Cd7L6PDkv0q91v6r/4XBMk6PPdNBP67rt/3QHXWrYmFa3KMaP2xJOyNy8DeuAw8HR6odJ8vDyk/2UwxwJVjY5j8YxTWT3xMr+fqUr1JV3tj0zFtUzSKSsrQrn4tjfv/ePK6yhQDQRAwXYsAJiGj+ie+2vq8Sm1+ba5aZucV49ytLHRr5Atbm/InrDuSiPj0XKzYFY8pvRoaY6gm9+2xJADAb//dxKTuIXKPDVp9FDkFJUi681Cvk4m9sRkKucu3cwtR291R/wFrQbZ0JwB8tv+KXFGKPA0nj2du3Edk0j280jMUNjLHStVu1pbA1E3osvOL8dKPUQrbLXhCzKjKygS0WrAHJWUCLi8ZjIcyFxsKi8tMVp1Qosf19u3RKfhTTbGX9ceTtG7SWdWzX59ClIqLClXXBlbXiat3MahVXXxxSH0PlwOXMrFkuEHf2iqxwq1yj39yxOLWKDHIMaJ7efo3YopLNc9qblVPvsyFbCW1s8lZGvdXdYXNmoxYewKJtx/izccb4XLGAzz7WCAKjTBNXVpWXqmldaAnXBzE+0gpKCnFoh2xeLxZHfRoXBsApN2avzl6Ta/XVJbzP+bbCOyf1Uv/geohNVvxokdWXhEirt1DAx8XNPN3x4PCEszedgFPtA7AlF/K/x583Bwwsp3yCyykXG4B09R0UVBSKk3JyswtgINMMZwLKdmmK9ShR07RjC0xah/XN8ABoDLAMRZtsiyM1dCxoLgUVzMfICE9F4cSMrFyVBuLLb1/O7dQYxEgshwMckSkLq9+n8zJ1e6LaRjUqq5Wr/n7mVt4ok1AtcemTmZuAeq4O+n8PGtZvGcOZK9anky8g7Hfnka7+rWwbWo36fbER+tWKmaBdsemY2LXYOnjWXlFqOWifXUyVdYdScTHexLQKcQbW17tovkJRvLjyevIyCnEhhPXjXq1ydClvGNuZuHHRymXqpRUubKYX1SCEV+dxLU75f/HH41sjcTbD7DzfBp2yqwxUrUOicgU0pQE56Yg9qzbLxG6pbhNqdLuQFcCBHytxYUcY/27vPDdabmgLry+F16qMqtuKbarmdkjy8M1OSKITc3GoNVH0XHpAZX7yH4YTfnlLDJzC1BcWqYxx7m6pSaVqVoV7eY9zV9csqlpBcWl2BSZbDGzJ4dNnB5TXWO/La/4dTY5S6v1SBUqrlKuP56EJ784jiw9Zx43/1fez0FZ/wlTysgx/Ho0U1nwd6zCtvO3sqQ/X66SGllYUiYNcADgnd/P47aS37+wuMzkV5StFftUKbqSkYsRWhRsMQVzuoZWtf+WrKrr7QDgUEL1v3NWaJGKaqiM8aKSMjyz9qS0wmvVzxhrKowzfXO0VtkhZJ4Y5BiRqqsmQz8/rnGxc9VZjz/PpqDXR4fQ7P3dBhqdorjUHOTIpGqcTLyDj/fEo7jKibOmxcsR1+4ibOEebI26CaD8ZHrOtgsW01D1xQ3mX2pT1ZfIKR0qGlVUKPvgnzicv5WNdUf0S+kyR8WlZfhkr/JeSaYgCILc382hBN3TPHUtbKHq/GXDiSSd37smuJyRi+sygWIFVaXuJys5Oa3ppvxyRu67TBAgF22oaxuw8fQNHLtinAtKVftfmZO9cfqVvVbnt/+0q9BmqEqL+y9l4MyN+/jueJLS9cPmFHBW118xqUi+p32rAjIvDHL0oO8C+s2RyXh9o3YVe7Kq9O9YviseqdnG++A+fe0uhnx+DL0/PizdNvbb0/jyUKJCecxluy4pfY3s/GJcTMnG5B+j8LCoFG8/WrB92ABXqUjesn+V/x+MWx+JG3cVT9yUqTrzcliPE3Fz9frGs3J9MExtyi9n0GbRXmTlFeFKRq5egbPs313VT5zbuZY7a2UInZcdQJKSAKWguFThoowyOQXFGPDpUfReeVh64nc1MxdLd8bhhe+q1wupJqlasfC+htng2NRsXEzJRszNLLz350WMW2+4tQ+yAZWymVFrVqTlDP5dFRUmdXHrfh7SZc5Fxn4bobAPU9PJXDDI0cPOC5r7aigze9sFvZ9rbPseXV1SVWZXliCULza/mJKNhX/HShsatlm0F8PWHFdaypcMS92/sbKTP23Ep+fqlZKjT1UjYzPG1VJd7InNQF5RKX48eQODPzum12uoO3FRNhOsrkqUtUnPKcDsP+Sr3uUWFKP5/N3o+dEhjc/PVHKlv9+qo/j2WJLav5+yMgFTfj4j6iyhOanaTPfHk6rXomTkFGDo58cxbM1xJFYj9W9fXIbSheGyfXkM0deKFGXnF6P7h4fkyuHfuKs4y2GO3wlUM7HwgB70WUz53p/qux5bmnnbL2JTZPlajPt5RXilZ6jB30MQBOy+mI4WAR7wdXOEqyMPV1k7zqWinpezwnYBqtMScgvUB6BXMnLRqI6bIYZHAD41UH8jfbNMftBQ0MCSFchUCrx5Lw89HgU3aUac8Y5IuovdsenYHQv8b0BTo72PpcrKK1J5grtyT2VgWHWNmS5eVpE2+PuZW1g5qg0A8QsPWKOHhSVK0zuVMdRMzsPCErnv/SsZudgek4JXejaEp7O9Yd6kiuocm2R+OJNjIhtPJ4s9BKUirt3FycQ7Cms8NOXuVgQ4AJCQnouhnx9Xua++n3c7L6ThtY1n0evjw2i5YI/cFDkBb2yKxu9nlORiC8D/tipvmPhHlW7x71bpAaOrrVE3ma9sAvw3VnTvYWXKnq4lwvU9CTZGCfYKZ27ct/hqeAfiM/HZAeWBvey/nTaVwPTx9aMmx5ZS5EYMrRfq/l16Nvk+Wi7YgznbtLtYa6PiS18QBERdvyfN/lBnx7lUtFywB29uipZu6//pUXx5KBGLjJiOuFXZdypZLAY5erCWqdiC4lKM/iYCY789jeNX70i3L90Zh5ka+gfI0nTCkKNn34n/qqwZ+ddMU/3E9KuK4HnbWe1Sl7Y8Kg5R4dP9l1FWJuDuA+3WfLxdzSDJGkUnG66aWWxqtlxJaKqkTZVHbRmiUbE2a4FUuXkvD8+sPYm+nxyp9jjE9kuE8s+k6v4LZ+YWYOCnR9XuY4nNbk0tp6AEnZerruwKlP9bb426Ka3mWlFBLy5Nu+JBqi7K7IvLwMh1p9Dnk8MaX+ONR8HN3+dSFR47J1N5kkgd5v/oQZup2KuZuWafKiJbjjqvqPLnig7yhlBWJuDOA/0WO/54SrdeA4Yw/MsTJn9PQxOqcTpxOeMBQuf+CwD4dXIndG2kupGfvmt/rEVBcSlKywSFNMqnDVhSV90MKVXSNj1GEARp48oKUTfu46YBZsriUnPQJqiWXs9daKYL5QVBUFshTVt5RSXIL1KeKvvloat4vU8jlc9NzcqHn4cTPt13BQlMJTKq0jIBNhLg6S9PIiUrH/HpuXh/WAudX+e3qFuIuHYPdx4U4sLCgbB9NLVTsfa3amElXVX8BZeVCbBRNW1EBM7kVFtRSRmirt9TWAjeb5X6K07WRN0Xj7ZVX7RhijTrmJtZJngX4zJUPvrY704jv6gUO86lKi1Z3WflYcO8kQUSBAGtFuxBywV7UFhSioeFJTickIkiI6YzkaJ3fj+n9ToBoHw9R5tFe5ElczyPWncKp69Vv8fTU9W4QHIg3vwqGx69fBttF+/Dnth06bbV+y9j9DenUFhSii8OXtH4GhIAJaVlaDF/D/ZfUv47frwnAZdUzBDsj8tA1xUH8erPUSgsUd8jjnRTtQFxQXEpenx4EC/+8J+0LPT640lKi3RoI/leHvKKSvH10UTpNkN+h1/NfIB2S/ZJUxS1JQgCTl69gztaZiuQZeNMTjU1e3+XtMGWMbus60KfqxvGat5V00vdisGQi257fHQQdx4UoWOIN357tYvhXtjCPSwqlc4IPLHmOC5nlK+lMEYBDlLtt6hb+C3qFpztbbXav+JEe9eFdLntVdM2CRj/qILZqz+fkX63rd5fHtj8cy4NK/dqLqpx+PJt9GxSW+N+slf2L6XlIDY1B8+0q4fvjpev3dl/KRNDW9fV+Xcg1Rb8HYsgb2c83swPQHlLgdTsAoVWFeOVVLLTxUe7E1BcImB6v8Zy2xftiMWQsLp4LNgb2XnFcHey0/q85drth+i3qjy1c/mueEzoGgwnLT8D9sSmY8ovZ+Fkb4P4Dwbr9suQxTHqTM6TTz6J+vXrw8nJCXXr1sW4ceOQmqqYX2lpluy8hP+u38PO82lyHYTTswtw4FIGgmfvFG9wAJ78UjHFpaikTCElwxQVaOYasKqcoRqZWbupv2rXi0kbFamGkUnaXeletc8w1cTMXasFe6Q/VwQ4gHxBDjKd/GLNV/kfysy267t+Rp/iJ/ceFuHVn6OwX0VZ8xMy6yEthbYz9DvOpWKdllfar2bmotuKgxj82TG8tfWcwsyPtmvTTiVq3xC5ppv0QxS+OnwVL/3wH0pU/J9qalyujU/3X8bPp67jYkq2dNuGE9cxat0pbI26iTaL92Lc96r7UwmCgIkbVAdbT36hfVrvofjyvn0FxZx1rwmMGuT06dMHv/32GxISEvDHH38gMTERI0eONOZbmsyodaewaId8HvWAT4/gpR9N2xVb2Yn/xZTKqf/SMgE37j7EqHUn0eOjQ3K9BGTTEIylOv0QSD9ipkx9fkBzCguRsfVfdQRnblQG5jkFxWgpE5j+HKHfej9VJ4LqfLgrHntiMzBZSenj7LxiPK+m+ag1XNhZf1zzGs8yQcDsPy5I06SA8kIzEXqkEY5R0pySVPtodwIOxGdi90Xjng+8/1es0oCponjNiat3MW/7BaUtOrLyitU2FZe90AQA3xxNxJeHruLug0Icis9UWVhky3+8KGXtjJquNnPmTOnPDRo0wOzZszF8+HAUFxfD3t44Nc5NKbNKKlaOhh4kxnA54wGa+rsrbL/7oBA+bo6YuSVGrjrJ72duoXOoDwDo1fhRV4b8il6xKx47zqViC9OmLEppmQBbGwkeFpbAyd5WugiVyFiuZD7AmG9O4/LSwRAEAcevGGa2RLaZs7YXEzJzVc/+3H6g+rH8olIM/uwoOoZ446ORbbQfpAkUaDFzpoulOy8pVO6qSc1tzYE2s6HG9ktEMiKT7qG0SlDymQ4XzwqKS7Hs3/Iqeyv3JkAQgGVPh2Fsp/oK+777xwU891jl9odsZG51TFZ44N69e9i4cSO6du1qFQGOuUjNzld6te/jR43XlJVftFQlZQLO3cq2qt/JklT94tHGlJ/PIHzxXlzJyEXLBXswYq3mymOCIGDNgSs4GK88vcecaWq2SqZTkVL10o9RmLrRMCmcsjML+UWaTwojk+7hxNXK2fMNJ7SvXLnzQhqu383Db1Hm17dj0Y44zTvpQNvSxGQ8prjoqY3LGQ+QeFu+mIg2lWoX/h2LqRvP4KvDMoUOHn1l7b+k+rtENrulpqRb1yRGLzzw7rvv4osvvkBeXh46d+6Mf/75R+W+hYWFKCysnB3JyeEHnyYvbvgPvZQs7Lyfp7xsc/LdynU5Vy208VyOkYokkHp/nL2Fp8Prwc5GolVZ2a8OX8XuRymREzf8BwA4p6Z6XWZOAVbsikegt4s07U1ZMQ99+y5RzbNyTwIOGqlymaZS7Vl5RXj261Ny2xbtiEPLAE90DPHW+PpxqZXff09+cRy/vdpF68XVhpaRU6CyJxdZB0OsvRFTZSCkmHan7jPgjU3RcHO0w2PBXmZ5QYGqR+eZnIULF0Iikai9RUVV5h6//fbbiI6Oxt69e2Fra4vx48erzDNevnw5PD09pbegoCD9f7Ma5MhlxVxVVanckdcrr0Sqy3E1lDQ9Fupqcpm9EkSRkJ6Ltov2Ytx6zdV2ysoEfLQ7QXpfNtdelXf+OI9t0Ska1/W8s5UNSEk7Xxy6arTX1rRcRtXsRNXAR5XvZWZ9zos8gz1xw386pQwRWYrbuYVIuvOQAY6V0nkmZ9q0aRg9erTafYKDg6U/+/r6wtfXF02aNEHz5s0RFBSEiIgIdOmiuK5izpw5mDVrlvR+Tk4OAx1SwA8jcVQsID6uoRrU98eTcFuPHgTXbmvud1JQXCqdHSIS0z4V1dK08bCwBPceFmH0N4pFBzJzClDHw0lh+7t/nMezHcT5PlTVx4bI0lSnWTZZHp2DnIqgRR8VMziyKWmyHB0d4ejoqNdrk6JEC01HI8u2+B/D5uvL+sCIr02ki3f+UJxRnPB9JD4fE46kOw/VrmH7KyYV22NSlDYk7LjsgNI0TUEAxn4bgQ7B3pjVv0n1Bq+BbKlfIiJLZbQ1OZGRkYiMjET37t3h5eWFa9euYf78+WjYsKHSWRwyLAFcREfWZyPXBZAZO3L5Ntos2gsACPF1Vblfdn6x3PpIbZ1MvIuTiXcxoIUfWtXz1Hucmgxbo33fESIic2W06mrOzs7Ytm0b+vbti6ZNm2LSpElo1aoVjhw5wtkaExAEqKzfXFJahkNGWoxLpC+mEZA1SbqjOv3yw93xSM/Rf70ii68Q6ebJL46jsET8MtlkWkabyQkLC8PBgweN9fKkwdnk++jyqB9OVeuOJGLlXs7ykP6qkwpZVibARo9eOTfual6zQ2QNNM3yJN5+gM6hPnr9HRHVROdvZWOtTHlpqhlM1ieHTOvewyLcfah87RMDHKqu6Zuj9X5uoZZNFCukZuXj+p2H6PXxYb3fk8iS9Pz4kNrH3/8rFqFz/8XhBM7IE2lr9X5WCKyuklLdvr/FxiDHisk2riMypIsp+ldbupdXpHW3eADouuIgeq88rPf7EVmriv5TRKSd/67fF3sIFk3Xi5RiY5BDRCbVbcVBDFp9VGG7sr4j1ZkxIqoJDLnOQFUPOyJroU3PNrIeRluTQ0SkyjU1i7Jl/RUjXgNEIkvQdN5u9Gjsi4Et/fFC5wZ6v05cag6GfH4Mjeu4GXB0ROaFq9hqFs7kEJFo4tNzsPDvWNzVo3koEZU7duUO5m2/WK2ZmCGfHwMAXMlkfzWyXhJGOTUKZ3KISBT5RaUYtLr8xOrW/Xxk5jDQIaqO+X/F4oPhrcQeBpHZKii2rDUlVD2cySEiUWTL9PrYfykDRRZWtYXI3PwccUPsIRCRFbO0VXucySEiUbD5J5HhlZYJsNWhf87bW8/hDtNFicgKMcghIlGsYr8mIoM7nXQXXRv6ar3/1jO3jDgaIiLxMF2NiETBkysiwysrA87dzMJfMSnSbflFpbidW4jT1+7KNfPLyCkQY4hERCbBmRwiIiIrIUDAU1+eAAAEejmjfQNvhC3cg5Ky8vTQKb0aYvbgZgCAF9lMlIisGGdyiIiIrFBiZnk/qooABwDWHUkEUD7bE5eWI8q4iMgyWVrDYAY5REREVqJUJqBRVdxjX1yGdLaHiEhblhXiMMghIiKyGhNlUtDO3LivdJ+Xf4oy1XCIiETDIIeIiMgKbY9JFXsIRESiYZBDRERkhYpK2GCXiGouBjlERERWquPS/WIPgYhIFAxyiIiIrFRmbqHYQyAiEgWDHCIiIiIisioMcoiIiIiISC0La5PDIIeIiIiIiKwLgxwiIiIiIrIqDHKIiIiIiEg9pqsREREREZE1ESwsyjFJkFNYWIi2bdtCIpEgJibGFG9JREREREQGwsIDSrzzzjsICAgwxVsREREREZGB2dtZVgKY0Ue7a9cu7N27FytXrjT2WxERERERkRFIxB6AjuyM+eIZGRl4+eWXsX37dri4uGjcv7CwEIWFld2Zc3JyjDk8IiIiIiKyQkabyREEARMnTsSUKVPQoUMHrZ6zfPlyeHp6Sm9BQUHGGh4REREREWnJwpbk6B7kLFy4EBKJRO0tKioKa9asQU5ODubMmaP1a8+ZMwfZ2dnS282bN3UdHhERERERGZhgYZUHdE5XmzZtGkaPHq12n+DgYCxZsgQRERFwdHSUe6xDhw54/vnn8eOPPyo8z9HRUWF/IiIiIiIiXegc5Pj6+sLX11fjfp9//jmWLFkivZ+amoqBAwdiy5Yt6NSpk65vS0REREREIrGseRwjFh6oX7++3H03NzcAQMOGDREYGGistyUiIiIiIgOzsGw10/TJISIiIiLdJSwZJHf/hc71VexJRLJMFuQEBwdDEAS0bdvWVG9JJKpm/u5iD4HIIrk7GrW7AZFFcbSzlbv/So+GIo2Eajpne1vNO5kRzuQQGcnuGT3FHgKRRfp8bLjYQyAyiUVPtkTEnL4a95vZrwkAYO3z7VDfxwXBPvK9B1c928Yo4yOS5WBnWWGDZY2WyMKsn9ABI9rVQ+yigWr3mze0udx9T2d7Yw6LSG+Xlwyu1vOrnpxV9WSbAPRuUhtrxjDQIevzXIcgvDek8vO+WyNfuDiqvjrev4UfAGB6v8a4vmIoBofVBQBsm9pNLrDp07SOkUZMZLkY5BBVQwMfF5yeq/oqXN/mflj1bFu4Otph3tDmaFzHDZte7oxry4ZgTMfyZrcLn2iByT1CsX5CZdPcD59pbfSxE+nDwc4GX49rD3cnO6x7ob3Oz3+ybT21j38+JhwSiQRDH53MEVmTD0e2xss9Q3FmXj/sndkTjeq4QaJkv86h3gj2cVEZ7Hu7OmBEu0B8+lwbfPRMa3i5Ohh34EQWiInPRNXgbG8LPw8nbJj4GF7/9SzyikpV7ju5Rygm9wiV3l/2dBhm9W+K2u7lvaH6NvfDsXf64FJajvTqHZE5GtjSH/2b+8HGRtnpmXoOtqqfM6t/E+nPNjYSvNa7IdYeTgRQPtu5ZOcl3QdLJKIATyekZhcAAIa2rgzcfdwc4eNW/tkvkSj+TbzZtzG6NtTcruPpcFarJVKFQQ6RDnZN74Gmfu4Infuv3PY+zeogbvEgBM/eqfVrSSQSaYBTIcjbBUHe6tN5iMyBPgFOj8a+GN81GL9EJCM9pwBjO9XHr6eTAZSndvZsUltu/5n9mqBtUC10CvHG9bt5Bhk3kSmtGRuOerVcsPNCGkZ1UB6QuDpUpqt1a+SDIC8XdAn1MdUQiawWgxwiHTSv6yF3v4GG9QWG8uOkjpjwfaRJ3otIlR8ndazW878Y2w4eTvaIeJTiWVomoEuoD8Lr10Kgl+LfkoOdDQa29AcAtHVhOg5ZlqNv90H9R98RL3UPUbmf7EzOihGtTXqha2T7QPx+5pbJ3o/IlLgmh0gPv0/pghHh9bBkeJjSxx1sDfun1avKFW4A2DDxMYO+B5Emob6uWu+7+ZXOCid2VQtq2NpI8ESbAKUBjjqdQ71x4H+9dHoOkan4uDpg2dNh0gBHG8fe6YMd07obJMBp5u+O6yuGKmwfGlYXGyd3ktvWrZHmGaOlT7eq9piIxMAgh0jGxyO1W/DfIdgbq55rq5ButviplujdtLZC8zZD2D+r8qSuVT0P9GlWB51DvRX22z2jh8Hfm+ijkcqvMKsqKdo51AczZdbYGJKNRIKGtd2M8tpE1RU1rx/GdtKtYWeQtwvCAj0NOo6vnm8nd9/N0Q7dGsmv8+kYUhnkLHta+UW75zs1MOi4iEyFQQ6RjOou+B/fJRg/vNhR6ULS6mpUp/Kk7tWe5c3g2gTVkttnet/GaObvoZBWR1Qdz3UIwrMdgpQ+1reZdqVrezTWvIjaWFrU9YAeS4iI9GKMz399DAmri6TlQ6T3ywRB7vGPR7aGvUwhkCFh/jj2Th+5fc6+39+4gyQyIgY5RDJqWUjefz0vZwDlQY0sY105p5rpmXaB+Pmljlg8vKXKfVaO0q4JoaqrxLqoWAM3rHWATs97a2ATuea8VftSGdLk7iHo15zVEWuSwEefxwDw68ud1OxpXBWB/GPBlTP8ygIun0flprs18pVLIXVxsJObrZ3YNRjeLE1NFoyFB4iqGNq6LnaeTxN7GGrZ25Rfn3BxsEOLuh6IS8uRe1yocsWOSFc2EmDlqNYar0q7Oqr+GnF1sEUTPzcUlpQhoJazyv209fe07ohNyUZnLStPTe/bGBdSstGrSR1k5RVJt0/uEWqUctSN67hh3rAWAKBTpUWybJ+Nbotn1p4CAK3KPhvLgf/1xu6L6RjfRT69zNfNEXceFEozFU7Mfhy5BSXSdOuTsx+HRFKZevrry53wd0wqZg3gRTOybAxyiKr4Ykw4lo8IQ0xyFhztbPDcNxGijGNACz/sjcuQKyX6Ss9QpNzPR6t6leloX49rjxW74/GKTA8eourydLavdtqNRCLB7uk9IaC8yIAhxtS1kfYnkbIzmz5ujvj5pY5wti8v1+vj6oC7D4tUPVWjV3qG4puj1+S2vd6nkd6vR5arTWAttKrngfoil/8P8XXFa70bKmw/MKsXrt5+gHb1awEAnOxt4WRfWba66gWIrg19FYK1yd1D8N3xJMMPmiyGbKlzS8Egh6gKiUQCDyd7hZ4dpvbJs22w62I6Brbwl26bO0QxzSbI2wVfjm2nsJ1IG+sndMC/F9IxsWsw/rt+D4v/iQOAaqWpLHyihfRnffrpaGv+sBZY/E8cujXygY1EgmNX7sDd0Q65hSVK9+/RuPJv+q9p3dD9w0M6vd/f07rhyS9OoGFtV/Rv4acQ5AwPr6f7L0EWz87WBjumdTebtThVebrYo30Dr2q9xrxhLTCkdV3suZiOr6sc91QzyAbGloJBDhGAsZ3q42Uzmwlxd7JXudibyFD6NvdD30drSMICPdHU3x2f7b+CZSP0Lxvbu6l2xQiqa1L3EEx6VKa6tExAek4BPtwVj7/PpWp8rmzZ6taBnjh/K1vjc1oH1pKW5o26fk/tvh+NbI0vDl7FnQeFyCsq1fjaZHmc7G3Q81HgbK4BjiG1q++FKxm5Yg+DRLLgSdVrM80VCw9QjbdvZk8sezoMITr0ADF3bkrWSex8s7sIIyFzJltZqUK3Rr74bUoXNKrjrtdrvjWgCYJF+FuytZGgnp7rfp5pp7wTvTqazmmf7RCEo+/0kauKKMuYxQ/IsLa80hk7pil+fl5YOBBfj2svwoiITO+J1nXFHoLOGORQjdfYT7+TOXP28ag2aBkgX0a6ZYBhezCQZbORlC9ANrRpjzfWvJMR6ZJm98HwVnjz8UYY11mfPiDaXbmXrXQla7KZzRyTap1CfRAW6In4Dyr7n/m6OcDe1qZGzODI6hIqXmEFEpclHusMcoisUIivK3a+2QNO9vwTp0qhj2ZY3J3scG35UNRxdxJ5RIY3o19j9G5aG5+PCde477jODTBrQFPY2EhwZelgvDOoKf6e1k2r93HWMj/9rQFNtdqPzJ9s8YzPR2s+vqxRfR8XHH+3D2ewaog1Y8IxrHVdLB9R/RYAYuAZENVYYfU88fuULmIPw6iCfeTThka21z0thyyfva0Ey54Ow4YXH8Mz7QKx7bWuBn39z0a3BVBecUxstVwc8MOLHfFkG9166djb2mBq70ZoHVhL6ePbpsr/mzWvq90MsLODLZ7tIP939934DjqNjcyDbGX+ugYoiW6pAr1cEF6lEbU6swc3M95gqFqUpWFWmNQtBE+0CcAXY9thTMf6JhyV4bDwANVYO96w/jUqX49rjw93x2NKr/KyoitHtcGS4a3woLAEHZbsBwAsGd4K87ZfVHhuw9quWDOmHUJruyK/qBRfH72GdUcSTTp+MowrSyu7nn/yrHbNO3XxVNt6eKqtdVcWa1dfvjpV1dSNf9R8ntT1rDwh/n1KF3R4lMK2clQbvLX1nJL9nZCWXVCd4ZKRWV7ijmHVdndEhwZesLWR4HSS+iIcLhZYerimCAtUncb+tBVUi+RMDpEVa+Djiq+eby93ddrJ3ha+bo7YNb0H9s7siRc6N8AwFQsKWwR4wMneFl6uDhjRzvI/8GqS78Z3gJ+Ho6gd2K1F9Pv9Ne7Tqp7qkwXZeKiDzBqdke0D8e4g+avc84Y2x0kjrJWi6rOTSVfzfdRIs6aSSCTYOqULNr/SWe1+y0eEwcPJ3kSjIl3EzFf/udbAV9y+T4bAIIdqlCZ+yisd1UTN63qgyaOiCxWdsGW1qZKO0MTPHVundMGxd/qYYnhUTf1a+OH03H6idmC3FrVcqneSNupRKfjeTRV7b03oKl/0oGIxu6qqbCQeGxsJDr3VG/tm9lRawbKmkUgkShejy65rEwTAS0kxEHVpUmQatVz074VmKRjkVMP8YS0070Rm5adJndAl1AfrXtB90eTErsGGH5CZeLJNAH6c1BERc/pKty1UUhP/sWBvBHm7YONkzg6Q9fqjypql6lYVqlfLGXGLB2LDxMcUHnNxsMOvMn9PFYHQc+yRZZZCfF2tsiJndQwJK29Y/UrPUOyb2VMuc8DFwRaCzGKmhU+0wPUVQ9WmSREZCoOcamB3a8vj7+mETa90xqBW/mIPxaxIJBL0alIb/p5OOL9wAM4tGKA2xaBbI19cWzZE6WOuzL8WTXVnHKhcdbvDK+PiYKcyWOrayBfxHwxC5Ny+aPCoWMiL3YINPgYiY1j9XDj+er0bZg9qJg0A5w1tjgEt/DC0Sir0xG4hYgyR1Hh7YHkFyDmDm8FHhxL8lsCoQU5wcLB0OrPiNnv2bGO+pUl5uzrgz6ld8d4QNnWrCSywRLxePJzs4ems+WTZxkb5P0js4kEYwQsAohj/qN9LzyaKaVFk3pzsbVHHo7Kkt50tr0Ga2ox+jZU2yCX1HOxs0Caoltx3wuQeofhmfAfY29ogPKj8ooGvm3WdQFuiJ5RUnXy9TyNEvtcXr/ZqiB8ndRRhVMZj9KTSxYsX4+WXX5bed3Ozjjzj9RPKS4CG1/dCeH0vLP33ksgjIk3eGtBEr+dN79sYv5+5ham9Gxl4RJYv+v3+CP9gn8L2zg19sC06RYQR1VyfjW6LoWF10bWRL9qoKINM2pNI5EsGk2X4aGRr/BWTghNX7+r8XK8qaxRm9mvCdZwG4Olij/MLB8DJjrP8YprRrzGu3X6o9LGKnmmNZY53Fy17gZkzo18qcnd3h7+/v/RmLUFO3+byC7XXPt8O/ZorLt4m8/DRM6317sQ+s38THH+3D2rX8Go6yni5OuD6iqEKfUBGtgvEZ6Pbws/DUevg0teN/776il00EE+1rQc7Wxt0DvWBM1MGq+3U7L6Y3rcxIt/rq3lnI6lY3P7d+A5K1wTKzi4PbxsAbxWpJiesoFrbpG4h6KBFGqGLgy0WPdlKr/dwc7STpu6M79IA0/s1xuAw5ZUnSTceTvZwsJM/5Qz0Ki+tbmdT3scLABtYG9H0vo01ZqQ42tkial4/nH2/v1XMJhv9N/jwww/h4+ODtm3bYunSpSgqKjL2Wxqdstrhg8Pq4rsJbPBmjlwdbPHsY9VbxFvdhcfWbmb/JvD3cML/+pcHNDY2EjzVth5Oz+2nEFxGv98fk7uH4P1hLfDd+A4Ir18Lp+f2xdfj2okxdLNW8VlTNa+9KldWejI4f08nzOzfRHqFU5kAT9WPGcKxd/rg9yld0Ld5Hbl1Qr9O7oQhYf44PbcyAGsdWEtpP5I2gZ6oV8sZ7k6WfYzMf6IFfteiiW37Bl56V6Z7sm0AXu4RisNv9cbCJxQLr5Bh/TipIwa19Mdf07phbKf6uLJ0MOI/GIyvx7XnmjQjkEgk6NrQR+N+vm6OKi+YWBqjfupNnz4d7dq1g5eXFyIjIzFnzhwkJSXhu+++U7p/YWEhCgsLpfdzcnKMOTy9ffpcW5WPfTu+A97aeg7Z+cWmGxApGNzKH7supos9jBqjrqczTs15XKtg0NnBFvNkKhP2e1S+2tfNEZ1DvRFxTX1juZrkk1Ft8FL3EDT1d8fO82liD4eqMPaMmZerAzq4lvfVqehlFVbPE8G+rujaqLw0+IfPhOFgfCbGdqqPTqHeeHNTNHo2qY2d59NQy8UePz+q3PZU2wD8EpFs1PGaQqcQb5XNJ0/Mflyu8aqu7B9duQ72ddX7NUh7DWu7Yd24ykqnFf/+A1v6o39zP7Rv4IVpv0aLNTyrNKp9EJzsbRWaG1srnWdyFi5cqFBMoOotKioKADBz5kz06tULrVu3xuTJk7Fu3TqsX78ed+8qz5Vdvnw5PD09pbegIMsrodm/hZ/GBktkfGtlSkTXhFrw5qC6s122NhJsfqWL3LbWVl5mdO/MnmgTVAteSqqiPRbsBRsbCVrV85R++QPAhC4NcH3FUGkTyTVjwk02XpJnyhleiUSCJ9oEKJyAP/dYfXw9rgOc7G3RMsATB/7XGwueaInI9/ph78xe0iqJ7wxqhvFdGih7abP0/cTKzIivZU6ElwxXnooWu2gg6tXSP8BxsILUHGtiYyPBsNaKi+RJe6G+rvhpUkcMCfPHb6+Wf7dWZFkEeVt+o09t6DyTM23aNIwePVrtPsHBwUq3d+5c3hn36tWr8PFRnDKbM2cOZs2aJb2fk5NjkYEOU5vENbNfecrULy91wsq9CVjxTJjIIyJZupxM/PhiR6WFDaxFQC1n/PV6N2w4kYRFO+Kk2xOXDUHV4nVDwvzx74V0jOsSDAB4rXdDjO/SgKlqIpo9qBkm/xSFCRYQPHg42WPxU61wISUb0clZYg9HrZYBHni8mR+urxgKQRDkvlNl02im9GqIdUcS8b/+TRT+Dqb2boivDieqfZ+jb/dBSlY+luyMwwcqgicS16CW/tgdy6wMfRx8qzeAml1tU+dvR19fX/j66tdBOzq6fNqxbl3l+eWOjo5wdLSOxcf+Hk5IzykQexhW6YPhrfD+9osK2+cNbY4jl2/j1V6hAIDujX3RvTG7vZuDoWF1sfNCGja93Fll6emqPh7ZWmmnbGtS0VNofJdguSDHVsm/0Zdj2yG/uBQuDpUf2wxwxNXv0cy9NiXXzYVNlYtwCUsGoem83SKNRtH4Lg0w7fHKSpZVLxp6uzqgS6gPBAh4d1BTvNQ9RGlRGH8t1kvV93FBfR8X7HyzR/UHTkaxblx7BM/eKfYwLEZTP3ckZOTik1FtxB6KWTDaN+SpU6cQERGBPn36wNPTE//99x9mzpyJJ598EvXr1zfW2xrNn1O74umvTqKXlhHxruk9rPoKtKmNCK8nLUnsoKKPweQeoZjcI9SUwyItfTE2HB8WtZZWi1In+v3+uJ9XhNDallWJ0cvFHvfzVK/F6xjijUiZtQQfj2wtPYGztZFget/G+OzAFZXPl0gkcgEOmQdLS4dtHeiJMzfuS+8LgnmVy178lPoZFYlEgl9f7iT9WVXVS2XfEva2EhSXmskvSlpzd7RDbmGJ2MOwCF0a+mDX9B5aX0y0dkZLQnV0dMSWLVvQu3dvtGjRAvPnz8fLL7+MTZs2GestjSq8vhfOvt8fGyY+ptX+Xq4OFpHCYClWyRR7sLVRPGw/G91WYRuZD4lEolWAA5T/7cgGOPtn9TLWsAwidtFAXF06WGOJ8t9e7YJQmfUUVWdrqpZXJTKGtwY0VWjWG7toIPbN7CnSiHRXsf5XnS5Kqkj1a+6n9YVKMh8Rc/vi2Dt9kLR8CF7r3VDs4Zg9BjiVjPat2q5dO0RERCArKwv5+fmIj4/HwoUL4eJiuYudvF0ddDp4lF0v6t+ispeOqgWUpNzox4IQ7OOCoVX6FjSu44an2iqW9SbroG85WFP46vl2cHW0g52tDSZ1C8Y/b3SXPvbNuPZoGeAht//cIc1Vvpall/gly+DqaIc5VY5DFwc7NPZzx9rnxS3jbsi0v0Z13LF/Vk9Ev99fenHhqbYBSju+k3lzdbRDkLcLJBIJeihJQX+8WR0RRiW+5zoorllvr0UvqZqE36pG1NjPXWHbmjHh6LL8AOp7u+CFzg0wT8naEqrUv4Uf3nv0hbzimdYKi1ABoFU9667ARcDWKV2wNzYd3x5LEnsoUm2CamGITMAtkZRXQjsx+3FczshF7ya1cSXzAWJTK0vh1/OqrP5UNR3v2Q5BOH7lDno15ZVmMq7a7o54e2BTONrZwEmmq3nHEG+Dv9eS4a2wKTJZ7u8AAK6vGIrHPzmMa7cfYmyn+niidQCa+Bn2gkajOuXfwTve6I6kOw/RMsADpWUCopPvo3Oo5n4hZH46hfigY4g3XB1s8d2Ex2BrI8HxK3dwMD5T7KGZVJC3M+YMaYYtUTel274YG65wEbimY5BjRGMeC0JuQTG6hPrgw93x6NvMD072toieP0C6z+KnWmL+X7EijtK8fTtevsEqK9fVTI8Fe+OxYG808HE1iwsDU3s3xKxHjU+rqlfLWatStm2Dasndd7K3xTfj2VCYTOP1Po0Utvm4OWJsp/r49bTh+um80LkBXujcANujUzBjS4zcY1te6YJDCZl4onWAUXsOuTraSS+G2dlKsPRpVty0VLY2Emk55AqhtSvTgCd0aYAfT90w9bBMqqLYiUQikRYaAMCS20owCdyI7GxtMLV3I4TX98LmV7rg5Z6Ki+LHdwlG/AeDYK9iMT0RVepkhCvN+ujfwg92WpTCrhqTM0Ynczd/WAu59WFn5vXDS91DpPevrxiqV2+m4eH1MKajfNGh2u6OeLZDkNGbqpJ1C5C5qDSwpb+IIzENFwc76QXfitLnfZgBoBRncsyAbLqAMvEfDMJfMSl4948LCo89HV4PHz7TGhdTszFt41mkZteMstVB3s64eS8fADC9r/oF32Q9lKWAiiFcy27Rkio1nmwZ5ZCZc7K3xYWFA3Ay8S46BnvD1dFOoWiI7JVzXdSrpbmsM1F1yBZ0WfRkSxy5fBsrR7XBwr9j8fe5VBFHVj1vD2yKZ9oFQiKRL1LTMcQb/73XDz5W3m5BX5zJMUMXFw2Uu+9kb4vujRWj9BHt6uGTUW3gYGeDdvW9sP9/5l2FSlfq/mj7NK1caFi1AzhZt4pmr2J5e2BTrfft/ejqWkVRgUZ13NC/hR9GP2Z5TY6p5nC0s0WfpnVU9mFq4ueOQC/NKZnLqqSFTe4RirGd6uOHF7WrUkqkKw9ne0zsGowXOtfHhK7B+H7iY/B2dcDnY8JxbdkQDAmzvJmeza90xpReDeHv6QQ/D8ULBbXdHVlRTQXO5JiJFSNa439bz+GtAU3g5mgHB1sbFJWWSR9XdviGB9WSO7Ble2jUq+WMlKx8hefsmt4D8ek5mLnlnEHHb2gt6nrg2wlcn0CKXu0Vik/3Xxbt/ZVV91GleV0PHHqrt7SXh0QiUVhnRmTuqk5A2tva4MjbfVBSVoavDiUq7e80ol09jO0kn57mZG+rEPgQGUKHBl6497AIjeu4YeGTLZXuY2MjgasF9hpjkQz9cSbHTDzTPhDnFgyQ9trYNUO+A7NsOepPn2uDFzrXx+iOik1Vt7/eDfOGNsexd/rg6Sq9EFoGeKB5XQ88HR6IczLFD4xpg55X7CZ1D9Fq8TbVPE72tnA1cQ7/gidaSH/WtZ9NiK+r1j2CiMzR8Ecl+sPr15Jus7WRwNHOFjOVFOCInNsXq55ta6LREZVX4Nw3q5fGtZLqWsF+9Exrww5Kg9f7sOePsTHIMSOyPQIa1nbDT5M6Yvvr3RT2G9DCH0uGh8FeyR9z26BamNwjFDY2Evh7yk9rbp1SWZHEzUQ9Ofo0rYOhrXUvaeihYXyv9W6IWi72eLWXYjEHsn4bXuxo8Nc8Nedx/E/JCdtvr3bBi91CMK1PIzzbIRBNzWRdEJGpBPu64tz8Afh9Sle1+7UNqoXEZUNQR0lKDZExSSQShQbLyghqopxnTZhGHODphNd6K1Y4JMNikGPGejapLS0zK1t9zUbLxcuyJUJDfF3l0tlsbSQ4t6D6szkvdK4PBzsbpSk8E7sGAwC+GBOOuMUD0TFY+8pYbaqU162qrqczzs7rjzmDVTdXJOtVkf5lSHU9nfFG38bwcim/2BBWzxMx8/tLe4e8NbApPhrZhmXMqUbydLFXeRJZ0WBzau+GWp1oEpkDsRpNX18xFCfn9FU6wz+xazBCfV2lzeJraqNTQ2EOhYWo4+6EKb0awtHORutym26Odni1Zyi+PnoN84YqBgOezvbY/no3DP/yhHTb2wOb4uM9CWpf94/XuuKZtScBAK/1boQPnmoFiUSCC7ey4efhiDoeTkjNykfdRzNJEokELg526NnEF5HX7ym83s8vdcS49ZFVfl/NJ7FcaFdzhfi64t1BzfDh7njptncGNcVHuyuP3StLB6Pxe7sAlBcAOJxwW+lrPdchCO/LpKPtmt4TRy/fxlPhAXC0Y2lbIk0+e64t5g1trnRRNJE5GdamLv44ewtB3s7YP6sXMnMKMGNLDN4f1kJh3+FtA+DuZI+fIwzXd6fqNbLj7/ZBenYBikrLIAhAt0aVF4y7NPRBA28Xg713TSQRBHWTd+LKycmBp6cnsrOz4eHhIfZwLFZuQTHcnexVPh48e6f056TlQ/D4J0eQdOeh0n2fDq+HT59rizM37iMnvxh9dLjK8OvpZMz9U7EM9vUVQ+XGULGNSJOb9/Iw4ftIvNQjBINa+qPHR4fQs3FtfDamLRztbHHzXh5KywTY2Urw3NcRcHeyQ3x6rvT5/7zRXdokkIiIrF9cag4a+LgorR645sAVfLKvvLBN0vIhuHE3D71XHjbYe0skQNJynt9Uhy6xAWdyagB1AQ4AnJz9OH6LuonnOzWARCLB+gkd8PgnRxT2a+Djgg8fLcxr30C7PiGyZBetqvP9RFafIu0Eebvg4Fu9pffPLxggt/A0SOYq2InZjwMArt95iO9PJGFq70YK69aIiMi6tQhQfWJc36fyO0MikSDY1xVH3u6NyxkP8PJPUXL7Dmjhh5OJd+HpbK9Qzfa5DkHYEnVTbpuzvS2+HtfeAL8BaYtBDiGgljNmyPQeCfF1xbMdAuHl6oA5g5sjK68Ins721V6L0LyudrNxXRtqX6KXSJamyjpA+SLqxU+1MsFoiIjIkjzROgCJmQ/QXmYNcQMfVzTwqezH16qeB74a214uIJqz7QI2RSYDAF7pGYrabpUp94nLhsDWRoKyMoFp9ibGIIcUSCQSfDSyjfR+LRfDddL9eGRrvP37een9uMUDFbY72XMdBBEREZmWjY0EswYob/i8Z0ZPnLlxH6MfC1IIVv43oAkupGShiZ873h7YFHlFpfju+DU83sxPWoyDAY7pcU0OmdzNe3nYdjYFU/s0lCuDnVNQDHdHO1avIiIiIovGmRvj4JocMmtB3i6Y3q+xwnYPDWuHiIiIiCwBAxzxsU8OERERERFZFQY5RERERERkVRjkEBERERGRVWGQQ0REREREVoVBDhERERERWRUGOUREREREZFUY5BARERERkVUx6z45FX1Kc3JyRB4JERERERGJqSImqIgR1DHrICc3NxcAEBQUJPJIiIiIiIjIHOTm5sLT01PtPhJBm1BIJGVlZUhNTYW7uzskEnE7x+bk5CAoKAg3b96Eh4eHqGMhy8BjhnTFY4Z0xWOGdMVjhnRlTseMIAjIzc1FQEAAbGzUr7ox65kcGxsbBAYGij0MOR4eHqL/B5Nl4TFDuuIxQ7riMUO64jFDujKXY0bTDE4FFh4gIiIiIiKrwiCHiIiIiIisCoMcLTk6OmLBggVwdHQUeyhkIXjMkK54zJCueMyQrnjMkK4s9Zgx68IDREREREREuuJMDhERERERWRUGOUREREREZFUY5BARERERkVVhkENERERERFaFQY6WvvrqK4SEhMDJyQnt27fHsWPHxB4SiWD58uV47LHH4O7ujjp16mD48OFISEiQ20cQBCxcuBABAQFwdnZG7969ERsbK7dPYWEh3njjDfj6+sLV1RVPPvkkbt26ZcpfhUSyfPlySCQSzJgxQ7qNxwxVlZKSghdeeAE+Pj5wcXFB27ZtcebMGenjPGZIVklJCebNm4eQkBA4OzsjNDQUixcvRllZmXQfHjM129GjR/HEE08gICAAEokE27dvl3vcUMfH/fv3MW7cOHh6esLT0xPjxo1DVlaWkX87FQTSaPPmzYK9vb3w7bffCnFxccL06dMFV1dX4caNG2IPjUxs4MCBwoYNG4SLFy8KMTExwtChQ4X69esLDx48kO6zYsUKwd3dXfjjjz+ECxcuCM8995xQt25dIScnR7rPlClThHr16gn79u0Tzp49K/Tp00do06aNUFJSIsavRSYSGRkpBAcHC61btxamT58u3c5jhmTdu3dPaNCggTBx4kTh9OnTQlJSkrB//37h6tWr0n14zJCsJUuWCD4+PsI///wjJCUlCVu3bhXc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",
      "text/plain": [
       "<Figure size 1000x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# --! data readout from a file --!\n",
    "\n",
    "def convert(s):\n",
    "    \"\"\"Converts a string ``s`` to a float while replacing commas with dots.\"\"\"\n",
    "    s = s.replace(',', '.')\n",
    "    return float(s)\n",
    "\n",
    "def read_detuning(name: str, nrow_skip: int=0, delim: str=None):\n",
    "    return torch.tensor(\n",
    "        np.loadtxt(\n",
    "            name,\n",
    "            delimiter=delim,\n",
    "            skiprows=nrow_skip,\n",
    "            dtype=np.float32,\n",
    "            ndmin=2,\n",
    "            converters=convert))\n",
    "\n",
    "dataname = '../../data/baselines/detuning_17072025_15-10_1_QL_4_5e7_KI_0x10000'\n",
    "rawdata  = read_detuning(dataname, nrow_skip=23, delim='\\t')\n",
    "\n",
    "print(f'inf >> read data shape is {rawdata.shape}')\n",
    "\n",
    "plt.figure(figsize=(10, 3))\n",
    "plt.plot(rawdata[:, 0], rawdata[:, 1])\n",
    "plt.xlabel('Time [s]')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cd8a6c19-31e4-4cca-ba29-aa8f4aca6cdb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f+3W/vXXX+vgwYPeng4AAKDBeR2ARo0apR07dri179y5U6NGjaqLmgAAAOqV1wFo9+7d6tmzp1v7z372M+3Zs6cuagIAAKhXXgcgi8WiiooKt/aysjI5HI46KQoAAKA+eR2AevfurdTUVJew43A4lJqaql69etVpcQAAAPXB63WAFi5cqNtvv1033HCDevfuLUnatm2bysvL9dFHH9V5gQAAAHXN6xmgLl266LPPPtPgwYNVUlKiiooKjRw5Ul9++aViYmLqo0YAAIA6xTpANWAdIAAAGp96XQdIOnvLa/jw4erRo4cOHTokSfrTn/6k7du3X8zpAAAAGpTXAWjlypW69957FRQUpF27dqmyslKSVFFRoQULFtR5gQAAAHXN6wD07LPP6vXXX9fSpUvVtGlTZ3uPHj20a9euOi0OAACgPngdgL766ivdfvvtbu0tWrTQsWPH6qImAACAeuV1AAoLC9OBAwfc2rdv365rr722TooCAACoT14HoN/85jeaPHmydu7cKYvFosOHD2vZsmWaPn26HnnkkfqoEQAAoE55HYCefPJJJScn684779QPP/yg22+/XePGjdNvfvMbPfroo14XkJaWpqioKFmtVsXFxWnbtm3n7V9ZWamUlBRFRkYqMDBQnTp1UmZmpkufV155RTfccIOCgoIUERGhqVOn6tSpU17XBgAArkxerQTtcDi0fft2Pf7440pJSVFeXp6qq6vVpUsXNWvWzOsvX7FihaZMmaK0tDT17NlTb7zxhvr376+8vDx16NChxmMGDx6s77//XhkZGbruuutUUlKiM2fOOPcvW7ZMM2bMUGZmpnr06KH9+/c7f6X+5Zdf9rpGAABw5fF6IUSr1ap9+/YpKirqkr88ISFBsbGxSk9Pd7ZFR0crOTlZqampbv03bNigoUOHKj8/X8HBwTWe89FHH9W+ffv04YcfOtsef/xx5eTkXHB26RwWQgQAoPGp14UQu3btqvz8/Isu7pyqqirl5uYqMTHRpT0xMVE7duyo8Zi1a9cqPj5eCxcuVHh4uDp37qzp06fr5MmTzj69evVSbm6ucnJyJEn5+fnKysrS/fffX2stlZWVKi8vd9kAAMCVy+sfQ50/f76mT5+uZ555RnFxcbr66qtd9ns6Y1JaWiqHw6HQ0FCX9tDQUBUXF9d4TH5+vrZv3y6r1arVq1ertLRUjzzyiI4ePep8Dmjo0KH6z3/+o169eskwDJ05c0YTJkzQjBkzaq0lNTVVc+fO9ahuAADQ+HkdgPr16ydJGjBggCwWi7PdMAxZLBY5HA6vzvfjc/z4PDWprq6WxWLRsmXLZLPZJEmLFi3SAw88oN///vcKCgrS5s2bNX/+fKWlpSkhIUEHDhzQ5MmTFRYWptmzZ9d43pkzZ2ratGnOz+Xl5YqIiPDqOgAAQOPhdQDatGlTnXxxSEiI/P393WZ7SkpK3GaFzgkLC1N4eLgz/EhnnxkyDEPfffedrr/+es2ePVsjRozQuHHjJJ29ZXf8+HE9/PDDSklJkZ+f+12/wMBABQYG1sl1AQCAy5/XAahPnz518sUBAQGKi4tTdna2/ud//sfZnp2drV/84hc1HtOzZ0+99957+uGHH5xvne3fv19+fn5q3769JOnEiRNuIcff31+GYYgfvgcAANJFBCBJOnbsmDIyMrRv3z5ZLBZ16dJFY8aMcZmZ8cS0adM0YsQIxcfHq3v37lqyZIkKCws1fvx4SWdvTR06dEhvv/22JOnBBx/UM888o9GjR2vu3LkqLS3VE088oTFjxigoKEiSlJSUpEWLFunWW2913gKbPXu2BgwYIH9//4u5XAAAcIXxOgB9+umnzl+Dv+2222QYhhYtWqT58+dr48aNio2N9fhcQ4YM0ZEjRzRv3jzZ7XbFxMQoKytLkZGRkiS73a7CwkJn/2bNmik7O1uTJk1SfHy8WrdurcGDB+vZZ5919pk1a5YsFotmzZqlQ4cO6ZprrlFSUpLmz5/v7aUCAIArlNfrAPXu3VvXXXedli5dqiZNzuanM2fOaNy4ccrPz9fWrVvrpdCGxDpAAAA0Pt78/fY6AAUFBWn37t268cYbXdrz8vIUHx+vEydOeF/xZYYABABA41OvCyG2aNHC5bbUOUVFRWrevLm3pwMAAGhwXgegIUOGaOzYsVqxYoWKior03Xffafny5Ro3bpyGDRtWHzUCAADUKY8egv7ss88UExMjPz8/vfjii7JYLBo5cqTzR0ibNm2qCRMm6LnnnqvXYgEAAOqCR88A+fv7y263q02bNrr22mv1ySefKCgoSAcOHJAkXXfddbrqqqvqvdiGwjNAAAA0Pt78/fZoBqhly5YqKChQmzZtdPDgQVVXV+uqq65St27d6qRgAACAhuRRAPrlL3+pPn36KCwsTBaLRfHx8bUuKlgXvxQPAABQnzwKQEuWLNHAgQN14MABPfbYY/r1r3/NG18AAKDR8ngl6HO/Ap+bm6vJkycTgAAAQKPl9U9h/OEPf6iPOgAAABqM1+sAAQAANHYEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDpeL4QIXO4c1YZyCo6qpOKU2jS36raoYPn7WXxdFgDgMkIAwhVlw+d2zV2XJ3vZKWdbmM2qOUld1C8mzIeVAQAuJ9wCwxVjw+d2TXhnl0v4kaTislOa8M4ubfjc7qPKAACXGwIQrgiOakNz1+XJqGHfuba56/LkqK6pBwDAbAhAuCLkFBx1m/n5MUOSveyUcgqONlxRAIDLFgEIV4SSitrDz8X0AwBc2QhAuCK0aW6t034AgCsbAQhXhNuighVms6q2l90tOvs22G1RwQ1ZFgDgMkUAwhXB38+iOUldJMktBJ37PCepC+sBAQAkEYBwBekXE6b04bFqa3O9zdXWZlX68FjWAQIAOLEQIq4o/WLCdE+XtqwEDQA4LwIQrjj+fhZ179Ta12UAAC5j3AIDAACmQwACAACm4/MAlJaWpqioKFmtVsXFxWnbtm3n7V9ZWamUlBRFRkYqMDBQnTp1UmZmpkufY8eOaeLEiQoLC5PValV0dLSysrLq8zIAAEAj4tNngFasWKEpU6YoLS1NPXv21BtvvKH+/fsrLy9PHTp0qPGYwYMH6/vvv1dGRoauu+46lZSU6MyZM879VVVVuueee9SmTRu9//77at++vYqKitS8efOGuiwAAHCZsxiG4bNfh0xISFBsbKzS09OdbdHR0UpOTlZqaqpb/w0bNmjo0KHKz89XcHDNC9q9/vrreuGFF/Tll1+qadOmHtVRWVmpyspK5+fy8nJFRESorKxMLVq08PKqAACAL5SXl8tms3n099tnt8CqqqqUm5urxMREl/bExETt2LGjxmPWrl2r+Ph4LVy4UOHh4ercubOmT5+ukydPuvTp3r27Jk6cqNDQUMXExGjBggVyOBy11pKamiqbzebcIiIi6uYiAQDAZclnt8BKS0vlcDgUGhrq0h4aGqri4uIaj8nPz9f27dtltVq1evVqlZaW6pFHHtHRo0edzwHl5+fro48+0q9+9StlZWXp66+/1sSJE3XmzBn97//+b43nnTlzpqZNm+b8fG4GCAAAXJl8vg6QxeK6QJ1hGG5t51RXV8tisWjZsmWy2WySpEWLFumBBx7Q73//ewUFBam6ulpt2rTRkiVL5O/vr7i4OB0+fFgvvPBCrQEoMDBQgYGBdXthAADgsuWzW2AhISHy9/d3m+0pKSlxmxU6JywsTOHh4c7wI519ZsgwDH333XfOPp07d5a/v79Ln+LiYlVVVdXDlQAAgMbGZwEoICBAcXFxys7OdmnPzs5Wjx49ajymZ8+eOnz4sH744Qdn2/79++Xn56f27ds7+xw4cEDV1dUufcLCwhQQEFAPVwIAABobn64DNG3aNL355pvKzMzUvn37NHXqVBUWFmr8+PGSzj6bM3LkSGf/Bx98UK1bt9bo0aOVl5enrVu36oknntCYMWMUFBQkSZowYYKOHDmiyZMna//+/fr73/+uBQsWaOLEiT65RgAAcPnx6TNAQ4YM0ZEjRzRv3jzZ7XbFxMQoKytLkZGRkiS73a7CwkJn/2bNmik7O1uTJk1SfHy8WrdurcGDB+vZZ5919omIiNDGjRs1depUdevWTeHh4Zo8ebKeeuqpBr8+AABwefLpOkCXK2/WEQAAAJeHRrEOEAAAgK8QgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOkQgAAAgOn4PAClpaUpKipKVqtVcXFx2rZt23n7V1ZWKiUlRZGRkQoMDFSnTp2UmZlZY9/ly5fLYrEoOTm5HioHAACNVRNffvmKFSs0ZcoUpaWlqWfPnnrjjTfUv39/5eXlqUOHDjUeM3jwYH3//ffKyMjQddddp5KSEp05c8at37fffqvp06erd+/e9X0ZAACgkbEYhmH46ssTEhIUGxur9PR0Z1t0dLSSk5OVmprq1n/Dhg0aOnSo8vPzFRwcXOt5HQ6H+vTpo9GjR2vbtm06duyY1qxZ43Fd5eXlstlsKisrU4sWLby6JgAA4Bve/P322S2wqqoq5ebmKjEx0aU9MTFRO3bsqPGYtWvXKj4+XgsXLlR4eLg6d+6s6dOn6+TJky795s2bp2uuuUZjx471qJbKykqVl5e7bAAA4Mrls1tgpaWlcjgcCg0NdWkPDQ1VcXFxjcfk5+dr+/btslqtWr16tUpLS/XII4/o6NGjzueA/vnPfyojI0N79uzxuJbU1FTNnTv3oq8FAAA0Lj5/CNpisbh8NgzDre2c6upqWSwWLVu2TLfddpvuu+8+LVq0SG+99ZZOnjypiooKDR8+XEuXLlVISIjHNcycOVNlZWXOraio6JKuCQDqiqPa0MffHNFf9xzSx98ckaPaZ08tAFcUn80AhYSEyN/f3222p6SkxG1W6JywsDCFh4fLZrM526Kjo2UYhr777jsdP35cBw8eVFJSknN/dXW1JKlJkyb66quv1KlTJ7fzBgYGKjAwsC4uCwDqzIbP7Zq7Lk/2slPOtjCbVXOSuqhfTJgPKwMaP5/NAAUEBCguLk7Z2dku7dnZ2erRo0eNx/Ts2VOHDx/WDz/84Gzbv3+//Pz81L59e914443au3ev9uzZ49wGDBigO++8U3v27FFERES9XhMA1JUNn9s14Z1dLuFHkorLTmnCO7u04XO7jyoDrgw+vQU2bdo0vfnmm8rMzNS+ffs0depUFRYWavz48ZLO3poaOXKks/+DDz6o1q1ba/To0crLy9PWrVv1xBNPaMyYMQoKCpLValVMTIzL1rJlSzVv3lwxMTEKCAjw1aUCgMcc1YbmrstTTTe7zrXNXZfH7TDgEvh0HaAhQ4boyJEjmjdvnux2u2JiYpSVlaXIyEhJkt1uV2FhobN/s2bNlJ2drUmTJik+Pl6tW7fW4MGD9eyzz/rqEgCgzuUUHHWb+fkxQ5K97JRyCo6qe6fWDVcYcAXx6TpAlyvWAQLgS3/dc0iTl++5YL/FQ2/RL24Jr/+CgEaiUawDBACoWZvm1jrtB8AdAQgALjO3RQUrzGZVzQuCSBadfRvstqjaV8QHcH4EIAC4zPj7WTQnqYskuYWgc5/nJHWRv19tEQnAhRCAAOAy1C8mTOnDY9XW5nqbq63NqvThsawDBFwin74FBgCoXb+YMN3Tpa1yCo6qpOKU2jQ/e9uLmR/g0hGAAOAy5u9n4VV3oB5wCwwAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJiOzwNQWlqaoqKiZLVaFRcXp23btp23f2VlpVJSUhQZGanAwEB16tRJmZmZzv1Lly5V79691apVK7Vq1Up9+/ZVTk5OfV8GAABoRHwagFasWKEpU6YoJSVFu3fvVu/evdW/f38VFhbWeszgwYP14YcfKiMjQ1999ZXeffdd3Xjjjc79mzdv1rBhw7Rp0yZ9/PHH6tChgxITE3Xo0KGGuCQAANAIWAzDMHz15QkJCYqNjVV6erqzLTo6WsnJyUpNTXXrv2HDBg0dOlT5+fkKDg726DscDodatWql1157TSNHjqyxT2VlpSorK52fy8vLFRERobKyMrVo0cLLqwIAAL5QXl4um83m0d9vn80AVVVVKTc3V4mJiS7tiYmJ2rFjR43HrF27VvHx8Vq4cKHCw8PVuXNnTZ8+XSdPnqz1e06cOKHTp0+fNzClpqbKZrM5t4iIiIu7KAAA0Cg08dUXl5aWyuFwKDQ01KU9NDRUxcXFNR6Tn5+v7du3y2q1avXq1SotLdUjjzyio0ePujwH9GMzZsxQeHi4+vbtW2stM2fO1LRp05yfz80AAaido9pQTsFRlVScUpvmVt0WFSx/P4uvywIAj/gsAJ1jsbj+B9MwDLe2c6qrq2WxWLRs2TLZbDZJ0qJFi/TAAw/o97//vYKCglz6L1y4UO+++642b94sq9Vaaw2BgYEKDAy8xCsBzGPD53bNXZcne9kpZ1uYzao5SV3ULybMh5UBgGd8dgssJCRE/v7+brM9JSUlbrNC54SFhSk8PNwZfqSzzwwZhqHvvvvOpe+LL76oBQsWaOPGjerWrVvdXwBgUhs+t2vCO7tcwo8kFZed0oR3dmnD53YfVQYAnvNZAAoICFBcXJyys7Nd2rOzs9WjR48aj+nZs6cOHz6sH374wdm2f/9++fn5qX379s62F154Qc8884w2bNig+Pj4+rkAwIQc1YbmrstTTW9OnGubuy5PjmqfvVsBAB7x6Wvw06ZN05tvvqnMzEzt27dPU6dOVWFhocaPHy/p7LM5P35z68EHH1Tr1q01evRo5eXlaevWrXriiSc0ZswY5+2vhQsXatasWcrMzFTHjh1VXFys4uJil9AE4OLkFBx1m/n5MUOSveyUcgqONlxRAHARfPoM0JAhQ3TkyBHNmzdPdrtdMTExysrKUmRkpCTJbre7rAnUrFkzZWdna9KkSYqPj1fr1q01ePBgPfvss84+aWlpqqqq0gMPPODyXXPmzNHTTz/dINcFXKlKKmoPPxfTDwB8xafrAF2uvFlHADCTj785omFL/3XBfu/++mfq3ql1A1QEAP+nUawDBKDxuS0qWGE2q2p72d2is2+D3Rbl2UKlAOArBCAAHvP3s2hOUhdJcgtB5z7PSerCekAALnsEIABe6RcTpvThsWprc11bq63NqvThsawDBKBR8PlCiAAan34xYbqnS1tWggbQaBGAAFwUfz8LDzoDaLS4BQYAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHlaBrYBiGJKm8vNzHlQAAAE+d+7t97u/4+RCAalBRUSFJioiI8HElAADAWxUVFbLZbOftYzE8iUkmU11drcOHD6t58+ayWOr2xx3Ly8sVERGhoqIitWjRok7Pjf/DODcMxrlhMM4Nh7FuGPU1zoZhqKKiQu3atZOf3/mf8mEGqAZ+fn5q3759vX5HixYt+B9XA2CcGwbj3DAY54bDWDeM+hjnC838nMND0AAAwHQIQAAAwHQIQA0sMDBQc+bMUWBgoK9LuaIxzg2DcW4YjHPDYawbxuUwzjwEDQAATIcZIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEoHqQmpqq//f//p+aN2+uNm3aKDk5WV999ZVLH8Mw9PTTT6tdu3YKCgrSHXfcoS+++MJHFV8ZUlNTZbFYNGXKFGcb41w3Dh06pOHDh6t169a66qqrdMsttyg3N9e5n3G+dGfOnNGsWbMUFRWloKAgXXvttZo3b56qq6udfRjni7N161YlJSWpXbt2slgsWrNmjct+T8a1srJSkyZNUkhIiK6++moNGDBA3333XQNexeXvfON8+vRpPfXUU+ratauuvvpqtWvXTiNHjtThw4ddztGQ40wAqgdbtmzRxIkT9a9//UvZ2dk6c+aMEhMTdfz4cWefhQsXatGiRXrttdf0ySefqG3btrrnnnucv0MG73zyySdasmSJunXr5tLOOF+6//73v+rZs6eaNm2q9evXKy8vTy+99JJatmzp7MM4X7rnn39er7/+ul577TXt27dPCxcu1AsvvKDf/e53zj6M88U5fvy4br75Zr322ms17vdkXKdMmaLVq1dr+fLl2r59u3744Qf9/Oc/l8PhaKjLuOydb5xPnDihXbt2afbs2dq1a5dWrVql/fv3a8CAAS79GnScDdS7kpISQ5KxZcsWwzAMo7q62mjbtq3x3HPPOfucOnXKsNlsxuuvv+6rMhutiooK4/rrrzeys7ONPn36GJMnTzYMg3GuK0899ZTRq1evWvczznXj/vvvN8aMGePSNnDgQGP48OGGYTDOdUWSsXr1audnT8b12LFjRtOmTY3ly5c7+xw6dMjw8/MzNmzY0GC1NyY/Heea5OTkGJKMb7/91jCMhh9nZoAaQFlZmSQpODhYklRQUKDi4mIlJiY6+wQGBqpPnz7asWOHT2pszCZOnKj7779fffv2dWlnnOvG2rVrFR8fr0GDBqlNmza69dZbtXTpUud+xrlu9OrVSx9++KH2798vSfr3v/+t7du367777pPEONcXT8Y1NzdXp0+fdunTrl07xcTEMPaXoKysTBaLxTmb3NDjzI+h1jPDMDRt2jT16tVLMTExkqTi4mJJUmhoqEvf0NBQffvttw1eY2O2fPly7dq1S5988onbPsa5buTn5ys9PV3Tpk3Tb3/7W+Xk5Oixxx5TYGCgRo4cyTjXkaeeekplZWW68cYb5e/vL4fDofnz52vYsGGS+Pe5vngyrsXFxQoICFCrVq3c+pw7Ht45deqUZsyYoQcffND5Y6gNPc4EoHr26KOP6rPPPtP27dvd9lksFpfPhmG4taF2RUVFmjx5sjZu3Cir1VprP8b50lRXVys+Pl4LFiyQJN1666364osvlJ6erpEjRzr7Mc6XZsWKFXrnnXf05z//WTfddJP27NmjKVOmqF27dnrooYec/Rjn+nEx48rYX5zTp09r6NChqq6uVlpa2gX719c4cwusHk2aNElr167Vpk2b1L59e2d727ZtJckt0ZaUlLj9vxDULjc3VyUlJYqLi1OTJk3UpEkTbdmyRa+++qqaNGniHEvG+dKEhYWpS5cuLm3R0dEqLCyUxL/PdeWJJ57QjBkzNHToUHXt2lUjRozQ1KlTlZqaKolxri+ejGvbtm1VVVWl//73v7X2gWdOnz6twYMHq6CgQNnZ2c7ZH6nhx5kAVA8Mw9Cjjz6qVatW6aOPPlJUVJTL/qioKLVt21bZ2dnOtqqqKm3ZskU9evRo6HIbrbvvvlt79+7Vnj17nFt8fLx+9atfac+ePbr22msZ5zrQs2dPt2Uc9u/fr8jISEn8+1xXTpw4IT8/1/8k+/v7O1+DZ5zrhyfjGhcXp6ZNm7r0sdvt+vzzzxl7L5wLP19//bU++OADtW7d2mV/g49znT9WDWPChAmGzWYzNm/ebNjtdud24sQJZ5/nnnvOsNlsxqpVq4y9e/caw4YNM8LCwozy8nIfVt74/fgtMMNgnOtCTk6O0aRJE2P+/PnG119/bSxbtsy46qqrjHfeecfZh3G+dA899JARHh5u/O1vfzMKCgqMVatWGSEhIcaTTz7p7MM4X5yKigpj9+7dxu7duw1JxqJFi4zdu3c73z7yZFzHjx9vtG/f3vjggw+MXbt2GXfddZdx8803G2fOnPHVZV12zjfOp0+fNgYMGGC0b9/e2LNnj8vfxsrKSuc5GnKcCUD1QFKN2x/+8Adnn+rqamPOnDlG27ZtjcDAQOP222839u7d67uirxA/DUCMc91Yt26dERMTYwQGBho33nijsWTJEpf9jPOlKy8vNyZPnmx06NDBsFqtxrXXXmukpKS4/HFgnC/Opk2bavxv8kMPPWQYhmfjevLkSePRRx81goODjaCgIOPnP/+5UVhY6IOruXydb5wLCgpq/du4adMm5zkacpwthmEYdT+vBAAAcPniGSAAAGA6BCAAAGA6BCAAAGA6BCAAAGA6BCAAAGA6BCAAAGA6BCAAAGA6BCAAAGA6BCAAl6VRo0YpOTnZ+fmOO+7QlClTfFLL5s2bZbFYdOzYMZ98P4C618TXBQCAJ1atWqWmTZv65Lt79Oghu90um83mk+8HUPcIQAAaheDgYJ99d0BAgNq2beuz7wdQ97gFBsBn3n//fXXt2lVBQUFq3bq1+vbtq+PHj9fY96e3wCorK/Xkk08qIiJCgYGBuv7665WRkeHcn5eXp/vuu0/NmjVTaGioRowYodLS0lpr+fbbb5WUlKRWrVrp6quv1k033aSsrCxJ7rfA7rjjDlksFrft4MGDkqSysjI9/PDDatOmjVq0aKG77rpL//73vy9tsADUKQIQAJ+w2+0aNmyYxowZo3379mnz5s0aOHCgPP195pEjR2r58uV69dVXtW/fPr3++utq1qyZ89x9+vTRLbfcok8//VQbNmzQ999/r8GDB9d6vokTJ6qyslJbt27V3r179fzzzzvP91OrVq2S3W53bgMHDtQNN9yg0NBQGYah+++/X8XFxcrKylJubq5iY2N199136+jRo94PFIB6wS0wAD5ht9t15swZDRw4UJGRkZKkrl27enTs/v379Ze//EXZ2dnq27evJOnaa6917k9PT1dsbKwWLFjgbMvMzFRERIT279+vzp07u52zsLBQv/zlL501/Ph8P/Xj23Evv/yyPvroI+3cuVNBQUH66KOPtHfvXpWUlCgwMFCS9OKLL2rNmjV6//339fDDD3t0jQDqFwEIgE/cfPPNuvvuu9W1a1fde++9SkxM1AMPPKBWrVpd8Ng9e/bI399fffr0qXF/bm6uNm3aVOMMzjfffFNjAHrsscc0YcIEbdy4UX379tUvf/lLdevW7bx1rF+/XjNmzNC6deuc58zNzdUPP/yg1q1bu/Q9efKkvvnmmwteG4CGQQAC4BP+/v7Kzs7Wjh07tHHjRv3ud79TSkqKdu7cqaioqPMeGxQUdN791dXVSkpK0vPPP++2LywsrMZjxo0bp3vvvVd///vftXHjRqWmpuqll17SpEmTauyfl5enoUOH6rnnnlNiYqLLd4eFhWnz5s1ux7Rs2fK8dQNoODwDBMBnLBaLevbsqblz52r37t0KCAjQ6tWrL3hc165dVV1drS1bttS4PzY2Vl988YU6duyo6667zmW7+uqraz1vRESExo8fr1WrVunxxx/X0qVLa+x35MgRJSUlaeDAgZo6darbdxcXF6tJkyZu3x0SEnLBawPQMAhAAHxi586dWrBggT799FMVFhZq1apV+s9//qPo6OgLHtuxY0c99NBDGjNmjNasWaOCggJt3rxZf/nLXySdfaD56NGjGjZsmHJycpSfn6+NGzdqzJgxcjgcNZ5zypQp+sc//qGCggLt2rVLH330Ua21DBw4UEFBQXr66adVXFzs3BwOh/r27avu3bsrOTlZ//jHP3Tw4EHt2LFDs2bN0qeffnrxAwagTnELDIBPtGjRQlu3btUrr7yi8vJyRUZG6qWXXlL//v09Oj49PV2//e1v9cgjj+jIkSPq0KGDfvvb30qS2rVrp3/+85966qmndO+996qyslKRkZHq16+f/Pxq/v99DodDEydO1HfffacWLVqoX79+evnll2vsu3XrVklng9iPFRQUqGPHjsrKylJKSorGjBmj//znP2rbtq1uv/12hYaGejg6AOqbxfD0nVMAAIArBLfAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6RCAAACA6fx/gIkXniHspAYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "slice_nsample = [20, 40, 60, 80, 100, 120]\n",
    "\n",
    "fore = []\n",
    "\n",
    "for nsample in slice_nsample:\n",
    "    data = torch.split(rawdata[:, 1], nsample)\n",
    "    fore.append(np.mean([utils_data.forecastability(d) for d in data]))\n",
    "\n",
    "plt.figure()\n",
    "plt.scatter(slice_nsample, fore)\n",
    "plt.xlabel('slice size')\n",
    "plt.ylabel('forecastability')\n",
    "plt.show()\n",
    "\n",
    "datasaved = True\n",
    "\n",
    "if datasaved:\n",
    "    x        = torch.tensor(slice_nsample).reshape(-1, 1)\n",
    "    y        = torch.tensor(fore).reshape(-1, 1)\n",
    "    savedir  = '../../savedata/baselines/tesla'\n",
    "    filename = 'forecastability'\n",
    "    savedata = torch.cat([x, y], dim=1)\n",
    "    savedata = torch.unsqueeze(savedata, 0)\n",
    "    utils_data.write_datafile(f'{savedir}/{filename}', savedata, delim=' ')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f7c75c3e-4379-4ba1-8c90-68cd4940d641",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "model(\n",
       "  (operator_stat): operator_stationary(\n",
       "    (fun_enc): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=40, out_features=128, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=128, out_features=128, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=128, out_features=640, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (mod_mean): Linear(in_features=8, out_features=8, bias=False)\n",
       "    (mod_var): Linear(in_features=8, out_features=8, bias=False)\n",
       "    (pre_mean_dec): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=8, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=40, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (pre_var_dec): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=8, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=40, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "  )\n",
       "  (operator_trans): operator_transient(\n",
       "    (fun_enc): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=10, out_features=128, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=128, out_features=128, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=128, out_features=80, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (mod_mean_att_enc): TransformerEncoder(\n",
       "      (layers): ModuleList(\n",
       "        (0-1): 2 x TransformerEncoderLayer(\n",
       "          (self_attn): MultiheadAttention(\n",
       "            (out_proj): NonDynamicallyQuantizableLinear(in_features=8, out_features=8, bias=True)\n",
       "          )\n",
       "          (linear1): Linear(in_features=8, out_features=64, bias=True)\n",
       "          (dropout): Dropout(p=0.1, inplace=False)\n",
       "          (linear2): Linear(in_features=64, out_features=8, bias=True)\n",
       "          (norm1): LayerNorm((8,), eps=1e-05, elementwise_affine=True)\n",
       "          (norm2): LayerNorm((8,), eps=1e-05, elementwise_affine=True)\n",
       "          (dropout1): Dropout(p=0.1, inplace=False)\n",
       "          (dropout2): Dropout(p=0.1, inplace=False)\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (mod_mean_gen): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=768, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (mod_var_gen): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=768, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (pre_mean_dec): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=8, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=10, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (pre_var_dec): fcnn(\n",
       "      (net): Sequential(\n",
       "        (0): Sequential(\n",
       "          (0): Linear(in_features=8, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (1): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=64, bias=True)\n",
       "          (1): ReLU()\n",
       "        )\n",
       "        (2): Sequential(\n",
       "          (0): Linear(in_features=64, out_features=10, bias=True)\n",
       "          (1): Identity()\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# --! load a trained stationary model --!\n",
    "\n",
    "model = torch.load('../../models/baselines/tesla_kind_filter.pt', weights_only=False)\n",
    "model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c6f5a933-5567-4773-8de4-c7da07425309",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inf >> number of training and test samples is 750000 and 250000, respectively\n"
     ]
    }
   ],
   "source": [
    "# --! define train-test data split --!\n",
    "\n",
    "test_ratio       = 0.25\n",
    "\n",
    "rawdata_nsample  = len(rawdata)\n",
    "test_nsample     = int(test_ratio * rawdata_nsample)\n",
    "train_nsample    = rawdata_nsample - test_nsample\n",
    "\n",
    "print(f'inf >> number of training and test samples is {train_nsample} and {test_nsample}, respectively')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d63113fa-18ec-4add-ac50-64935a159b19",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasaved = True\n",
    "\n",
    "if datasaved:\n",
    "    datum            = rawdata[:train_nsample, [1]]\n",
    "    savedir          = '../../data/baselines/tesla_train_stat'\n",
    "    utils_data.save_stat(model, savedir, [datum])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "aeee3d3a-10bc-42d5-afe7-438c9d4a21fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasaved = True\n",
    "\n",
    "if datasaved:\n",
    "    datum            = rawdata[:train_nsample, [1]]\n",
    "    savedir          = '../../data/baselines/tesla_train_trans'\n",
    "    utils_data.save_trans(model, savedir, [datum])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "41412884-c9f4-4c6b-86ea-d9a1f0ce2320",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasaved = True\n",
    "\n",
    "if datasaved:\n",
    "    timeseries_nsample = model.lookback_nsample + model.forecast_nsample\n",
    "\n",
    "    savedir_stat  = '../../data/baselines/tesla_train_stat'\n",
    "    savedir_trans = '../../data/baselines/tesla_train_trans'\n",
    "    savedir_mixed = '../../data/baselines/tesla_train_mixed'\n",
    "\n",
    "    utils_data.save_mixed_dataset(savedir_stat, savedir_trans, timeseries_nsample, savedir_mixed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "237cb3e5-bd9d-4c6a-b7db-df66f952b40a",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasaved = True\n",
    "\n",
    "if datasaved:\n",
    "    savedir  = '../../data/baselines/tesla_test'\n",
    "    filename = 'eval'\n",
    "    testdata = rawdata[train_nsample:, [1]]\n",
    "    testdata = torch.unsqueeze(testdata, 0)\n",
    "    utils_data.write_datafile(f'{savedir}/{filename}', testdata)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20ef6e03-8e63-4548-8951-e78915996580",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.13.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
