{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import re\n",
    "from einops import rearrange\n",
    "\n",
    "sys.path.append(\"..\")\n",
    "\n",
    "\n",
    "from dataset.cyclone import CycloneDataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(255, 16, 32)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtsAAAJjCAYAAADd6d2wAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOydeZhUxbn/v909vcy+MSwjm6CCCIqCuwaQGI3ikkhcfu6S4G7Mdk3M4pLERKMSo9HI1RCvMYvilhhjoonbdcVdr6iIiOwwA7MvPdNdvz/61Knvoavo7nFGxvh+nsfHorpOnTp16tQ5U++33jeklFIQBEEQBEEQBKHfCW/vBgiCIAiCIAjCfyrysS0IgiAIgiAIA4R8bAuCIAiCIAjCACEf24IgCIIgCIIwQMjHtiAIgiAIgiAMEPKxLQiCIAiCIAgDhHxsC4IgCIIgCMIAIR/bgiAIgiAIgjBAyMe2IAiCIAiCIAwQ8rEtCJ8wv/vd7xAKhfDSSy/1W52rVq1CIpHAM8880291bk8+/PBDhEIh/O53v8tZ9owzzsDYsWP79fxjx47FGWeckZV/9913o6amBm1tbf16vr7Q1taGoUOH4q677treTREGId/97nex7777ZuU3NjaitLQUDz/8cN7HCILw8ZCPbUH4D+DKK6/EvvvuiwMPPHB7N+U/llQqhcsuuwwXXnghysrK/PyxY8ciFApZ/+vq6gJg/sCy/ffd734XM2fOdP7O/11++eX+eW+44QaUl5fjxBNP9PMuv/zyQPmSkhJMmjQJP/jBD9DS0lLwNV911VV44IEH+txnhbJmzRocf/zxqKqqQkVFBY455hh88MEH1rK33347dt11VyQSCey888648cYbB1WdnZ2dmDdvHiZPnozKykqUlZVhjz32wA033ICenp6sOpuamjB//nzU1dWhtLQUs2bNwiuvvGI9/1/+8hfstddeSCQSGD16NC677DL09vYGylx88cV4/fXX8Ze//CWQX1tbi69+9av44Q9/mFWv6xhBED4eRdu7AYIgfDw2bdqEO+64A3fcccf2bsp/NH/961/x7rvvYv78+Vm/TZ06Fd/61rey8mOxWODfV155JXbcccdA3uTJkzF79mx89atf9fOWLFmCX/3qV7j00kux6667+vm77747AKCnpwc33HADvvGNbyASiWSd95ZbbkFZWRna2trwz3/+Ez/96U/x73//G8888wxCoVDe13zVVVdh7ty5OPbYY/M+pq+0tbVh1qxZaG5uxqWXXopoNIoFCxZgxowZeO2111BbW+uXvfXWW3HOOefguOOOwze/+U08/fTTuOiii9DR0YFLLrlkUNTZ2dmJ//u//8MRRxyBsWPHIhwO49lnn8U3vvENvPDCC/jDH/7g15lOp3HkkUfi9ddfx3e+8x0MGTIEN998M2bOnImXX34ZO++8s1/273//O4499ljMnDkTN954I95880385Cc/wcaNG3HLLbf45YYPH45jjjkG1157LY4++uhAX59zzjn41a9+hX//+9845JBD8jpGEISPgRIE4RNl0aJFCoBasmRJv9R3/fXXq+LiYtXa2tov9Q0GVqxYoQCoRYsW5Sx7+umnqzFjxvTr+ceMGaNOP/30QN7RRx+tDjroIGvZI488cpv1FXrP77nnHgVAPf7449bf77vvPgVAvf/++4H8yy67TAFQmzZtCuR/+ctfVgDUs88+m9f5NaWlpVn9MFBcffXVCoB68cUX/bylS5eqSCSivve97/l5HR0dqra2NqvPTz75ZFVaWqo2b948KOp0ccEFFygAat26dX7en//8ZwVA3XPPPX7exo0bVVVVlTrppJMCx0+aNEntscceqqenx8/7/ve/r0KhkFq6dGmg7OLFi1UoFFLLly/PasfkyZPVqaeempW/rWMEQegbIiMRhH5i5cqVOO+88zBhwgQUFxejtrYWX/nKV/Dhhx9ay3d0dODss89GbW0tKioqcNppp2HLli2BMi+99BIOO+wwDBkyBMXFxdhxxx1x1llnBco88MAD2HfffQPSBsCtO545cyZmzpzp//uJJ55AKBTC3XffjZ/+9KcYOXIkEokEZs+ejffffz/r2MmTJ+Pll1/GAQcc4LfpN7/5TaBcMpnEj370I0ybNg2VlZUoLS3FwQcfjMcffzyrPU1NTTjjjDNQWVmJqqoqnH766WhqarL22QMPPIDJkycjkUhg8uTJuP/++63l0uk0fvnLX2K33XZDIpHAsGHDcPbZZ2f1r1IKP/nJTzBy5EiUlJRg1qxZ+L//+7+s+rq6uvDII4/g85//vPV8nzQPPPAAxo4di/Hjx+dVXq9erlixAgDQ3t6Ob33rWxg1ahTi8TgmTJiAa6+9Fkop/5hQKIT29nbccccdviyFx9OaNWtw1llnYdiwYYjH49htt93w29/+NnDeQsbW4sWLsffee2Pvvff28yZOnIjZs2fj7rvv9vMef/xxNDY24rzzzgscf/7556O9vR1/+9vfBkWdLvT+Ah7jixcvxrBhw/DlL3/Zz6urq8Pxxx+PBx98EN3d3QCAt99+G2+//Tbmz5+PoiJjmD7vvPOglMLixYsD59Lj9cEHH8xqx6GHHoq//vWvgXue6xhBEPqGfGwLQj+xZMkSPPvsszjxxBPxq1/9Cueccw7+9a9/YebMmejo6Mgqf8EFF2Dp0qW4/PLLcdppp+Guu+7Cscce67/8Nm7ciC984Qv48MMP8d3vfhc33ngjTj75ZDz//PN+HT09PViyZAn22muvj93+n//857j//vvx7W9/G9/73vfw/PPP4+STT84qt2XLFhxxxBGYNm0arrnmGowcORLnnntu4EOrpaUFt912G2bOnImrr74al19+OTZt2oTDDjsMr732ml9OKYVjjjkGd955J0455RT85Cc/werVq3H66adnnfef//wnjjvuOIRCIfzsZz/DscceizPPPNO60fTss8/Gd77zHRx44IG44YYbcOaZZ+Kuu+7CYYcdFtDL/uhHP8IPf/hD7LHHHvjFL36BcePG4Qtf+ALa29sD9b388stIJpPOfu7p6UFDQ0PgP9s9b25uzirXF5599tmC7vny5csBZPS6SikcffTRWLBgAQ4//HBcf/31mDBhAr7zne/gm9/8pn/MnXfeiXg8joMPPhh33nkn7rzzTpx99tkAgA0bNmC//fbDY489hgsuuAA33HADdtppJ8ybNw+//OUvs86fa2yl02m88cYbmD59etax++yzD5YvX47W1lYAwKuvvgoAWWWnTZuGcDjs/76969Qkk0k0NDRg1apVuP/++3HttddizJgx2Gmnnfwyr776Kvbaay+Ew+GsOjs6OvDee+9ts5319fUYOXKk/7umsrIS48ePt26cnjZtGpqamrL+uNzWMYIg9JHtuKouCP9RdHR0ZOU999xzCoD6n//5Hz9PSwqmTZumksmkn3/NNdcoAOrBBx9USil1//3355QevP/++wqAuvHGG7N+s0khlFJqxowZasaMGf6/H3/8cQVA7brrrqq7u9vPv+GGGxQA9eabbwaOBaCuu+46P6+7u1tNnTpVDR061L+e3t7eQF1KKbVlyxY1bNgwddZZZ/l5DzzwgAKgrrnmGj+vt7dXHXzwwVkykqlTp6oRI0aopqYmP++f//ynAhCQkTz99NMKgLrrrrsC53/kkUcC+Rs3blSxWEwdeeSRKp1O++UuvfRSBSDQd7fddltWX2jGjBmjAGT9d9lll/ll9D23/WdjWzKSnp4eFQqF1Le+9a2s37SM5N1331WbNm1SK1asULfeequKx+Nq2LBhqr293e/zn/zkJ4Fj586dq0KhUECa4pKRzJs3T40YMUI1NDQE8k888URVWVnpPwv5jq1NmzYpAOrKK6/MOtevf/1rBUC98847Simlzj//fBWJRKz9VldXp0488cRBUafmj3/8Y+B+T58+Xb3xxhuBMqWlpYHnQvO3v/1NAVCPPPKIUkqpX/ziFwqA+uijj7LK7r333mq//fbLyv/CF76gdt1116z8Z599VgFQf/7zn/M+RhCEviEr24LQTxQXF/vpnp4eNDY2YqeddkJVVZXVq8D8+fMRjUb9f5977rkoKiryXXJVVVUBAB566CGr9wIg48YLAKqrqz92+88888zAhr6DDz4YALK8LBQVFfkrnEBmE+DZZ5+NjRs34uWXXwYARCIRv650Oo3Nmzejt7cX06dPD/TFww8/jKKiIpx77rl+XiQSwYUXXhg457p16/Daa6/h9NNPR2VlpZ9/6KGHYtKkSYGy99xzDyorK3HooYcGVpCnTZuGsrIyX8ry2GOPIZlM4sILLwxsGrz44ouz+iZXP++777549NFHA/+ddtppWeV+/etfZ5UrlM2bN0Mptc17PmHCBNTV1WHHHXfE2WefjZ122gl/+9vfUFJSgocffhiRSAQXXXRR4JhvfetbUErh73//+zbPr5TCvffei6OOOgpKqUAfH3bYYWhubs4a77nGVmdnJwAgHo9nnS+RSATKdHZ2Zm085bJcbnvWqZk1axYeffRR3HPPPTjnnHMQjUazLCednZ15t3Nb59/63EBmzNosKHr8uH7rq9VFEIRsxBuJIPQTnZ2d+NnPfoZFixZhzZo1AS1kc3NzVnn2MAAAZWVlGDFihK/xnjFjBo477jhcccUVWLBgAWbOnIljjz0W/+///b+sl63aSnfZF0aPHh34t34Zb61zrq+vR2lpaSBvl112AZDxj73ffvsBAO644w5cd911eOeddwJ/LLA3jpUrV2LEiBFZevMJEyYE/r1y5UoA2X2my/LH3bJly9Dc3IyhQ4dar3Pjxo3brLOurs75Ievq5yFDhuSl595nn32sEoS+sK17fu+996KiogLRaBQjR44MaLtXrlyJ+vp6lJeXB47RXk90v7jYtGkTmpqasHDhQixcuNBaRvexJtfY0n+oam0yo90n6jLFxcVIJpPW83Z1dQXKbc86NcOGDcOwYcMAAHPnzsVVV12FQw89FMuWLcPw4cP9Y/Jt57bOv/W5gcw4sXmg0ePH9VshXmsEQdg28rEtCP3EhRdeiEWLFuHiiy/G/vvvj8rKSoRCIZx44olIp9MF1xcKhbB48WI8//zz+Otf/4p//OMfOOuss3Ddddfh+eefR1lZme9mbOsPYn28jVQqZXUXZ8sD+vYh//vf/x5nnHEGjj32WHznO9/B0KFDEYlE8LOf/czXDw8U6XR6m8Fe6urqCq6T+3nkyJEfq30fl5qaGoRCIes913zuc5/DkCFDBuT8eiyfcsopVm09YFwUanKNrZqaGsTjcaxbty6rjM6rr68HAIwYMQKpVAobN24M/EGVTCbR2Njol9vedbqYO3cuvv/97+PBBx/0LUQjRozIu506f9SoUVll99lnn6w6tmzZYh0Levy4fhuo8SMIn0XkY1sQ+onFixfj9NNPx3XXXefndXV1OT1rLFu2DLNmzfL/3dbWhnXr1uGII44IlNtvv/2w33774ac//Sn+8Ic/4OSTT8af/vQnfPWrX8Xo0aNRXFzse5lgqqurredeuXIlxo0b17eLBLB27Vq0t7cHVrf1Bi7taWHx4sUYN24c7rvvvsBH/2WXXRaoa8yYMfjXv/6Ftra2wOr2u+++m1UOyPTZ1mxddvz48Xjsscdw4IEHWlf6bHVyf2zatCnrQ3bixIkAMt48pkyZ4qzzk6CoqAjjx4+33vN8GDNmDB577DG0trYGVrffeecd/3eN7Q+2uro6lJeXI5VK9Zt3lnA4jClTplg3u77wwgsYN26c39apU6cCyHjq4WflpZdeQjqd9n/f3nW60FIPtnZNnToVTz/9NNLpdGCT5AsvvICSkhLfcsTt5A/rtWvXYvXq1VYf8CtWrMAee+xhzQcQ8OOe6xhBEPqGaLYFoZ+IRCJZq8A33ngjUqmUtfzChQsD8opbbrkFvb29+OIXvwggs7q0dX36ZavNyNFoFNOnT7e+/MePH4/nn38+YB5/6KGHsGrVqsIvjujt7cWtt97q/zuZTOLWW29FXV0dpk2bBsCsZHL7X3jhBTz33HOBuo444gj09vYGgnGkUqmsyH0jRozA1KlTcccddwQ+Uh599FG8/fbbgbLHH388UqkUfvzjH1vbrv8A+fznP49oNIobb7wx0E6bN41p06YhFotZ+3l7sP/++/e5LUcccQRSqRRuuummQP6CBQsQCoX88QcApaWlWX+wRSIRHHfccbj33nvx1ltvZdW/adOmPrVr7ty5WLJkSeC63n33Xfz73//GV77yFT/vkEMOQU1NTWDMAJnnp6SkBEceeeSgqLOhocFqFbrtttsABD2KzJ07Fxs2bMB9990XOP6ee+7BUUcd5cvGdtttN0ycOBELFy4MzCu33HILQqEQ5s6dGzhXc3Mzli9fjgMOOCCrHS+//DIqKyux22675X2MIAh95JPekSkI/6mcdtppKhKJqK9//evq1ltvVWeccYYaOXKkqq2tDXh00J4ppkyZog4++GB14403qgsuuECFw2F10EEH+Z4xFixYoHbeeWf1X//1X+rWW29V1157rZowYYKqqKhQH3zwgV/ftddeq+LxuGpubg60R3vfmDVrlrrlllvUt7/9bTV8+HA1fvx4qzcSDqihlD2wzIwZM1R9fb0aOnSouvDCC9WNN96oDjroIAVALVy40C/329/+VgFQRx99tLr11lvVd7/7XVVVVaV22223gOeQVCqlDjzwQBUOh9V5552nbrrpJnXIIYeo3XffPevcf//731U4HFaTJ09W119/vfrBD36gKisrs+pUSqmzzz5bAVBf/OIX1YIFC9RNN92kvv71r6v6+vrAdX7ve99TANQRRxyhbrrpJjVv3jxVX1+vhgwZkuWFY86cOWr//ffPuu/bI6jN4sWLfa8jjCuoDZNKpdSsWbNUKBRS8+fPV7/+9a/VMcccowCoiy++OFD2iCOOUKWlpeq6665Tf/zjH9Xzzz+vlFJq/fr1asyYMaqkpMQf7z/72c/UV77yFVVdXe0fX8jYamlpUePHj1dDhw5V11xzjVqwYIEaNWqUqq+vVxs3bgwcrz1/zJ07V/33f/+3Ou200xQA9dOf/jRQbnvWuWDBAjVhwgR1ySWX+M/voYceqgCoo446KlBnb2+v2m+//VRZWZm64oor1K9//Wu12267qfLy8izvJn/9619V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PvoozjjjDLz77ru46qqr/Drb2towa9YsNDc349JLL0U0GsWCBQswY8YMvPbaa6itrfXL3nrrrTjnnHNw3HHH4Zvf/CaefvppXHTRRejo6MAll1zil9tzzz0xffp0XHfddfif//mfQF+fc845OOKII7B8+XKMHz8+r2MEQcgTJQhCwSxatEgBUEuWLFFKKXXZZZcpAGrTpk3bPA6AOv/88/M+T2lpqTr99NOtvyWTSTVkyBD1gx/8IOu3iy66SI0ePVql0+m8zzXYefzxxxUA9fjjj+csO2PGDDVjxox+PT8AddlllwXydt99d3XKKadYy+a6z/mOGc0vfvELBUCtWLHC+vv111+viouLVWtrayD/9NNPV6WlpYG8VCqlpk+frgCoNWvW5HV+pZTatGmTtR8GinPPPVcVFxerlStX+nmPPvqoAqBuvfVWP2/16tUqGo0G+jydTquDDz5YjRw5UvX29g6KOl3MmTNHlZaWBuq8+uqrFQD14osv+nlLly5VkUhEfe973/PzOjo6VG1trTryyCMDdZ588smqtLRUbd68OZB/7bXXqtLS0qxxkkwmVXV1tfrhD3+Y1T7XMYIg5IfISAThU8r//u//oqGhAZ///OezfnvggQdwyCGHIBQKBfJduuOxY8fijDPO8P+tJS3PPPMMvvnNb6Kurg6lpaX40pe+lGUaHzt2LObMmYN//vOfmDp1KhKJBCZNmoT77rsvUG7z5s349re/jSlTpqCsrAwVFRX44he/aDVPr169GsceeyxKS0sxdOhQfOMb33BKHhYuXIjx48ejuLgY++yzD55++mlrue7ublx22WXYaaedEI/HMWrUKPzXf/1XVr3d3d34xje+gbq6OpSXl+Poo4/G6tWrs+pbsWIF3njjDWv/bw8eeOAB7Lvvvlmr5DbC4bC/Mv3hhx8CADZu3Ih58+Zh2LBhSCQS2GOPPQKr5B9++CHq6uoAAFdccYUvS+Hx9M4772Du3LmoqalBIpHA9OnT8Ze//CVw7kLG1r333os5c+Zg9OjRft7nP/957LLLLrj77rv9vAcffBA9PT0477zz/LxQKIRzzz0Xq1evxnPPPTco6nQxduxYdHR0IJlM+nmLFy/G3nvvjb333tvPmzhxImbPnh2o8/HHH0djY2OgnQBw/vnno729HX/7298C+Yceeija29vx6KOPBvKj0ShmzpyJBx98MKt9rmMEQcgP+dgWhH5k8+bNaGho8P/bsmVLVpmurq5AmYaGhoK1swDw7LPPIhQKYc899wzkr1mzBh999BH22muvPl+H5sILL8Trr7+Oyy67DOeeey7++te/4oILLsgqt2zZMpxwwgn44he/iJ/97GcoKirCV77ylcDL+YMPPsADDzyAOXPm4Prrr8d3vvMdvPnmm5gxYwbWrl3rl+vs7MTs2bPxj3/8AxdccAG+//3v4+mnn8Z//dd/ZZ339ttvx9lnn43hw4fjmmuuwYEHHoijjz4aq1atCpRLp9M4+uijce211+Koo47CjTfeiGOPPRYLFizACSecECj71a9+Fb/85S/xhS98AT//+c8RjUZx5JFHZp1bS3Rc/Zzvfc5nzOSip6cHS5YsKeieL1++HABQW1uLzs5OzJw5E3feeSdOPvlk/OIXv0BlZSXOOOMM3HDDDQCAuro63HLLLQCAL33pS7jzzjtx55134stf/jIA4P/+7/+w3377YenSpfjud7+L6667DqWlpTj22GNx//33Z50/19has2YNNm7ciOnTp2cdu88+++DVV1/1//3qq6+itLQUu+66a1Y5/ftgqFPT2dmJhoYGfPjhh7jjjjuwaNEi7L///r7MKJ1O44033nDWuXz5crS2tgbasXXZadOmIRwOZ51/0qRJKC4utm6inTZtGt566y20tLTkfYwgCLkRzbYg9CMTJkwI/HvMmDH+yqHm9ttvx+233x7IW7RoUWBlOR/eeecd1NTUoKKiIisfAHbccceC6rNRW1uLf/7zn/4KeTqdxq9+9Ss0NzejsrLSL/fee+/h3nvv9T+85s2bh4kTJ+KSSy7xPaVMmTIF7733XmAj4amnnoqJEyfi9ttvxw9/+EMAmZXq9957D3fffTe+8pWvAAC+9rWvYY899gi0raenB5deeimmTp2Kxx9/3NfFTpo0CfPnz8eoUaP8sn/4wx/w2GOP4cknn8RBBx3k50+ePBnnnHMOnn32WRxwwAF4/fXX8fvf/x7nnXcefv3rXwPIrBCefPLJeOONNwLnz9XP+d7nfMZMLj766CN0dnZu8543NDQAAJqbm3H33XfjgQcewO67744JEybghhtuwNKlS/H73/8eJ598MoCMhnfGjBn4wQ9+gLPOOgvl5eWYO3cuzj33XOy+++445ZRTAvV//etfx+jR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NTbj4iilDc+OOTrVFiJy5513yllnnXWqzRRFURRFURTlh4o77rhDDh06lPr30xpsh2Eohw8flnq9LkGQND+tKIqiKIqiKD88RFEk7XZbDhw4IJkkf2DDaQ22FUVRFEVRFEU5czRBUlEURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1GUe4w3vvGN8oAHPEDCMK0W2D3L3/zN30ihUJDbb7/9nj4U5QeQxzzmMfIrv/Irc+s/8YlPSK1WkxMnTtwDR6Uoyg8aOthWFEXe+973ShAEif//H//jf4iIyLnnnpu6zSc+8YnUv538f0ur1ZI3vOEN8opXvMIrBhAEgVx77bWzf3//+99P3ddjHvOY2XYveMEL/k2O7/Of//xsn6961avkOc95jpxzzjmzdU960pO87VdXV+WRj3ykvPvd7z7jHw2HDx+W17zmNfLVr371jD73r+Ev//Iv5fGPf7xUKhXZt2+fXHfdddLpdOa2Gw6H8opXvEIOHDgg5XJZHv3oR8unP/3pH6h9fv3rX5dnPetZcp/73EcqlYqsr6/LE5/4RPk//+f/JO7zn/7pn+Syyy6TWq0mq6ur8lM/9VOJA+IwDOWNb3yjnHfeeVIqleQhD3mIfOADH5jb7hWveIW87W1vk6NHj3rrL7vsMrnvfe8rv/7rv554HIqi/HCRO/UmiqL8sPDa175WzjvvPG/dgx/84Nnywx72MPmlX/qluc89/OEPlxtvvNFb98pXvlJqtZq86lWvSvyud7/73TKZTOQ5z3nOaR3bc57zHHnqU5/qrdvY2PD+XSwW5Q/+4A/mPvvQhz507vje9773yac//em59Q984ANFROSrX/2qfOYzn5G//Mu/nNvfoUOHZgOpEydOyPve9z550YteJN/+9rflN37jN07rfETiwfYNN9wg5557rjzsYQ877c/9S/nqV78ql1xyiTzwgQ+UN7/5zXLnnXfKb/7mb8qtt94qH//4x71tX/CCF8iHP/xhefnLXy4XXHCBvPe975WnPvWpcvPNN8vjH//4H4h93n777dJut+X5z3++HDhwQHq9nnzkIx+RK664Qt75znfK1VdfPdv2zjvvlCc+8YmytLQkr3/966XT6chv/uZvyte+9rVZBMPyqle9Sn7jN35DXvKSl8gjH/lIuemmm+S5z32uBEEgz372s2fbPeMZz5BGoyFvf/vb5bWvfa13ri996Uvll3/5l+WGG26Qer3+L7xjiqLcK4gURfmh5z3veU8kItHf/u3fpm5zzjnnRE972tNOe58XXnhhdPHFF6f+/SEPeUj0vOc9b269iETXXHPN7N+33XZbJCLRm970prv9vuc///lRtVo97eO75pprorvrAq+77rro7LPPjsIw9NZffPHF0YUXXuit63a70aFDh6JqtRqNRqPTPoa//du/jUQkes973nPan/nXcPnll0f79++Pdnd3Z+t+//d/PxKR6JOf/ORs3Re/+MW5a97v96Pzzz8/euxjH/sDs88kJpNJ9NCHPjS6//3v763/uZ/7uahcLke33377bN2nP/3pSESid77znbN1d955Z5TP5702GIZh9IQnPCE6dOhQNJlMvP1ee+210TnnnDPXTo4dOxZls9noD//wD+/2eBVFufejMhJFUf7due222+Qf/uEf5NJLL72nDyWVj33sY/KUpzzFk76kUalU5DGPeYx0u92ZLOF73/uePOtZz5LV1dXZ3//sz/5s9pnPf/7z8shHPlJERF74whfOZCnvfe97Z9t88YtflMsuu0yWlpakUqnIxRdfLF/4whe8737Na14jQRDId77zHXnBC14gy8vLsrS0JC984Qul1+vNtmu1WvLpT39anve850mj0Zit/+mf/mmp1WrywQ9+cLbuwx/+sGSzWW9muFQqyYte9CL5q7/6K7njjjt+IPaZRDablbPOOkuazaa3/iMf+Yj8xE/8hJx99tmzdZdeeqnc73738/Z50003yXg8lpe97GWzdUEQyM/93M/JnXfeKX/1V3/l7fc//+f/LLfffvucFGjPnj3ykIc8RG666aa7PV5FUe796GBbUZQZu7u7srm56f2fjMfjub9zQHe6WGnGf/pP/+m0P9Pr9ea+ezwez2138ja7u7tnfHx33XWX/PM///MZHd/3vvc9yWazsry8LMeOHZPHPe5x8slPflJe9rKXyete9zoZDAZyxRVXyEc/+lERieUqVnpw9dVXy4033ig33nijPPGJTxQRkc997nPyxCc+UVqtllx//fXy+te/XprNpjzlKU+Rv/mbv5n7/quuukra7bb8+q//ulx11VXy3ve+V2644YbZ37/2ta/JZDKRH/mR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ysc+9jG55ZZb5I//+I/n5Dqf/vSn5eyzz5aHP/zh3vrjx4/LP/zDP8g111xzxvdJUZR7GfdYOR1FUX5guCcqSL75zW+OarVa1Ov1vPXyA1JB8stf/nIkItEtt9zirU+qIJnEd7/73ejKK6+MlpeXo1KpFD3qUY+K/vRP/3Ruu5tuuil60IMeFOVyublqkl/5ylein/zJn4zW1taiYrEYnXPOOdFVV10Vffazn51tc/3110ciEp04ccLbr72nt912m7f+lltuiR73uMdFpVIp2tjYiK655pqo1WrNHVe/349++Zd/Odq3b19ULBajRz7ykdEnPvGJxHO9p/b5gQ98ILr00kujvXv3RrlcLlpZWYkuvfTS6Kabbkrc5z/+4z9GP/ZjPxZVKpVoeXk5+m//7b9FR48endtuOp1Gr3/966NzzjknKhQK0YUXXhi9//3vT9xu//790atf/eq5v/3e7/1eVKlUEq+Doig/XARRlJJuryiKskB2d3flPve5j7zxjW+UF73oRff04SRyySWXyIEDB+TGG2+8pw9F+QHkYx/7mDz3uc+V7373u3Me3g9/+MPlSU96krzlLW+5h45OUZQfFHSwrSjKPcYb3vAGec973iPf+MY3PM/oHxS++MUvyhOe8AS59dZbZ0mNimJ57GMfK094whPkjW98o7f+E5/4hFx55ZXyve99T/21FUXRwbaiKIqiKIqiLIofvKkkRVEURVEURbmXoINtRVEURVEURVkQOthWFEVRFEVRlAWhg21FURRFURRFWRCnVdQmDEM5fPiw1Ov1My7uoCiKoiiKoij3NqIokna7LQcOHLhbR63TGmwfPnx4VkpXURRFURRFUZSYO+64Qw4dOpT699MabNfrdRERqeRfIUFQ/Lc5MkVRFEVRFEX5D0oUDaU3fsNsnJzGaQ22rXQkCIoSBKV//dEpiqIoiqIoyr2AU0msNUFSURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURZE7nQ2iqLI/He40INRFEVRFEVRlP8I2HGxHSencVqD7Xa7LSIivfEb/pWHpSiKoiiKoij3HtrttiwtLaX+PYhONRwXkTAM5fDhw1Kv1yUIgn/TA1QURVEURVGU/2hEUSTtdlsOHDggmUy6Mvu0BtuKoiiKoiiKopw5miCpKIqiKIqiKAtCB9uKoiiKoiiKsiB0sK0oiqIoiqIoC0IH24qiKIqiKIqyIHSwrSiKoiiKoigLQgfbiqIoiqIoirIgdLCtKIqi3KMEQSCvec1r7unDUBRFWQg62FYURVEURVGUBaGDbUVRFEVRFEVZEDrYVhRFAWEYymAw+Hf7vl6v9+/2XYqiKMq/PzrYVhTlXslrXvMaCYJAvvnNb8pVV10ljUZD1tbW5Bd+4Re8wXQQBHLttdfKH//xH8uFF14oxWJRPvGJT4iIyF133SU/8zM/I3v37pVisSgXXnihvPvd7/a+5/Of/7wEQSB/8id/Ir/6q78q+/btk2q1KldccYXccccd3rZPetKT5MEPfrB86Utfkic+8YlSqVTkV3/1V0VE5Pjx4/KiF71I9u7dK6VSSR760IfKH/3RH82dVxiG8tu//dty0UUXSalUko2NDbnsssvk7/7u77zt3v/+98sjHvEIKZfLsrq6Ks9+9rPnjufWW2+VZz7zmbJv3z4plUpy6NAhefazny27u7uzbT796U/L4x//eFleXpZarSb3v//9Z8dsGQ6Hcv3118t973tfKRaLctZZZ8mv/MqvyHA4nNvuv//3/y4bGxtSr9fliiuukDvvvPNu76OiKMp/dHL39AEoiqIskquuukrOPfdc+fVf/3X567/+a/md3/kd2dnZkfe9732zbT73uc/JBz/4Qbn22mtlfX1dzj33XDl27Jg85jGPmQ3GNzY25OMf/7i86EUvklarJS9/+cu973nd614nQRDIK17xCjl+/Li89a1vlUsvvVS++tWvSrlcnm23tbUll19+uTz72c+W5z3vebJ3717p9/vypCc9Sb7zne/ItddeK+edd5586EMfkhe84AXSbDblF37hF2aff9GLXiTvfe975fLLL5cXv/jFMplM5JZbbpG//uu/lh/5kR+ZHcv//J//U6666ip58YtfLCdOnJDf/d3flSc+8Ynyla98RZaXl2U0GsmP//iPy3A4lJ//+Z+Xffv2yV133SV/+qd/Ks1mU5aWluTrX/+6/MRP/IQ85CEPkde+9rVSLBblO9/5jnzhC1+YHU8YhnLFFVfI//t//0+uvvpqeeADHyhf+9rX5C1veYt8+9vflo997GOzbV/84hfL+9//fnnuc58rj3vc4+Rzn/ucPO1pT/s3vuOKoig/YESKoij3Qq6//vpIRKIrrrjCW/+yl70sEpHo7//+76MoiiIRiTKZTPT1r3/d2+5FL3pRtH///mhzc9Nb/+xnPztaWlqKer1eFEVRdPPNN0ciEh08eDBqtVqz7T74wQ9GIhL99m//9mzdxRdfHIlI9I53vMPb51vf+tZIRKL3v//9s3Wj0Sh67GMfG9Vqtdl+P/e5z0UiEl133XVz5xuGYRRFUfT9738/ymaz0ete9zrv71/72teiXC43W/+Vr3wlEpHoQx/6UNoljN7ylrdEIhKdOHEidZsbb7wxymQy0S233OKtf8c73hGJSPSFL3whiqIo+upXvxqJSPSyl73M2+65z31uJCLR9ddfn/odiqIo/5FRGYmiKPdqrrnmGu/fP//zPy8iIn/+538+W3fxxRfLgx70oNm/oyiSj3zkI/L0pz9doiiSzc3N2f9//Md/XHZ3d+XLX/6yt9+f/umflnq9Pvv3lVdeKfv37/e+R0SkWCzKC1/4Qm/dn//5n8u+ffvkOc95zmxdPp+X6667Tjqdjvzf//t/RUTkIx/5iARBINdff/3ceQZBICIi//t//28Jw1Cuuuoq77j37dsnF1xwgdx8880iIrK0tCQiIp/85CdTdePLy8siInLTTTdJGIaJ23zoQx+SBz7wgfKABzzA+76nPOUpIiKz77PX4brrrvM+f3KEQFEU5d6GDrYVRblXc8EFF3j/Pv/88yWTycj3v//92brzzjvP2+bEiRPSbDblXe96l2xsbHj/twPl48eP3+33BEEg973vfb3vERE5ePCgFAoFb93tt98uF1xwgWQyfpf8wAc+cPZ3EZHvfve7cuDAAVldXU0931tvvVWiKJILLrhg7tj/6Z/+aXbc5513nvziL/6i/MEf/IGsr6/Lj//4j8vb3vY2T6/9X//rf5Uf/dEflRe/+MWyd+9eefazny0f/OAHvYH3rbfeKl//+tfnvut+97ufd51uv/12yWQycv7553vHe//73z/1XBRFUe4NqGZbUZQfKuwMMKGmWkRmg8nnPe958vznPz9xPw95yEP+Rd9/8nf9WxOGoQRBIB//+Mclm83O/b1Wq82Wf+u3fkte8IIXyE033SSf+tSn5Lrrrptp2w8dOiTlcln+4i/+Qm6++Wb5sz/7M/nEJz4hf/InfyJPecpT5FOf+pRks1kJw1AuuugiefOb35x4PGedddbCzlVRFOU/AjrYVhTlXs2tt97qzVx/5zvfkTAM5dxzz039jHXLmE6ncumll57295AoiuQ73/nOaQ3KzznnHPmHf/gHCcPQm93+5je/Ofu7SDwr/8lPflK2t7dTZ7fPP/98iaJIzjvvvNns8t1x0UUXyUUXXSSvfvWr5S//8i/lR3/0R+Ud73iH/Nqv/ZqIiGQyGbnkkkvkkksukTe/+c3y+te/Xl71qlfJzTffLJdeeqmcf/758vd///dyySWXJP6Q4TmGYSjf/e53vdnsb33rW6c8RkVRlP/IqIxEUZR7NW9729u8f//u7/6uiIhcfvnlqZ/JZrPyzGc+Uz7ykY/IP/7jP879/cSJE3Pr3ve+90m73Z79+8Mf/rAcOXLkbr/H8tSnPlWOHj0qf/InfzJbN5lM5Hd/93elVqvJxRdfLCIiz3zmMyWKIrnhhhvm9hFFkYiI/ORP/qRks1m54YYbZuu4zdbWloiItFotmUwm3t8vuugiyWQyM8u+7e3tue952MMeJiIy2+aqq66Su+66S37/939/btt+vy/dbldE3PX+nd/5HW+bt771rQlXRFEU5d6DzmwrinKv5rbbbpMrrrhCLrvsMvmrv/qrmfXcQx/60Lv93G/8xm/IzTffLI9+9KPlJS95iTzoQQ+S7e1t+fKXvyyf+cxn5gaiq6ur8vjHP15e+MIXyrFjx+Stb32r3Pe+95WXvOQlpzzGq6++Wt75znfKC17wAvnSl74k5557rnz4wx+WL3zhC/LWt751lnj55Cc/WX7qp35Kfud3fkduvfVWueyyyyQMQ7nlllvkyU9+slx77bVy/vnny6/92q/JK1/5Svn+978v/+W//Bep1+ty2223yUc/+lG5+uqr5Zd/+Zflc5/7nFx77bXyrGc9S+53v/vJZDKRG2+8cfZDQ0Tkta99rfzFX/yFPO1pT5NzzjlHjh8/Lm9/+9vl0KFD8vjHP15ERH7qp35KPvjBD8rP/uzPys033yw/+qM/KtPpVL75zW/KBz/4QfnkJz8pP/IjPyIPe9jD5DnPeY68/e1vl93dXXnc4x4nn/3sZ+U73/nOv+S2Koqi/MfhHvNBURRFWSDW+u8b3/hGdOWVV0b1ej1aWVmJrr322qjf78+2E5HommuuSdzHsWPHomuuuSY666yzonw+H+3bty+65JJLone9612zbaz13wc+8IHola98ZbRnz56oXC5HT3va06Lbb7/d29/FF18cXXjhhanf9cIXvjBaX1+PCoVCdNFFF0Xvec975rabTCbRm970pugBD3hAVCgUoo2Njejyyy+PvvSlL3nbfeQjH4ke//jHR9VqNapWq9EDHvCA6Jprrom+9a1vRVEURd/73vein/mZn4nOP//8qFQqRaurq9GTn/zk6DOf+cxsH5/97GejZzzjGdGBAweiQqEQHThwIHrOc54Tffvb3/a+azQaRW94wxuiCy+8MCoWi9HKykr0iEc8Irrhhhui3d3d2Xb9fj+67rrrorW1taharUZPf/rTozvuuEOt/xRFuVcTRNFJcUZFUZR7Aa95zWvkhhtukBMnTsj6+vrCvufzn/+8PPnJT5YPfehDcuWVVy7sexRFUZT/mKhmW1EURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEarYVRVEURVEUZUHozLaiKIqiKIqiLAgdbCuKoiiKoijKgjitojZhGMrhw4elXq/fbTleRVEURVEURflhIIoiabfbcuDAAclk0uevT2uwffjwYTnrrLP+zQ5OURRFURRFUe4N3HHHHXLo0KHUv5/WYNuWCn7T+puknCl7fwuj+ZnucOrWBYHLv8xm7z4Xk/vK4HOZTDi37WSaTfw+7mM0ibcZj93npqH7+5TbYh87ZptjMnHrMqPZcj5yv16WIncJy0aVMxZ37FzmlUr6/ZPH2jK25lUb4F+7wVRERLaCwWzdVgbLWD8y2zaiwmzdSljEebjlZWyzZs5vDcdWz7n7kcc9LeTdcrkQX7tKZej22+i5v1fccqHornMuHy8HuOcR2xiWpxPXBkbD+DgHfdc+21233O2WZss9s+1k4s5pOpVExqHbZjSJv3uCYwhwP4q4FknXJY/rxvadxbnmeG1z8UHlC+76FHJuuVhybbJac9ezVu+KiEi53p+tK+Hv+ZJ7IHKFeDlXdvvichbbZrE+U4mXMzW3TrAtG3jUdu1pulUVEZHRdnW2btSuuOWea4ejvvvcuB+v73fcPR303T0dj/KSxHhk+oCJ+/ug775jMMSxoQ/I5+NrX8gnX+9MQvscYV+tljun49tu+UTf9Rc7pu30xDU+Pt9TthGvzcXL7CNWxD0Lewvu2PauuDawttqOt13dna2rL7dmy7Xlzmy5WHN9R9a0Qz6TGfblufmHJxq74xni2ePyBPdsNIiXeU9HA3efeG+87zF9dRbPTbHs+pxK1bX7Es4pX4zbahbPVhbnwfdWiH5mduw4v/HA3Xce89C05X6XbRbtLXT74PcVzDPJY68td9054T7xnALTVjM4D55fwHuGxantO3fqs3Vbd67Nlo/cuW+2fPzY6mx5uxWfV3fgHvYe+lTX8vz3oD063tEC/sURRskcc7XgzqlWdue0tOSu0frajlvetxX/fU/T7XfVXbdCxV23TN61nSBrlnE/2O4DHEcG762Mvc74e5CbH7eIiEQJbTlImRDlttEgvk9hz7WhCZ6nwVZtttzZbMyWW5tLIiKyfXxltu7EJu5j0/XFW233TG6b7+6IO48R7mMkyeM52z8VcU9reCFUsG2Fz61ZpngijzFFCX1x2bxrCkX3zslncW/Q1idj993jaXwNxyPXD/cH6IembluOO/KmXeQS7mk/7Msrtn55Nk5O47QG21Y6cu7eoVSygYxwoONJvDzl4Nc7nuRO0s62sxMNMbBJGsRzgMIjTxqM8zgmuICDoftgFy++XRy/3Tof4EUb5PB3DoRx3uaT7Jp5FmmNM2cG7/mUa5XF+pLwBRwvV9B8V0N3zIcC1/jG5oHhC7yII13DYHsDPyBWzb1fQidSKaEzz6ScUyZvjtftK48fOhU8DMsN9/KvLcedZzbvvmOKF9sAL67dHXfe/V7coQza7u8hXuZFPMHlcvzdfMERPmQckNs26f0QxM3OewNldMRmF2OeB9shHvZ2Z77X5fVeabhXWKXiBkpVdlrmv1m8+CVy16qQwYu7Gr+ACiUM+LGcybnjCdAuMuN435mRG9hky+4FJmvuOKODbjkYxAPW6Jj73OSYu1aDTddhDXfx3JqXQB/tZohB5WiAH7gcxAXx8kjcC6pcxk0r4+WItmwHceOJu4aTAX4UTNy1GA7j7+hiILXTwcB75M5j6PUB8fGHgTuPEM/shOvRJitRfPxLkTvPDTSbFQwCSmj3+an5bgyOpm28rMdLbiddDEztQCLleeEPYPsS63XctWo13T3d2XGDgN0WfgybZ6A3dPdmgv4ih3tTxn2vmpduo+6Od6mBQdW0PVvOZN3zkjcTEfnAvawzkbv23gCb7zbbH4zdtQ/xA5F9Tmievwg/7jL4exQmj7CiSXwcg9HybN2k7e5pF89LPu+OP0jpi2fHg/fgeOzar71Xm1vu/t9x3N2zfx66+3Ak475vN4if5VGQMFgVkTL6/iraatG0l1rkrmuFkzl4xsumXythQNwour5jo+b6ln3r7tj2HIjv7/I57p4X19EWqm4fAfad2MZ5XTkIxztRbB/NfXFYMnDXIuq55XA3fv6mXfQzHfzgxGA6NO8Pts0BBsq7J9xgurntnrOmeeZO8P5uumfve1N3oN/LuXfDrYWmiIgUcG+WI3c8ddxTbzmMlwsp93cp565hHe+2ejVuTzVM0BULboKjUODEx9D8F5NEeOcSjiun5hngxMgQ70m+o/k85Uy7zmbn3xfd6UBkS04psdYESUVRFEVRFEVZEDrYVhRFURRFUZQFcVoyEkuQCSWTCaUInYxdDjyNU3I4y9PYmnAjQ/aBF57nFH48dZ8mF6GEhWEAK3FhGKEC3Wm96rYtIZw62Y3DCtv4jjFiQnkIrKi3bBvZSYhQcZq+u4Hl0kzj5CjhZ1AB1zOLSIXVE/dw/i3st4tj7plQXxPa8x5kMkezLhzHfRw1yxWEwmtDFzKqUmuHYyub+9eoJDexPGQiZejnCkZmUAxcKCmP9sY2wrZTrsTH3++58Fin5UJsHchPbNuj7n86ZajJ7XeI9tQ3Ie5xSo4AJTWMKGVMe+DfcwilpelRk76jg5B1FLmw4AC60aoJrVLHXfLOD+dkQshpkpoMwma8D6V6vO8ytKSFZfd9WchEPP296QNCSGcmOKcp1idpZXPUoAa8nm79BBKPvLkuGVz7fg/SCYQQqcO1fY0XuoQ+nW3PhueXcV33Yl9dfF8b4eJ2z8hPENLvTt35d9CPbOFZ3TbP8F2Bu945zJsUem650XX7axyNdbg12Zitq/P5RZ9LLaWVMZVL7hgY6i0hrG/fBxnICShfKED2UC5BimOu12jq1m3huWjjWnTHbnlkzrW65WQPeyMXTj+n7r7v3INbs+W1jWZ8btBF59AnRZCwUHIxMctDPG/Dobun/R7zAYxmm20dsjTKG5lLZMlgVQGShVIBORe4T1Y26Uk6E+SYIn6eiGWM561SdN93APekMnHn3TTDhy5kJAMsR55O2y13zDZDPL8D6Nd7uC4Vcy4V6G5Zhq9ccnKlZej9p+Y6sw+JJskSgaCMXBN7nXk/IPkL28gpudN99xQ6aksWci7h84D2MDS5HePu/LHHB43jMNcrD+lEY29ztlxddTKZNeS2DE3/0206TfcDIO3ie7IPyVOv3zD/defWw7u/BTlMB9erZy5tD+OPTYyTdiZu20LH3ZOyeRctZd2xr9XcvVmmVGwpvkbs93OUFuN6c9kOeb3xasqYgvLV0EhtcnnI8sx3RwnPbhI6s60oiqIoiqIoC+KMZrZ73ZJItuz9WrazxmmJjvz1zplEm2TG2eo8sqg585n8Kxy/NpMnvGe/8Hm8/FXM4+Evmpw5tnI4P7MmInI8cLPA+QBJhsbdYw9cPpiRm8MyvRPsHvKcyfBms5EZTwcV84sKaWle1jexd6GEpIUBkrGG+OXJPE27mEUCRBnfwWTREmbGGpX4V5//a9TNgtaYxFScnzEc4xc0l5m1zVlX25QnCZENkZPbZLwNZ7MJv4O/eu2MdosuJrjcvBZF3L+CmaIqZ9zxFjAjVaig3efm2z2fBSaMVJEcZB1IREQqZn0ZM9sVXHvORufNDCUdSDJwFckwqpCQie/NCnEGAbNI0y0kFjbj5T5mIoeYhRl5zg7zy5ypmqZkjkdewl7erMNhot0U0fYKeADtzBdnTpKSY0TczAZn1DsTd85ewi2OeWjaUQt9J2ezOTM08GYP4+PoYrab0bQ6epcGnlvrCLAfvf6eJfd8rqJd1KqubdlkJGb+20iSiEgObdbeEyYd+ZEEunFk5pbZe7H3pfMKz6lgPlBD37OGCMQq3CoYLe2ZSBedaaIUpyP//pnoFkwC2t3kyIW915mUSG9IZyx0ZUmz0Vkkjg4KiMhiBtq+U9Nms9m3MGIz2y+SN4dM6sVx8p4sm/ZUjzgT6xZ9cwCH3UcuSP47epSZO08bXUsTjhk7veXZ8gk4HN3+/f0iIlKBMw3vPxPYK0lOTmj/jOhxljQLd4yC6T/LK+69lkUCe37NraeDU9n2qew7i4gO4P5KMT7+iLPyfSSwtxAVPOGuxcRcl+GOm9ke7rr+iaYCvV04muzGn2tjXRMJzluYHd/ede3ettUA7SJtXMIxkW0XjOgw4uP1nTYpvYPzRP/LvprvfpsY2WOfxLFGynNvEyS9can5jp7ObCuKoiiKoijKPYsOthVFURRFURRlQZyRjGRzpy7lTFkm0/mpfcpIWLEyl03WeCR5FnPbIkLWtrAEEzPL8PRleMwLIY9tQYvc3LqTl3sDt9w0YYE+wrRlyC8y4kIQlWj+Eh7PutAVw7uUcFS85fiCDRB26SCJgAE/Cies9KOHEPMufFAZZrbbUjrC6GbB8wtnUZ75+1dC6IeemQ0UGyjmp3IyDL0yzFxgwk9+PhnWKzCRkkxoQ9lMtvSOuYSEPbM/ylcoJ8gXGMh02HBUlBKmJZ6sISHM5Hl4elIFelxPveM9GSZ0FXHeVjJSYpESJi/CYzZjZCBBKVkuIryPPA17nPSVhf9xhGIEmUPuOCrjE/F/kbgXtZy0IIT38hhh4eFOvNxHKLSLZRYOGUIaYK8dpQ4M6+em7trTe9XKTygnyHpheNde7HcwdMkwPUOPJayvmb4zQt+TxXMfYC5khL7B9jkjPJtV9EP7Qtc/nY31Zy3Fx7zGAikIs/M4c/n5RFRKcTxv2oQCP0wqZBjXT0aSOZgAXvRyw5KlDHbPIzxjHXgaZ1GEjc9krRovl5Bslk0oziPih5Zte+B5LNV7ictJz22a3CnJKMBLAMa9oQQiqRAPEyRHkIZQYjeCT3jXJHVSCnAYbfIOeJGfyLp+pmPWZzx5ZPL8HbdZMj7MG6F73pZwV5lqaOVDVawr4Cvq6KtYg2DPnrjAzZ4DJ2br1g5uzpZrSCwsothNbiV+NjIoBiUr7hmZLru2Pl6BDMo2M7TZEd6Nw2yyB/SZkDWJldk+rvc2ZC3bOB70o71jyyIi0j3hEupbLHoDaUi7hf7VyPvYVpjgS3lvo4riZ6Z/LY1g3IB+DWXQPHGJvcq72HaKJMzJZH5sN4QEpFh07ZfPCJ8tey5dJDJ3+8nyqaxXQ8MUOcvNj0v6KiNRFEVRFEVRlHsWHWwriqIoiqIoyoI4IxnJl3fyUpBCQsHhdKKUEuSBWc+QoF+WnMsxvsOD+1yZITaEr22Yg5IG+pVyebUBmYHx0szCD5PHtgthRxshNiu/YEn0Ca5QB9s2IgTLTFgtSJEn8Br38a9mJj4OWzZXRKQJf+oW1lsf3lpEpwJ3DBsIPe9D6Hnd3KAGylov1eGCcQq/XYajSwhZV2vwZ0Yo18pHxiN3bH1k+3dRBrrjLcchL4aH6JFNbFn1MqQTDKdTrpTLzoeWGZai3IWZ6kkhZMoMKFWZ5lKkClG8TRGSqSIkIJUlyDNQiri0dzc+9lV3jYMqgneQ+0g+IZZPqQ78bSkZCZfjYxuvQ+5UQygcjTYzxvXqG7/SXUhZ8Bxm8XUh/G0zpoRxkHK9KcWJivNzCJQ9jBB69Mr2stS2kXgwfB/Aeob7szIJyg26aLMtuK3sduCjba4tw5D9FG/iAmQky6a/WEPAfRmytCWYvC9B2mNleqcjg0qC3vFsv3k843RosEwgHyuVnSCAz1khH4evsxn3TOd6kBqlVCK38hHP+QLbjhD2HrFEuZEaUWLo7RfHnORQ4DmXpEjbrCyH/YwvZ3PbJkk8uN/8BP2Qa07eM2CPKUxxWeK2xWC+z2WfNd2GhzSelzzaajOIr1Eb0kW6WvHdRx/4LfN9lDxSYllEW7fyxgrWrYXu3qyhi19bde4fh847LCIiey64a7auepbzWc+tu77Tk82Z84sgRZI73XOWOQxZKCQFkiKXncE2BHnFrK9lE2Itgeq8pDGCBC9sUi7iZCKUjFi3kT79tCG7oyPPeMRnzrosuWvfQin57ba7LkkOXXRXY90QuplxfDgyl5BC0CO4NYf78EmfLcOfXDjugod7gg885bEh2mw+pc8tmTER3eXs0uiUo+AYndlWFEVRFEVRlAWhg21FURRFURRFWRBnJCMZSiShRBLRHcL8N4uwWp7FPTCer2B9xSxWEYopecU7aNYf/5dhLpa+pll9mOCUMkBIkMtpZTptGJJZ0Ty/XsaFeSjbsE4fzLymWwmXGTWy4bRjCKD0g+TMeLqiWNnKOEgOYyxHLjxkj6kI4U4Nx7OE/a7AVX6lEh/bSgPFaVBAhYVVGMrPm1BYCRKIEhwzyvhcCbKUgtmGpW69+4QQ6Rjhr74x6e/uulBZDzKTQUIp3yQHABHfPYGZ/bZUs9cOWYQmm7zsCqQkuz3k8/NuLPHnEoo5oShIT1zmeJI0oISQb24Kl4QpJCX2OmdT4vQ8BEhKMu34WuQhqcqgjPakmlIwyJxeMMLx0pmkjy6JxTSMbKFYc23Iu38sMtNmUZu7v2elDFxcUNxiFkKl9KCHkC2KIthy3CxrfAwOK4fxKB/NuGu/Y/qOVs6t68FBiA5BVci/lo38i24OVfQoy5COrNVd/7Rk3BqWlyE5wvPpO7ag2Ji59t7zi2eWTjh5I5nwyp2jzVZbru9oLLvrubwaL+/BM8vrTdcBLttiOHRG8Jxg0CdRtmIL9fA5zJ5CBsb1/JznppTgrCTsv8KU5yLhehdQaKpQHSQuZ3GuoXVoaLtrSMeeASQA7Nds0bBe131u5fjKbHn5+PJs+XDT9bnbpujbAEXcBinh+1HAsH28DeUidbx/yhgzJAkB2dM1IS244671uW37kHCtHF5135FQ2EvEyaAylIiklPb21pv+M6CbFO5NFvfS62vN5nyvRWP3DgtZun06/95iHzlFX8X9Tcz95bVgifYWHEiaKGCz04rby3FI3zah0dpFXzXGeyBv9FHViP2XOx4WqKrBsWW9Gu+jVnHPEGWqhfy8pIZOKa22a9+bLbRTSGNORPEzuQkJUxt98tCTlLhjtvLbqjeeM/LBSGUkiqIoiqIoinKPooNtRVEURVEURVkQZyQj2StZKUpWkJQ/Cx4wtJPHchnD+QJCvXkTSqkU3bR9tYzsZIbjTEiHoXm6RGTSCueYUApDPww30/CfLhajMdK9E2BmNZdL0fy6vBcSc1eJchC7nCbFKWCZYbWRCcd1EaIbMyMX6212bi7lGIoprjHWSL7X5111IajBEFIVhELt/aHMZGnZZYtnEaZjuDRpXwzNRQy3sjiJCREzPDhFhn+IbHCx1zmlXfBzDIGPjAPFeDjvWnGmeG32FCHrAF/BcDOPjSHirTs3RMRJeURESlWE/XFPCsbdJMfiHvhcBrKWDMLwtjBOZgkSgiUX8sutuf1N6wijm3OJSrj2zLjvuHPyQqHm+Ry0XKi7veWKMfQQFvWy601olcVp0qBkJAkW0sp5fZFxSsEjtI7wboAwbHnqjq1hut9Wxq2jY1EHYdpdyNWOZeI2fgSfOxa6PuvQ0LWFjaFbv2ZcltYRbl1CIZAa2whcM4pGcuDJq1goDM+DlZrkKYFAKDiH4lGVhpPtVLvxsVXblIFRRgLXGDjB2HvmSYPo3oPvYxGrJIlHKgnFZ+how0IgSc4OU++6JfcXlL5UqvF1qaJATm3J9WtlyJ1yeCatRIX9F999dDJK2qYP2Y7ntkKpAtaHMn/t+B7JQDpAhy4rt6T8sU0ZQsR337wbCSWPIQ6BclIrxaGTE98N9UPOmaSwx72XZv2Z59hE1xF8IV1ohub44KDkOZrgvkfoi0LbRnoo7OXJQXDtzbbjLhy38IxY1xERkS7kIG2z3N6lXKQ+W95uuj71eIL87ThkFpuQ3Q1x/yhJXTWyIo41ltDs99bd/liIaMm08WrVtW8WqcsmyNy8IoYs4IRrTMeplrkGTbwvdvBOGaY8n/YZoNfSyHz38DSH0TqzrSiKoiiKoigL4oxmtstBJMUg8rwRg4Rft3kM4Yv0wsWvwqxZZrn2MRKwspn5X94BpvjGTBLAz42kpDcmzwT4KZxWKr5sZttr8MNc5q9RzE5VM+4SWp9H/oLxvRrpHzo/c1301jnoL17ir/esLaOM5E16/eJXsZ3T6CLjrYskzG3MorUwE1Pqx8sFzNjk4W1Zxm2o4ths6fb1Zfc5RibKSPLxEnfML8s8vGn5i5YeutOEUsSccePsDb1+k8quh14ipFtmYqWdteIvZXr3MiksqRQzZ5kmXklltw9vf+ZzeZw/Zx8ZNahitqtitmGyZZq3so0aMCEoYHIQ2l5S8MObvfFmc901YidjPWZDRErGnNWBt/2UPtvWs3jF+ePm4Y2+NGq6z03m7/uEHtqYveBsbWLyGmc+cQ09X2QTYeh2MFuy7Xxuy5tuObOFcvTmOAYRQxdukTNDSf74e+CNvwdJavvRT+6puud6fTluI6srLkGy1nDXk7NIXjKkaU+lWnKSXgbPtX2OxogUtk+4CAT9fbtM0jIzbW1GKDB7zOclzXPb4vXliNiU0V7s7HcuwRdc5KRnnMumPaUlVzNCNjt2PNP09Q7xmPXQvzZNkncGzcJLWEXSp+ezbZ4/Rhs7uA99PKssad8yJaqPI9HrqDeb6fqZYRalzc2bjkn3jM6WsL4eunt50LTbFbwpN5DUu4qZz7qZ5SzRkx3L9C1fXt11+zt0XERElg5su23XXLvPLbtzos/2rD9D/8W+aopZZc5Az/y5U0p3e4n9rAVhZlWHWMe+iqQl7c7+jrZXTkj2Zl/Hdkgf7Qz2UTfJ6ufgPAdTNyM+STlXO16psY4Jop4rrA+BfqRcie8JE469uhOsf2GSJTMpif3eOxzJ7Dbiwb6gVkVCMe7DAO8fa7Yxwhh1YJZzUehPeaegM9uKoiiKoiiKsiB0sK0oiqIoiqIoC+KMZCT32deVciaUEOEDG4JgEognz0BImqEw65MdpHhYZhEesGVrGW5n0kYBoUCG3uyxDRHCCikdwD4YMtgyZUiPIDTQgf8ifcYpDYmMjGSIv/cg1aDvKJMli+aYmLDopXMxqu/5as7vd4h4xgTX2yZIsqQpPX2HOM5MQvi6gmPL4ZyZuEKpzbRn/Y1diIb3nyGtesOFlitGGpHNnTouQ8mIlXgwCWRnx4WvOyz5bsKCgyESIdl+cY1CYXsx38sQMo6HMqkCSyObcFoBz0Lac8EQuC33XCwkh8KZxMbkr7xZZiixAvlFAfITG3qcQjLFUCiTU0OWGTanyuc0KOGe0VuYsg1z7UOGY5lUxIRTJr+Y8F5v24Ux6anuJ63OS4LCFH9jL+kaSWrWMz6HUGiax64N0xYn7n4wmbJScm2vUUa59rbxN8YzNECi0QDPZBbzIitGRnIQMpKz0JMfWHP3fWPNhdaXV+JEsAbCuGUk4RXRtjII31ooxRoN3LNFudbQPIf0uO/j2RuNXHi+D+mELW/PMG4XkiKGb4l91xQhQ2jU3HmEKXIPmzzcgOc4z5/315OjGV/fMcu5U6KEdmYlKmxjXigfn0tKrKRUpeAlerpwuldi3Ya6IXtZaszL0kR8WY69Dye23fN0eBdluSd376M99frLZCJs0zR1Kpr4+23oOta23PEfMr7e+yBDWF1Gm8V18c7P9AdTjhnQnsITuH8dmCOYhEO29ciTmiEBFM9I3siVsvn550bEb0PEJhJ73umUS1SQ1GsSXANKn5jIivObQJo5NstDrBvAi72PxMohZJNd8wzTk3sXycD0td6F7GbXvFePo2YCl8sn4OdeceeyZzXulzY2mrN1dcjcpniOpqZN8nnylvEeoRFGxxz/cUj7ttHWe6Pk+1Qx74E6PMDXTB/SD/siRxM/5qEz24qiKIqiKIqyIHSwrSiKoiiKoigL4oxkJNnsVHKZqYTIdp+Vr0Umc5rzgR/KDc3n4SGNcPoU0Rj7uQkzesfJbg75/HzYl/63U+yD0pEdeOHeZSIb/wxPyV2U92Q0mS4BNvuaCekVCELoTFLB7xwbgKG3Nm8MrxoLltqjo6yBEpYxgnrWE3PoyWH4HZS1MIs8PpI1uiFwW+yjDElBZSadgIwG4c3jKAfcbDppgL1naWF/3ndm2m8b6c/xkfvcCZxrP5gP7+UR2qzhnjVwz+i2kjXHRrcdz2EH1z6TcPgM+Ra8cs8o65uZl5fQVYTuAwyVeY4H5jozCzub8FyIuFLFOfgiZ+EEIyxhjYZtPbc994VxshSFDc1uT//YEcKYoxbcOiANsZ7izNT3ZWfJ4dtsOJ+Jz2tFtxnP6cZIoqaeJCXNVcLK3Nyx0V2ihTB1s+c+Z8U8lIExJF/HM1eBvGTDyOIOIOK50YAzC6QhVbjXWLcRlhT3HHLo2AMP95nDCEPy4/nzj7eJj42+2LzGbchLdhHK3t6Nr1ET0q4RjWDcoidVsHe14Lpqz2ljveH2RxePamSPDW4dkLtMEu6viCvpThcTLntSBnON6Bc+Hic7TVBKZp1SvFoEkEvQNaYAt5UZKc8FHYco07P3t9N0EoETR1zp8zvu3OOWj7tt7jLPyBbkiPTTpl82ZVDZBBcLvu8osdy1EtIdd2+O7rp7Vrpreba8UnPXYmM1lgetre/M1q3ucctLkCpUV52UqGykDDnIOnJ1OO9U3XcEWBYrLyjh/ZqfL8suIhLgHSVWtkCZFBu7V8AknNsXfb2zcE3J9VFLwbg9FSH7KLbgqb/rnkPKS8pGbliH7KzecsstvLcb8MdfNe/lNlymBkP0v7j/3YF7Pm8/Gks7tnE89OFeWXbfbeVf1sFExHcxoc82n2X7HNGRqYJ3Hx2QOFa0crRsguQzF6SJp3x0ZltRFEVRFEVRFoQOthVFURRFURRlQZyRjOS7hxtSDCpeZCNj/sES7pQ1TJMjKe7zWOa2JOlzWYb3E46HJBXeuTtq5gz3o1BEOcUlgIUnbNiMYTCa/BdTyq5b+QgPnV4cQxz/0HMTia9MCyWeKXehZMQeky8RcSGTZSzvwdHtKcbfsYZQWg0htiIlEAxZzgruuPOgYT5DunTVKBlHgDxCQpQAMOy723SOCOVSHNIq77qQbQ0h+90QYaWE0vVpD0KP7dfeX1bvneCe4gbmEWEMzPWk/CQbuJAeJSeFhOJKBThilBFOrsFVhNdoJu3CNUzLhs8WjesG7m8Wbg7MfA9Qtjiom20acAOoQOJSTH7msjvmWtyBcCvCdXQu8WQNJixI+YnnboTwbQBpjy1gQ0nKBKF8lt0eJxST8IreeKWB3bHZ0r/HdlzbO4awaRM9WB8hdxtNZX+xCulIHuHWDTyT+0zBqGVc+wbagl92HfIg83zyPEaQi1Aa0ocEyS5TDjKm8xCWrbymP6Ckxn1HD2HjNjL/rVxgkOJs4ctIIH0xyyzbnR+68zsC54PGlluufC+WRlSKKPOO54xFVKooN183Dj+1hiv9XUF5aRYDypt9pMk3WLgrQFu2sivKxLKUnaHsehEl77NmPb+Pz0vIZwD3ZGikW6mSIhY5K7rj2DCfa3Xdflu4p33cE95XK1mso79chZNRlcWHzPelvTtqKLS0tOzKrq/vjcuxrx3adNvudwVuivudS092zd1Lqcb3JCqjf6rB1cupaGRSRd9gLhdevxKMIefpJi8H9gWTxUuAkhIWbcmZZbxzBG2Wn8sU5qV7lPOFLNKHdwPX236C/UUR7aJSw+fQRqx7HGW6Hbx/d3GcO2gXLdM3Dsfo4yEpqf+zk62syyEREVnOuc/Xy3hXseYhrpctRNPBe4btlGJEvjHt05JLkJUOo9MbRuvMtqIoiqIoiqIsCB1sK4qiKIqiKMqCOCMZyZ1hJAWJvIz5cTAfLg4QdmABGIYFpwnSjizm/osRQ/zz8oxMcpTaizdOZ/+lQ8e8Kb+ISBPxn51cHMYaIahQxKUqpPxGCRPOyZNtIERcx/qpWS7h/FyQT6SO9cu4RiPjbsJ9VRHSYEGdkTnXCe7CwCu4w/ARl825MYSO7F5KIFjYKJiYYhMIx7LQR62OMGx9PgybTSiqIeI7QqysN2fLh4wEYIy/c1u6SkxNCMlz18Ayw6lJTgtJkg0RVwhFxHcQsTAcx239gjTjuW24Lg9ZQAHhba63ziMZOiYgZE3JSG4lvg8ZuFkIQsWST8m0NpfAy7hn+A+hfC/73hY34LUvu2MrIPucBXXsOQ07yW4lIcKCSZIZhtYzobs3hRIcYpKcHUiKy1KUEPanMwldLnpdFxbtWnnGgFn7CL0i1L+LWOcJ47ZxJwpFDI+56zKR1dlymBC+L6M/WcJ9WIKkolF196Rh2ksdRZKWllw2f8krtBRfQ7rmRF4RNLiNwLGk142Pv9t159HBvR7iek5YJMlc+yHu+RjtkO5UVbQz69jSgBykivMroa/K5SiPM+eV8N4T8SVKtkAI+yRKbtIkSne3TuQkuV5CoTB+Xx/XswdpkO+WE68/1nL3405oOo9m3HOxG7jlaRDf91BgBUOnJrwc6MRl34kslFbu4z2JY2tIfGwrRXee+1bdfVrOUs7j+o6SkTpSxjjYcRoQymiKkB4W9sVSlGAZ/dAQfccu3SiokTTbstvvuu+I4KYy3XF9wNQU9/IK0uDYvCJJ5j2Qg4woV0/uL6coGjbcjs/bc33CNR7B1WuINjIw/RadhUYpy0P0xfZZpWSshWe2hT6JY7OqaQ90BvOK/1H2aRaH6Fs6cJSj/LPtyfjMeyTFQYd4bdZ8t+ewY5ZHpylT1pltRVEURVEURVkQOthWFEVRFEVRlAVxRjKSr2R3JBsMvHUTMwU/SfQMEclhPM/CKXaKvoiczxLCSpRf2FAC/15KmOLntiLO3aPgyTPm3UNERJgMPszEoYZmxoVrTgTI8MdxVMSFLqpGJlJOkY40Qne567guNqxLLwRfcoP1XojF7BfnFOK7KSNpmfBfG84lPZTIycDG5buRCw81pvFyfccdXS1yoaYqJSzeOcUsF9yZrNZdCHKZZvUrLou8YcLTFbgr5PLJRTgYTs1VjXMHsu/HCHMxtGrJM8MfjigsAMNQrpUnpBXc4bYRtqG8IOk8CB0hrCMAQ9OUTniFRbBcNCFyFqfJsmiN5zZiCyWw8lPKb3BISmy2flhH6LKG84eSI9eGY822KWaFjPQsHAy876a0xyzTtSFAAYZhj2FRhDdNuHQ4cH9PkwGxPc2+D39PkwDYbShVGkIaQmlEG8dsw/dtuOa0IYdooRPYRNjzmOmX6EI0RY/BvriMLn5/GH/3QTgPVSAD2lh1z9y+vc65YW0jXl5acw4O1RVXYKKIULZ1zfDcCRAiH0JS00URlcJO7DRASVWj4b6D98GTqFjHBLRfSrjoasSiF/Z5p0QrrfATsd8TJRRmETlJrmbuZSYLuQykMZMUR5ck0iQnPE677MnV0MdV4JTCa+SKarn7MWi65yUPV659nsDRnEeKrJTOWRNINoemfdI5a1tQLAb7tjIDuj6tHHXHsOfIwdnyOd86MFs+70DcVvfs2Zqts4VQRHzXmBwctWx7KUKiV8S7KIttM7n59wTdPNJkZwE+Z5+XLNphYdnJZDIJBZMoEdk9sn+23N12bh29XVdkxkqJuiwoBSev7R33uSYK3+yafmkX176Le5okzxChLAMjl4DP1t27tXnjMrQGtqeZ0Qse01GKaxvlwi3T5lqQQ3FMNIAPXAFjUzuOzSXc02nU9wdpKejMtqIoiqIoiqIsiDOa2d4TVSQnZe/XiP0Vw9LgSUk5Iv6sc97MTJckeba6imU7C1zHTFcZMzJVeOyWC/RatLNh7hzGmFHrIsHoBGZfAjNrMcYvIp4HEyf5S6hq5qY5m72M2ewafttUsb+SWV3GjE0pJTGNCR99M3PSxi9PzsdkEq43pw06+EWXx7EtR+6Xs408LCHxcgXTliuYEW/A87NuytcuYdZreckls9Qwa8XElry5f5wNHk7c8dA/M/QSr+Lj44wiZzPpoWw9gjk7lU+Z1ZokJFZyXVoSk59kmZnbdkr/25SZcntMpaKbZSljxoXXjbM2SyZxlEmBBdwHL7nLzrLA51aqmE3BsxVW3Oei+QkuyQxTTPVpIVwwzyQ8UTMTJCbyerJUvDlOztaXMAM0xex4yHtmEg5H9I2Gd6vnM43P2VluznZyFjSDWXAbxWCb7WEGe2dzGcfmtrHtcETP1wnbQnLbqplnsYZnklGzQ0h2Prjk2sv+jXi2jyWs6RfN2b5ieT75ljOAnF2mT+/URGNGmMHuYOasjdns9i6WTbnnbpde3skl05mInTftooHkxgbKS+cTZrNFRCrGn5pJxkzK9r5vxJn5uE/poTw1z6OD9TbxlcmyTCSbTJNnqwtmNrOMhN08rn0Vvt5VJJfbmXtvttuLDiW/U2z0Z3l5ebaucXxltnxix53TFqIwg4TdsVvgu4jb2qvMll5EU68i8bBk+rAykneLeCbLJddmmcC7bKKlK+suGlNDie4SI6dMSrdJiIgE5uHlnRohNEmLAftRJlBi3BHuIlnS9EWTDiJzSNhkf2gTIBnRZNv0+j0s20RG+uT3kSDpeeIP8Tk7DnJHI1105jtMnEWUom2iFDRg4JiwhGHneuiOaZ9ZbmBMuIprWMWYyLaHYoIRgYj/bPne/vG13Z0gwohz2k0wlRARGZr1HOfa8dWEg7K7QWe2FUVRFEVRFGVB6GBbURRFURRFURbEGclI9odFKUhJ2gETA0xYWOalJSIiUYoHoU2QrEAuwvBBhaWvzTJLsU8Q5hugNHKW3p42jI6swjxCEUtZhIogS8m247BKZeLCn7sBQs9BcjiulHBOZaEcxh1zHWVGbYnuIpIJ08qN9hCy3TTrjyN56mjGhbw2sdyReQ/hBrQAq0h6PBi6c90fxtvsRd7Heg0evAilVVhm14RA6a1dRpiaPrZeyNqG8ZAYQr/sAZLN+j13nO1WHMptNt0924FcgD68GVvOPJsm1YFkiCF+I1Xowcd3lCIj4a9YW8Y9y/Bu4qdO2ofZqIJQWa3irguTTBnK3jVh+/ox57dcRWi9ghLPNpmyAO9thk0zCF97IdRqvBzg/kvdtYsIYV/PZ9t4oUYIpU6a7j5NkKBDv9mRSSakzzY9YemzzYTSvvlcvwd/bpQcnkCqkJRsxjbLkD0lJUn77eB+NHeWZsubSGI6Ya7BUVwfPstb6J8YvrRe+stIdFxG31lG6DULGYGVZXQ7ThZAvARPhJkzCUUNKCOhPIFJpkn76nk+2kjiMiHuAX18WUYa/T2TxDu9+BowsWsJEp561d0/JgiWK/GzU6CEAH1OGlYGxHZD6RplQnZ5hHYxQNg/g/ZWYLK2eeYoHalUIMdbddKIJcgkbFKfJ4ug/36CxFJEZGySi1eOOulIoeA+Nxgdmi3vwg87b15SKU78Xh+3jveuTZRfW3ESplWcUx19lfVwL3iSmuRaA9VV9HF7m/G2e1zyfWYFUjr0TwJJnzBZe/Z3yH3QzwSUidjngdviWoWQiUxbrq2OmvEzYPs3EV8m4kuC4u+gPDCPPtm1et9/3bajImRUfP9SfrOBPrVl+lo+W9WuO7YsEmezeOPZeikdCFAoKaExwzYrz5uxWxH3I0dpH/TABdOePB/9yvz4Q0Qkhz7JStBY26DbS5bUjJDsOjTPcBdyoJY5zqEE8hdyanRmW1EURVEURVEWhA62FUVRFEVRFGVBnJGM5OxMIMUgkONT97EdEx6gz+IkxY0kaWRPX85ehHAkpBh2Mp/h0SJDKZCAUAIwTCjb7DtNuO/YQnjkqDmOY8i2pRymDBeAJMkIv7WUUGJUxC/1WjfSAIZrJwil5F2UQyrIdl4yYY69CFcdGrvw9c4UjggmPM0MYvpLMlt4F+sDo2UYTRkidyGYGkqklnIuLFwxYbolSBKW6smOAUvw2bbhwizCqt4yQkJZlDy34f6lZbevfSmlZQfGpYRhfzofjNFuev0E2w3c4SwizxOWtKf/56ypwnHAC58ly0us7CRHyRHCZkWEU/0QoQ29Yh2y74uUQ5gwpOeegpLhDJtSERaYku5+KBXnwdBsF97gJ+L2OT7h5BRDuoNQJgI/WeuZPuE9Y4lgZtdDMmK9ZVlymKT5KdsQPx1tdnecNy0dZKyryADbMjS5ixDyCfQzJ4wE7yj8/NOeSdYjsM5B7LzZbkaQXNBxqVSMr1ex4NYVILnJDiljo/94fExsT/Qh5vNp3S8mI1YNwHGy3cMpxN4nepL34Z4wxH2npMQeJ+UyDC1TGkJnkqx5f/A8+e7IpEhjMgXrqT5O3Dbp+4qQdVS980h2I7El6D25U4HSAnFg2fo+835k6LKU4kZiXS7oXOJdi5RnpGtWD7x26j63jP2xxsKBfbEbzp69zgN7Fb7uVbhW5ROkMVnex6I71xzeNfnVeB+ZJdQFwZhB4LoRoax62I6f1RB9iycdwT7oRpKx5d0pryqzDaFvpM92Pd5HOUj+ewCHryDBoSwaoI3AxWRwzEnXeptxX5vJunVse+zj6PRjlzkuKWKZNS3YV9mxIKUjdG0jlLKuGFncEvq6Gr6vXqKcMm4D+QSv83jZfQefcdvnsA+hzCuCLU4R136pFprPuevTNvUcBtFExBndpKIz24qiKIqiKIqyIHSwrSiKoiiKoigL4oxkJF+LJpKXsYwybnrdhgzSbL0Z8aKkpGjG+SymMmYoAjnO1rmkABeIEjJ2S0gyplTDujlMWQgGy018xxbkFdu5OLTDsscryLxlqIxuIzbwlPUK+ThKCCVlWHrUyFmqhWSXD0K5g8zOO7nUb57uJ6YQDUvvVgK3rx5cEOh80DXr6QSTRdGeLEJJRZxfIWcLsrj9MkOYLgAMw9oiI5QL+MVgsnPbijjpQB/Z1D0UyBgM3XnbkDRDTSxU00dobgsymS1zrj22TbcLaeAalRl6MzKQAkKMhXxyyJ5YqVEZhVzqKGRThTSErhk2VJZFyJNlhMe4bjZ0nMexMfScwXdnEhw4IsgUGIb2CjqArAm30uWE3+GVQ6ZkqG+KCiBbnI4gZRTtWc24kLSFLhEjhE1Z5n0AKcrYyCsYyqc8ZQfFWWzRj7s6btsjKHxF6VYr4yQ8NszKZ2+SUDRBRKSOcKstKlZPee4ruO9ry65drK/FEqtlyLbqKC5VgnNHke3JhPLzfH6xLdvLrJw5i/fwGsMppN9217PSie9fFTIiFoNhUSq6E9mwrhcqRsn3sudAwhLd82059AqBwNEmwclmiP6E/UyfRbXMMQ8gy6J0cYpQtieDyVl3KtcuRnTYwfXM3O5KlCcRon/mu4PFdaxUbqvt9nsYDl9HIW1qZtxzNkxwnuG7L4d3Y2PHfd+e7X0iInLg2/tm687a49rhoYMnZsvre+JnucZS63jWS3BWYhuYSUpwvb2BAKA8I1Mez60TT+KBfpsFbOz6KhyZ6nguIHUNeu6YMjvxtY9a7tqHPbxVWPAsMt9H6QQdeyj/w313RbfgroE+kBJLSii7/fieneA7EFZAO+i32IfZI855UiTINiAvOYr+0LrYbWN8UUIBvWX0r3uN7OxgzX3v+nJyW2i1UJTJSG2aKM40pOyOY0WM0aZmecqS8Lag4+nVtNGZbUVRFEVRFEVZFDrYVhRFURRFUZQFcUYyknwUSF4CiWAuTteQJPjXkucwMl/Wg7m2nK5nER3LBIVlKHsYJ4TkCziKXDD/vfF3I/vehD+G2FcHoTQe+xCfs+eXT5GRdFCcpoCwfsFkRufbLnxSzLjQZRaHPMHpdafWPJ6hHXecHRYfkvniQwxTr0JeUkfopmGuXQM3cqXsQjcrDSd3qUPWUDUhW5rnl1C8hiHdIrbJGPkBw5+hF0o7tWOAhWFThnKtcT3davooZjDEfaLDSM0s1rz2hPA1QsEMC1tXkQwjmghdRSnPUMZKtHDPmS3OcDoLa1hHhDzC6b7TAuRMRgJACUiY4OJz8jaRydQOvDAtGioyx6Pl+YJKwQkXes9CqlHAuWaYtd82cqas+xzlMHS/SCoswjY0hbtA6N2H+Wz2LI6hvuRC2WUUGdnYaIqIyDmQQGyjqM3xHXfM2yO3Tcs8k3xOeyn9WhFtpGqezyraofsGv3jSBOc6k0DgumUyTtYxRnuaoA1Y15c0uROZmmdu0KWcC4Vs2i6kywJUW0aK04JzzZCSi5SvtnesCMeepQplV67PqUGCZQvH0D2E/QnPldI1S4R2wwI/dEKxzzuLZ/lFM9Ke+/miW3QeqkDCw35vYNxbtndQjA1OOHSm6eO7d81zewRSgO2s+w6+i8MEpzFKn/iepLSAA4FvmX+sh66N7Dvi2siew/eZLS9lzhMRkRpkHQ1INVaWIB9DYZwN43Syss85ntQ3nHwqTxlUgqMFZXeE7SJDlyzrzpTiJMJtpZDwfZAuRuirMpBhzhyeMP4K2N7ozAJpnnVyKaH9L+FaEd+tLb4GLKonOM4iimo1KMM0fRj7Mros0aWEXcq6Kay3gf3WUhy87BX4Z0hL/rHj+tw+vttvvzGjwD1PncwkcVuOG2thbm5d5qT/ngqd2VYURVEURVGUBXFGM9ujIJQopVQ5Z3vzmCHyZnk5u5bwOc4505/aLnu/NVNmOnh09vcKEy85xzZImRG3onzOnucws0Rv7byXEBIvp/2CySfM5os4If4uvZmn7rs5wz7AMfWMyTN/NfbhZzkJ5mckCjj2jcjNJlSj5F/y9trRu7eHWeBp081OcBbFzp4W8EufiX4srcoZiYZJhOGMDWccmShF7+SeSZjYbcFnHL6jnNUZm5kDzgCWMHNSK+FXMf04TanWIWaF0ub6+Dm7PI2Sv6+I2YkKyu/a61VmRCAlUlCtOW9aW46dfrUlemvTI3nml43rzUSxNn2Y3XLORApyk/lf+iIiAb2QMbM7bcb3ZHTczb4Ndtw9G3ZSZq7Nd3sJjUiG5exjmDD770VHToOcabec7fS+A8+n3YYJwCuRu/YsF1xB6WObpNOEh/0AbcRLGOdzb5bHXjQO3u94Pid4PnvmGjaQpFhjOXO0J9/PPl7OwdeeM/7ERhLGSOjr4T7ROzupNHIP7amFSMnIS1aSueUpVgZop5UdJoQ7n/SaTT7Gs1cqpiwjmbKYkCSc5pc9Ox7P55cl03HPkFC83IjbzhKSAiuYleRzz1l1O9u+98DxxGObTpKfEZsM2uu6dnF803kyH95060+gXHXP3JMu3qOst8F36tDzXLa1Ody1uC3rEiSPoo5F1Szn8b3TJsYG6DvWb1ueLZ9dPFtERA6soyT8irue9br7vir6xoopXV6CZzdrFDBJOIe+Oh8O59ZxZptELAlv2kvEe4MoLJczRbPM5GOUfmc/2t12/WvL3MudzeXZum0uN5MjIbumfkcPz2Hbq8fhzo/qA3uvOUvMyNxq6Pp1jjuqZny0iq56mXVF4NVeNlHbHBJWvXECo9boZ2zkrIkE562pO54dnEdSWx7L/D0dS5g+EAA6s60oiqIoiqIoC0IH24qiKIqiKIqyIM5IRnJ+VJBiVPRmzO2kOuUbFCSwaC8T/exygL3lM/w7fCnNckpuo5dAxs/ZJDV+LvKkGu4LOwg7bJuNmggZjHCGbfiMJ0ljvBL0CJUNsL8SrlLFhMqYQMrlBpaZvDgy+6jBL3s348KcuxDN2MSVFhIDep5PppNcbCBxJW+SFehfXkTopo5kpFoFSTwm1MnQOqUODYRI6Zdsk7HoAzpBoiP9b1tIQmsaL82j2y7keQResTu49lZSw8ZfwP0IsJwUHWL7brA8cQHXBUmk1jc3kxJOphd5UqInk9UGQXHu7yLJZadDhOSn2EeRCYkmgYwlkDMsScxjS/DGDiANEvpsIyxKL24bQqU3M0OvTDxjopBNWGJbQZ6Qd428UH5CWH96GslPdh9T9BFMEOV9smF9ykyKpWLituyLspl4myySAjsI2fZw7BN0XFZK1oW0hPKy4/hcFslN2VZ8LsvwnV3PuuWVChOfXRh9qR4/t0zMo3zBSxoz6/OCJEX4DbM/yEPOYhN/hyPIG0K0ezQtymfsUgHPIZOq1oqolVBz310zUirKQrKZ5JA0mZWHzyXf0zykNrZcO6VIlG8ktSER5xOexTVmCfZShRIHlCg31zbHa4wEUa5nAuDI+J23jy3P1q3c5vy7qxXnh73WdO3FSvMmaLP9SXJbPtWYgXhjhoRtua8Knsn9SMQ+96zYq5uSmqU1J1csLznpSIGyHJswzroDlFSxfDrWZ+x6fE68RG1WZHDYPjpNRjKBBGJqZJMTvAPHfbff7q67N20kye5sLYuIyPa2kwbZhGQRka2220cT/YWtQ0LThWNInN0J3HVjkqwdz7AUe0WYBI/xDOZ714yUqoZrzJLp2YQE5mmKkcIY19MzQjDLI9wmzjhXUuTCVu7MMYOVNw8TpCVJ6My2oiiKoiiKoiwIHWwriqIoiqIoyoI4IxnJ2UsjKQdZ30PYlnv2/EX5dzh6IDxtw230Oc3TV5fLCaH1tCxr3ys3XmZmKst2+1mqbn1kHBja2Nd21oWovJAJJBzWi7GO8OceBMUqLL+Ma1QxpVxLXgnv5NAEPS9tSKSN89+Cs8FmBmXHTcjnOMrtnkCp1F7kQkUTL2gXh3oDeF9GQ7iRsJQ6JABD4wJRR2id9zGH9pIfu+/O5+PlasNJTign6MHLmG3Ahq/peLIXIbaRJzOYP176V4eeAwm2MefKsHEZ0gq6ivAZSfInZnn4Xj/Fb9c8O14p5zHkMHT8oPOMdT/Bd0zgDlGAO0TRhFALcCgpIExN5xJKP2aSEYbbw+SwMUu3Z4zUiOW8c/T1piQM19Ye0xgl1SeQw0xZwpvZ+sa9hjIaSfGL9hw4zLkWEWKmE4HnAmH7GfQnA3hLM7xbZyjXhHeDwMmhJgjp9qfJUgZb1pguRN2EcskiIksI5Z41je/7AZSOPrDu+oAluDJQ7mG98unaUIY7Bq9RwXyOsgdCP/Qh2mG3Ffcz9OQe9OnVjW3pbmJC6/Tlp9PRyjJdJ+DYY46/SHeJfLJEKUJ3OJNosb/wnjMsG/kb2yPbDa9hDcdZNn1fnm4XOKcc5Hr0iLYShoznvYxzgiSMz23RlAfndxC+U8Nw/2y524+lCm2+X1O0IZR7rFbi42N57XoNbQvHYd8H3jgBy3XIEVf2b8+WGwdjf+3SXicdySy76x2UIX+D84zk08QtBq+/w3rb9+HdGMGTWugwgn4rMOvDYfL7gt7ZIvHxs++cos8pQObFZ9LKjqq4xksNJzNZg4MX5SWbpi+qTuAegrFGM+P6YkpKmpm4fR4O3PO2Ke7Yqhl3zCvonw6Z/uksuLVUIcdswBWmsRQ/L3TpYRuhHHGEPqdjznVr2zkTHdtycrb2KHlsY+XJJfj523f/IJqIuMc3FZ3ZVhRFURRFUZQFoYNtRVEURVEURVkQZyQjqVdGUs5kPUcPSzYlU5/SEUpKbIjcn+53h8PCONzG4kkIKFVBKCHJdSDIIESeSw519kwoaBUhocwU4c2UUqDWhWQLjh9ZSc5ubUFqUhzG51dCqCmpNKmIXx48kxBlZgl2Rrms80gT4Z5q5MIrB0MXStoX0pkk3mYPvmwNrgVVyDYo4bBZ/gxHUxrEAhkM79pCLAxDM/RcwP4qCCvZEtR0MaFzCSUVM3kG2mm+kOwI4hvlx/eHhXVOp1iKc9OZd7sQ8cuuTxJKQ/O54TUsFlHsBiFEez290PQyCtyg2E3W3Cc6kHihZ6xPKkXMcGxamDryqrVn5/aV4bVnBj/lYeY6e/cDRY0GKIYzndx9t+aFxfF9LJJj7wmvd4HFTVBcqGgdXbLJ0je2rUKRz0h8YQrsI1Mcl7wCIebJHqcUGKugKAgLSKyYnqSC+1TEOVUqbEOQlJhzpQuGLZwkIlLGtrY0tFf2Gf06r32Q4C5AiVYBJcqLJRTBWm/O7Y/OHfnCvCxNxO87coWEvt8rnoVnEs/7xLRJ9gEDSJs8FyXzLFPuxXfSNKXvmJVrRx9YRbicoXNel/ysBD0cVvLJfRllVX0j3bGuFSIid961MVu+/biTFhyF4qIZ2OI07hiG7KvwLlqHDLFtSmxv95yUYbnkQvmrS66drRi5wPKKK7VeXXP9V33NrS/ifZAzUpQMXHWCVff3qExJnFtMtUhJIuH2BSX0kVW0sUFy0amoGz+fAeQgLHrDe2YlJQHlEvhctph8363UKJtLfo9wmWOisrkn1V3XL9bgLFWmsw7GBxnT3vuQ2LIYTOQVqJpfHmO/dBJpQUJq+4s0dx+vrSeMAylb4hjFk17Szetu3vP9cKAyEkVRFEVRFEW5J9HBtqIoiqIoiqIsiDOSkQyHOclk/I9YR4dpgtRDxJc6JLmU+A4lDJG7kIid5k+TfQwGLlQ6Rgh5aGQEDAHkUiQuOYQhrStIDkVRGMYdeMUk3P7GJgbFK5Hx4lLu2HKQlBRk/tql/Qrq4zr3TdilgxDNLgruTPHde4w0ZA8kIvyOZUhK1hGGXjfZtytVF2qpo1ACM/+LSSFyhILLDEPXkt0MbNESZuIXawzZu+X+rgs9ZrLxeSU5f4iIjJBoP02QaqD+j0yzyVff7pthauIVofCcV+J2m0kIm4v4RXsoKbHwc3QzoJNCEdfWhvXLCPUXscxCF7Y4jScdYUY+iwaw8IJx7Jm2XYiRcpAM5SUIaVpZSoBiBZmJ+1yYcP4iLuw96kEmhPA9pSOUhjj3iOTiB4T3rJBwjyfMxEfIfXIsXs97RzlBu+Pa6W7LPX8d45bTRoi5BbehDp7fHvqcvHlyD0HaVkWxqwYLRSB7fsOE5zdW4eCw6twalhiqR3spmZArC6jQ+YDha+uUMIJ7yBDhXxbb6KK4TqcdL/d6bls6e6RhQ+AMBVNmwftIGUnJ9D+ZbPKzRYkLJVb2/FhYZMh2iGO27YxuSpSnjPDeYttJKqjD/oJhf2LlLGMU+2KbZTidz8DIyLGacM3Zarr7t40+oAXXm5Zxw+nhHTjE8gQSgTsyLs4+Mm2ZTjln9913n91zx79nO24PjePLs3VLh53EZQ0ykn0HXQGbPebZauC6Frqu3Wfg6OIVojH3L0pxAmJhqwBOGVJOeCdwTASJKIt8hcYJhg4ldBthcR0rL7GfERGZdFzbG2y7Z6t9wrlttI3zBvus7S24IsGZYxP3fcfIaLegG96ERJYObZuQ5zaDeLnAPokFbjC+WIK8aMlIDMtwr+K4rEBHmsL8O5V4bnV431tnuuHIHU8PrmVD3IcwYUzLMayVew3D0xtG68y2oiiKoiiKoiyIM5rZzuVCyWVCTzh+qpLoxP+lEO8ji409f0ks29kAzmD73p+YOcDMQtf8YunjV+UYM0cDnMcm1t9pfr0N4EnNREevlDp+1eTNDHUeM9Us0lrC+jJ+5lTMzImXuITZQJYsDXHenV78q7CPhIrx1P1S7KNEbMdczhZmwTdR2v27WTfz8I8yH0Eod915VjpIkojgIcxfrGZ5DQ1jreT2u7oEL9wl991Lxje1Bp9tljLOpCRB2OUcZn3KFXf/Skhos+2F7a3oeSgnf4ed2WU79n7pppT4tb++mZTlJbCklHO2iWVjJnqmJP+NEmbXBphRLGDWg37RNhHVOzYkuma9Y8ayiTx4M9hop/SyDpHEY2dlppidmfL88KxO6UdrLjkjG1xOw85yRyk+6t5sPf1rZ/cas+RYLo5dm7T3p9d1M9idjnsumojAHN5xM0c22ewEZgubmC0aeLOEro3UTBRqA1Gqs5BZeXDFtfsNzPzZxMIaEpIZVfKWcW1te+Gs3hh9MWex7TWcpM3g0mcbCa4dU7q9idnuwZCJyCmRU3NMRbRT+oVPEvz1RdxzxIgQzzmL2TUmTtqZxlwxObrVn7h7Yn3EuyhLTx9xzmbz2tpooBe5KiXfJz63th/xPfczicucge+ZyAsTMhkhHp1w90Q482fPg9+Hi1zE+24jcv1TwcxgFnFdGZlhPvWWmV1t4h2Xa7p91Y+5WdkjR1dnywePrIuIyN7bT8zW1VbczHYJkVWvPyzNR1ZzrDVAj/O+u15B3hwTI6tBchsK++jv+vP9IaN7NIewy+yHPM9t3NM8+vC6OW/WtsilqAQ4tuuN4/bLMicljIP2hsXE5Y6pG7AbJPdloSQPEJPW5jjLnZufxU4aA4j4zwDbdVJiZS6L680oLMej5vnMJEXOw+S+4GR0ZltRFEVRFEVRFoQOthVFURRFURRlQZyRjOSOzbIUg4qfAJgQ3Zuy5DL+XvGkEXFIYIJEhCFCRV0kQlnpBKfwM9lkyQnDIIPRfIKN/V4RkQITwZC0MJjEYZ67kJTEkMgwQLgGkhKbuMRy7fw9w/DJmImOo3ib5ghJkyhpmsX5FTIM2cX76OAabiOMxxLONsGTgRh6cjNZZT0qYX18XVYQ5lvFT7QarmGpiGubi0NvlMBUEJqjbywTX22yYBNlrdPwwzzz3tn0FeW2SaEkeuXSQ3e36eQX2ybxqIswIEPTJZxrIUEmkhbyooyEScIlE6rmtaL/cbXm5ABlJq+ZMDNDpSzBXsC2OSsHYTg6RQ7CJMrsmjmONchzluFx7yLnkkFyav5EfH9zx1xoOmxBhkBJCeQnk65J/kK/MIE8wUtMY1KYCbNyHSUOLGNPyYEtwU1pCZPNkpLY2PZquDcrTKbDdwxb8fEP8Gz10Z8MIfnKoX540WzDMP0KvO8pHVnb2Jkt28RBJvKy1Dh9xildsn1tJqGcvYh48V/rfc6kwT5LrXcotXHLO+bZ2kXC12iMEHlC6WQRkbxJAOVzmM+5feQh52Fiob1/TFjsIkGQ14Xb2GQrJhvSz58l5vvmGrC8/GjMfSX3BzZcXsfzuwSpHRNAmaw9k/B4CddMDqMcDe3QHD8TeTd3nNxlG++lTbxTTpgHm+3Uq2aOmzJG+w2i+PxKGH7Qk5tvzzBhHZngPcpEt23z/uB51pE4SpliteGurZWPUB7o+cHT5IH+1OZzOUh8mDjMPtVL4reypJr7HGuBJNU2kBQTAPpzT9ru/o2a8X0tNl37LkCWRLOCdfQXZ5vr1WonS+JO7Lrn7PB4vr5HF/d8gPHT8Yx7hx3F8mYYf8/+qXteDmy55X0dlHmvx+dHgwZKv3iN+ZwNTP/Efmar59phCwOkETo2e2WTpMDD6PSG0TqzrSiKoiiKoigLQgfbiqIoiqIoirIgzkhGciKM3TV6ECNYeULAsHjK5zNw/MgZ2QbDRwyLuiCI812khCKDLyl4/sbzJbGniHgOGMbF8bQRarCZ/3TXqJ9mqEDkpDLp+Nc0JfxTNWHhFaGMBCEMfK4LmYx1GOniO/oppeQtnrc2nFRq8E2p4z7UTZh2uepCYjVkZFP2kOZxnfR3hl4pAypYf25KFpgODcYIyfaNP+8WvUQRNtvpuPNrmbAo/UO3EB7tYznAtciZ5QKlIwj7V/E4LcGFZdlIl2qlZLeZIJiXJMTrrdMPSpEjvN1HeLrUhoe5CTMXWy7kl+QxLOK8uHOQ+NCBJIP7y23EPGeUJGTGKX0Arv10Oz6m8QknzxnBe5r+xVPc33Bi/Y3pbJHsre35CZvrlST7OBnPFcZ8zm9jkEMgtGrlAm3IJbaa7pyOIEx5AiH3jvEpjtD+y+hnGvC+r3jtLF7eD0lcrQKva5xrD9IAe43o7pPmGX8qr2ff93lerkXpBV1H6KPdhktHy8iEWpDzddA/d9GXjRLqEvDZW225EPEK2lZtyzlX2DL1dDjI4v6zNoNX+nlq3yl4j6CNjCF9GU2spy+kQSwBndJdFsyz1eq669aGsxBD52U6k5h+Ms2NhE5dSfUomvDMP4Y2exj94S6W7ftliHfOEE5WI3qV851i2nUEBwuW8B5DVmVrUOS9Ptfti0pQSj8qRja3DB/5+rJzI0l3dDH9Ghws6DyTx7VnfziT48FRzHMugTuIsO+34xUcg9B1g6449vzYueI+hZtwjdlFmzXtcwp55AB9VQcOQJRvWt91r19ruTZJ6QjlRduZ+Lz5HsWtkYa4+17CvS4ZsQbHhPRMaVPm1zYSLTpdUQKC90EXz2THbNPmuAzLee9977Dtl2O7rvkHVJJ3i85sK4qiKIqiKMqC0MG2oiiKoiiKoiyIM5KRdCSUgoSzcqsiLsye7L/hQu/xNvNhZn6OwUEKB/omdDdA5rEfgkNoLmEf/I48lhkSGCCMZcuxtxNCZvH+5qUF8fEHcyeSRciLMpmaFz6J1zMccSfiJ76IIpxb34dhPMs693D81gmljO8dw1WFIZiId9CGcrvuytEloAJpRAkhNFtatQoXjCrkC9Way0Jmdr2VLdA9YoTwV1oo32ZMNxE23kX2cguh3JaRj7BdnIWQfYHLuBShaQKjlPBvHve9iLhZUpGnQmH+Won4YW0bIq54xXkQQuZ6FucwoU4v/MkCGVVmzI/Mf1OK2iBU6pV0N/KRCFndLEnMjPmIBRtseWKEBCkXocPIEM4jQxPKpGMGlykd8UraW1kSsu+zKYULgsz83AMdOMpop2t7tt05hfOFXFiunYVM6FZhi3SxRLBXTATuAj06miQ0wG04A9hiVyJ+oSzrBsRn0it04Tn5zLvpUM6VSynKZAtIcJ29ByIi1WpywZmOudfZIO2N4GBfPDTLbdzHHchPKrvuWjQQAq+a8Hwuk/wwU9lFmWKjGp9LHe4RdfRlJa84Vvw5Spy8ct8pshx77bxrSBkYCnRRAmGLnQz5DKEdUtpDxxJbUKjdddvmcP6Uyg3wbogSPEJyuHBldHxJRbWH3jgiWSqYNe+rOr53Oef2u4HiaPs2mrPltfXYVaOx4px52O9RRlJAMSO77ElE6ih2hGXKRAL7HmTpdzZf6l1OIbcUuqgNE+ZDWegGz/oUfXHkFe6K9zHouL6nteMkVbtchvRwx7xLN9uuPW1Bbkvp5WbGXYuWkceNcU9Z+IjSkTretSumdLvnfAYZDR2Xls19KJeSZXCUTA0onzFFkux/RXzJCa2V2DdYN6Q2xhE7pn2PUor0nIzObCuKoiiKoijKgtDBtqIoiqIoiqIsiDOSkUwkmnOcsCG9MdZzpwWEoEqe5CKGkgwXrBApUIph9p311mE5JRRoo1ghCwawGI7MhwlERJZMWHsbxWmYvdrJ0LnChUpsERkWr2EWdlIBHBEXVqHjAEN3dMQYY9/2OHo4BhYY4HFYJxRKS3g844y7+pkQMgoTKiyEDA/OFr1rT2eSsgl7MqxaRCi/gNAyM7/zJiwaIMxXQkY9w6kFOCnY/ZWK7nO1igvfryJrmU4D7jwQCoeUg+GovgnDhrgWPOe0dmgL+xRxvKUijx3LPKfCvDNLDteKTgMszpIdx99H6Qgz9T25gwktsogJQ5CUZHB/BROSTcvOz6SE96am8MQIRRf6O67YRKfplnsIafa68TJD5Dz/NCecbRNCHOBzIxb3QFiU9922W0p4ypBf0MXDyitOx/GE2H6JhU5YmKMNp4EthD23TF+0hX5oM3DH1pvA9abvPndoK76GByPnOLCB8HYDYdpq2Z2fbbdlPsuUKOFaJBVw4n2aphQGqpvwPYtBbcC5IzyDa8t9lNDP8JmzEi32Q5RteLIOPAP2mCfjZEkGnVfG3Xg9ZUKDIdthcqkWe5yU5ZUhHaEDie0jTj7Ok4/35HMitj8c4d60semJjLtumyi4MjbtcOK5Obh91OCs48sX54+D70OOGQoJLhAs4paBNKhYcH1H3RStqS+7782xb4V0xOu3TNsJ0Bd4kgy8RygJmlXzCVPaKe8NP2ckIyzmxZMN0AZmRW0oUeSxeQWzXN85NDIhviP4zNZRMInPQ70e933LKPa0gqI2lTb2h3uSN3K8LVQzG2BcQhlyB34jGVMhkZLW6RRFoCBlTTLwSpNjFiMWzZt/9w9x7LssgEOHHLNM5xK7bpwokppHZ7YVRVEURVEUZUHoYFtRFEVRFEVRFsQZyUiKkpFClPGywW1IYIDQQFeSM3KTQkU0ES8i5MVQUlL0iwG4CveL75tJVRgS5PEgq7mEcGrRhCAKCN2WUMSAnvO5AM4cgSnUQ9mKd8yUlCQUS+HfPRcXB3O2qyb8x+u9hazgXS4H8XIncOsY2qkhK7iWccurUSwzWI5Q9Aah6RrcFeooRWQLuTRQbKNedd+9jNBVDdn8NlRPyQmdDwglFdbdhDKTCkKFPRjz27A2w6r8jnwOLjS4713jfsFQP2UmaAqevKRopDF0c2DImqFehqHtcrYLiQvOmSFkSk0GpsjKEG4dZV7jupNGWBlIseauVZBSqChgkQrzEGQTHEpETgpvIkQ6MdeODg2S4MQg4jstVKRnztOdMyUJLD4zRva5ddVg6J0SiMmUsgaZW2YRlj7aOu+ZddWgPKUNZwAWJ+nCaaBrQpYdfHEHz3Ib8rDdrLs/9lneDNx9JA08q3vCMtbH313DpW8kZPiLnCT/MteLkppaveu2Lc+XdUgrBkR3DMq5BqaNDOBoQxnNBO2JfXXd9C8VSAHotlKrJ7se2TB6mrTCK2SDdmb7gyicJm5byM/Lp0JPUgPJHCVo6Bvypi+iO0wxQV4m4vdbU/NMJTnexMvu2g/wTFrXmzGKlFTwntwXun1Q3mjli5QF9CEL6ECyyFB7zryvwxSHrxI6Uvto0EVsGcWc9q26+7sXbiQNU8Cm0oBTDPq44hLWr7tiN7mVuF0HeG8JJFWJRWa4ntOXVBfAwUsgVRAja8iOUZRqmiJFse0I75yIDlB4RpKK8lAGmOuyL8Nhou/sGhelFlxMtruQvPFS4DArpp/JoGhRI4B0L8W9w7aHXciWepFr3ycgRfqWuWV5yBGTxlQi4n2bK8Tk1vYxJppQouO1z4w5t3mp7+mJSHRmW1EURVEURVEWxhnNbEfmf0llx6v41ZFFYgRH81y2v2TpPc0ESs5QW/9iljDP4xdmwZsxdJ+zQnuuG8ODlaVzd4dufdP8QmRSZIRlJiyu4Vyr5pcVf4VnU36kUuBvZ9s5Ax9G/IUF0T5+RnXML69uxp3/ALNh7cD9QmwF8ewTf1VyNruA+XPOjNkZ7Q0kTW7g4NfK7hf0Ut39QmwYT23Pg5ZJPph9KmMG2s7AFjBbxkSUMWaVM/Av7ptlbxYNs8ScoU5KkCT+rBaSEM2yl5jH9oYZiR5mOW0ZZCZWeuWucX45zA7by5yW8FXHDHU1ctfZzg5z9pjJMYPOfLKk78mN2WomjWG5YGZBmQiZa8CDFp62ASIatilHKMsdslw7ypxPca+tFzeTgCYs1YsktTBhZihKKb8dedfo7su8n2oWdEpvV7RNlkOm57b1N+5gHWeRmkgI2hq5a3EkiGeMGIEa4rlfwUzkPswu7TWNdb3q7tlKw7WhBmYBmZBnZ10ZdeCzxQRBe41OZ8aYz0NStInPBb1wmwN3nXcG8XcXMu66VfLuetcqS1h2bbJi+hdGObzIE57DpMRJHiejaZzxt1GotPLpJC3SlfR3RnzyWLbfQz/tUYrn9ojRJnP/umiHy1vuuh3ZcutLE9QuMDN7rO1Qgk96z5vldtd5aN6lG2ibbKerGCnUzHu+jkTBBiOkDXe9GyjHvrQWl2mvrTmf7eqe5my5sOo+R+/s2Yx2zX1HVEfRi3xKu87Orw8GeE+wT4I3dmQjXZyt5jITLs0+QkSNQsxsT1CXYNKHv7ppA2MmiXMGG/Uqjp1Yni1v7sT3vYnv2AzdeW7hnjY5G20iGsMU73R6ay9hrMFZY8swweRBRGaz/AGeFb/MO6KFjLyYY2vh2LeRyMlkX0YF95plJvrapTClHsDJ6My2oiiKoiiKoiwIHWwriqIoiqIoyoI4IxnJXslKMch6pdInCdt5VUr5ZQne2XkM93OZ+RB6vE28PoeERv59iBKavdH874ciMhozXolct5M+wjW2DOk2Qg1F/C5ZgaSimJLIaDkd8by9niMcwwB/p98jwyM2fDdCuIbhui0kUA3MOZUgeynh9q8ijLcSueUl4zVOD3QmmWazlEDMJ9YxAY1SDkpDCkxqNKFs+qCSIkLBJcgoyiZRIp+fD6uKiPQz5bn1DBVTcjFEiLXPMKwJvdEfd5zg23ky1sM7m7IpZS30urVtNUzxbuW1p0+4TQpkkiklIJSMFExiGZNnsghNZ5DERT/arJGJ5CAX8cq551NavrleLOE+bSNpDtKRCRNRTYh0hPDoEEk+XE/pD9vcDMpIKGuYUmoS/zfLviObHBadmHZBCRPlIkyy7EAm0jHH3+wggRKJVF3KkvDc28Sc+0yd520V/dMSEyBL7phXTVJYHc8WZV5+UjI9a6dz6/JIBPRKX5t2RKkD294UIfAB7l+nVTP/dSHtEaQqnld3OH+fKL8qI5GTHsL1ZbdcNDI2tnvKpzJIks5CxmWTgBnKp7RtQnmGkXPQ155yLr/tzT/jvIbeNUYfyD7MJnLy++ivn0lJfB6ZZ6u17cp2V6sb7rvz67PlWtO1uV2TKN/GM9aC/HGA90soSMizdTNSEtrYTRbNO78KuWIDso8G7i9Ls9skcF7DKZNCt5wndwDvaHuNgoR7PrfM65nQ30W4xp50Dc94ZO5ZhH4/RP+VYf9j+tcsy8RTfoR95MZ4lk1f670D0L75jLA9VcrxNWrQW7vl+tkypCgVyrwy8XGw/kda7RHKWq0kZBktoJoiLbal1DMpCg7WTRmgXsrIjN0GaI/DqWsL05Sk3bJZLnO8ZxaHCfKXJHRmW1EURVEURVEWxGnNbEfm1+pQ+iKRbz93qplt/t7jjHjWVuTBuhx+FXMf08jMbGNb/n1I67SEXxlRhF+HtC3EtkP87hibikMTVjfC30cyxvL893FNSp5QItx05C0nz2yPzXmNcZzTyP3qD7EcmW1CzGxPcb0nuEZjLI/MfD3Pk9d7gOpM/RCJJmH8yzqcumsVTpFAN8HszBhnOzJVE3PJFQjDiTu2ydgtD8xscwe/6LsT930DzBzNkpyYAMuZ7alr4T2UsxoZ265hiFmt0/hVG6RYHVnClH3Yz2WZLAvrMHuNRUSyuLZizjvAtQhxjccjWAZmzcw2IiIZ3NMMrkUuYDJZvE0uw2cEMz2wbJIJls0DH/ZR1YvLA9jyIWl5MjRV7kZ41hHFom3ZFEnQ/+qZbfYdYcrMtmmHA3xvD+2tzxlqJBj1zTKfoaHXJ7nPsQ8YJbSnvPd8uvUD3Id+GN/rLJ5TtpvJFLNhsG3LmefEX+fu0ziHWdesmX2TtJltJFninnVN4l0X92s8ReTpVDPbeJZDPPcB+pkAz8DIPAN52KPmA7Z7LIfzs5zRGP0w2+mIycemwuKY558825nUtHKYGRxl8czmkivDTs2zar/35L9758GZbfNMeX0n2kU/RIQUbWtoksXS2ykNBhx2PDH1osLJ7X5gnr9+iEgKjofHWeZsrrm/0yH6LPZf7EcxsJjNbE/OcGZ7Mj+zLQkJfSInz2xH3n9F/H7IS9Q1xxygTw69bh9Wi+hH+6N4uYP236U1J2bEu/junpkRZtSf/cnQGxO59WOzzSSlmjVntsesLJow1vAs/HA57Qx0Wmpi6LVTtk/73+T+NG1m2y7z2G1geSh9c3x3/54PolNtISJ33nmnnHXWWafaTFEURVEURVF+qLjjjjvk0KFDqX8/rcF2GIZy+PBhqdfrns5ZURRFURRFUX4YiaJI2u22HDhwQDKZ9Ej3aQ22FUVRFEVRFEU5czRBUlEURVEURVEWhA62FUVRFEVRFGVB6GBbURRFURRFURaEDrYVRVEURVEUZUHoYFtRFEVRFEVRFoQOthVFURRFURRlQehgW1EURVEURVEWxP8PQrR6evR6GEkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import colormaps\n",
    "\n",
    "directory = \"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2\"\n",
    "\n",
    "data = CycloneDataset(\n",
    "    split=\"val\",\n",
    "    normalization=None,\n",
    "    spatial_ifft=True,\n",
    "    trajectories=[\"cyclone4_2_2.h5\"],\n",
    "    input_fields=[\"df\", \"phi\"],\n",
    ")\n",
    "\n",
    "k = 100\n",
    "\n",
    "PHI = k * 3\n",
    "\n",
    "# load\n",
    "phi_filename = f\"Poten00000{PHI}\"\n",
    "a = np.loadtxt(os.path.join(directory, phi_filename))\n",
    "phi = np.reshape(a, (392, 16, 96), order=\"F\")\n",
    "spc_filename = f\"Spc3d00000{PHI}\"\n",
    "b = np.loadtxt(os.path.join(directory, spc_filename))\n",
    "spc = np.reshape(b, (255, 16, 32), order=\"F\")\n",
    "\n",
    "# phi preprocessing\n",
    "fphi = np.fft.fftn(phi, axes=(0, 2), norm=\"forward\")\n",
    "fphi = np.fft.fftshift(fphi, axes=(0, 2))\n",
    "fphi_pad = fphi.copy()\n",
    "out_shape = (255, 16, 32)\n",
    "fphi = fphi[..., fphi.shape[2] // 2 :]\n",
    "xpad = (fphi.shape[0] - out_shape[0]) // 2 + 1\n",
    "fphi = fphi[xpad : out_shape[0] + xpad, :, : out_shape[2]]\n",
    "# back to real\n",
    "ifphi = np.fft.ifftshift(fphi, axes=(0, 2))\n",
    "ifphi = np.fft.ifftn(ifphi, axes=(0, 2), norm=\"forward\")\n",
    "\n",
    "fphi_ = np.abs(fphi)\n",
    "ifphi_ = np.abs(ifphi)\n",
    "\n",
    "fig, ax = plt.subplots(5, 1, figsize=(10, 6), constrained_layout=True)\n",
    "\n",
    "vmin = min(spc.min(), fphi_.min())\n",
    "vmax = max(spc.max(), fphi_.max())\n",
    "\n",
    "c_map = colormaps[\"plasma\"]\n",
    "\n",
    "ax[0].matshow(np.squeeze(fphi_.sum(1)).T, cmap=c_map, vmin=vmin, vmax=vmax)\n",
    "ax[0].set_title(f\"abs(unpadded(FFT({phi_filename})))\", fontsize=12)\n",
    "ax[0].set_xticks([])\n",
    "ax[0].set_yticks([])\n",
    "\n",
    "ax[1].matshow(np.squeeze(spc.sum(1)).T, cmap=c_map, vmin=vmin, vmax=vmax)\n",
    "ax[1].set_title(f\"{spc_filename}\", fontsize=12)\n",
    "ax[1].set_xticks([])\n",
    "ax[1].set_yticks([])\n",
    "\n",
    "ax[2].matshow(np.squeeze(ifphi_.sum(1)).T, cmap=c_map)\n",
    "ax[2].set_title(f\"IFFT((unpadded(FFT({phi_filename})))\", fontsize=12)\n",
    "ax[2].set_xticks([])\n",
    "ax[2].set_yticks([])\n",
    "\n",
    "# spc check\n",
    "spc_phi = np.fft.fftn(ifphi, axes=(0, 2), norm=\"forward\")\n",
    "spc_phi = np.fft.fftshift(spc_phi, axes=(0, 2))\n",
    "spc_phi = np.abs(spc_phi)\n",
    "\n",
    "ax[3].matshow(np.squeeze((spc - spc_phi).sum(1)).T, cmap=c_map, vmin=vmin, vmax=vmax)\n",
    "ax[3].set_title(f\"FFT(IFFT({phi_filename}))\", fontsize=12)\n",
    "ax[3].set_xticks([])\n",
    "ax[3].set_yticks([])\n",
    "\n",
    "\n",
    "torch_phi = data[k].phi.numpy()\n",
    "torch_phi = np.complex64(torch_phi[0] + 1j * torch_phi[1])\n",
    "print(torch_phi.shape)\n",
    "torch_phi = np.abs(torch_phi)\n",
    "\n",
    "ax[4].matshow(np.squeeze(torch_phi.sum(1)).T, cmap=c_map)\n",
    "ax[4].set_title(\"preprocessed\", fontsize=12)\n",
    "ax[4].set_xticks([])\n",
    "ax[4].set_yticks([])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = CycloneDataset(\n",
    "    split=\"val\",\n",
    "    normalization=None,\n",
    "    spatial_ifft=True,\n",
    "    trajectories=[\"cyclone4_2_2.h5\"],\n",
    "    input_fields=[\"df\", \"phi\"],\n",
    ")\n",
    "\n",
    "print(f\"Val: {len(data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def is_number(string):\n",
    "    pattern = r\"^[+-]?(\\d+\\.?\\d*|\\.\\d+)([eE][+-]?\\d+)?$\"\n",
    "    return bool(re.fullmatch(pattern, string.strip()))\n",
    "\n",
    "\n",
    "def load_geom(file_path):\n",
    "    data = {}\n",
    "    with open(file_path, \"r\") as f:\n",
    "        lines = f.readlines()\n",
    "\n",
    "    key = None\n",
    "    values = []\n",
    "\n",
    "    for line in lines:\n",
    "        line = line.strip()\n",
    "        if not line:\n",
    "            continue\n",
    "\n",
    "        parts = line.split()\n",
    "        if len(parts) == 1 and not is_number(parts[0]):\n",
    "            try:\n",
    "                if len(values) == 0:\n",
    "                    values.extend(map(float, parts))\n",
    "                    data[key] = values[0]\n",
    "                    key = None\n",
    "                    values = []\n",
    "                    continue\n",
    "                else:\n",
    "                    raise ValueError\n",
    "            except:\n",
    "                if key is not None:\n",
    "                    data[key] = np.array(values, dtype=np.float64)\n",
    "                key = parts[0]\n",
    "                values = []\n",
    "        else:\n",
    "            values.extend(map(float, parts))\n",
    "\n",
    "    if key is not None:\n",
    "        data[key] = np.array(values, dtype=np.float64)\n",
    "\n",
    "    return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from typing import Dict, Tuple\n",
    "\n",
    "\n",
    "def df_fft(df: torch.Tensor, norm: str = \"backward\"):\n",
    "    df = df.movedim(0, -1).contiguous()\n",
    "    df = torch.view_as_complex(df)\n",
    "    df = torch.fft.fftn(df, dim=(3, 4), norm=norm)\n",
    "    return torch.fft.ifftshift(df, dim=(3,))\n",
    "\n",
    "\n",
    "def phi_to_spc(phi: torch.Tensor, out_shape: Tuple, norm: str = \"forward\"):\n",
    "    # drop channels and apply fft\n",
    "    phi = torch.fft.fftn(phi.squeeze(0), dim=(0, 2), norm=norm)\n",
    "    phi = torch.fft.fftshift(phi, dim=(2, 0))\n",
    "    # unpad (and positive half of spectra)\n",
    "    nx, _, ny = out_shape\n",
    "    phi = phi[..., phi.shape[-1] // 2 :]\n",
    "    xpad = (phi.shape[0] - nx) // 2 + 1\n",
    "    return phi[xpad : nx + xpad, :, :ny]\n",
    "\n",
    "\n",
    "@torch.vmap\n",
    "def pev_flux_df_phi(\n",
    "    df: torch.Tensor,\n",
    "    phi: torch.Tensor,\n",
    "    geometry: Dict,\n",
    "    aggregate: bool = True,\n",
    "    magnitude: bool = False,\n",
    "):\n",
    "    \"\"\"\n",
    "    Computes particle, heat and momentum fluxes based on the distribution function (df)\n",
    "    and electrostatic potential (phi).\n",
    "\n",
    "    Args:\n",
    "        df (torch.Tensor): 5D density function. Shape: (b, c, vpar, vmu, s, x, y).\n",
    "        phi (torch.Tensor): 3D electrostatic potential. Shape: (b, 1, x, s, y).\n",
    "        geometry (Dict): Dictionary containing geometry parameters and settings.\n",
    "        aggregate (bool, optional): Whether to return the summed fluxes. Default: True.\n",
    "        magnitude (bool, optional): Whether to use df and phi absolutes. Default: False.\n",
    "    \"\"\"\n",
    "    ns, nx, ny = df.shape[3:]\n",
    "    # df to fourier, phi to fourier and unpad\n",
    "    df = df_fft(df)  # (par, mu, s, x, y)\n",
    "    phi = phi_to_spc(phi, out_shape=(nx, ns, ny))  # (x, s, y)\n",
    "    # expand geometry constants for broadcasting\n",
    "    # grids\n",
    "    krho = rearrange(geometry[\"krho\"], \"y -> 1 1 1 1 y\")\n",
    "    kxrh = rearrange(geometry[\"kxrh\"], \"x -> 1 1 1 x 1\")\n",
    "    ints = rearrange(geometry[\"ints\"], \"s -> 1 1 s 1 1\")\n",
    "    intmu = rearrange(geometry[\"intmu\"], \"mu -> 1 mu 1 1 1\")\n",
    "    intvp = rearrange(geometry[\"intvp\"], \"par -> par 1 1 1 1\")\n",
    "    vpgr = rearrange(geometry[\"vpgr\"], \"par -> par 1 1 1 1\")\n",
    "    mugr = rearrange(geometry[\"mugr\"], \"mu -> 1 mu 1 1 1\")\n",
    "    # settings\n",
    "    little_g = rearrange(geometry[\"little_g\"], \"s three -> three 1 1 s 1 1\")\n",
    "    bn = rearrange(geometry[\"bn\"], \"s -> 1 1 s 1 1\")\n",
    "    efun = rearrange(geometry[\"efun\"], \"s -> 1 1 s 1 1\")\n",
    "    rfun = rearrange(geometry[\"rfun\"], \"s -> 1 1 s 1 1\")\n",
    "    bt_frac = rearrange(geometry[\"bt_frac\"], \"s -> 1 1 s 1 1\")\n",
    "    parseval = rearrange(geometry[\"parseval\"], \"y -> 1 1 1 1 y\")\n",
    "    mas, vthrat, signz = geometry[\"mas\"], geometry[\"vthrat\"], geometry[\"signz\"]\n",
    "    # gyroaveraged phi\n",
    "    krloc = torch.sqrt(\n",
    "        krho**2 * little_g[0] + 2 * krho * kxrh * little_g[1] + kxrh**2 * little_g[2]\n",
    "    )\n",
    "    bessel = torch.special.bessel_j0(\n",
    "        mas * vthrat * krloc * torch.sqrt(2.0 * mugr / bn) / signz\n",
    "    )\n",
    "\n",
    "    phi_gyro = bessel * rearrange(phi, \"x s y -> 1 1 s x y\")\n",
    "    # absolute values of df and phi\n",
    "    if magnitude:\n",
    "        df = -1j * torch.abs(df)\n",
    "        phi_gyro = torch.abs(phi_gyro)\n",
    "    # grid derivatives\n",
    "    dum = parseval * ints * (efun * krho) * df\n",
    "    dum1 = dum * torch.conj(phi_gyro)\n",
    "    dum2 = dum1 * bn\n",
    "    d3X = ints * geometry[\"d2X\"]\n",
    "    d3v = intmu * bn * intvp\n",
    "    signB = geometry[\"signB\"]\n",
    "    # flux fields\n",
    "    pflux_det = d3X * d3v * torch.imag(dum1)\n",
    "    eflux_det = d3X * d3v * (vpgr**2 * torch.imag(dum1) + 2 * mugr * torch.imag(dum2))\n",
    "    vflux_det = d3X * d3v * (torch.imag(dum1) * vpgr * rfun * bt_frac * signB)\n",
    "    # sum total fluxes\n",
    "    if aggregate:\n",
    "        pflux_det = pflux_det.sum()\n",
    "        eflux_det = eflux_det.sum()\n",
    "        vflux_det = vflux_det.sum()\n",
    "    return pflux_det, eflux_det, vflux_det"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "directory = \"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2\"\n",
    "\n",
    "KS = np.arange(1, 150, 5)\n",
    "\n",
    "geometry = {}\n",
    "\n",
    "geometry[\"parseval\"] = torch.tensor([1.0] + [32.0] * (32 - 1), dtype=torch.float32)\n",
    "geometry[\"signz\"] = 1.0\n",
    "geometry[\"vthrat\"] = 1.0\n",
    "geometry[\"tmp\"] = 1.0\n",
    "geometry[\"mas\"] = 1.0\n",
    "geometry[\"d2X\"] = 1.0\n",
    "geometry[\"signB\"] = 1.0\n",
    "\n",
    "geom = load_geom(os.path.join(directory, \"geom.dat\"))  # bn CHECK\n",
    "\n",
    "geometry[\"kxrh\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"kxrh\"))[0], dtype=torch.float32\n",
    ")  # CHECK\n",
    "geometry[\"krho\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"krho\")).T[0] / geom[\"kthnorm\"],\n",
    "    dtype=torch.float32,\n",
    ")  # CHECK\n",
    "\n",
    "# mugr and intmu\n",
    "mugr = np.zeros(8 + 1)\n",
    "intmu = np.zeros(8 + 1)\n",
    "mumax = 4.5\n",
    "dvperp = np.sqrt(2.0 * mumax) / 8\n",
    "for j in range(8 + 1):\n",
    "    vperp = (j - 0.5) * dvperp\n",
    "    mugr[j] = vperp**2 / 2.0\n",
    "    intmu[j] = abs(np.pi * ((vperp + 0.5 * dvperp) ** 2 - (vperp - 0.5 * dvperp) ** 2))\n",
    "\n",
    "geometry[\"intmu\"] = torch.tensor(intmu[1:], dtype=torch.float32)  # CHECK?\n",
    "geometry[\"mugr\"] = torch.tensor(mugr[1:], dtype=torch.float32)  # CHECK?\n",
    "\n",
    "geometry[\"intvp\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"intvp.dat\"))[0], dtype=torch.float32\n",
    ")  # CHECK\n",
    "geometry[\"vpgr\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"vpgr.dat\"))[0], dtype=torch.float32\n",
    ")\n",
    "\n",
    "ints = np.concatenate(\n",
    "    [np.array([0.0]), np.diff(np.loadtxt(os.path.join(directory, \"sgrid\")))]\n",
    ")\n",
    "ints[0] = ints[1]  # CHECK\n",
    "geometry[\"ints\"] = torch.tensor(ints, dtype=torch.float32)\n",
    "\n",
    "geometry[\"efun\"] = torch.tensor(-geom[\"E_eps_zeta\"], dtype=torch.float32)  # CHECK\n",
    "\n",
    "geometry[\"little_g\"] = torch.tensor(\n",
    "    np.stack([geom[\"g_zeta_zeta\"], geom[\"g_eps_zeta\"], geom[\"g_eps_eps\"]], -1),\n",
    "    dtype=torch.float32,\n",
    ")\n",
    "\n",
    "geometry[\"bn\"] = torch.tensor(geom[\"bn\"])\n",
    "geometry[\"bt_frac\"] = torch.tensor(geom[\"Bt_frac\"])\n",
    "geometry[\"rfun\"] = torch.tensor(geom[\"R\"])\n",
    "\n",
    "########################################################################################\n",
    "\n",
    "gkw = []\n",
    "py = []\n",
    "\n",
    "for k in KS:\n",
    "    df = data[k].y.unsqueeze(0)\n",
    "    phi = data[k].y_poten.unsqueeze(0)\n",
    "    flux = data[k].y_flux\n",
    "    df_raw = data.__getitem__(k, get_normalized=False).y.unsqueeze(0)\n",
    "    phi_raw = data.__getitem__(k, get_normalized=False).y_poten.unsqueeze(0)\n",
    "\n",
    "    df = torch.stack([data.denormalize(df[b]) for b in [0]])\n",
    "    phi = torch.stack([data.phi_denormalize(phi[b]) for b in [0]])\n",
    "\n",
    "    assert torch.allclose(df, df_raw)\n",
    "    assert torch.allclose(phi, phi_raw)\n",
    "\n",
    "    pflux_det, eflux_det, _ = pev_flux_df_phi(df, phi, geometry=geometry)\n",
    "    gkw.append(flux)\n",
    "    py.append(eflux_det.sum())\n",
    "\n",
    "    print(f\"t = {k}\\t E: {eflux_det.sum():.4f} (py) vs {flux:.4f} (gkw)\")\n",
    "    print(f\"\\t P: {pflux_det.sum():.4f} (py)\")\n",
    "\n",
    "fig, ax = plt.subplots(1, 1)\n",
    "\n",
    "ax.plot(KS, gkw, lw=3, c=(32 / 255, 70 / 255, 125 / 255), label=\"gkw\")\n",
    "ax.plot(KS, py, lw=3, c=(255 / 255, 70 / 255, 125 / 255), label=\"py\")\n",
    "\n",
    "ax.grid()\n",
    "fig.legend()\n",
    "ax.set_xlabel(r\"K\", fontsize=20)\n",
    "ax.set_ylabel(r\"$\\int \\delta f$\", fontsize=20)\n",
    "ax.tick_params(labelsize=14)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from matplotlib import colormaps\n",
    "\n",
    "\n",
    "def force_aspect(ax, aspect=1):\n",
    "    im = ax.get_images()\n",
    "    extent = im[0].get_extent()\n",
    "    ax.set_aspect(abs((extent[1] - extent[0]) / (extent[3] - extent[2])) / aspect)\n",
    "\n",
    "\n",
    "def distribution_5D(x, **kwargs):\n",
    "    _ = kwargs\n",
    "    labels = [r\"v_{par}\", r\"v_{\\mu}\", r\"s\", r\"k_x\", r\"k_y\"]\n",
    "\n",
    "    if isinstance(x, torch.Tensor):\n",
    "        x = x.cpu().detach().numpy()\n",
    "\n",
    "    comb = torch.combinations(torch.arange(5), 2).tolist()\n",
    "\n",
    "    fig, ax = plt.subplots(5, 5, figsize=(20, 20))\n",
    "    for i in range(5):\n",
    "        for j in range(5):\n",
    "            if [i, j] not in comb:\n",
    "                ax[i, j].remove()\n",
    "\n",
    "    c_map = colormaps[\"RdBu_r\"]\n",
    "    c_map.set_bad(\"r\")\n",
    "\n",
    "    imin = -1\n",
    "    for i, j in comb:\n",
    "        other = tuple([o for o in range(5) if o != i and o != j])\n",
    "        xx = x.mean(other)\n",
    "        ax[i, j].matshow(xx, cmap=c_map)\n",
    "\n",
    "        if i > imin:\n",
    "            ax[i, j].set_ylabel(rf\"${labels[i]}$\", fontsize=20)\n",
    "            ax[i, j].set_xlabel(rf\"${labels[j]}$\", fontsize=20)\n",
    "            imin = i\n",
    "\n",
    "        force_aspect(ax[i, j])\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = data[60].x\n",
    "\n",
    "df = torch.view_as_complex(rearrange(df, \"c ... -> ... c\").contiguous())\n",
    "# df = torch.fft.fftn(df, dim=(-2, -1), norm=\"forward\")\n",
    "# df = torch.fft.fftshift(df, dim=(-2,))\n",
    "\n",
    "distribution_5D(df.numpy().real)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import matplotlib.ticker as tkr\n",
    "\n",
    "\n",
    "def plot4x4_sided(x1, x2, title=\"\"):\n",
    "    labels = [r\"v_{par}\", r\"v_{\\mu}\", r\"s\", r\"k_x\", r\"k_y\"]\n",
    "    comb = torch.combinations(torch.arange(5), 2).tolist()\n",
    "\n",
    "    fig, ax = plt.subplots(5, 5, figsize=(30, 14))\n",
    "    for i in range(5):\n",
    "        for j in range(5):\n",
    "            if j == 0:\n",
    "                ax[i, j].remove()\n",
    "                continue\n",
    "            if i == 4:\n",
    "                ax[i, j].remove()\n",
    "                continue\n",
    "            ax_ij = ax[i, j]\n",
    "            ax_ij.set_frame_on(False)\n",
    "            ax_ij.tick_params(labelleft=False, labelbottom=False)\n",
    "            ax_ij.set_xticks([])\n",
    "            ax_ij.set_yticks([])\n",
    "\n",
    "    # fig.tight_layout()\n",
    "    fig.suptitle(title)\n",
    "    c_map = matplotlib.colormaps[\"RdBu_r\"]\n",
    "    c_map.set_bad(\"k\")\n",
    "\n",
    "    for i, j in comb:\n",
    "        other = tuple([o for o in range(5) if o != i and o != j])\n",
    "\n",
    "        x1_plot = x1.mean(other)\n",
    "        x2_plot = x2.mean(other)\n",
    "        ax_ij = ax[i, j]\n",
    "        pos = ax_ij.get_position()\n",
    "\n",
    "        # create two new axes within the same space as the original subplot\n",
    "        plot_width = 0.475 * pos.width\n",
    "        left_margin = 0.0 * pos.width\n",
    "        x_left_1 = pos.x0 + left_margin\n",
    "        x_left_2 = x_left_1 + plot_width\n",
    "        y = pos.y0\n",
    "        h = pos.height\n",
    "        ax1 = fig.add_axes([x_left_1, y, plot_width, h])\n",
    "        ax2 = fig.add_axes([x_left_2, y, plot_width, h])\n",
    "\n",
    "        # compute shared vmin and vmax\n",
    "        vmin = min(x1_plot.min(), x2_plot.min())\n",
    "        vmax = max(x1_plot.max(), x2_plot.max())\n",
    "\n",
    "        im1 = ax1.matshow(x1_plot, cmap=c_map, vmin=vmin, vmax=vmax)\n",
    "        ax2.matshow(x2_plot, cmap=c_map, vmin=vmin, vmax=vmax)\n",
    "\n",
    "        # shared colourbar\n",
    "        cbar = fig.colorbar(\n",
    "            im1, ax=[ax_ij], format=tkr.FormatStrFormatter(\"%.2g\"), pad=0, fraction=0.05\n",
    "        )\n",
    "        cbar.set_ticks([vmin, (vmin + vmax) / 2, vmax])\n",
    "        cbar.ax.tick_params(labelsize=12)\n",
    "\n",
    "        if i == 0:\n",
    "            # Set axis labels\n",
    "            ax1.set_title(\"gkw\", fontsize=24)\n",
    "            ax2.set_title(\"py\", fontsize=24)\n",
    "\n",
    "        if j == 1 or (i == 1 and j == 2) or (i == 2 and j == 3) or (i == 3 and j == 4):\n",
    "            ax_ij.set_ylabel(rf\"${labels[i]}$\", fontsize=14)\n",
    "\n",
    "        if i == 3 or j == 1 or (i == 1 and j == 2) or (i == 2 and j == 3):\n",
    "            ax_ij.set_xlabel(rf\"${labels[j]}$\", fontsize=14)\n",
    "\n",
    "        # Remove axis ticks and labels\n",
    "        ax1.set_xticks([])\n",
    "        ax1.set_yticks([])\n",
    "        ax2.set_xticks([])\n",
    "        ax2.set_yticks([])\n",
    "        ax1.tick_params(labelleft=False, labelbottom=False)\n",
    "        ax2.tick_params(labelleft=False, labelbottom=False)\n",
    "        # Force aspect ratio\n",
    "        force_aspect(ax1)\n",
    "        force_aspect(ax2)\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "@torch.vmap\n",
    "def invert_ifft(x):\n",
    "    # knth = rearrange(x, \"b c ... -> b ... c\").contiguous()\n",
    "    x = x.movedim(0, -1).contiguous()\n",
    "    x = torch.view_as_complex(x)\n",
    "    x = torch.fft.fftn(x, dim=(3, 4))\n",
    "    x = torch.fft.ifftshift(x, dim=(3,))\n",
    "    return x\n",
    "\n",
    "\n",
    "k = 80\n",
    "\n",
    "# invert_ifft = torch.vmap(invert_ifft)\n",
    "\n",
    "df = invert_ifft(data[k].x.unsqueeze(0))[0]\n",
    "\n",
    "with open(\n",
    "    f\"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2/K{str(k + 1).turbill(2)}\",\n",
    "    \"rb\",\n",
    ") as fid:\n",
    "    ff = np.fromfile(fid, dtype=np.complex128)\n",
    "df_ = np.reshape(ff, (32, 8, 16, 255, 32), order=\"F\").copy()\n",
    "\n",
    "plot4x4_sided(np.abs(df_ - df.numpy()), df.real)\n",
    "\n",
    "np.abs(df_ - df.numpy()).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "directory = \"/restricteddata/ukaea/dumps/autoreg/xnet/K61\"\n",
    "\n",
    "\n",
    "NVPAR = 32\n",
    "NMU = 8\n",
    "NS = 16\n",
    "NX = 255\n",
    "NY = 32\n",
    "number_of_species = 1\n",
    "# parseval_correction = np.array([1.0] + [2.0] * (NVPAR - 1))\n",
    "parseval_correction = np.array([1.0] + [32.0] * (NVPAR - 1))  # WRONG\n",
    "\n",
    "signz = 1.0  # CHECK\n",
    "vthrat = 1.0  # CHECK\n",
    "tmp = 1.0  # CHECK\n",
    "\n",
    "geom = load_geom(os.path.join(directory, \"geom.dat\"))  # bn CHECK\n",
    "\n",
    "kxrh = np.loadtxt(os.path.join(directory, \"kxrh\"))[0]  # CHECK\n",
    "krho = np.loadtxt(os.path.join(directory, \"krho\")).T[0] / geom[\"kthnorm\"]  # CHECK\n",
    "\n",
    "mugr = np.zeros(NMU + 1)\n",
    "intmu = np.zeros(NMU + 1)\n",
    "\n",
    "mumax = 4.5\n",
    "dvperp = np.sqrt(2.0 * mumax) / NMU\n",
    "for j in range(NMU + 1):\n",
    "    vperp = (j - 0.5) * dvperp\n",
    "    mugr[j] = vperp**2 / 2.0\n",
    "    intmu[j] = abs(np.pi * ((vperp + 0.5 * dvperp) ** 2 - (vperp - 0.5 * dvperp) ** 2))\n",
    "\n",
    "intmu = intmu[1:]  # CHECK?\n",
    "mugr = mugr[1:]  # CHECK?\n",
    "\n",
    "intvp = np.loadtxt(os.path.join(directory, \"intvp.dat\"))[0]  # CHECK\n",
    "vpgr = np.loadtxt(os.path.join(directory, \"vpgr.dat\"))[0]\n",
    "\n",
    "ints = np.concatenate(\n",
    "    [np.array([0.0]), np.diff(np.loadtxt(os.path.join(directory, \"sgrid\")))]\n",
    ")\n",
    "ints[0] = ints[1]  # CHECK\n",
    "\n",
    "efun = -geom[\"E_eps_zeta\"]  # CHECK\n",
    "\n",
    "little_g = np.stack(\n",
    "    [geom[\"g_zeta_zeta\"], geom[\"g_eps_zeta\"], geom[\"g_eps_eps\"]], -1\n",
    ")  # WRONG\n",
    "\n",
    "krloc = np.reshape(\n",
    "    np.loadtxt(os.path.join(directory, \"krloc\")), (NX, NS, NY), order=\"F\"\n",
    ")\n",
    "krloc = np.moveaxis(krloc, 1, 0)\n",
    "\n",
    "########################################################################################\n",
    "\n",
    "with open(f\"{directory}/FDS\", \"rb\") as fid:\n",
    "    ff = np.fromfile(fid, dtype=np.complex128)\n",
    "df = np.reshape(ff, (32, 8, 16, 255, 32), order=\"F\").copy()\n",
    "\n",
    "out_shape = (255, 16, 32)\n",
    "a = np.loadtxt(f\"{directory}/Poten00000502\")\n",
    "phi = np.reshape(a, (392, 16, 96), order=\"F\")\n",
    "fphi = np.fft.fftn(phi, axes=(0, 2), norm=\"forward\")\n",
    "fphi = np.fft.fftshift(fphi, axes=(0, 2))\n",
    "# positive half of fft\n",
    "fphi = fphi[..., fphi.shape[2] // 2 :]\n",
    "# # padding sizes\n",
    "xpad = (fphi.shape[0] - out_shape[0]) // 2 + 1\n",
    "fphi = fphi[xpad : out_shape[0] + xpad, :, : out_shape[2]]\n",
    "\n",
    "fluxes = np.loadtxt(f\"{directory}/fluxes.dat\")\n",
    "\n",
    "# pflux_py, eflux_py, vflux_py = calc_fluxes_vec_full(\n",
    "#     phi=fphi,\n",
    "#     df=df,\n",
    "#     nvpar=NVPAR,\n",
    "#     nmu=NMU,\n",
    "#     ns=NS,\n",
    "#     nx=NX,\n",
    "#     nmod=NY,\n",
    "#     ints=ints,  # diff of sgrid\n",
    "#     bn=geom[\"bn\"],\n",
    "#     efun=efun,\n",
    "#     krho=krho,  # (ny,)\n",
    "#     kxrh=kxrh,  # (nx,)\n",
    "#     intmu=intmu,  # (nmu,)\n",
    "#     intvp=intvp,  # (vpar,)\n",
    "#     vpgr=vpgr,  # (npar,)\n",
    "#     mugr=mugr,\n",
    "#     # krloc=krloc,\n",
    "#     little_g=little_g,\n",
    "#     bt_frac=geom[\"Bt_frac\"],\n",
    "#     Rfun=geom[\"R\"],\n",
    "#     parseval_correction=parseval_correction,\n",
    "#     number_of_species=number_of_species,\n",
    "# )\n",
    "\n",
    "k = 80\n",
    "\n",
    "df = data[k].y\n",
    "phi = data[k].y_poten\n",
    "flux = data[k].y_flux\n",
    "\n",
    "df = torch.view_as_complex(rearrange(data[k].x, \"c ... -> ... c\").contiguous())\n",
    "df = torch.fft.fftn(df, dim=(-2, -1), norm=\"backward\")\n",
    "df = torch.fft.fftshift(df, dim=(-2,))\n",
    "\n",
    "kname = f\"K{str(k + 2).turbill(2)}\"\n",
    "if k + 2 > 100:\n",
    "    kname = k + 2\n",
    "\n",
    "with open(f\"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2/{kname}\", \"rb\") as fid:\n",
    "    ff = np.fromfile(fid, dtype=np.complex128)\n",
    "_df = np.reshape(ff, (32, 8, 16, 255, 32), order=\"F\").copy()\n",
    "_df = torch.from_numpy(_df).to(torch.complex64)\n",
    "\n",
    "print((df - _df).sum(), df.sum(), _df.sum())\n",
    "\n",
    "pflux_py, eflux_py, _ = pev_flux_df_phi(df, phi, geometry=geometry, aggregate=False)\n",
    "pflux_gkw, eflux_gkw, _ = pev_flux_df_phi(_df, phi, geometry=geometry, aggregate=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fluxes_full_detail_gkw = np.fromfile(\"/restricteddata/ukaea/dumps/autoreg/xnet/K61/fluxes_det.dat\", dtype=np.float64)\n",
    "# fluxes_full_detail_gkw = fluxes_full_detail_gkw.reshape((32, 8, 16, 255, 32, 3), order=\"F\")\n",
    "# pflux_gkw = fluxes_full_detail_gkw[..., 0]\n",
    "# eflux_gkw = fluxes_full_detail_gkw[..., 1]\n",
    "# vflux_gkw = fluxes_full_detail_gkw[..., 2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "_ = plot4x4_sided(\n",
    "    pflux_gkw.squeeze(0).numpy(),\n",
    "    pflux_py.squeeze(0).numpy(),\n",
    "    title=f\"Pflux: gkw: {pflux_gkw.sum():.3f} - py: {pflux_py.sum():.3f}\",\n",
    ")\n",
    "_ = plot4x4_sided(\n",
    "    eflux_gkw.squeeze(0).numpy(),\n",
    "    eflux_py.squeeze(0).numpy(),\n",
    "    title=f\"Eflux: gkw: {eflux_gkw.sum():.3f} - py: {eflux_py.sum():.3f}\",\n",
    ")\n",
    "# _ = plot4x4_sided(vflux_gkw, 10 * vflux_py.squeeze(0).numpy(), title=f\"Vflux: gkw: {vflux_gkw.sum():.3f} - py: {vflux_py.sum():.3f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "directory = \"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2\"\n",
    "\n",
    "geometry = {}\n",
    "\n",
    "geometry[\"parseval\"] = torch.tensor([1.0] + [32.0] * (32 - 1), dtype=torch.float32)\n",
    "geometry[\"signz\"] = 1.0\n",
    "geometry[\"vthrat\"] = 1.0\n",
    "geometry[\"tmp\"] = 1.0\n",
    "geometry[\"mas\"] = 1.0\n",
    "geometry[\"d2X\"] = 1.0\n",
    "geometry[\"signB\"] = 1.0\n",
    "\n",
    "geom = load_geom(os.path.join(directory, \"geom.dat\"))  # bn CHECK\n",
    "\n",
    "geometry[\"kxrh\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"kxrh\"))[0], dtype=torch.float32\n",
    ")  # CHECK\n",
    "geometry[\"krho\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"krho\")).T[0] / geom[\"kthnorm\"],\n",
    "    dtype=torch.float32,\n",
    ")  # CHECK\n",
    "\n",
    "# mugr and intmu\n",
    "mugr = np.zeros(8 + 1)\n",
    "intmu = np.zeros(8 + 1)\n",
    "mumax = 4.5\n",
    "dvperp = np.sqrt(2.0 * mumax) / 8\n",
    "for j in range(8 + 1):\n",
    "    vperp = (j - 0.5) * dvperp\n",
    "    mugr[j] = vperp**2 / 2.0\n",
    "    intmu[j] = abs(np.pi * ((vperp + 0.5 * dvperp) ** 2 - (vperp - 0.5 * dvperp) ** 2))\n",
    "\n",
    "geometry[\"intmu\"] = torch.tensor(intmu[1:], dtype=torch.float32)  # CHECK?\n",
    "geometry[\"mugr\"] = torch.tensor(mugr[1:], dtype=torch.float32)  # CHECK?\n",
    "\n",
    "geometry[\"intvp\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"intvp.dat\"))[0], dtype=torch.float32\n",
    ")  # CHECK\n",
    "geometry[\"vpgr\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"vpgr.dat\"))[0], dtype=torch.float32\n",
    ")\n",
    "\n",
    "ints = np.concatenate(\n",
    "    [np.array([0.0]), np.diff(np.loadtxt(os.path.join(directory, \"sgrid\")))]\n",
    ")\n",
    "ints[0] = ints[1]  # CHECK\n",
    "geometry[\"ints\"] = torch.tensor(ints, dtype=torch.float32)\n",
    "\n",
    "geometry[\"efun\"] = torch.tensor(-geom[\"E_eps_zeta\"], dtype=torch.float32)  # CHECK\n",
    "\n",
    "geometry[\"little_g\"] = torch.tensor(\n",
    "    np.stack([geom[\"g_zeta_zeta\"], geom[\"g_eps_zeta\"], geom[\"g_eps_eps\"]], -1),\n",
    "    dtype=torch.float32,\n",
    ")\n",
    "\n",
    "geometry[\"bn\"] = torch.tensor(geom[\"bn\"])\n",
    "geometry[\"bt_frac\"] = torch.tensor(geom[\"Bt_frac\"])\n",
    "geometry[\"rfun\"] = torch.tensor(geom[\"R\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from typing import Dict, Tuple\n",
    "\n",
    "\n",
    "def df_fft(df: torch.Tensor, norm: str = \"backward\"):\n",
    "    df = df.movedim(0, -1).contiguous()\n",
    "    df = torch.view_as_complex(df)\n",
    "    df = torch.fft.fftn(df, dim=(3, 4), norm=norm)\n",
    "    return torch.fft.ifftshift(df, dim=(3,))\n",
    "\n",
    "\n",
    "@torch.vmap\n",
    "def phi_integral(df: torch.Tensor, geometry: Dict, padded_shape: Tuple = (392, 16, 96)):\n",
    "    ns, nx, ny = df.shape[3:]\n",
    "    # df to fourier, phi to fourier and unpad\n",
    "    df = df_fft(df)  # (par, mu, s, x, y)\n",
    "    # phi tensor\n",
    "    phi = torch.zeros((ns, nx, ny), dtype=df.dtype, device=df.device)\n",
    "    bufphi = torch.zeros((ns, nx, ny), dtype=df.dtype, device=df.device)\n",
    "    # expand geometry constants for broadcasting\n",
    "    # grids\n",
    "    krho = rearrange(geometry[\"krho\"], \"y -> 1 1 1 1 y\")\n",
    "    kxrh = rearrange(geometry[\"kxrh\"], \"x -> 1 1 1 x 1\")\n",
    "    ints = rearrange(geometry[\"ints\"], \"s -> 1 1 s 1 1\")\n",
    "    intmu = rearrange(geometry[\"intmu\"], \"mu -> 1 mu 1 1 1\")\n",
    "    intvp = rearrange(geometry[\"intvp\"], \"par -> par 1 1 1 1\")\n",
    "    mugr = rearrange(geometry[\"mugr\"], \"mu -> 1 mu 1 1 1\")\n",
    "    # settings\n",
    "    little_g = rearrange(geometry[\"little_g\"], \"s three -> three 1 1 s 1 1\")\n",
    "    bn = rearrange(geometry[\"bn\"], \"s -> 1 1 s 1 1\")\n",
    "    mas, vthrat, signz = geometry[\"mas\"], geometry[\"vthrat\"], geometry[\"signz\"]\n",
    "    tmp = geometry[\"tmp\"]\n",
    "    # gyroaveraged phi\n",
    "    krloc = torch.sqrt(\n",
    "        krho**2 * little_g[0] + 2 * krho * kxrh * little_g[1] + kxrh**2 * little_g[2]\n",
    "    )\n",
    "    bessel = torch.special.bessel_j0(\n",
    "        mas * vthrat * krloc * torch.sqrt(2.0 * mugr / bn) / signz\n",
    "    )\n",
    "    # exponentially scaled bessel i0 function\n",
    "    gamma = 0.5 * ((mas * vthrat * krloc) / (signz * bn)) ** 2\n",
    "    gamma = torch.special.i0(gamma) * torch.exp(-gamma)\n",
    "\n",
    "    # poisson terms\n",
    "    # density of the species\n",
    "    de = 1.0\n",
    "    cfen = torch.zeros_like(ints)\n",
    "    poisson_int = signz * de * intmu * intvp * bessel * bn\n",
    "    poisson_int = torch.where(torch.abs(intvp) < 1e-9, 0.0, poisson_int)\n",
    "\n",
    "    diagz = (\n",
    "        signz\n",
    "        * de\n",
    "        * (signz * (gamma - 1.0) * torch.exp(-cfen) / tmp - torch.exp(-cfen) / tmp)\n",
    "    )\n",
    "    matz = -ints / diagz\n",
    "    matz[..., 1:] = 0.0  # only keep y=0 (turb)\n",
    "\n",
    "    # ! sum all the dum elements over the s-direction?\n",
    "    # if (parallel_s) then\n",
    "    #   call mpiallreduce_sum_inplace(dum_elem,1,COMM_S_NE)\n",
    "    # endif\n",
    "    maty = (-matz * torch.exp(-cfen)).sum((2,), keepdim=True)\n",
    "    maty = tmp / (de * torch.exp(-cfen)) + maty / torch.exp(-cfen)\n",
    "    maty[..., 0, :] = 1 + 0j\n",
    "    maty = torch.where(maty == 0, 1.0, maty)  # avoid infs\n",
    "    maty = 1 / maty\n",
    "    maty[..., 1:] = 0.0  # only keep y=0 (turb)\n",
    "\n",
    "    poisson_diag = torch.exp(-cfen) * (signz**2) * de * (gamma - 1.0) / tmp\n",
    "    poisson_diag[..., 0, 0] = 0.0\n",
    "    poisson_diag = poisson_diag + signz * torch.exp(-cfen) * de / tmp\n",
    "\n",
    "    # first usmv\n",
    "    phi = (1 + 0j) * poisson_int * df\n",
    "\n",
    "    # TODO finish the species sum and the velspace integral\n",
    "    # call mpiallreduce_sum_inplace(fdis(n_phi_start:nregular_fields_end), nregular_fields_end-n_phi_start+1,COMM=COMM_S_EQ)\n",
    "    phi = phi.sum((0, 1), keepdim=True)\n",
    "\n",
    "    # second usmv\n",
    "    bufphi = bufphi + (1 + 0j) * matz * phi\n",
    "\n",
    "    # surface average\n",
    "    # call mpiallreduce_sum_inplace(bufphi(1:nx),nx,COMM_S_NE)\n",
    "    bufphi = bufphi.sum(\n",
    "        (\n",
    "            2,\n",
    "            4,\n",
    "        ),\n",
    "        keepdim=True,\n",
    "    )\n",
    "\n",
    "    # third usmv\n",
    "    phi = phi + (1 + 0j) * maty * bufphi\n",
    "\n",
    "    # normalize\n",
    "    phi = phi * poisson_diag\n",
    "    phi = rearrange(phi.squeeze(), \"s x y -> x s y\")\n",
    "    # pad phi in fourier to padded_shape\n",
    "    if padded_shape is not None:\n",
    "        xpad = (padded_shape[0] - phi.shape[0]) // 2 + 1\n",
    "        # TODO\n",
    "    return phi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 70\n",
    "\n",
    "\n",
    "def phi_to_spc(phi: torch.Tensor, out_shape, norm: str = \"forward\"):\n",
    "    # drop channels and apply fft\n",
    "    phi = torch.fft.fftn(phi.squeeze(0), dim=(0, 2), norm=norm)\n",
    "    phi = torch.fft.fftshift(phi, dim=(2, 0))\n",
    "    # unpad (and positive half of spectra)\n",
    "    nx, _, ny = out_shape\n",
    "    phi = phi[..., phi.shape[-1] // 2 :]\n",
    "    xpad = (phi.shape[0] - nx) // 2 + 1\n",
    "    return phi[xpad : nx + xpad, :, :ny]\n",
    "\n",
    "\n",
    "df = data[k].y.unsqueeze(0)\n",
    "gkw_phi = data[k].y_poten.squeeze()\n",
    "gkw_phi = phi_to_spc(gkw_phi, out_shape=(255, 16, 32))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "py_phi = phi_integral(df, geometry=geometry).squeeze()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "py_phi.std(), gkw_phi.std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, ax = plt.subplots(4, 3, figsize=(20, 8))  # Changed to 4 rows\n",
    "\n",
    "for i in range(4):\n",
    "    for j in range(3):\n",
    "        ax[i, j].set_xticks([])\n",
    "        ax[i, j].set_yticks([])\n",
    "        ax[i, j].tick_params(labelleft=False, labelbottom=False)\n",
    "\n",
    "# Prepare full fields\n",
    "py_iphi = torch.fft.ifftshift(py_phi, dim=(0, 2))\n",
    "py_iphi = torch.fft.ifftn(py_iphi, dim=(0, 2), norm=\"forward\")\n",
    "\n",
    "gkw_iphi = torch.fft.ifftshift(gkw_phi, dim=(0, 2))\n",
    "gkw_iphi = torch.fft.ifftn(gkw_iphi, dim=(0, 2), norm=\"forward\")\n",
    "\n",
    "# Prepare turbulent fields (without zonal flow)\n",
    "py_phi_turb = py_phi.clone()\n",
    "py_phi_turb[:, :, 0] = 0.0\n",
    "py_iphi_turb = torch.fft.ifftshift(py_phi_turb, dim=(0, 2))\n",
    "py_iphi_turb = torch.fft.ifftn(py_iphi_turb, dim=(0, 2), norm=\"forward\")\n",
    "\n",
    "gkw_phi_turb = gkw_phi.clone()\n",
    "gkw_phi_turb[:, :, 0] = 0.0\n",
    "gkw_iphi_turb = torch.fft.ifftshift(gkw_phi_turb, dim=(0, 2))\n",
    "gkw_iphi_turb = torch.fft.ifftn(gkw_iphi_turb, dim=(0, 2), norm=\"forward\")\n",
    "\n",
    "# Prepare zonal flow fields (only kx=0 mode)\n",
    "py_phi_zf = py_phi.clone()\n",
    "py_phi_zf[:, :, 1:] = 0.0  # Zero out all modes except kx=0\n",
    "py_iphi_zf = torch.fft.ifftshift(py_phi_zf, dim=(0, 2))\n",
    "py_iphi_zf = torch.fft.ifftn(py_iphi_zf, dim=(0, 2), norm=\"forward\")\n",
    "\n",
    "gkw_phi_zf = gkw_phi.clone()\n",
    "gkw_phi_zf[:, :, 1:] = 0.0  # Zero out all modes except kx=0\n",
    "gkw_iphi_zf = torch.fft.ifftshift(gkw_phi_zf, dim=(0, 2))\n",
    "gkw_iphi_zf = torch.fft.ifftn(gkw_iphi_zf, dim=(0, 2), norm=\"forward\")\n",
    "\n",
    "cmap = None\n",
    "\n",
    "# Row 0: Log magnitude plots\n",
    "log_py = torch.log(py_phi).abs()[:, 7, :].T\n",
    "log_gkw = torch.log(gkw_phi).abs()[:, 7, :].T\n",
    "vmin_log, vmax_log = min(log_py.min(), log_gkw.min()), max(log_py.max(), log_gkw.max())\n",
    "\n",
    "im00 = ax[0, 0].matshow(log_py, cmap=cmap, vmin=vmin_log, vmax=vmax_log)\n",
    "ax[0, 0].set_title(r\"$\\phi_{py}$\")\n",
    "im01 = ax[0, 1].matshow(log_gkw, cmap=cmap, vmin=vmin_log, vmax=vmax_log)\n",
    "ax[0, 1].set_title(r\"$\\phi_{gkw}$\")\n",
    "im02 = ax[0, 2].matshow(log_py - log_gkw, cmap=cmap)\n",
    "ax[0, 2].set_title(r\"$\\phi_{py} - \\phi_{gkw}$\")\n",
    "\n",
    "# Row 1: IFFT plots\n",
    "ifft_py = torch.abs(py_iphi)[:, 7, :].T\n",
    "ifft_gkw = torch.abs(gkw_iphi)[:, 7, :].T\n",
    "vmin_ifft, vmax_ifft = min(ifft_py.min(), ifft_gkw.min()), max(\n",
    "    ifft_py.max(), ifft_gkw.max()\n",
    ")\n",
    "\n",
    "im10 = ax[1, 0].matshow(ifft_py, cmap=cmap, vmin=vmin_ifft, vmax=vmax_ifft)\n",
    "ax[1, 0].set_title(r\"$\\text{IFFT}(\\phi_{py})$\")\n",
    "im11 = ax[1, 1].matshow(ifft_gkw, cmap=cmap, vmin=vmin_ifft, vmax=vmax_ifft)\n",
    "ax[1, 1].set_title(r\"$\\text{IFFT}(\\phi_{gkw})$\")\n",
    "im12 = ax[1, 2].matshow(ifft_py - ifft_gkw, cmap=cmap)\n",
    "ax[1, 2].set_title(r\"$\\text{IFFT}(\\phi_{py}) - \\text{IFFT}(\\phi_{gkw})$\")\n",
    "\n",
    "# Row 2: IFFT no ZF plots\n",
    "ifft_py_turb = torch.abs(py_iphi_turb)[:, 7, :].T\n",
    "ifft_gkw_turb = torch.abs(gkw_iphi_turb)[:, 7, :].T\n",
    "vmin_turb, vmax_turb = min(ifft_py_turb.min(), ifft_gkw_turb.min()), max(\n",
    "    ifft_py_turb.max(), ifft_gkw_turb.max()\n",
    ")\n",
    "\n",
    "im20 = ax[2, 0].matshow(ifft_py_turb, cmap=cmap, vmin=vmin_turb, vmax=vmax_turb)\n",
    "ax[2, 0].set_title(r\"$\\text{IFFT}(\\phi_{py})$ no ZF\")\n",
    "im21 = ax[2, 1].matshow(ifft_gkw_turb, cmap=cmap, vmin=vmin_turb, vmax=vmax_turb)\n",
    "ax[2, 1].set_title(r\"$\\text{IFFT}(\\phi_{gkw})$ no ZF\")\n",
    "im22 = ax[2, 2].matshow(ifft_py_turb - ifft_gkw_turb, cmap=cmap)\n",
    "ax[2, 2].set_title(r\"$\\text{IFFT}(\\phi_{py}) - \\text{IFFT}(\\phi_{gkw})$ no ZF\")\n",
    "\n",
    "# Row 3: Zonal flow only plots\n",
    "ifft_py_zf = torch.abs(py_iphi_zf)[:, 7, :].T\n",
    "ifft_gkw_zf = torch.abs(gkw_iphi_zf)[:, 7, :].T\n",
    "vmin_zf, vmax_zf = min(ifft_py_zf.min(), ifft_gkw_zf.min()), max(\n",
    "    ifft_py_zf.max(), ifft_gkw_zf.max()\n",
    ")\n",
    "\n",
    "im30 = ax[3, 0].matshow(ifft_py_zf, cmap=cmap, vmin=vmin_zf, vmax=vmax_zf)\n",
    "ax[3, 0].set_title(r\"$\\text{IFFT}(\\phi_{py})$ ZF only\")\n",
    "im31 = ax[3, 1].matshow(ifft_gkw_zf, cmap=cmap, vmin=vmin_zf, vmax=vmax_zf)\n",
    "ax[3, 1].set_title(r\"$\\text{IFFT}(\\phi_{gkw})$ ZF only\")\n",
    "im32 = ax[3, 2].matshow(ifft_py_zf - ifft_gkw_zf, cmap=cmap)\n",
    "ax[3, 2].set_title(r\"$\\text{IFFT}(\\phi_{py}) - \\text{IFFT}(\\phi_{gkw})$ ZF only\")\n",
    "\n",
    "# Add shared colorbars for first two columns in each row\n",
    "fig.colorbar(im00, ax=[ax[0, 0], ax[0, 1]], location=\"right\", pad=0.02)\n",
    "fig.colorbar(im10, ax=[ax[1, 0], ax[1, 1]], location=\"right\", pad=0.02)\n",
    "fig.colorbar(im20, ax=[ax[2, 0], ax[2, 1]], location=\"right\", pad=0.02)\n",
    "fig.colorbar(im30, ax=[ax[3, 0], ax[3, 1]], location=\"right\", pad=0.02)\n",
    "\n",
    "# Add individual colorbars for difference plots\n",
    "fig.colorbar(im02, ax=ax[0, 2], location=\"right\", pad=0.02)\n",
    "fig.colorbar(im12, ax=ax[1, 2], location=\"right\", pad=0.02)\n",
    "fig.colorbar(im22, ax=ax[2, 2], location=\"right\", pad=0.02)\n",
    "fig.colorbar(im32, ax=ax[3, 2], location=\"right\", pad=0.02)\n",
    "\n",
    "\n",
    "fig.savefig(\"tmp.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from typing import Dict, Tuple\n",
    "\n",
    "\n",
    "def df_fft(df: torch.Tensor, norm: str = \"backward\"):\n",
    "    df = df.movedim(0, -1).contiguous()\n",
    "    df = torch.view_as_complex(df)\n",
    "    df = torch.fft.fftn(df, dim=(3, 4), norm=norm)\n",
    "    return torch.fft.ifftshift(df, dim=(3,))\n",
    "\n",
    "\n",
    "def phi_to_spc(phi: torch.Tensor, out_shape: Tuple, norm: str = \"forward\"):\n",
    "    # drop channels and apply fft\n",
    "    phi = torch.fft.fftn(phi.squeeze(0), dim=(0, 2), norm=norm)\n",
    "    phi = torch.fft.fftshift(phi, dim=(2, 0))\n",
    "    # unpad (and positive half of spectra)\n",
    "    nx, _, ny = out_shape\n",
    "    phi = phi[..., phi.shape[-1] // 2 :]\n",
    "    xpad = (phi.shape[0] - nx) // 2 + 1\n",
    "    return phi[xpad : nx + xpad, :, :ny]\n",
    "\n",
    "\n",
    "@torch.vmap\n",
    "def pev_flux_df_phi(\n",
    "    df: torch.Tensor,\n",
    "    phi: torch.Tensor,\n",
    "    geometry: Dict,\n",
    "    aggregate: bool = True,\n",
    "    magnitude: bool = False,\n",
    "):\n",
    "    \"\"\"\n",
    "    Computes particle, heat and momentum fluxes based on the distribution function (df)\n",
    "    and electrostatic potential (phi).\n",
    "\n",
    "    Args:\n",
    "        df (torch.Tensor): 5D density function. Shape: (b, c, vpar, vmu, s, x, y).\n",
    "        phi (torch.Tensor): 3D electrostatic potential. Shape: (b, 1, x, s, y).\n",
    "        geometry (Dict): Dictionary containing geometry parameters and settings.\n",
    "        aggregate (bool, optional): Whether to return the summed fluxes. Default: True.\n",
    "        magnitude (bool, optional): Whether to use df and phi absolutes. Default: False.\n",
    "    \"\"\"\n",
    "    ns, nx, ny = df.shape[3:]\n",
    "    # df to fourier, phi to fourier and unpad\n",
    "    df = df_fft(df)  # (par, mu, s, x, y)\n",
    "    # expand geometry constants for broadcasting\n",
    "    # grids\n",
    "    krho = rearrange(geometry[\"krho\"], \"y -> 1 1 1 1 y\")\n",
    "    kxrh = rearrange(geometry[\"kxrh\"], \"x -> 1 1 1 x 1\")\n",
    "    ints = rearrange(geometry[\"ints\"], \"s -> 1 1 s 1 1\")\n",
    "    intmu = rearrange(geometry[\"intmu\"], \"mu -> 1 mu 1 1 1\")\n",
    "    intvp = rearrange(geometry[\"intvp\"], \"par -> par 1 1 1 1\")\n",
    "    vpgr = rearrange(geometry[\"vpgr\"], \"par -> par 1 1 1 1\")\n",
    "    mugr = rearrange(geometry[\"mugr\"], \"mu -> 1 mu 1 1 1\")\n",
    "    # settings\n",
    "    little_g = rearrange(geometry[\"little_g\"], \"s three -> three 1 1 s 1 1\")\n",
    "    bn = rearrange(geometry[\"bn\"], \"s -> 1 1 s 1 1\")\n",
    "    efun = rearrange(geometry[\"efun\"], \"s -> 1 1 s 1 1\")\n",
    "    rfun = rearrange(geometry[\"rfun\"], \"s -> 1 1 s 1 1\")\n",
    "    bt_frac = rearrange(geometry[\"bt_frac\"], \"s -> 1 1 s 1 1\")\n",
    "    parseval = rearrange(geometry[\"parseval\"], \"y -> 1 1 1 1 y\")\n",
    "    mas, vthrat, signz = geometry[\"mas\"], geometry[\"vthrat\"], geometry[\"signz\"]\n",
    "    # gyroaveraged phi\n",
    "    krloc = torch.sqrt(\n",
    "        krho**2 * little_g[0] + 2 * krho * kxrh * little_g[1] + kxrh**2 * little_g[2]\n",
    "    )\n",
    "    bessel = torch.special.bessel_j0(\n",
    "        mas * vthrat * krloc * torch.sqrt(2.0 * mugr / bn) / signz\n",
    "    )\n",
    "\n",
    "    phi_gyro = bessel * rearrange(phi, \"x s y -> 1 1 s x y\")\n",
    "    # absolute values of df and phi\n",
    "    if magnitude:\n",
    "        df = -1j * torch.abs(df)\n",
    "        phi_gyro = torch.abs(phi_gyro)\n",
    "    # grid derivatives\n",
    "    dum = parseval * ints * (efun * krho) * df\n",
    "    dum1 = dum * torch.conj(phi_gyro)\n",
    "    dum2 = dum1 * bn\n",
    "    d3X = ints * geometry[\"d2X\"]\n",
    "    d3v = intmu * bn * intvp\n",
    "    signB = geometry[\"signB\"]\n",
    "    # flux fields\n",
    "    pflux_det = d3X * d3v * torch.imag(dum1)\n",
    "    eflux_det = d3X * d3v * (vpgr**2 * torch.imag(dum1) + 2 * mugr * torch.imag(dum2))\n",
    "    vflux_det = d3X * d3v * (torch.imag(dum1) * vpgr * rfun * bt_frac * signB)\n",
    "    # sum total fluxes\n",
    "    if aggregate:\n",
    "        pflux_det = pflux_det.sum()\n",
    "        eflux_det = eflux_det.sum()\n",
    "        vflux_det = vflux_det.sum()\n",
    "    return pflux_det, eflux_det, vflux_det"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "directory = \"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2\"\n",
    "\n",
    "KS = np.arange(1, 150, 5)\n",
    "\n",
    "geometry = {}\n",
    "\n",
    "geometry[\"parseval\"] = torch.tensor([1.0] + [32.0] * (32 - 1), dtype=torch.float32)\n",
    "geometry[\"signz\"] = 1.0\n",
    "geometry[\"vthrat\"] = 1.0\n",
    "geometry[\"tmp\"] = 1.0\n",
    "geometry[\"mas\"] = 1.0\n",
    "geometry[\"d2X\"] = 1.0\n",
    "geometry[\"signB\"] = 1.0\n",
    "\n",
    "geom = load_geom(os.path.join(directory, \"geom.dat\"))  # bn CHECK\n",
    "\n",
    "geometry[\"kxrh\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"kxrh\"))[0], dtype=torch.float32\n",
    ")  # CHECK\n",
    "geometry[\"krho\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"krho\")).T[0] / geom[\"kthnorm\"],\n",
    "    dtype=torch.float32,\n",
    ")  # CHECK\n",
    "\n",
    "# mugr and intmu\n",
    "mugr = np.zeros(8 + 1)\n",
    "intmu = np.zeros(8 + 1)\n",
    "mumax = 4.5\n",
    "dvperp = np.sqrt(2.0 * mumax) / 8\n",
    "for j in range(8 + 1):\n",
    "    vperp = (j - 0.5) * dvperp\n",
    "    mugr[j] = vperp**2 / 2.0\n",
    "    intmu[j] = abs(np.pi * ((vperp + 0.5 * dvperp) ** 2 - (vperp - 0.5 * dvperp) ** 2))\n",
    "\n",
    "geometry[\"intmu\"] = torch.tensor(intmu[1:], dtype=torch.float32)  # CHECK?\n",
    "geometry[\"mugr\"] = torch.tensor(mugr[1:], dtype=torch.float32)  # CHECK?\n",
    "\n",
    "geometry[\"intvp\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"intvp.dat\"))[0], dtype=torch.float32\n",
    ")  # CHECK\n",
    "geometry[\"vpgr\"] = torch.tensor(\n",
    "    np.loadtxt(os.path.join(directory, \"vpgr.dat\"))[0], dtype=torch.float32\n",
    ")\n",
    "\n",
    "ints = np.concatenate(\n",
    "    [np.array([0.0]), np.diff(np.loadtxt(os.path.join(directory, \"sgrid\")))]\n",
    ")\n",
    "ints[0] = ints[1]  # CHECK\n",
    "geometry[\"ints\"] = torch.tensor(ints, dtype=torch.float32)\n",
    "\n",
    "geometry[\"efun\"] = torch.tensor(-geom[\"E_eps_zeta\"], dtype=torch.float32)  # CHECK\n",
    "\n",
    "geometry[\"little_g\"] = torch.tensor(\n",
    "    np.stack([geom[\"g_zeta_zeta\"], geom[\"g_eps_zeta\"], geom[\"g_eps_eps\"]], -1),\n",
    "    dtype=torch.float32,\n",
    ")\n",
    "\n",
    "geometry[\"bn\"] = torch.tensor(geom[\"bn\"])\n",
    "geometry[\"bt_frac\"] = torch.tensor(geom[\"Bt_frac\"])\n",
    "geometry[\"rfun\"] = torch.tensor(geom[\"R\"])\n",
    "\n",
    "########################################################################################\n",
    "\n",
    "gkw = []\n",
    "py = []\n",
    "\n",
    "for k in KS:\n",
    "    df = data[k].y.unsqueeze(0)\n",
    "    gt_phi = data[k].y_poten\n",
    "    flux = data[k].y_flux\n",
    "\n",
    "    phi = phi_integral(df, geometry=geometry)\n",
    "\n",
    "    pflux_det, eflux_det, _ = pev_flux_df_phi(df, phi, geometry=geometry)\n",
    "    gkw.append(flux)\n",
    "    py.append(eflux_det.sum())\n",
    "\n",
    "    print(f\"t = {k}\\t E: {eflux_det.sum():.4f} (py) vs {flux:.4f} (gkw)\")\n",
    "    print(f\"\\t P: {pflux_det.sum():.4f} (py)\")\n",
    "\n",
    "fig, ax = plt.subplots(1, 1)\n",
    "\n",
    "ax.plot(KS, gkw, lw=3, c=(32 / 255, 70 / 255, 125 / 255), label=\"gkw\")\n",
    "ax.plot(KS, py, lw=3, c=(255 / 255, 70 / 255, 125 / 255), label=\"py\")\n",
    "\n",
    "ax.grid()\n",
    "fig.legend()\n",
    "ax.set_xlabel(r\"K\", fontsize=20)\n",
    "ax.set_ylabel(r\"$\\int \\delta f$\", fontsize=20)\n",
    "ax.tick_params(labelsize=14)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mhd",
   "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
