{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import pickle\n",
    "import torch\n",
    "\n",
    "sys.path.append(\"..\")\n",
    "\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cuda\"\n",
    "# CKP = \"../outputs/20250324_104749\"  # LSTM\n",
    "CKP = \"../outputs/20250324_104847\"  # MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val: 165\n"
     ]
    }
   ],
   "source": [
    "import yaml\n",
    "from omegaconf import OmegaConf\n",
    "\n",
    "from utils import load_model_and_config\n",
    "\n",
    "from dataset.cyclone import CycloneDataset\n",
    "\n",
    "cfg = OmegaConf.create(yaml.safe_load(open(f\"{CKP}/config.yaml\", \"r\")))\n",
    "\n",
    "traindata = CycloneDataset(\n",
    "    active_keys=cfg.dataset.active_keys,\n",
    "    path=cfg.dataset.path,\n",
    "    split=\"train\",\n",
    "    random_seed=cfg.seed,\n",
    "    normalization=cfg.dataset.normalization,\n",
    "    spatial_ifft=cfg.dataset.spatial_ifft,\n",
    "    bundle_seq_length=cfg.model.bundle_seq_length,\n",
    "    subsample=cfg.dataset.subsample,\n",
    "    trajectories=cfg.dataset.training_trajectories,\n",
    ")\n",
    "\n",
    "data = CycloneDataset(\n",
    "    active_keys=cfg.dataset.active_keys,\n",
    "    path=cfg.dataset.path,\n",
    "    split=\"val\",\n",
    "    random_seed=cfg.seed,\n",
    "    normalization=None,\n",
    "    dataset_stats=traindata.dataset_stats,\n",
    "    spatial_ifft=cfg.dataset.spatial_ifft,\n",
    "    bundle_seq_length=cfg.model.bundle_seq_length,\n",
    "    trajectories=cfg.dataset.validation_trajectories,\n",
    "    subsample=cfg.dataset.subsample,\n",
    "    separate_zf=cfg.dataset.separate_zf,\n",
    ")\n",
    "\n",
    "print(f\"Val: {len(data)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameters: 0.0M\n",
      "Loading model ../outputs/20250324_104847/best.pth (stopped at epoch 280) with loss 0.090886\n"
     ]
    }
   ],
   "source": [
    "from experimental.baselines.run import get_baseline\n",
    "\n",
    "# from experimental.run_xnet import get_xnet\n",
    "\n",
    "model, target = get_baseline(cfg, dataset=data)\n",
    "last = False\n",
    "path = f\"{CKP}/best.pth\" if not last else f\"{CKP}/ckp.pth\"\n",
    "\n",
    "model, _, _ = load_model_and_config(path, model, device)\n",
    "\n",
    "model = model.to(device)\n",
    "model = model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "IDX_0 = 0\n",
    "IDX_END = len(data) - 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [],
   "source": [
    "losses = []\n",
    "pred_fluxes = []\n",
    "sample_0 = data[IDX_0]\n",
    "phit = sample_0.x_poten.to(device).unsqueeze(0)\n",
    "itg = sample_0.itg.to(device).unsqueeze(0)\n",
    "f_idx = sample_0.file_index.item()\n",
    "flux_seq = data.get_flux_seq(\n",
    "    [sample_0.timestep_index.item()], [sample_0.file_index.item()], window=10\n",
    ").to(device, dtype=itg.dtype).unsqueeze(-1)\n",
    "timesteps = data.get_timesteps(torch.tensor([0], dtype=torch.long))\n",
    "files = []\n",
    "gt_corr = {}\n",
    "\n",
    "with torch.no_grad():\n",
    "    for idx in range(IDX_0, IDX_END + 1):\n",
    "        ts = timesteps[:, idx].to(device)\n",
    "        \n",
    "        if target == \"phi\":\n",
    "            phit = (phit - phit.mean()) / phit.std()\n",
    "            phit, fluxi = model(phit, timestep=ts, itg=itg)\n",
    "        if target == \"flux\":\n",
    "            fluxi = model(ts, itg)\n",
    "        if target == \"seq_flux\":\n",
    "            fluxi = model(flux_seq, ts, itg)\n",
    "            flux_seq = flux_seq.clone()\n",
    "            flux_seq_ = torch.zeros_like(flux_seq, device=flux_seq.device)\n",
    "            flux_seq_[:, :-1] = flux_seq[:, 1:]\n",
    "            flux_seq_[:, -1] = fluxi\n",
    "            flux_seq = flux_seq_\n",
    "        \n",
    "        pred_fluxes.append(fluxi.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "means -> GT: 18.24 vs PRED: 19.27\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "\n",
    "directory = \"/restricteddata/ukaea/gyrokinetics/raw/cyclone4_2_2\"\n",
    "\n",
    "# load data files\n",
    "time = np.loadtxt(os.path.join(directory, \"time.dat\"))\n",
    "gt_fluxes = np.loadtxt(os.path.join(directory, \"fluxes.dat\"))\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(8, 3))\n",
    "fig.suptitle(\"XNet fluxes\")\n",
    "ax.plot(time[0:-1:3], gt_fluxes[0:-1:3, 1], lw=3, c=(32 / 255, 70 / 255, 125 / 255))\n",
    "ax.plot(time[IDX_0 * 3 + 5 : -3 : 3], pred_fluxes, lw=3, c=\"r\")\n",
    "\n",
    "print(\n",
    "    f\"means -> GT: {sum(gt_fluxes[50:-1:3, 1]) / len(gt_fluxes[50:-1:3, 1]):.2f} vs PRED: {sum(pred_fluxes[50:]) / len(pred_fluxes[50:]):.2f}\"\n",
    ")\n",
    "\n",
    "ax.grid()\n",
    "ax.set_xlabel(r\"$t$\", fontsize=20)\n",
    "ax.set_ylabel(r\"$\\int \\delta f$\", fontsize=20)\n",
    "ax.tick_params(labelsize=14)\n",
    "# fig.savefig(\"fluxes.svg\")"
   ]
  },
  {
   "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": 4
}
