{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "KANO Synthetic operator G_2.\n",
    "\n",
    "G = x*dx + dx**2\n",
    "a(x,k) = 1j*x*k - k**2\n",
    "\n",
    "All trained models and dataset used are included in the zipfile"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "(1) We first train KANO with MLP subnetworks instead of KAN,\n",
    "(2) Train KAN with the trained MLP subnetworks,\n",
    "(3) Employ the KAN subnetwork into KANO\n",
    "(4) Train till convergence. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.optim.lr_scheduler as lr_scheduler\n",
    "import matplotlib.pyplot as plt\n",
    "import time\n",
    "\n",
    "##############################################################################\n",
    "# The PDE Operator Architecture (Kano)\n",
    "##############################################################################\n",
    "\n",
    "# MLP subnetwork for symbol a(x,k)\n",
    "class SymbolNet(nn.Module):\n",
    "    \"\"\"\n",
    "    Ordinary 2D->2D MLP: (x, k) -> (real, imag).\n",
    "    \"\"\"\n",
    "    def __init__(self, hidden_dim=32, num_layers=2):\n",
    "        super().__init__()\n",
    "        in_dim = 2   # (x, k)\n",
    "        out_dim = 2  # (real, imag)\n",
    "        layers = [nn.Linear(in_dim, hidden_dim), nn.GELU()]\n",
    "        for _ in range(num_layers - 1):\n",
    "            layers += [nn.Linear(hidden_dim, hidden_dim), nn.GELU()]\n",
    "        layers.append(nn.Linear(hidden_dim, out_dim))\n",
    "        self.net = nn.Sequential(*layers)\n",
    "\n",
    "    def forward(self, xk: torch.Tensor) -> torch.Tensor:\n",
    "        \"\"\"\n",
    "        xk shape: (batch_size, 2) => (x, k)\n",
    "        returns:  (batch_size, 2) => (real, imag)\n",
    "        \"\"\"\n",
    "        return self.net(xk)\n",
    "\n",
    "\n",
    "# Solution Baseline\n",
    "class TrueSymbol(nn.Module):\n",
    "    \"\"\"\n",
    "    Ground‑truth symbol for Gf = x d/dx(f) + d^2/dx^2(f),\n",
    "    under KN quantization => a(x,k) = -k^2 + i(x*k).\n",
    "    \"\"\"\n",
    "    def forward(self, xk: torch.Tensor) -> torch.Tensor:\n",
    "        x = xk[:, 0]\n",
    "        k = xk[:, 1]\n",
    "        real = -k**2\n",
    "        imag = x * k\n",
    "        return torch.stack([real, imag], dim=1)\n",
    "\n",
    "\n",
    "# KN branch module. Since the dataset is real, we truncate the imaginary part \n",
    "# of the KN branch output for the synthetic operator experiments.\n",
    "class pdo(nn.Module):\n",
    "    \"\"\"\n",
    "    Kohn–Nirenberg PDO that returns only the real part g_real of shape (N,).\n",
    "    Stores the imaginary part in self.last_imag (not used in final output).\n",
    "    \"\"\"\n",
    "    def __init__(self, a_net_2d: nn.Module):\n",
    "        super().__init__()\n",
    "        self.a_net_2d = a_net_2d\n",
    "        self.x_cache = None\n",
    "        self.k_cache = None\n",
    "        self.exp_factor_cache = None\n",
    "        self.factor = None\n",
    "        self.n_center = None\n",
    "        self.last_imag = None  # (N,)\n",
    "\n",
    "    def build_cache_for_x(self, x_center: torch.Tensor):\n",
    "        \"\"\"\n",
    "        Builds and caches the FFT-based phase factor exp(i (x_n - x_m) k) \n",
    "        so we don't rebuild it for each forward pass.\n",
    "        \"\"\"\n",
    "        N = x_center.shape[0]\n",
    "        self.n_center = N\n",
    "        if N <= 1:\n",
    "            self.x_cache = x_center.clone()\n",
    "            self.k_cache = None\n",
    "            self.exp_factor_cache = None\n",
    "            self.factor = None\n",
    "            return\n",
    "\n",
    "        dx = (x_center[1] - x_center[0]).item()\n",
    "        k = torch.fft.fftfreq(N, d=dx) * (2 * math.pi)\n",
    "        k = k.to(x_center.device)\n",
    "        dk = (k[1] - k[0]).item()\n",
    "        factor = (dx * dk) / (2 * math.pi)\n",
    "\n",
    "        X_n = x_center.view(N, 1, 1)  # (N,1,1)\n",
    "        X_m = x_center.view(1, N, 1)  # (1,N,1)\n",
    "        K_3d = k.view(1, 1, N)        # (1,1,N)\n",
    "        phase = K_3d * (X_n - X_m)\n",
    "        exp_factor = torch.exp(1j * phase)\n",
    "\n",
    "        self.x_cache = x_center.clone()\n",
    "        self.k_cache = k\n",
    "        self.exp_factor_cache = exp_factor\n",
    "        self.factor = factor\n",
    "\n",
    "    def forward(self, x_center: torch.Tensor, f_center: torch.Tensor) -> torch.Tensor:\n",
    "        \"\"\"\n",
    "        Returns shape (N,) for real part only; caches are reused if x_center hasn't changed.\n",
    "        \"\"\"\n",
    "        N = x_center.shape[0]\n",
    "        # Build cache once if needed\n",
    "        if (self.x_cache is None or self.n_center != N\n",
    "            or not torch.allclose(x_center, self.x_cache)):\n",
    "            self.build_cache_for_x(x_center)\n",
    "\n",
    "        if N <= 1 or self.exp_factor_cache is None:\n",
    "            self.last_imag = torch.zeros_like(f_center)\n",
    "            return f_center.clone()\n",
    "\n",
    "        # Evaluate symbol a(x,k) in an N x N grid\n",
    "        X_grid = self.x_cache.view(N, 1).expand(N, N)\n",
    "        K_grid = self.k_cache.view(1, N).expand(N, N)\n",
    "        xk_pairs = torch.stack([X_grid.flatten(), K_grid.flatten()], dim=1)  # (N*N,2)\n",
    "\n",
    "        a_vals = self.a_net_2d(xk_pairs)       # (N*N,2)\n",
    "        a_vals_complex = a_vals[:, 0] + 1j*a_vals[:, 1]\n",
    "        A = a_vals_complex.view(N, N)          # (N,N)\n",
    "\n",
    "        # Multiply with f and exp(i phase)\n",
    "        A_expanded = A.unsqueeze(1)           # (N,1,N)\n",
    "        f_expanded = f_center.view(1, N, 1)   # (1,N,1)\n",
    "        combined = A_expanded * f_expanded * self.exp_factor_cache\n",
    "        g_complex = combined.sum(dim=(1,2))   # (N,)\n",
    "        g_complex = self.factor * g_complex\n",
    "\n",
    "        g_real = g_complex.real\n",
    "        g_imag = g_complex.imag\n",
    "        self.last_imag = g_imag.detach()\n",
    "        return g_real\n",
    "\n",
    "\n",
    "# Single layer module of KANO\n",
    "class KanoLayer(nn.Module):\n",
    "    \"\"\"\n",
    "    Single layer = PDO -> (g_real, f) -> activation -> updated f\n",
    "    \"\"\"\n",
    "    def __init__(self, symbol_net: nn.Module, act_net: nn.Module):\n",
    "        \"\"\"\n",
    "        symbol_net: e.g. SymbolNet, outputs (real, imag).\n",
    "        act_net:    MLP that takes (N,2) => (N,1), \n",
    "                    or nn.Identity() if you want to skip.\n",
    "        \"\"\"\n",
    "        super().__init__()\n",
    "        self.pdo = pdo(symbol_net)\n",
    "        self.act_net = act_net\n",
    "\n",
    "    def forward(self, x: torch.Tensor, f: torch.Tensor) -> torch.Tensor:\n",
    "        \"\"\"\n",
    "        x: shape (N,)\n",
    "        f: shape (N,)\n",
    "        returns: shape (N,) updated function\n",
    "        \"\"\"\n",
    "        g_real = self.pdo(x, f)  # shape (N,)\n",
    "        # if act_net is Identity, just return g\n",
    "        if isinstance(self.act_net, nn.Identity):\n",
    "            return g_real\n",
    "        # otherwise, combine g_real and f as usual\n",
    "        cat_input = torch.stack([g_real, f], dim=1)  # (N,2)\n",
    "        out = self.act_net(cat_input)                # (N,1)\n",
    "        return out.squeeze(1)                        # (N,)\n",
    "\n",
    "\n",
    "class Kano(nn.Module):\n",
    "    \"\"\"\n",
    "    Stack of KanoLayer modules.\n",
    "    \"\"\"\n",
    "    def __init__(self, num_layers: int, symbol_net: nn.Module, act_net: nn.Module):\n",
    "        super().__init__()\n",
    "        self.layers = nn.ModuleList(\n",
    "            [KanoLayer(symbol_net, act_net) for _ in range(num_layers)]\n",
    "        )\n",
    "\n",
    "    def forward(self, x: torch.Tensor, f: torch.Tensor) -> torch.Tensor:\n",
    "        \"\"\"\n",
    "        x: (N,)  f: (N,)  returns shape (N,)\n",
    "        \"\"\"\n",
    "        for layer in self.layers:\n",
    "            f = layer(x, f)\n",
    "        return f\n",
    "\n",
    "\n",
    "##############################################################################\n",
    "# Caching-Utilizing Train Module\n",
    "##############################################################################\n",
    "\n",
    "def gather_symbol_data(kano, dataset, device):\n",
    "    \"\"\"\n",
    "    Gathers a representative (x,k) mesh from the first PDE sample in the dataset\n",
    "    for PDE symbol net updating (if desired).\n",
    "    \"\"\"\n",
    "    if len(dataset) == 0:\n",
    "        return None\n",
    "\n",
    "    (x, f, Gf, name) = dataset[0]\n",
    "    x = x.to(device)\n",
    "    N = x.shape[0]\n",
    "    if N <= 1:\n",
    "        return None\n",
    "\n",
    "    dx = x[1] - x[0]\n",
    "    k = torch.fft.fftfreq(N, d=dx) * (2 * torch.pi)\n",
    "    k = k.to(device)\n",
    "\n",
    "    x_grid = x.view(N,1).expand(N,N)\n",
    "    k_grid = k.view(1,N).expand(N,N)\n",
    "    x_k_pairs = torch.stack([x_grid.flatten(), k_grid.flatten()], dim=1)  # (N*N,2)\n",
    "    return x_k_pairs\n",
    "\n",
    "\n",
    "def update_symbol_net_grid(kano, dataset, device, symbol_is_kan):\n",
    "    \"\"\"\n",
    "    If symbol_is_kan=True, we do a \"regular\" grid update \n",
    "    on the PDE's symbol net (but NOT refine).\n",
    "    That is, we call sym_net.update_grid(...) each time we want to adapt \n",
    "    the existing grid points to the new distribution.\n",
    "    \"\"\"\n",
    "    if not symbol_is_kan:\n",
    "        return\n",
    "\n",
    "    xk_data = gather_symbol_data(kano, dataset, device)\n",
    "    if xk_data is None:\n",
    "        return\n",
    "\n",
    "    for i, layer in enumerate(kano.layers):\n",
    "        sym_net = layer.pdo.a_net_2d\n",
    "        if sym_net is None:\n",
    "            continue\n",
    "        if hasattr(sym_net, 'update_grid'):\n",
    "            #print(f\"Regular update_grid of PDE symbol net in layer {i}, shape={xk_data.shape}\")\n",
    "            sym_net.update_grid(xk_data)\n",
    "\n",
    "\n",
    "def build_2d_data_for_layer(kano, layer_idx, dataset, device):\n",
    "    \"\"\"\n",
    "    Gather [pdo_out, f_in] => shape(N,2) for the 'layer_idx' activation net \n",
    "    across the entire dataset.\n",
    "    \"\"\"\n",
    "    all_pairs = []\n",
    "    with torch.no_grad():\n",
    "        for (x, f, Gf, _) in dataset:\n",
    "            x, f = x.to(device), f.to(device)\n",
    "            # forward up to layer_idx\n",
    "            f_curr = f\n",
    "            for i in range(layer_idx):\n",
    "                f_curr = kano.layers[i](x, f_curr)\n",
    "            # PDE out\n",
    "            pdo_out = kano.layers[layer_idx].pdo(x, f_curr)\n",
    "            data_2d = torch.stack([pdo_out, f_curr], dim=-1)  # shape(N,2)\n",
    "            all_pairs.append(data_2d)\n",
    "    return torch.cat(all_pairs, dim=0)  # shape(M,2)\n",
    "\n",
    "\n",
    "def update_activation_grid(kano, dataset, device, activation):\n",
    "    \"\"\"\n",
    "    If activation=True, do a \"regular\" grid update each time \n",
    "    for each layer's activation net (if it has update_grid).\n",
    "    \"\"\"\n",
    "    import torch.nn as nn\n",
    "    if not activation:\n",
    "        return\n",
    "\n",
    "    for i, layer in enumerate(kano.layers):\n",
    "        if isinstance(layer.act_net, nn.Identity):\n",
    "            continue\n",
    "        act_net = layer.act_net\n",
    "        if hasattr(act_net, 'update_grid'):\n",
    "            data_2d = build_2d_data_for_layer(kano, i, dataset, device)\n",
    "            #print(f\"Regular update_grid of activation net in layer {i}, shape={data_2d.shape}\")\n",
    "            act_net.update_grid(data_2d)\n",
    "\n",
    "\n",
    "def train_kano(\n",
    "    dataset, \n",
    "    kano,\n",
    "    test_dataset=None,\n",
    "    num_epochs=15,\n",
    "    lr=1e-3,\n",
    "    device=torch.device(\"cpu\"),\n",
    "    symbol_is_kan=False,\n",
    "    activation=True,\n",
    "    reduce_on='test',\n",
    "    factor=0.5,\n",
    "    patience=5,\n",
    "    min_lr=1e-6,\n",
    "    cooldown=0,\n",
    "    grid_update_freq=1,    \n",
    "    start_grid_update_epoch=0,\n",
    "    stop_grid_update_epoch=9999,\n",
    "    early_stop_threshold=None\n",
    "):\n",
    "    \"\"\"\n",
    "    Training loop that:\n",
    "     - uses the pdo caching by building caches once at the beginning (for the first sample's x).\n",
    "     - updates PDE symbol net + activation net grid every 'grid_update_freq' epochs \n",
    "       within [start_grid_update_epoch, stop_grid_update_epoch].\n",
    "     - no refinement logic here.\n",
    "     - has an LR scheduler (ReduceLROnPlateau).\n",
    "     - can stop early if 'early_stop_threshold' is reached.\n",
    "     - **adds an L1 penalty on the imaginary part (g_imag) of each PDO layer**.\n",
    "\n",
    "    ARGS:\n",
    "      symbol_is_kan (bool): if True, we do symbol_net.update_grid(...) \n",
    "      activation (bool): if True, we do activation_net.update_grid(...)\n",
    "      ...\n",
    "    \"\"\"\n",
    "\n",
    "    kano.to(device)\n",
    "    optimizer = optim.Adam(kano.parameters(), lr=lr)\n",
    "    scheduler = lr_scheduler.ReduceLROnPlateau(\n",
    "        optimizer,\n",
    "        mode='min',\n",
    "        factor=factor,\n",
    "        patience=patience,\n",
    "        threshold=1e-4,\n",
    "        cooldown=cooldown,\n",
    "        min_lr=min_lr,\n",
    "        verbose=True\n",
    "    )\n",
    "\n",
    "    def rel_l2_loss(pred, truth):\n",
    "        return torch.norm(pred - truth)/(torch.norm(truth) + 1e-8)\n",
    "\n",
    "    # ---------------------------------------------------------------------\n",
    "    # (A) pdo caching: build once for each layer, using domain from first sample\n",
    "    # ---------------------------------------------------------------------\n",
    "    if len(dataset) > 0:\n",
    "        # Just use the first sample's x\n",
    "        x0, f0, Gf0, _ = dataset[0]\n",
    "        x0 = x0.to(device)\n",
    "        # Call build_cache_for_x on each layer's pdo\n",
    "        for i, layer in enumerate(kano.layers):\n",
    "            layer.pdo.build_cache_for_x(x0)\n",
    "        print(\"[train_kano] Built pdo cache(s) once using the first sample's domain.\")\n",
    "\n",
    "    # ---------------------------------------------------------------------\n",
    "    # (B) main training loop\n",
    "    # ---------------------------------------------------------------------\n",
    "    loss_history = []\n",
    "    test_loss_history = []\n",
    "    start_time = time.time()\n",
    "    early_stopped = False\n",
    "\n",
    "    for epoch in range(num_epochs):\n",
    "        epoch_start = time.time()\n",
    "\n",
    "        # (B1) Possibly do a \"regular\" grid update if epoch in [start, stop] and epoch%grid_update_freq == 0\n",
    "        if (start_grid_update_epoch <= epoch < stop_grid_update_epoch) and (epoch % grid_update_freq == 0):\n",
    "            update_symbol_net_grid(kano, dataset, device, symbol_is_kan)\n",
    "            update_activation_grid(kano, dataset, device, activation)\n",
    "\n",
    "        # (B2) normal training pass\n",
    "        epoch_loss = 0.0\n",
    "        for (x, f, Gf, _) in dataset:\n",
    "            x, f, Gf = x.to(device), f.to(device), Gf.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            pred = kano(x, f)\n",
    "\n",
    "            # PDE loss (relative L2)\n",
    "            pde_loss = rel_l2_loss(pred, Gf)\n",
    "\n",
    "            # (B2.1) Add L1 penalty on g_imag from each layer\n",
    "            #        so the final loss = PDE_loss + sum of L1 norms of imag\n",
    "            pdo_imag_l1 = 0.0\n",
    "            for lay in kano.layers:\n",
    "                # last_imag is shape (N,) if not None\n",
    "                if lay.pdo.last_imag is not None:\n",
    "                    pdo_imag_l1 += lay.pdo.last_imag.abs().sum()  # sum or .mean(), either is an L1 norm\n",
    "\n",
    "            # total loss\n",
    "            total_loss = pde_loss + pdo_imag_l1\n",
    "\n",
    "            total_loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            # (B2.2) We only accumulate PDE loss in epoch_loss for printing\n",
    "            epoch_loss += pde_loss.item()\n",
    "\n",
    "        epoch_loss_avg = epoch_loss / len(dataset)\n",
    "        loss_history.append(epoch_loss_avg)\n",
    "\n",
    "        # (B3) Evaluate on test dataset if provided\n",
    "        if test_dataset is not None:\n",
    "            test_epoch_loss = 0.0\n",
    "            for (x, f, Gf, _) in test_dataset:\n",
    "                x, f, Gf = x.to(device), f.to(device), Gf.to(device)\n",
    "                with torch.no_grad():\n",
    "                    pred = kano(x, f)\n",
    "                # we only measure PDE-based rel L2 for printing\n",
    "                test_epoch_loss += rel_l2_loss(pred, Gf).item()\n",
    "            test_epoch_loss_avg = test_epoch_loss / len(test_dataset)\n",
    "            test_loss_history.append(test_epoch_loss_avg)\n",
    "        else:\n",
    "            test_epoch_loss_avg = None\n",
    "\n",
    "        epoch_time = time.time() - epoch_start\n",
    "\n",
    "        # (B4) Step LR scheduler\n",
    "        metric = test_epoch_loss_avg if (reduce_on=='test' and test_epoch_loss_avg is not None) else epoch_loss_avg\n",
    "        scheduler.step(metric)\n",
    "\n",
    "        # (B5) Early stopping check\n",
    "        if early_stop_threshold is not None:\n",
    "            # If reduce_on='test' and we have test dataset => use test metric\n",
    "            # else fallback to train\n",
    "            if reduce_on == 'test' and test_epoch_loss_avg is not None:\n",
    "                if test_epoch_loss_avg < early_stop_threshold:\n",
    "                    print(f\"\\nEarly stopping triggered at epoch {epoch+1} \"\n",
    "                          f\"since test_loss={test_epoch_loss_avg:.10f} < {early_stop_threshold}\")\n",
    "                    early_stopped = True\n",
    "                    break\n",
    "            else:\n",
    "                # fallback => train metric\n",
    "                if epoch_loss_avg < early_stop_threshold:\n",
    "                    print(f\"\\nEarly stopping triggered at epoch {epoch+1} \"\n",
    "                          f\"since train_loss={epoch_loss_avg:.10f} < {early_stop_threshold}\")\n",
    "                    early_stopped = True\n",
    "                    break\n",
    "\n",
    "        # (B6) Print info\n",
    "        current_lr = optimizer.param_groups[0]['lr']\n",
    "        if test_epoch_loss_avg is not None:\n",
    "            msg = (f\"Epoch [{epoch+1}/{num_epochs}] | \"\n",
    "                   f\"Train Loss={epoch_loss_avg:.10f} | \"\n",
    "                   f\"Test Loss={test_epoch_loss_avg:.10f} | \"\n",
    "                   f\"Time={epoch_time:.2f}s | LR={current_lr:.2e}\")\n",
    "        else:\n",
    "            msg = (f\"Epoch [{epoch+1}/{num_epochs}] | \"\n",
    "                   f\"Train Loss={epoch_loss_avg:.10f} | \"\n",
    "                   f\"Time={epoch_time:.2f}s | LR={current_lr:.2e}\")\n",
    "\n",
    "        print(msg)\n",
    "\n",
    "    total_time = time.time() - start_time\n",
    "    print(f\"\\nTotal training time: {total_time:.2f}s\")\n",
    "\n",
    "    # (C) Plot\n",
    "    plt.figure()\n",
    "    plt.semilogy(loss_history, label=\"Train Rel L2 Loss\")\n",
    "    if test_dataset is not None:\n",
    "        plt.semilogy(test_loss_history, label=\"Test Rel L2 Loss\")\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Relative L2 Loss\")\n",
    "    plt.grid()\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    return loss_history, test_loss_history, early_stopped"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Data Generation Modules."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import math\n",
    "import numpy as np\n",
    "from scipy.special import hermite, j0\n",
    "\n",
    "#############################################\n",
    "# 1) Outer Envelope with Zero Buffers\n",
    "#############################################\n",
    "def outer_envelope(x: torch.Tensor) -> torch.Tensor:\n",
    "    W = torch.zeros_like(x)\n",
    "    limit_in = 5.0 * math.pi / 6.0  # ±5π/6\n",
    "    limit_out = math.pi            # ±π\n",
    "\n",
    "    abs_x = x.abs()\n",
    "    # Region where |x| <= 5π/6 => envelope=1\n",
    "    mask_in = (abs_x <= limit_in)\n",
    "    W[mask_in] = 1.0\n",
    "\n",
    "    # Smooth ramp region: 5π/6 < |x| < π\n",
    "    mask_ramp = (abs_x > limit_in) & (abs_x < limit_out)\n",
    "    alpha = (abs_x[mask_ramp] - limit_in) / (limit_out - limit_in)\n",
    "    W[mask_ramp] = torch.cos(alpha * (math.pi / 2))**4\n",
    "\n",
    "    return W\n",
    "\n",
    "#############################################\n",
    "# 2) \"Inner\" Envelope (optional)\n",
    "#############################################\n",
    "def inner_sin4_envelope(x: torch.Tensor) -> torch.Tensor:\n",
    "    return torch.sin(0.5 * (x + math.pi))**4\n",
    "\n",
    "#############################################\n",
    "# 3) Combined Envelope\n",
    "#############################################\n",
    "def full_envelope(x: torch.Tensor) -> torch.Tensor:\n",
    "    return outer_envelope(x)\n",
    "\n",
    "#############################################\n",
    "# 4) Spectral Derivatives (Periodic Grid)\n",
    "#############################################\n",
    "def spectral_first_derivative(f: torch.Tensor, x: torch.Tensor) -> torch.Tensor:\n",
    "    n = f.shape[0]\n",
    "    dx = (x[-1] - x[0] + (x[1] - x[0])) / n\n",
    "    fhat = torch.fft.fft(f)\n",
    "    k = torch.fft.fftfreq(n, d=dx) * (2 * math.pi)\n",
    "    dfhat = 1j * k * fhat\n",
    "    return torch.fft.ifft(dfhat).real\n",
    "\n",
    "def spectral_second_derivative(f: torch.Tensor, x: torch.Tensor) -> torch.Tensor:\n",
    "    n = f.shape[0]\n",
    "    dx = (x[-1] - x[0] + (x[1] - x[0])) / n\n",
    "    fhat = torch.fft.fft(f)\n",
    "    k = torch.fft.fftfreq(n, d=dx) * (2 * math.pi)\n",
    "    d2fhat = -(k**2) * fhat\n",
    "    return torch.fft.ifft(d2fhat).real\n",
    "\n",
    "#############################################\n",
    "# 5) Ground Truth Operator\n",
    "#############################################\n",
    "def apply_operator(x: torch.Tensor, f: torch.Tensor) -> torch.Tensor:\n",
    "    df  = spectral_first_derivative(f, x)\n",
    "    d2f = spectral_second_derivative(f, x)\n",
    "    return x * df + d2f\n",
    "\n",
    "\n",
    "\n",
    "#############################################\n",
    "# 6) High‑Frequency Train Families (frequencies halved: 16→8)\n",
    "#############################################\n",
    "\n",
    "def random_periodic_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    base_freq = np.random.uniform(0.5, 3.0)\n",
    "    freq      = base_freq * 8.0          # was *16.0\n",
    "    phase1    = np.random.uniform(0, 2 * math.pi)\n",
    "    phase2    = np.random.uniform(0, 2 * math.pi)\n",
    "    base      = torch.sin(freq * x + phase1) + torch.cos(freq * x + phase2)\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "def random_gaussian_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    mu     = np.random.uniform(-2.0, 2.0)\n",
    "    sigma  = np.random.uniform(0.5, 2.0) / 8.0   # was /16.0\n",
    "    base   = torch.exp(-((x - mu)**2) / (2 * sigma**2))\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "def random_gaussian_hermite_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    deg    = np.random.randint(1, 4)\n",
    "    H      = hermite(deg)\n",
    "    mu     = np.random.uniform(-2.0, 2.0)\n",
    "    sigma  = np.random.uniform(0.5, 2.0) / 8.0   # was /16.0\n",
    "    poly   = torch.tensor(H((x - mu) / sigma), dtype=torch.float32, device=x.device)\n",
    "    base   = poly * torch.exp(-((x - mu)**2) / (2 * sigma**2))\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "def random_sine_beats_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    freq1  = np.random.uniform(0.5, 3.0) * 8.0   # was *16.0\n",
    "    freq2  = np.random.uniform(0.5, 3.0) * 8.0\n",
    "    phase1 = np.random.uniform(0, 2 * math.pi)\n",
    "    phase2 = np.random.uniform(0, 2 * math.pi)\n",
    "    base   = torch.sin(freq1 * x + phase1) * torch.sin(freq2 * x + phase2)\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "\n",
    "\n",
    "#############################################\n",
    "# 7) High‑Frequency Unseen Families (frequencies +50%: 8→12)\n",
    "#############################################\n",
    "\n",
    "def chirped_cosine_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    alpha = np.random.uniform(0.5, 2.0) * 12.0   # was *8.0\n",
    "    base  = torch.cos(alpha * x**2)\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "def wave_packet_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    mu     = np.random.uniform(-2.0, 2.0)\n",
    "    sigma  = np.random.uniform(0.5, 2.0) / 12.0   # was /8.0\n",
    "    omega  = np.random.uniform(2.0, 6.0) * 12.0   # was *8.0\n",
    "    phi    = np.random.uniform(0, 2 * math.pi)\n",
    "    base   = torch.exp(-((x - mu)**2) / (2 * sigma**2)) * torch.sin(omega * x + phi)\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "def sinc_pulse_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    alpha   = np.random.uniform(0.5, 3.0) * 12.0  # was *8.0\n",
    "    x_alpha = alpha * x\n",
    "    base    = torch.zeros_like(x)\n",
    "    mask    = x_alpha.abs() > 1e-12\n",
    "    base[mask]   = torch.sin(x_alpha[mask]) / x_alpha[mask]\n",
    "    base[~mask]  = 1.0\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "def bessel_j0_highfreq(x: torch.Tensor) -> torch.Tensor:\n",
    "    freq = np.random.uniform(2.0, 5.0) * 12.0     # was *8.0\n",
    "    arg  = freq * x\n",
    "    vals = j0(arg.cpu().numpy())\n",
    "    base = torch.tensor(vals, dtype=torch.float32, device=x.device)\n",
    "    return full_envelope(x) * base\n",
    "\n",
    "UNSEEN_FAMILIES_HIGHFREQ = {\n",
    "    \n",
    "    \"wave_packet\": wave_packet_highfreq,\n",
    "    \"sinc_pulse\":     sinc_pulse_highfreq,\n",
    "    \"gaussian_hermite\":      random_gaussian_hermite_highfreq\n",
    "}\n",
    "\n",
    "TRAIN_FAMILIES_HIGHFREQ = {\n",
    "    \"sine_beats\": random_sine_beats_highfreq,\n",
    "    \n",
    "    \"chirped_cosine\": chirped_cosine_highfreq,\n",
    "    \"periodic\": random_periodic_highfreq\n",
    "}\n",
    "#############################################\n",
    "# 8) generate_dataset & generate_dataset_unseen\n",
    "#############################################\n",
    "def generate_dataset(num_samples: int = 100,\n",
    "                     n: int = 128,\n",
    "                     x_min: float = -math.pi,\n",
    "                     x_max: float = math.pi):\n",
    "    dataset = []\n",
    "    x = torch.linspace(x_min, x_max, n+1, dtype=torch.float32)[:-1]\n",
    "    for _ in range(num_samples):\n",
    "        ftype     = np.random.choice(list(TRAIN_FAMILIES_HIGHFREQ.keys()))\n",
    "        base_func = TRAIN_FAMILIES_HIGHFREQ[ftype]\n",
    "        f         = base_func(x)\n",
    "        max_val   = f.abs().max().item()\n",
    "        if max_val > 1e-12:\n",
    "            f = f / max_val\n",
    "        df  = spectral_first_derivative(f, x)\n",
    "        d2f = spectral_second_derivative(f, x)\n",
    "        Gf  = x * df + d2f\n",
    "        dataset.append((x.clone(), f.clone(), Gf.clone(), ftype))\n",
    "    return dataset\n",
    "\n",
    "def generate_dataset_unseen(num_samples: int = 100,\n",
    "                            n: int = 128,\n",
    "                            x_min: float = -math.pi,\n",
    "                            x_max: float = math.pi):\n",
    "    dataset = []\n",
    "    x = torch.linspace(x_min, x_max, n+1, dtype=torch.float32)[:-1]\n",
    "    for _ in range(num_samples):\n",
    "        ftype     = np.random.choice(list(UNSEEN_FAMILIES_HIGHFREQ.keys()))\n",
    "        base_func = UNSEEN_FAMILIES_HIGHFREQ[ftype]\n",
    "        f         = base_func(x)\n",
    "        max_val   = f.abs().max().item()\n",
    "        if max_val > 1e-12:\n",
    "            f = f / max_val\n",
    "        df  = spectral_first_derivative(f, x)\n",
    "        d2f = spectral_second_derivative(f, x)\n",
    "        Gf  = x * df + d2f\n",
    "        dataset.append((x.clone(), f.clone(), Gf.clone(), ftype))\n",
    "    return dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Dataset is provided in the zipfile with same file names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_321888/3082890924.py:90: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  poly   = torch.tensor(H((x - mu) / sigma), dtype=torch.float32, device=x.device)\n"
     ]
    }
   ],
   "source": [
    "train_data = generate_dataset(num_samples=2000, n=128)\n",
    "torch.save(train_data, 'train_2.pt')\n",
    "sample_data = generate_dataset(num_samples=400, n=128)\n",
    "torch.save(sample_data, 'sample_2.pt')\n",
    "test_data = generate_dataset_unseen(num_samples=400, n=128)\n",
    "torch.save(test_data, 'test_2.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def count_parameters(model: nn.Module) -> int:\n",
    "    \"\"\"\n",
    "    Count all trainable parameters of a model.\n",
    "    \"\"\"\n",
    "    return sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "\n",
    "import time\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "def evaluate_operator(dataset, operator, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    For each (x, f, Gf, func_type) in the dataset, all shaped (N,):\n",
    "      - g_pred = operator(x, f) -> shape (N,)\n",
    "      - measure rel_l2 = ||g_pred - Gf|| / ||Gf||\n",
    "    Prints mean results per function type and overall.\n",
    "    Returns a list of the per-sample losses in the order of dataset.\n",
    "    \"\"\"\n",
    "    # Move operator to device and switch to eval mode (no grad)\n",
    "    operator = operator.to(device).eval()\n",
    "\n",
    "    # Count trainable parameters\n",
    "    total_params = sum(p.numel() for p in operator.parameters() if p.requires_grad)\n",
    "    print(f\"Total trainable parameters: {total_params:,}\")\n",
    "\n",
    "    losses = []\n",
    "    type_losses = {}\n",
    "    total_inference_time = 0.0\n",
    "\n",
    "    # No grad needed for inference\n",
    "    with torch.no_grad():\n",
    "        for x, f, Gf, func_type in dataset:\n",
    "            # Ensure data is on correct device\n",
    "            x, f, Gf = x.to(device), f.to(device), Gf.to(device)\n",
    "\n",
    "            t0 = time.time()\n",
    "            # operator(...) should produce shape (N,)\n",
    "            g_pred = operator(x, f)\n",
    "            total_inference_time += (time.time() - t0)\n",
    "\n",
    "            # Compute relative L2 difference: (N,) - (N,) => no dimension issue\n",
    "            numerator = torch.linalg.norm(g_pred - Gf)\n",
    "            denominator = torch.linalg.norm(Gf) + 1e-8  # avoid /0\n",
    "            rel_l2 = numerator / denominator\n",
    "            loss_val = rel_l2.item()\n",
    "\n",
    "            # Accumulate results\n",
    "            losses.append(loss_val)\n",
    "            type_losses.setdefault(func_type, []).append(loss_val)\n",
    "\n",
    "    # --- Reporting ---\n",
    "    for ftype, vals in type_losses.items():\n",
    "        mean_val = np.mean(vals)\n",
    "        print(f\"Function type '{ftype}': mean Rel-L2 = {mean_val:.10f}\")\n",
    "\n",
    "    overall_mean = np.mean(losses) if losses else 0.0\n",
    "    print(f\"Overall mean Rel-L2 = {overall_mean:.10f}\")\n",
    "    if len(dataset) > 0:\n",
    "        avg_time = total_inference_time / len(dataset)\n",
    "    else:\n",
    "        avg_time = 0.0\n",
    "    print(f\"Average inference time / sample = {avg_time:.6f} s\")\n",
    "\n",
    "    return losses\n",
    "\n",
    "\n",
    "def plot_functions(dataset, operator, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Plot the target and inferred functions for each function pair.\n",
    "    Relative L2 loss is computed on the fly and included in the title along with the function type.\n",
    "    \n",
    "    Args:\n",
    "        dataset: An iterable of tuples (x, f, Gf, func_type).\n",
    "        operator: The operator object with a forward(x, f) method.\n",
    "        device: The torch.device to use.\n",
    "    \"\"\"\n",
    "    num_pairs = len(dataset)\n",
    "    num_rows = (num_pairs + 3) // 4  # 4 columns per row.\n",
    "    num_cols = 4\n",
    "    operator.to(device)\n",
    "    plt.figure(figsize=(20, 5 * num_rows))\n",
    "    \n",
    "    for idx, (x, f, Gf, func_type) in enumerate(dataset):\n",
    "        # Move data to device.\n",
    "        x_dev, f_dev, Gf_dev = x.to(device), f.to(device), Gf.to(device)\n",
    "        \n",
    "        with torch.no_grad():\n",
    "            g_pred = operator(x_dev, f_dev)\n",
    "        \n",
    "        # Compute relative L2 loss.\n",
    "        rel_loss = torch.norm(g_pred - Gf_dev, p=2) / (torch.norm(Gf_dev, p=2) + 1e-8)\n",
    "        loss_value = rel_loss.item()\n",
    "        \n",
    "        plt.subplot(num_rows, num_cols, idx + 1)\n",
    "        # Plot only the target and inferred functions.\n",
    "        plt.plot(x.cpu().numpy(), Gf.cpu().numpy(), label=\"Target: $Gf(x)$\", linestyle=\"--\", linewidth=2)\n",
    "        plt.plot(x.cpu().numpy(), g_pred.cpu().numpy(), label=\"Inferred: $g(x)$\", linestyle=\"-.\", linewidth=2)\n",
    "        plt.xlabel(\"$x$\")\n",
    "        plt.ylabel(\"Function Value\")\n",
    "        plt.title(f\"Type: {func_type}\\nRelative L2 Loss: {loss_value:.6f}\")\n",
    "        plt.legend()\n",
    "        plt.grid()\n",
    "    \n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "We do not use activation subnetwork for this linear operator problem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters:  1218\n"
     ]
    }
   ],
   "source": [
    "# Model Definition\n",
    "sym_net = SymbolNet(hidden_dim=32, num_layers=2)\n",
    "kano_mlp = Kano(num_layers=1, symbol_net=sym_net, act_net=nn.Identity())\n",
    "true_kano = Kano(num_layers=1, symbol_net=TrueSymbol(), act_net=nn.Identity())\n",
    "\n",
    "sym_net.load_state_dict(torch.load('kanosymmlp_2.pth'))\n",
    "\n",
    "print(\"Total trainable parameters: \", count_parameters(sym_net))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = torch.load('train_2.pt', weights_only=False)\n",
    "test_data = torch.load('test_2.pt', weights_only=False)\n",
    "sample_data = torch.load('sample_2.pt', weights_only=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = 'cuda:1'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Total trainable parameters: 0\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000215859\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000841780\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000444880\n",
      "Overall mean Rel-L2 = 0.0000503945\n",
      "Average inference time / sample = 0.000379 s\n",
      "--------------test----------------\n",
      "Total trainable parameters: 0\n",
      "Function type 'gaussian_hermite': mean Rel-L2 = 0.0000707574\n",
      "Function type 'sinc_pulse': mean Rel-L2 = 0.0000525050\n",
      "Function type 'wave_packet': mean Rel-L2 = 0.0000279582\n",
      "Overall mean Rel-L2 = 0.0000509628\n",
      "Average inference time / sample = 0.000345 s\n",
      "--------------sample----------------\n",
      "Total trainable parameters: 0\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000725483\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000245468\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000464966\n",
      "Overall mean Rel-L2 = 0.0000474558\n",
      "Average inference time / sample = 0.000346 s\n"
     ]
    }
   ],
   "source": [
    "# Solution baseline\n",
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, operator = true_kano, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = true_kano, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = true_kano, device = device)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_functions(dataset=sample_data,operator=true_kano,device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_functions(dataset=test_data,operator=true_kano,device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jinlee/kn_mlp/kano/lib/python3.10/site-packages/torch/optim/lr_scheduler.py:62: UserWarning: The verbose parameter is deprecated. Please use get_last_lr() to access the learning rate.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[train_kano] Built pdo cache(s) once using the first sample's domain.\n",
      "Epoch [1/400] | Train Loss=0.5712322223 | Test Loss=0.5637520534 | Time=5.75s | LR=1.00e-03\n",
      "Epoch [2/400] | Train Loss=0.4480624754 | Test Loss=0.4036057681 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [3/400] | Train Loss=0.3247575544 | Test Loss=0.2864224619 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [4/400] | Train Loss=0.2167784149 | Test Loss=0.1709274101 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [5/400] | Train Loss=0.1273263527 | Test Loss=0.1131618008 | Time=5.59s | LR=1.00e-03\n",
      "Epoch [6/400] | Train Loss=0.0805843629 | Test Loss=0.0803417272 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [7/400] | Train Loss=0.0538327815 | Test Loss=0.0706488999 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [8/400] | Train Loss=0.0390586460 | Test Loss=0.0427012080 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [9/400] | Train Loss=0.0283101904 | Test Loss=0.0506844728 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [10/400] | Train Loss=0.0223486042 | Test Loss=0.0421619872 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [11/400] | Train Loss=0.0179482251 | Test Loss=0.0220820099 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [12/400] | Train Loss=0.0149940416 | Test Loss=0.0150019495 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [13/400] | Train Loss=0.0132127541 | Test Loss=0.0122991031 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [14/400] | Train Loss=0.0123204517 | Test Loss=0.0124885472 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [15/400] | Train Loss=0.0117106048 | Test Loss=0.0194385758 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [16/400] | Train Loss=0.0114707103 | Test Loss=0.0109768559 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [17/400] | Train Loss=0.0114420622 | Test Loss=0.0140147500 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [18/400] | Train Loss=0.0109879002 | Test Loss=0.0128657958 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [19/400] | Train Loss=0.0107789339 | Test Loss=0.0112932241 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [20/400] | Train Loss=0.0105549620 | Test Loss=0.0075051758 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [21/400] | Train Loss=0.0100567638 | Test Loss=0.0082249045 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [22/400] | Train Loss=0.0101179586 | Test Loss=0.0085243663 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [23/400] | Train Loss=0.0103455238 | Test Loss=0.0220699473 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [24/400] | Train Loss=0.0098753112 | Test Loss=0.0076623842 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [25/400] | Train Loss=0.0098058128 | Test Loss=0.0086161032 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [26/400] | Train Loss=0.0099719644 | Test Loss=0.0239555150 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [27/400] | Train Loss=0.0097549731 | Test Loss=0.0066836675 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [28/400] | Train Loss=0.0098901617 | Test Loss=0.0222911997 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [29/400] | Train Loss=0.0092170113 | Test Loss=0.0124131233 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [30/400] | Train Loss=0.0097163244 | Test Loss=0.0098374094 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [31/400] | Train Loss=0.0089846716 | Test Loss=0.0251369342 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [32/400] | Train Loss=0.0094067014 | Test Loss=0.0088855060 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [33/400] | Train Loss=0.0090083040 | Test Loss=0.0111152765 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [34/400] | Train Loss=0.0086984594 | Test Loss=0.0118866364 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [35/400] | Train Loss=0.0088900084 | Test Loss=0.0054701503 | Time=5.58s | LR=1.00e-03\n",
      "Epoch [36/400] | Train Loss=0.0090162002 | Test Loss=0.0104317996 | Time=5.57s | LR=1.00e-03\n",
      "Epoch [37/400] | Train Loss=0.0088861126 | Test Loss=0.0096198383 | Time=5.39s | LR=1.00e-03\n",
      "Epoch [38/400] | Train Loss=0.0091207585 | Test Loss=0.0194262664 | Time=5.95s | LR=1.00e-03\n",
      "Epoch [39/400] | Train Loss=0.0089170603 | Test Loss=0.0124936790 | Time=6.56s | LR=1.00e-03\n",
      "Epoch [40/400] | Train Loss=0.0090454635 | Test Loss=0.0162077841 | Time=6.59s | LR=1.00e-03\n",
      "Epoch [41/400] | Train Loss=0.0083425881 | Test Loss=0.0097827828 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [42/400] | Train Loss=0.0088250055 | Test Loss=0.0091130432 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [43/400] | Train Loss=0.0089964910 | Test Loss=0.0136404263 | Time=6.59s | LR=1.00e-03\n",
      "Epoch [44/400] | Train Loss=0.0085037335 | Test Loss=0.0057060508 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [45/400] | Train Loss=0.0092267621 | Test Loss=0.0131003356 | Time=6.56s | LR=1.00e-03\n",
      "Epoch [46/400] | Train Loss=0.0081960627 | Test Loss=0.0063906409 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [47/400] | Train Loss=0.0083470878 | Test Loss=0.0085020927 | Time=6.56s | LR=1.00e-03\n",
      "Epoch [48/400] | Train Loss=0.0087112116 | Test Loss=0.0063828137 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [49/400] | Train Loss=0.0083810278 | Test Loss=0.0100343408 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [50/400] | Train Loss=0.0084146122 | Test Loss=0.0108127537 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [51/400] | Train Loss=0.0084696484 | Test Loss=0.0118149736 | Time=7.19s | LR=1.00e-03\n",
      "Epoch [52/400] | Train Loss=0.0081243857 | Test Loss=0.0177025348 | Time=6.50s | LR=1.00e-03\n",
      "Epoch [53/400] | Train Loss=0.0079806862 | Test Loss=0.0053653388 | Time=6.62s | LR=1.00e-03\n",
      "Epoch [54/400] | Train Loss=0.0079984580 | Test Loss=0.0081290743 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [55/400] | Train Loss=0.0076351296 | Test Loss=0.0082643998 | Time=6.59s | LR=1.00e-03\n",
      "Epoch [56/400] | Train Loss=0.0082621265 | Test Loss=0.0053215285 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [57/400] | Train Loss=0.0083798189 | Test Loss=0.0059621089 | Time=5.83s | LR=1.00e-03\n",
      "Epoch [58/400] | Train Loss=0.0078132708 | Test Loss=0.0068841391 | Time=4.50s | LR=1.00e-03\n",
      "Epoch [59/400] | Train Loss=0.0079126922 | Test Loss=0.0072728199 | Time=4.50s | LR=1.00e-03\n",
      "Epoch [60/400] | Train Loss=0.0079341099 | Test Loss=0.0051547116 | Time=4.54s | LR=1.00e-03\n",
      "Epoch [61/400] | Train Loss=0.0078725392 | Test Loss=0.0068363824 | Time=4.52s | LR=1.00e-03\n",
      "Epoch [62/400] | Train Loss=0.0080364183 | Test Loss=0.0048178629 | Time=5.23s | LR=1.00e-03\n",
      "Epoch [63/400] | Train Loss=0.0075604149 | Test Loss=0.0114114762 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [64/400] | Train Loss=0.0079721927 | Test Loss=0.0141844318 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [65/400] | Train Loss=0.0075629576 | Test Loss=0.0082713777 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [66/400] | Train Loss=0.0076516361 | Test Loss=0.0090774159 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [67/400] | Train Loss=0.0074991399 | Test Loss=0.0043243861 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [68/400] | Train Loss=0.0076195099 | Test Loss=0.0077683071 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [69/400] | Train Loss=0.0072971065 | Test Loss=0.0080787223 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [70/400] | Train Loss=0.0076381135 | Test Loss=0.0061789434 | Time=6.59s | LR=1.00e-03\n",
      "Epoch [71/400] | Train Loss=0.0076070607 | Test Loss=0.0079599740 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [72/400] | Train Loss=0.0078467834 | Test Loss=0.0067545885 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [73/400] | Train Loss=0.0077824412 | Test Loss=0.0044264940 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [74/400] | Train Loss=0.0071600482 | Test Loss=0.0083430771 | Time=6.59s | LR=1.00e-03\n",
      "Epoch [75/400] | Train Loss=0.0075279163 | Test Loss=0.0049093619 | Time=6.73s | LR=1.00e-03\n",
      "Epoch [76/400] | Train Loss=0.0074958381 | Test Loss=0.0072419410 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [77/400] | Train Loss=0.0080094341 | Test Loss=0.0068692806 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [78/400] | Train Loss=0.0073539277 | Test Loss=0.0065627611 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [79/400] | Train Loss=0.0078033388 | Test Loss=0.0081691678 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [80/400] | Train Loss=0.0070999674 | Test Loss=0.0102009632 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [81/400] | Train Loss=0.0071537583 | Test Loss=0.0051803463 | Time=6.56s | LR=1.00e-03\n",
      "Epoch [82/400] | Train Loss=0.0073224354 | Test Loss=0.0089971000 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [83/400] | Train Loss=0.0072311542 | Test Loss=0.0119573292 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [84/400] | Train Loss=0.0075649842 | Test Loss=0.0071931670 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [85/400] | Train Loss=0.0072602800 | Test Loss=0.0094329772 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [86/400] | Train Loss=0.0072563161 | Test Loss=0.0147179760 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [87/400] | Train Loss=0.0073256448 | Test Loss=0.0077630057 | Time=6.58s | LR=1.00e-03\n",
      "Epoch [88/400] | Train Loss=0.0071122786 | Test Loss=0.0056448691 | Time=6.57s | LR=1.00e-03\n",
      "Epoch [89/400] | Train Loss=0.0071367603 | Test Loss=0.0075351755 | Time=6.59s | LR=1.00e-03\n",
      "Epoch [90/400] | Train Loss=0.0073005090 | Test Loss=0.0094683635 | Time=6.61s | LR=1.00e-03\n",
      "Epoch [91/400] | Train Loss=0.0073117913 | Test Loss=0.0105237387 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [92/400] | Train Loss=0.0042733463 | Test Loss=0.0045949297 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [93/400] | Train Loss=0.0045110163 | Test Loss=0.0094312303 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [94/400] | Train Loss=0.0042671494 | Test Loss=0.0056167764 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [95/400] | Train Loss=0.0044680723 | Test Loss=0.0071691881 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [96/400] | Train Loss=0.0044545764 | Test Loss=0.0038091201 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [97/400] | Train Loss=0.0044185610 | Test Loss=0.0034805527 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [98/400] | Train Loss=0.0043600466 | Test Loss=0.0036900381 | Time=6.60s | LR=5.00e-04\n",
      "Epoch [99/400] | Train Loss=0.0041370331 | Test Loss=0.0052018720 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [100/400] | Train Loss=0.0043655336 | Test Loss=0.0035598322 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [101/400] | Train Loss=0.0042005299 | Test Loss=0.0033193941 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [102/400] | Train Loss=0.0043481938 | Test Loss=0.0038561149 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [103/400] | Train Loss=0.0040542510 | Test Loss=0.0040178746 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [104/400] | Train Loss=0.0044388110 | Test Loss=0.0039601276 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [105/400] | Train Loss=0.0043212385 | Test Loss=0.0047233422 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [106/400] | Train Loss=0.0042541190 | Test Loss=0.0047082317 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [107/400] | Train Loss=0.0044507971 | Test Loss=0.0054140020 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [108/400] | Train Loss=0.0042999811 | Test Loss=0.0065784641 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [109/400] | Train Loss=0.0042695821 | Test Loss=0.0074587586 | Time=6.76s | LR=5.00e-04\n",
      "Epoch [110/400] | Train Loss=0.0043341839 | Test Loss=0.0048359695 | Time=6.66s | LR=5.00e-04\n",
      "Epoch [111/400] | Train Loss=0.0041709725 | Test Loss=0.0047741086 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [112/400] | Train Loss=0.0041867420 | Test Loss=0.0033826225 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [113/400] | Train Loss=0.0040472520 | Test Loss=0.0058383204 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [114/400] | Train Loss=0.0041102934 | Test Loss=0.0032147635 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [115/400] | Train Loss=0.0040388748 | Test Loss=0.0064098128 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [116/400] | Train Loss=0.0041963191 | Test Loss=0.0058195497 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [117/400] | Train Loss=0.0041460005 | Test Loss=0.0032976274 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [118/400] | Train Loss=0.0042572570 | Test Loss=0.0051539983 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [119/400] | Train Loss=0.0041924726 | Test Loss=0.0036630088 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [120/400] | Train Loss=0.0041178263 | Test Loss=0.0051352370 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [121/400] | Train Loss=0.0041475190 | Test Loss=0.0059057181 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [122/400] | Train Loss=0.0040082817 | Test Loss=0.0031962321 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [123/400] | Train Loss=0.0041783673 | Test Loss=0.0034406785 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [124/400] | Train Loss=0.0041000927 | Test Loss=0.0036406477 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [125/400] | Train Loss=0.0042347776 | Test Loss=0.0034047463 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [126/400] | Train Loss=0.0041347367 | Test Loss=0.0089422330 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [127/400] | Train Loss=0.0039531897 | Test Loss=0.0056305462 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [128/400] | Train Loss=0.0040290756 | Test Loss=0.0047037518 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [129/400] | Train Loss=0.0041898988 | Test Loss=0.0043308493 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [130/400] | Train Loss=0.0039232278 | Test Loss=0.0038083123 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [131/400] | Train Loss=0.0039395638 | Test Loss=0.0048613891 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [132/400] | Train Loss=0.0039229907 | Test Loss=0.0078027234 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [133/400] | Train Loss=0.0041763811 | Test Loss=0.0045402074 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [134/400] | Train Loss=0.0038192193 | Test Loss=0.0067004223 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [135/400] | Train Loss=0.0040886425 | Test Loss=0.0048227437 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [136/400] | Train Loss=0.0040070956 | Test Loss=0.0035206276 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [137/400] | Train Loss=0.0041890477 | Test Loss=0.0066877802 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [138/400] | Train Loss=0.0040317423 | Test Loss=0.0029066011 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [139/400] | Train Loss=0.0037575957 | Test Loss=0.0031344746 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [140/400] | Train Loss=0.0039333408 | Test Loss=0.0053751283 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [141/400] | Train Loss=0.0038960167 | Test Loss=0.0036003309 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [142/400] | Train Loss=0.0038393835 | Test Loss=0.0062030840 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [143/400] | Train Loss=0.0038688178 | Test Loss=0.0053453120 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [144/400] | Train Loss=0.0038337843 | Test Loss=0.0052545764 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [145/400] | Train Loss=0.0039772189 | Test Loss=0.0063174658 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [146/400] | Train Loss=0.0038939824 | Test Loss=0.0053947645 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [147/400] | Train Loss=0.0037211131 | Test Loss=0.0035600653 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [148/400] | Train Loss=0.0038759773 | Test Loss=0.0055981081 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [149/400] | Train Loss=0.0037140240 | Test Loss=0.0039719911 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [150/400] | Train Loss=0.0036379940 | Test Loss=0.0029238605 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [151/400] | Train Loss=0.0036786385 | Test Loss=0.0066714378 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [152/400] | Train Loss=0.0038314052 | Test Loss=0.0040384601 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [153/400] | Train Loss=0.0038314526 | Test Loss=0.0069516559 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [154/400] | Train Loss=0.0038953948 | Test Loss=0.0038445893 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [155/400] | Train Loss=0.0038084728 | Test Loss=0.0037886429 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [156/400] | Train Loss=0.0036077242 | Test Loss=0.0031314419 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [157/400] | Train Loss=0.0038571521 | Test Loss=0.0064321142 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [158/400] | Train Loss=0.0037495926 | Test Loss=0.0031613534 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [159/400] | Train Loss=0.0037165741 | Test Loss=0.0033658954 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [160/400] | Train Loss=0.0034940457 | Test Loss=0.0035165734 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [161/400] | Train Loss=0.0037772353 | Test Loss=0.0027854607 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [162/400] | Train Loss=0.0035251408 | Test Loss=0.0025990020 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [163/400] | Train Loss=0.0037675163 | Test Loss=0.0069350622 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [164/400] | Train Loss=0.0037048496 | Test Loss=0.0053392728 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [165/400] | Train Loss=0.0036748356 | Test Loss=0.0036697388 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [166/400] | Train Loss=0.0038266715 | Test Loss=0.0051872799 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [167/400] | Train Loss=0.0036841159 | Test Loss=0.0044247778 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [168/400] | Train Loss=0.0038287257 | Test Loss=0.0060235431 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [169/400] | Train Loss=0.0038132293 | Test Loss=0.0038336087 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [170/400] | Train Loss=0.0037336790 | Test Loss=0.0031549040 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [171/400] | Train Loss=0.0034443802 | Test Loss=0.0027171521 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [172/400] | Train Loss=0.0035803729 | Test Loss=0.0041259712 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [173/400] | Train Loss=0.0036068697 | Test Loss=0.0044824153 | Time=6.59s | LR=5.00e-04\n",
      "Epoch [174/400] | Train Loss=0.0036709308 | Test Loss=0.0077973596 | Time=6.60s | LR=5.00e-04\n",
      "Epoch [175/400] | Train Loss=0.0036912703 | Test Loss=0.0029035078 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [176/400] | Train Loss=0.0037523731 | Test Loss=0.0040188538 | Time=6.60s | LR=5.00e-04\n",
      "Epoch [177/400] | Train Loss=0.0036231817 | Test Loss=0.0063922826 | Time=6.57s | LR=5.00e-04\n",
      "Epoch [178/400] | Train Loss=0.0036715030 | Test Loss=0.0049423365 | Time=6.60s | LR=5.00e-04\n",
      "Epoch [179/400] | Train Loss=0.0035972573 | Test Loss=0.0053689032 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [180/400] | Train Loss=0.0036049218 | Test Loss=0.0029037139 | Time=6.60s | LR=5.00e-04\n",
      "Epoch [181/400] | Train Loss=0.0035755528 | Test Loss=0.0060831780 | Time=6.58s | LR=5.00e-04\n",
      "Epoch [182/400] | Train Loss=0.0035790186 | Test Loss=0.0025665578 | Time=6.60s | LR=2.50e-04\n",
      "Epoch [183/400] | Train Loss=0.0021751428 | Test Loss=0.0038027873 | Time=6.09s | LR=2.50e-04\n",
      "Epoch [184/400] | Train Loss=0.0022300951 | Test Loss=0.0024491449 | Time=6.16s | LR=2.50e-04\n",
      "Epoch [185/400] | Train Loss=0.0022484820 | Test Loss=0.0023125204 | Time=6.58s | LR=2.50e-04\n",
      "Epoch [186/400] | Train Loss=0.0021226635 | Test Loss=0.0026018426 | Time=6.60s | LR=2.50e-04\n",
      "Epoch [187/400] | Train Loss=0.0022480311 | Test Loss=0.0022991978 | Time=6.58s | LR=2.50e-04\n",
      "Epoch [188/400] | Train Loss=0.0021197542 | Test Loss=0.0028534741 | Time=6.59s | LR=2.50e-04\n",
      "Epoch [189/400] | Train Loss=0.0021695230 | Test Loss=0.0022329794 | Time=6.59s | LR=2.50e-04\n",
      "Epoch [190/400] | Train Loss=0.0021512667 | Test Loss=0.0034996615 | Time=6.59s | LR=2.50e-04\n",
      "Epoch [191/400] | Train Loss=0.0021791578 | Test Loss=0.0039036032 | Time=6.59s | LR=2.50e-04\n",
      "Epoch [192/400] | Train Loss=0.0021229890 | Test Loss=0.0027426154 | Time=6.60s | LR=2.50e-04\n",
      "Epoch [193/400] | Train Loss=0.0021299391 | Test Loss=0.0022249250 | Time=6.61s | LR=2.50e-04\n",
      "Epoch [194/400] | Train Loss=0.0021259141 | Test Loss=0.0029081795 | Time=5.97s | LR=2.50e-04\n",
      "Epoch [195/400] | Train Loss=0.0020657718 | Test Loss=0.0025371329 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [196/400] | Train Loss=0.0021277740 | Test Loss=0.0018389026 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [197/400] | Train Loss=0.0021054016 | Test Loss=0.0034584392 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [198/400] | Train Loss=0.0021504705 | Test Loss=0.0026977032 | Time=5.87s | LR=2.50e-04\n",
      "Epoch [199/400] | Train Loss=0.0021057353 | Test Loss=0.0027740172 | Time=5.92s | LR=2.50e-04\n",
      "Epoch [200/400] | Train Loss=0.0020898179 | Test Loss=0.0020163679 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [201/400] | Train Loss=0.0020734893 | Test Loss=0.0028724767 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [202/400] | Train Loss=0.0021174572 | Test Loss=0.0035945328 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [203/400] | Train Loss=0.0021324402 | Test Loss=0.0028504638 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [204/400] | Train Loss=0.0020662016 | Test Loss=0.0025231371 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [205/400] | Train Loss=0.0021235644 | Test Loss=0.0036304440 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [206/400] | Train Loss=0.0020566305 | Test Loss=0.0018682132 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [207/400] | Train Loss=0.0020546624 | Test Loss=0.0019088662 | Time=5.39s | LR=2.50e-04\n",
      "Epoch [208/400] | Train Loss=0.0020400321 | Test Loss=0.0016088965 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [209/400] | Train Loss=0.0020739671 | Test Loss=0.0019435573 | Time=5.39s | LR=2.50e-04\n",
      "Epoch [210/400] | Train Loss=0.0020254875 | Test Loss=0.0025514477 | Time=5.39s | LR=2.50e-04\n",
      "Epoch [211/400] | Train Loss=0.0021547570 | Test Loss=0.0024398014 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [212/400] | Train Loss=0.0020548926 | Test Loss=0.0022250749 | Time=5.39s | LR=2.50e-04\n",
      "Epoch [213/400] | Train Loss=0.0020007890 | Test Loss=0.0022184219 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [214/400] | Train Loss=0.0019733340 | Test Loss=0.0020079088 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [215/400] | Train Loss=0.0019964731 | Test Loss=0.0027930424 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [216/400] | Train Loss=0.0020539283 | Test Loss=0.0025208091 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [217/400] | Train Loss=0.0020073863 | Test Loss=0.0030470095 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [218/400] | Train Loss=0.0019660643 | Test Loss=0.0031928442 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [219/400] | Train Loss=0.0020588761 | Test Loss=0.0025002380 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [220/400] | Train Loss=0.0020994882 | Test Loss=0.0030705698 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [221/400] | Train Loss=0.0019569932 | Test Loss=0.0032779513 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [222/400] | Train Loss=0.0020839861 | Test Loss=0.0034061409 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [223/400] | Train Loss=0.0020244068 | Test Loss=0.0019457289 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [224/400] | Train Loss=0.0019708781 | Test Loss=0.0025689427 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [225/400] | Train Loss=0.0019812270 | Test Loss=0.0023199587 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [226/400] | Train Loss=0.0019341873 | Test Loss=0.0017977602 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [227/400] | Train Loss=0.0020125889 | Test Loss=0.0018271683 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [228/400] | Train Loss=0.0018781580 | Test Loss=0.0017516938 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [229/400] | Train Loss=0.0019365979 | Test Loss=0.0024424284 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [230/400] | Train Loss=0.0019799446 | Test Loss=0.0031953608 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [231/400] | Train Loss=0.0019272240 | Test Loss=0.0034925886 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [232/400] | Train Loss=0.0019394427 | Test Loss=0.0030764559 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [233/400] | Train Loss=0.0019618520 | Test Loss=0.0018416328 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [234/400] | Train Loss=0.0019208515 | Test Loss=0.0035798924 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [235/400] | Train Loss=0.0019198494 | Test Loss=0.0029439384 | Time=5.39s | LR=2.50e-04\n",
      "Epoch [236/400] | Train Loss=0.0019439571 | Test Loss=0.0021456475 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [237/400] | Train Loss=0.0020023154 | Test Loss=0.0019771597 | Time=5.39s | LR=2.50e-04\n",
      "Epoch [238/400] | Train Loss=0.0019076104 | Test Loss=0.0031980729 | Time=5.40s | LR=2.50e-04\n",
      "Epoch [239/400] | Train Loss=0.0018895691 | Test Loss=0.0028324009 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [240/400] | Train Loss=0.0012806521 | Test Loss=0.0019427530 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [241/400] | Train Loss=0.0012860582 | Test Loss=0.0018708776 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [242/400] | Train Loss=0.0012924634 | Test Loss=0.0018731571 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [243/400] | Train Loss=0.0012455029 | Test Loss=0.0020344309 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [244/400] | Train Loss=0.0012754061 | Test Loss=0.0018431960 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [245/400] | Train Loss=0.0012647228 | Test Loss=0.0018888830 | Time=5.40s | LR=1.25e-04\n",
      "Epoch [246/400] | Train Loss=0.0012716290 | Test Loss=0.0014170408 | Time=5.40s | LR=1.25e-04\n",
      "Epoch [247/400] | Train Loss=0.0012817801 | Test Loss=0.0014493884 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [248/400] | Train Loss=0.0012420368 | Test Loss=0.0021677261 | Time=5.40s | LR=1.25e-04\n",
      "Epoch [249/400] | Train Loss=0.0012632965 | Test Loss=0.0014590171 | Time=5.39s | LR=1.25e-04\n",
      "Epoch [250/400] | Train Loss=0.0012496337 | Test Loss=0.0021229019 | Time=5.53s | LR=1.25e-04\n",
      "Epoch [251/400] | Train Loss=0.0012252146 | Test Loss=0.0018607088 | Time=5.52s | LR=1.25e-04\n",
      "Epoch [252/400] | Train Loss=0.0012517813 | Test Loss=0.0015370006 | Time=5.34s | LR=1.25e-04\n",
      "Epoch [253/400] | Train Loss=0.0012309286 | Test Loss=0.0017967136 | Time=5.49s | LR=1.25e-04\n",
      "Epoch [254/400] | Train Loss=0.0012090609 | Test Loss=0.0019933271 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [255/400] | Train Loss=0.0012264378 | Test Loss=0.0016878270 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [256/400] | Train Loss=0.0012147912 | Test Loss=0.0015405548 | Time=5.34s | LR=1.25e-04\n",
      "Epoch [257/400] | Train Loss=0.0012174598 | Test Loss=0.0019007482 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [258/400] | Train Loss=0.0012427548 | Test Loss=0.0019308085 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [259/400] | Train Loss=0.0012435420 | Test Loss=0.0017128796 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [260/400] | Train Loss=0.0012126855 | Test Loss=0.0014779147 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [261/400] | Train Loss=0.0012038636 | Test Loss=0.0018418651 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [262/400] | Train Loss=0.0012112843 | Test Loss=0.0024143315 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [263/400] | Train Loss=0.0012098506 | Test Loss=0.0021841704 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [264/400] | Train Loss=0.0011927938 | Test Loss=0.0020940380 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [265/400] | Train Loss=0.0011884868 | Test Loss=0.0019750809 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [266/400] | Train Loss=0.0011817973 | Test Loss=0.0023440847 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [267/400] | Train Loss=0.0011799306 | Test Loss=0.0020514888 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [268/400] | Train Loss=0.0011771517 | Test Loss=0.0017667123 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [269/400] | Train Loss=0.0011922264 | Test Loss=0.0018870806 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [270/400] | Train Loss=0.0011992377 | Test Loss=0.0016734560 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [271/400] | Train Loss=0.0011753930 | Test Loss=0.0019151497 | Time=5.35s | LR=1.25e-04\n",
      "Epoch [272/400] | Train Loss=0.0011716523 | Test Loss=0.0019690434 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [273/400] | Train Loss=0.0011803291 | Test Loss=0.0014367027 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [274/400] | Train Loss=0.0012073382 | Test Loss=0.0017781607 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [275/400] | Train Loss=0.0011919348 | Test Loss=0.0019670149 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [276/400] | Train Loss=0.0011540211 | Test Loss=0.0019313615 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [277/400] | Train Loss=0.0011637239 | Test Loss=0.0022816014 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [278/400] | Train Loss=0.0011556064 | Test Loss=0.0018483695 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [279/400] | Train Loss=0.0011679152 | Test Loss=0.0019338855 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [280/400] | Train Loss=0.0011426357 | Test Loss=0.0014130023 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [281/400] | Train Loss=0.0011743085 | Test Loss=0.0023097228 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [282/400] | Train Loss=0.0011506839 | Test Loss=0.0020097528 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [283/400] | Train Loss=0.0011767886 | Test Loss=0.0019250627 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [284/400] | Train Loss=0.0011501572 | Test Loss=0.0016686193 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [285/400] | Train Loss=0.0011735947 | Test Loss=0.0021492440 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [286/400] | Train Loss=0.0011376954 | Test Loss=0.0019493814 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [287/400] | Train Loss=0.0011452797 | Test Loss=0.0020972196 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [288/400] | Train Loss=0.0011674245 | Test Loss=0.0018993778 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [289/400] | Train Loss=0.0011368806 | Test Loss=0.0020580620 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [290/400] | Train Loss=0.0011596385 | Test Loss=0.0017204135 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [291/400] | Train Loss=0.0011404131 | Test Loss=0.0019644698 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [292/400] | Train Loss=0.0011539598 | Test Loss=0.0017544436 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [293/400] | Train Loss=0.0011102801 | Test Loss=0.0021753373 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [294/400] | Train Loss=0.0011453702 | Test Loss=0.0015770995 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [295/400] | Train Loss=0.0011342447 | Test Loss=0.0018519927 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [296/400] | Train Loss=0.0011018145 | Test Loss=0.0019891861 | Time=5.38s | LR=1.25e-04\n",
      "Epoch [297/400] | Train Loss=0.0011141990 | Test Loss=0.0019282176 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [298/400] | Train Loss=0.0011470218 | Test Loss=0.0018350123 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [299/400] | Train Loss=0.0011198376 | Test Loss=0.0019734822 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [300/400] | Train Loss=0.0011487979 | Test Loss=0.0017409890 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [301/400] | Train Loss=0.0011176339 | Test Loss=0.0019788763 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [302/400] | Train Loss=0.0011146176 | Test Loss=0.0016803650 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [303/400] | Train Loss=0.0011369293 | Test Loss=0.0017550270 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [304/400] | Train Loss=0.0011450675 | Test Loss=0.0017151482 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [305/400] | Train Loss=0.0011000017 | Test Loss=0.0016434657 | Time=5.38s | LR=1.25e-04\n",
      "Epoch [306/400] | Train Loss=0.0011104345 | Test Loss=0.0017925165 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [307/400] | Train Loss=0.0010878436 | Test Loss=0.0020824323 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [308/400] | Train Loss=0.0011042215 | Test Loss=0.0014938393 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [309/400] | Train Loss=0.0011321377 | Test Loss=0.0021233324 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [310/400] | Train Loss=0.0010786689 | Test Loss=0.0019966070 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [311/400] | Train Loss=0.0011005875 | Test Loss=0.0020739361 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [312/400] | Train Loss=0.0011211673 | Test Loss=0.0020908375 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [313/400] | Train Loss=0.0010795362 | Test Loss=0.0016540437 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [314/400] | Train Loss=0.0010842398 | Test Loss=0.0017262282 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [315/400] | Train Loss=0.0011283401 | Test Loss=0.0017332801 | Time=5.38s | LR=1.25e-04\n",
      "Epoch [316/400] | Train Loss=0.0010998364 | Test Loss=0.0018812635 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [317/400] | Train Loss=0.0011278554 | Test Loss=0.0015561944 | Time=5.37s | LR=1.25e-04\n",
      "Epoch [318/400] | Train Loss=0.0011260438 | Test Loss=0.0017228276 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [319/400] | Train Loss=0.0010888367 | Test Loss=0.0019040203 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [320/400] | Train Loss=0.0010865018 | Test Loss=0.0016309983 | Time=5.36s | LR=1.25e-04\n",
      "Epoch [321/400] | Train Loss=0.0010844028 | Test Loss=0.0019736409 | Time=5.36s | LR=6.25e-05\n",
      "Epoch [322/400] | Train Loss=0.0007907626 | Test Loss=0.0013775916 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [323/400] | Train Loss=0.0008050016 | Test Loss=0.0013917338 | Time=5.36s | LR=6.25e-05\n",
      "Epoch [324/400] | Train Loss=0.0008040616 | Test Loss=0.0013977747 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [325/400] | Train Loss=0.0008027251 | Test Loss=0.0014006273 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [326/400] | Train Loss=0.0008014932 | Test Loss=0.0014009946 | Time=5.38s | LR=6.25e-05\n",
      "Epoch [327/400] | Train Loss=0.0008000895 | Test Loss=0.0014023200 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [328/400] | Train Loss=0.0007985675 | Test Loss=0.0014028067 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [329/400] | Train Loss=0.0007973923 | Test Loss=0.0014037854 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [330/400] | Train Loss=0.0007960513 | Test Loss=0.0014041915 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [331/400] | Train Loss=0.0007949257 | Test Loss=0.0014040391 | Time=5.37s | LR=6.25e-05\n",
      "Epoch [332/400] | Train Loss=0.0007936536 | Test Loss=0.0014043077 | Time=5.36s | LR=6.25e-05\n",
      "Epoch [333/400] | Train Loss=0.0007924466 | Test Loss=0.0014037941 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [334/400] | Train Loss=0.0006653127 | Test Loss=0.0010740352 | Time=5.35s | LR=3.13e-05\n",
      "Epoch [335/400] | Train Loss=0.0006681784 | Test Loss=0.0010730829 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [336/400] | Train Loss=0.0006680697 | Test Loss=0.0010723354 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [337/400] | Train Loss=0.0006673288 | Test Loss=0.0010721391 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [338/400] | Train Loss=0.0006665534 | Test Loss=0.0010716980 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [339/400] | Train Loss=0.0006657854 | Test Loss=0.0010717336 | Time=5.35s | LR=3.13e-05\n",
      "Epoch [340/400] | Train Loss=0.0006650075 | Test Loss=0.0010714941 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [341/400] | Train Loss=0.0006642373 | Test Loss=0.0010712122 | Time=5.35s | LR=3.13e-05\n",
      "Epoch [342/400] | Train Loss=0.0006634963 | Test Loss=0.0010710695 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [343/400] | Train Loss=0.0006627347 | Test Loss=0.0010711887 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [344/400] | Train Loss=0.0006619784 | Test Loss=0.0010709816 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [345/400] | Train Loss=0.0006612457 | Test Loss=0.0010706327 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [346/400] | Train Loss=0.0006604926 | Test Loss=0.0010704406 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [347/400] | Train Loss=0.0006597733 | Test Loss=0.0010703874 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [348/400] | Train Loss=0.0006590423 | Test Loss=0.0010702646 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [349/400] | Train Loss=0.0006583282 | Test Loss=0.0010700030 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [350/400] | Train Loss=0.0006575958 | Test Loss=0.0010696900 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [351/400] | Train Loss=0.0006568842 | Test Loss=0.0010695931 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [352/400] | Train Loss=0.0006561759 | Test Loss=0.0010693360 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [353/400] | Train Loss=0.0006554661 | Test Loss=0.0010692700 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [354/400] | Train Loss=0.0006547751 | Test Loss=0.0010688746 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [355/400] | Train Loss=0.0006540762 | Test Loss=0.0010685665 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [356/400] | Train Loss=0.0006533797 | Test Loss=0.0010683400 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [357/400] | Train Loss=0.0006526883 | Test Loss=0.0010681589 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [358/400] | Train Loss=0.0006519957 | Test Loss=0.0010676875 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [359/400] | Train Loss=0.0006513043 | Test Loss=0.0010674600 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [360/400] | Train Loss=0.0006506269 | Test Loss=0.0010671795 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [361/400] | Train Loss=0.0006499556 | Test Loss=0.0010669144 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [362/400] | Train Loss=0.0006492843 | Test Loss=0.0010665473 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [363/400] | Train Loss=0.0006485907 | Test Loss=0.0010663596 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [364/400] | Train Loss=0.0006479406 | Test Loss=0.0010660756 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [365/400] | Train Loss=0.0006472889 | Test Loss=0.0010656579 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [366/400] | Train Loss=0.0006465983 | Test Loss=0.0010654063 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [367/400] | Train Loss=0.0006459566 | Test Loss=0.0010649823 | Time=5.39s | LR=3.13e-05\n",
      "Epoch [368/400] | Train Loss=0.0006452963 | Test Loss=0.0010646776 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [369/400] | Train Loss=0.0006446283 | Test Loss=0.0010642791 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [370/400] | Train Loss=0.0006439718 | Test Loss=0.0010641773 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [371/400] | Train Loss=0.0006433460 | Test Loss=0.0010637939 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [372/400] | Train Loss=0.0006426913 | Test Loss=0.0010634680 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [373/400] | Train Loss=0.0006420255 | Test Loss=0.0010632282 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [374/400] | Train Loss=0.0006414170 | Test Loss=0.0010628541 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [375/400] | Train Loss=0.0006407746 | Test Loss=0.0010625349 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [376/400] | Train Loss=0.0006401507 | Test Loss=0.0010621901 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [377/400] | Train Loss=0.0006394993 | Test Loss=0.0010619220 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [378/400] | Train Loss=0.0006388801 | Test Loss=0.0010616399 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [379/400] | Train Loss=0.0006382419 | Test Loss=0.0010611843 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [380/400] | Train Loss=0.0006376123 | Test Loss=0.0010608938 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [381/400] | Train Loss=0.0006369907 | Test Loss=0.0010606708 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [382/400] | Train Loss=0.0006363853 | Test Loss=0.0010602322 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [383/400] | Train Loss=0.0006357504 | Test Loss=0.0010601112 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [384/400] | Train Loss=0.0006351430 | Test Loss=0.0010595408 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [385/400] | Train Loss=0.0006345344 | Test Loss=0.0010594905 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [386/400] | Train Loss=0.0006339309 | Test Loss=0.0010590072 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [387/400] | Train Loss=0.0006333244 | Test Loss=0.0010586885 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [388/400] | Train Loss=0.0006327086 | Test Loss=0.0010583362 | Time=5.36s | LR=3.13e-05\n",
      "Epoch [389/400] | Train Loss=0.0006321097 | Test Loss=0.0010579172 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [390/400] | Train Loss=0.0006315088 | Test Loss=0.0010577738 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [391/400] | Train Loss=0.0006309117 | Test Loss=0.0010577331 | Time=5.39s | LR=3.13e-05\n",
      "Epoch [392/400] | Train Loss=0.0006303279 | Test Loss=0.0010570801 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [393/400] | Train Loss=0.0006297417 | Test Loss=0.0010569824 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [394/400] | Train Loss=0.0006291335 | Test Loss=0.0010565630 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [395/400] | Train Loss=0.0006285527 | Test Loss=0.0010561797 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [396/400] | Train Loss=0.0006279647 | Test Loss=0.0010559487 | Time=5.39s | LR=3.13e-05\n",
      "Epoch [397/400] | Train Loss=0.0006273840 | Test Loss=0.0010555240 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [398/400] | Train Loss=0.0006268064 | Test Loss=0.0010553948 | Time=5.38s | LR=3.13e-05\n",
      "Epoch [399/400] | Train Loss=0.0006262271 | Test Loss=0.0010550043 | Time=5.37s | LR=3.13e-05\n",
      "Epoch [400/400] | Train Loss=0.0006256453 | Test Loss=0.0010548179 | Time=5.38s | LR=3.13e-05\n",
      "\n",
      "Total training time: 2337.00s\n"
     ]
    },
    {
     "data": {
      "image/png": "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ijFjxgDQs2dPysvLAa3PAwYM4JhjjkFRFHr1avnSEQmEosRuSYU6qK0siXZThBCiWeLNRjbcOzVq7x0pni9kj8rKSu6++24+/vhj9u7di8PhoKamhp07dzZ4neHDh3vvJyYmkpKS4t0LK5Q5c+bw5z//mUOHDnHXXXcxYcIEJkyYAMD69etxOp0MHjzY7zV1dXUtssXJ0qVLueSSS3j++ecZMmRIs66xbds27HY7EydO9B4zm80cddRRbNy4EYCrrrqKs846i59++okpU6Zw+umnM3ToUEALJidPnsygQYOYNm0ap556KlOmTDn8zjVAAqEocVlToQKcVYei3RQhhGgWRVEiNjwVTYmJiX6Pb7zxRhYvXszf/vY3+vfvT3x8PLNnz8ZmszV4HbPZ7PdYURRcroZnBqemptK/f39Ay8b079+fo48+mkmTJlFZWYnRaGTlypXU1NT4bUqqL/KOhK+//prTTjuNxx9/nIsuuiii1w40ffp0duzYwaJFi1i8eDGTJ0/msssu4x//+AdHHnkkBQUFfPLJJ3zxxRecc845TJo0ibfffrvF2iPF0lFiiE/T7tRIICSEEG3Jd999x8UXX8zMmTMZNmwY2dnZbN++vcXfNykpifnz53PjjTeiqiqjRo3C6XSyb98++vbtS//+/b0/2dnZEXvfr776ilNOOYWHH374sJcE6NevHxaLhe+++857zG63s3LlSnJzc73HOnfuzNy5c/m///s/HnvsMV5++WXvcykpKZx77rk8//zzvPHGG7zzzjuUlLTc6En7D+VbSH5+Pvn5+Tidzha5vjFRK54z1JW1yPWFEEI0z4ABA3j33Xc57bTTUBSFO+64o9HMTqT86U9/4q9//SvvvPMOs2fPZs6cOVx88cXce++9TJgwgYMHD7JkyRKGDx/OKaecEvZ1CwoK6q37M2DAAFasWMGpp57K/PnzOeussygqKgLAYrE0WuStX4bAY8iQIVx11VXcdNNNZGRk0LNnTx555BGqq6v54x//CMCdd97J6NGjGTJkCHV1dXz88ccMHDgQgMcee4ycnBxGjRqFwWDgrbfeIjs7u0UXjZRAKISWXkfImqz9gZns5RG/thBCiOZ77LHHuPTSS5kwYQKZmZnccsst3mLelpaRkcFFF13E3XffzaxZs1i4cCF//etf+ctf/sLevXvJzMzk6KOPbvIaPwsWLKh37Ntvv+Xll1+murqaBx980G+a+vHHH9/oNP3zzjuv3rHCwkIeeughXC4XF154IRUVFYwZM4bPPvuM9PR0QAuybrvtNrZv3058fDzHHHMM//73vwFITk7mkUceYcuWLRiNRsaOHcuiRYu8Q4ItQVEjvYRljPEEQmVlZaSkpETsuge/eYFOX97A164RHHv31xgMsbebs91uZ9GiRcyYMaPe2HksiPX+Qez3Mdb7B5HtY21tLQUFBfTp04e4uLgItfDwuFwuysvLSUlJadEvy2iK9T4eTv8a+psM9/s79n6j7URiWiYAKVRxqLrhAjwhhBBCtAwJhKLElKilCFOoYn9lXZRbI4QQQnRMEghFiRqXBkCaUsm+cgmEhBBCiGiQQCha4rSMUCpVHKqSQEgIIYSIBgmEoiVem4lmUlxUVcoUeiGEECIaJBCKFlM8dvfqBbVlsvGqEEIIEQ0SCEWLolClaMu626okEBJCCCGiQQKhKKo1aIGQS/YbE0IIIaJCAqEQ8vPzyc3NZezYsS32Hp5ASJX9xoQQQjTg6quvZubMmdFuRkySQCiEvLw8NmzYwMqVK1vsPWxGLRBSaktb7D2EEKIjUxSlwZ+77777sK79/vvvN6kNKSkpjB07lg8++KDZ7xvMV199haIolJaWBn3++eef59hjjyU9PZ309HQmTZrEihUrGrzmSy+91KJ7fLUVEghFkd2kBUJG2XhVCCFaxN69e70/TzzxBCkpKX7HbrzxxlZpx8KFC9m7dy+rVq1i4sSJzJ49m/Xr17fKe4MWKJ1//vksXbqU5cuX06NHD6ZMmcLu3btbrQ1tlQRCUeR0B0Jm2XhVCCFaRHZ2tvcnNTUVRVH8jr3++uscccQRxMXFMXjwYJ5++mnva202G/PmzSMnJ4e4uDh69erl3Zi0d+/eAMycORNFUbyPQ0lLSyM7O5uBAwfy17/+FYfDwdKlS73PFxYWcs4555CWlkZGRgZnnHEG27dvj9jv4dVXX+Xqq69m5MiRDB48mBdeeAGXy8WSJUuafc2dO3dyxhlnkJSUREpKCueccw7FxcXe59euXcuJJ55IcnIyKSkpjB49mlWrVgGwY8cOTjvtNNLT00lOTmb8+PEsWrTosPvZHLL7fBSp5gQA4hzluFxqTG68KoSIYaoK9urovLc5AZTD+3/mq6++yp133sk///lPRo0axc8//8zll19OYmIic+fO5cknn+TDDz/kzTffpGfPnhQWFlJYWAjAypUrycrKYuHChUybNg2j0RjWezocDu9O6xaLBdA2xp06dSrjx4/n22+/xWQycd999zFt2jTWrVuHyRT5r+rq6mrsdjsZGRnNer3L5fIGQV9//TUOh4O8vDzOPfdc7671c+bMYdSoUTzzzDMYjUbWrFnj3fg3Ly8Pm83GN998Q3x8PKtWrSIpKSlS3WsSCYSiSDVrH3oKVVTaHKTExebu10KIGGWvhge6Rue9b98DlsTDusRdd93F3//+d2bNmgVAnz592LBhA8899xxz585l586dDBgwgGOOOQZFUejVq5f3tZ07dwZ8mZ7GnH/++RiNRmpqanC5XPTu3ZtzzjkHgDfeeAOXy8ULL7yA4g7uFi5cSFpaGl999RWTJk06rH4Gc8stt9C1a9dmX3vJkiWsX7+egoICevToAcArr7zCkCFDWLlyJWPHjmXnzp3cdNNNDB48GIABAwZ4X79z507OOusshg0bhsvlIjMzs8Ed4luSDI1FkdOs/UecSiVl1fYot0YIITqOqqoqtm3bxh//+EeSkpK8P/fddx/btm0D4OKLL2bNmjUMGjSIa6+9ls8//7zZ7/f444+zZs0aPvnkE3Jzc3nhhRe82Zi1a9eydetWkpOTve3IyMigtrbW25ZIeuihh3j99dd57733iIuLa9Y1Nm7cSI8ePbxBEEBubi5paWls3LgRgAULFnDZZZcxadIkHnroIb++XHvttdx3331MnDiRu+++m19++eXwOnUYJCMURXajNjSWqlRxqNpGj4yEKLdICCGawJygZWai9d6HobKyEtBmU40bN87vOc8w15FHHklBQQGffPIJX3zxBeeccw6TJk3i7bffbvL7ZWdn079/f/r378/ChQuZMWMGGzZsICsri8rKSkaPHs2rr75a73WezFOk/O1vf+Ohhx7iiy++YPjw4RG9dqC7776bCy64gI8//phPPvmEu+66i9dff52ZM2dy2WWXMXXqVD7++GM+++wzHnroIf72t79x7bXXtmibgpFAKIpsRm1oLJUqdkhGSAjR3ijKYQ9PRUuXLl3o2rUrv//+O3PmzAl5XkpKCueeey7nnnsus2fPZtq0aZSUlJCRkYHZbMbpdDb5vY866ihGjx7N/fffzz/+8Q+OPPJI3njj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r2bfvn0ceeSRmEwmTCYTX3/9NU8++SQmk4kuXbq0mc9RAqFWZrFYGD16NEuWLPEec7lcLFmyxG9suL2qrKxk27Zt5OTkMHr0aMxms19fN2/ezM6dO9ttX/v06UN2drZfn8rLy/nxxx+9fRo/fjylpaWsXr3ae86XX36Jy+Xy/s+sPdm1axcHDx4kJycHaPv9U1WVefPm8d577/Hll1/Sp08fv+fD+bscP34869ev9wv4Fi9eTEpKinfoIpoa62Mwa9asAfD7HNtyHwO5XC7q6upi4vMLxdPHYNrb53fyySezfv161qxZ4/0ZM2YMc+bM8d5vM59jxMquRdhef/111Wq1qi+99JK6YcMG9YorrlDT0tL8KuPbixtuuEH96quv1IKCAvW7775TJ02apGZmZqr79u1TVVWbHtmzZ0/1yy+/VFetWqWOHz9eHT9+fJRb3bCKigr1559/Vn/++WcVUB977DH1559/Vnfs2KGqqjZ9Pi0tTf3ggw/UdevWqWeccUbQ6fOjRo1Sf/zxR3XZsmXqgAED2sz08ob6V1FRod54443q8uXL1YKCAvWLL75QjzzySHXAgAFqbW2t9xptuX9XXXWVmpqaqn711Vd+U4+rq6u95zT2d+mZtjtlyhR1zZo16qeffqp27ty5zUxNbqyPW7duVe+991511apVakFBgfrBBx+offv2VY877jjvNdpyH2+99Vb166+/VgsKCtR169apt956q6ooivr555+rqtr+Pz9VbbiP7f3zCyVwJlxb+RwlEIqSp556Su3Zs6dqsVjUo446Sv3hhx+i3aRmOffcc9WcnBzVYrGo3bp1U88991x169at3udramrUq6++Wk1PT1cTEhLUmTNnqnv37o1iixu3dOlSFaj3M3fuXFVVtSn0d9xxh9qlSxfVarWqJ598srp582a/axw8eFA9//zz1aSkJDUlJUW95JJL1IqKiij0pr6G+lddXa1OmTJF7dy5s2o2m9VevXqpl19+eb0gvS33L1jfAHXhwoXec8L5u9y+fbs6ffp0NT4+Xs3MzFRvuOEG1W63t3Jvgmusjzt37lSPO+44NSMjQ7VarWr//v3Vm266yW8dGlVtu3289NJL1V69eqkWi0Xt3LmzevLJJ3uDIFVt/5+fqjbcx/b++YUSGAi1lc9RUVVVjVx+SQghhBCi/ZAaISGEEEJ0WBIICSGEEKLDkkBICCGEEB2WBEJCCCGE6LAkEBJCCCFEhyWBkBBCCCE6LAmEhBBCCNFhSSAkhBBCiA5LAiEhhGgiRVF4//33o90MIUQESCAkhGhXLr74YhRFqfczbdq0aDdNCNEOmaLdACGEaKpp06axcOFCv2NWqzVKrRFCtGeSERJCtDtWq5Xs7Gy/n/T0dEAbtnrmmWeYPn068fHx9O3bl7ffftvv9evXr+ekk04iPj6eTp06ccUVV1BZWel3zosvvsiQIUOwWq3k5OQwb948v+cPHDjAzJkzSUhIYMCAAXz44Yct22khRIuQQEgIEXPuuOMOzjrrLNauXcucOXM477zz2LhxIwBVVVVMnTqV9PR0Vq5cyVtvvcUXX3zhF+g888wz5OXlccUVV7B+/Xo+/PBD+vfv7/ce99xzD+eccw7r1q1jxowZzJkzh5KSklbtpxAiAiK6l70QQrSwuXPnqkajUU1MTPT7uf/++1VVVVVAvfLKK/1eM27cOPWqq65SVVVV//Wvf6np6elqZWWl9/mPP/5YNRgMalFRkaqqqtq1a1f1z3/+c8g2AOpf/vIX7+PKykoVUD/55JOI9VMI0TqkRkgI0e6ceOKJPPPMM37HMjIyvPfHjx/v99z48eNZs2YNABs3bmTEiBEkJiZ6n584cSIul4vNmzejKAp79uzh5JNPbrANw4cP995PTEwkJSWFffv2NbdLQogokUBICNHuJCYm1huqipT4+PiwzjObzX6PFUXB5XK1RJOEEC1IaoSEEDHnhx9+qPf4iCOOAOCII45g7dq1VFVVeZ//7rvvMBgMDBo0iOTkZHr37s2SJUtatc1CiOiQjJAQot2pq6ujqKjI75jJZCIzMxOAt956izFjxnDMMcfw6quvsmLFCv79738DMGfOHO666y7mzp3L3Xffzf79+7nmmmu48MIL6dKlCwB33303V155JVlZWUyfPp2Kigq+++47rrnmmtbtqBCixUkgJIRodz799FNycnL8jg0aNIhNmzYB2oyu119/nauvvpqcnBz++9//kpubC0BCQgKfffYZ8+fPZ+zYsSQkJHDWWWfx2GOPea81d+5camtrefzxx7nxxhvJzMxk9uzZrddBIUSrUVRVVaPdCCGEiBRFUXjvvfc488wzo90UIUQ7IDVCQgghhOiwJBASQgghRIclNUJCiJgio/1CiKaQjJAQQgghOiwJhIQQQgjRYUkgJIQQQogOSwIhIYQQQnRYEggJIYQQosOSQEgIIYQQHZYEQkIIIYTosCQQEkIIIUSH9f+qh1WVmucc/gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "\n",
    "loss_history, test_loss_history, early_stop = train_kano(\n",
    "    dataset=train_data,\n",
    "    kano=kano_mlp,\n",
    "    test_dataset=test_data,\n",
    "    num_epochs=400,\n",
    "    lr=1e-3,\n",
    "    device=device,\n",
    "    symbol_is_kan=False,\n",
    "    activation=False,\n",
    "    reduce_on='train',\n",
    "    factor=0.5,\n",
    "    patience=10,\n",
    "    min_lr=1e-10,\n",
    "    cooldown=0,\n",
    "    grid_update_freq=9999,\n",
    "    start_grid_update_epoch=9999,\n",
    "    stop_grid_update_epoch=9999,\n",
    "    early_stop_threshold=1e-6\n",
    ")\n",
    "\n",
    "torch.save(sym_net.state_dict(), 'kanosymmlp_2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(sym_net.state_dict(), 'kanosymmlp_2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Total trainable parameters: 1,218\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0006404252\n",
      "Function type 'periodic': mean Rel-L2 = 0.0007647802\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0005859160\n",
      "Overall mean Rel-L2 = 0.0006620571\n",
      "Average inference time / sample = 0.000381 s\n",
      "--------------test----------------\n",
      "Total trainable parameters: 1,218\n",
      "Function type 'gaussian_hermite': mean Rel-L2 = 0.0011822451\n",
      "Function type 'sinc_pulse': mean Rel-L2 = 0.0013611916\n",
      "Function type 'wave_packet': mean Rel-L2 = 0.0005892718\n",
      "Overall mean Rel-L2 = 0.0010548179\n",
      "Average inference time / sample = 0.000380 s\n",
      "--------------sample----------------\n",
      "Total trainable parameters: 1,218\n",
      "Function type 'periodic': mean Rel-L2 = 0.0007223839\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0006614012\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0005832458\n",
      "Overall mean Rel-L2 = 0.0006557772\n",
      "Average inference time / sample = 0.000381 s\n"
     ]
    }
   ],
   "source": [
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, operator = kano_mlp, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = kano_mlp, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = kano_mlp, device = device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Building dataset from the trained MLP subnetworks to train KAN subnetwork"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n",
      "Train Input Shape: torch.Size([900, 2])\n",
      "Test Input Shape: torch.Size([100, 2])\n",
      "Train Label Shape: torch.Size([900, 2])\n",
      "Test Label Shape: torch.Size([100, 2])\n",
      "tensor([[ -0.0912,  54.1341],\n",
      "        [  1.8397,  41.8338],\n",
      "        [  2.3051,  11.8519],\n",
      "        [ -1.9151, -46.4464],\n",
      "        [  0.6698, -22.9990],\n",
      "        [ -1.2673,  34.0180],\n",
      "        [ -2.3365,  54.5185],\n",
      "        [  0.8585, -63.2312],\n",
      "        [ -1.2044, -51.6997],\n",
      "        [ -1.6321,  33.5055]], device='cuda:1')\n",
      "tensor([[-2922.5835, -3402.5771],\n",
      "        [-1729.8694, -1954.2411],\n",
      "        [ -128.8382,  -121.4531],\n",
      "        [-2184.5549, -2500.2839],\n",
      "        [ -526.2451,  -659.6780],\n",
      "        [-1136.8560, -1482.4352],\n",
      "        [-2966.9563, -3642.9856],\n",
      "        [-4018.7068, -4563.6582],\n",
      "        [-2686.8992, -3080.7783],\n",
      "        [-1094.8014, -1465.8214]], device='cuda:1')\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from scipy.special import hermite\n",
    "\n",
    "\n",
    "print(device)\n",
    "\n",
    "grid_size = 1000\n",
    "x_values = np.linspace(-torch.pi, torch.pi, grid_size)\n",
    "k_values = np.linspace(-64, 64, grid_size)\n",
    "\n",
    "# Shuffle them, so (x, k) pairs are in random order\n",
    "np.random.shuffle(x_values)\n",
    "np.random.shuffle(k_values)\n",
    "\n",
    "# Stack x and k into input tensor of shape (1000, 2)\n",
    "xk_tensor = torch.tensor(np.column_stack((x_values, k_values)), dtype=torch.float32)\n",
    "xk_tensor = xk_tensor.to(device)\n",
    "\n",
    "sym_net = sym_net.to(device)\n",
    "# Make sure sym_net outputs shape (N,2)! \n",
    "# e.g. if it's KAN or MLP, ensure last layer has out_dim=2.\n",
    "\n",
    "# Perform inference\n",
    "with torch.no_grad():\n",
    "    # Now sym_net(xk_tensor) is expected to return (1000,2)\n",
    "    outputs = sym_net(xk_tensor).cpu().numpy()  # shape (1000, 2)\n",
    "\n",
    "# Create dataset inputs\n",
    "inputs = np.column_stack((x_values, k_values))  # shape (1000,2)\n",
    "labels = outputs  # shape (1000,2)\n",
    "\n",
    "# Shuffle and split into train/test\n",
    "indices = np.arange(len(x_values))\n",
    "np.random.shuffle(indices)\n",
    "\n",
    "train_ratio = 0.9\n",
    "train_size = int(train_ratio * len(x_values))\n",
    "\n",
    "train_indices = indices[:train_size]\n",
    "test_indices = indices[train_size:]\n",
    "\n",
    "# Create train and test arrays\n",
    "train_input = inputs[train_indices]   # shape (train_size, 2)\n",
    "test_input = inputs[test_indices]     # shape (test_size, 2)\n",
    "train_label = labels[train_indices]   # shape (train_size, 2)\n",
    "test_label = labels[test_indices]     # shape (test_size, 2)\n",
    "\n",
    "# Convert to Torch\n",
    "train_input = torch.tensor(train_input, dtype=torch.float32).to(device)\n",
    "test_input = torch.tensor(test_input, dtype=torch.float32).to(device)\n",
    "train_label = torch.tensor(train_label, dtype=torch.float32).to(device)\n",
    "test_label = torch.tensor(test_label, dtype=torch.float32).to(device)\n",
    "\n",
    "# Combine into a dictionary for KAN\n",
    "dataset = {\n",
    "    'train_input': train_input,\n",
    "    'test_input': test_input,\n",
    "    'train_label': train_label,\n",
    "    'test_label': test_label\n",
    "}\n",
    "\n",
    "print(\"Train Input Shape:\", train_input.shape)\n",
    "print(\"Test Input Shape:\", test_input.shape)\n",
    "print(\"Train Label Shape:\", train_label.shape)\n",
    "print(\"Test Label Shape:\", test_label.shape)\n",
    "\n",
    "# If you'd like to see sample data\n",
    "print(dataset['test_input'][0:10])\n",
    "print(dataset['test_label'][0:10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 1.09e+01 | test_loss: 1.08e+01 | reg: 1.04e+02 | : 100%|█| 1000/1000 [04:35<00:00,  3.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 31 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Now build a KAN with 2D input => 2D output.\n",
    "from kan import *\n",
    "\n",
    "# KAN: 2D in, 2D out\n",
    "# e.g. grid=3, k=3, but out_dim=2 => width=[2,2].\n",
    "\n",
    "sym_kan = KAN(width=[[2,0],[2,2],[2,0]], grid=10, k=3, seed=0, base_fun = 'identity', device=device)\n",
    "\n",
    "### Train the model\n",
    "# Fit to map (x,k)->(some 2D output)\n",
    "sym_kan.fit(\n",
    "    dataset = dataset,\n",
    "    opt=\"LBFGS\",\n",
    "    steps=1000,\n",
    "    lamb=2,\n",
    "    lamb_l1=10.,\n",
    "    lamb_entropy=10.,\n",
    "    update_grid=True, \n",
    "    grid_update_num=200,\n",
    "    start_grid_update_step=-1, \n",
    "    stop_grid_update_step=1000\n",
    ")\n",
    "\n",
    "sym_kan.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 1.55e+01 | test_loss: 1.53e+01 | reg: 3.94e+02 | : 100%|█| 1000/1000 [02:17<00:00,  7.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x200 with 11 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sym_kan = KAN(width=[[2,0],[1,1]], grid=10, k=3, seed=0, base_fun = 'identity', device=device)\n",
    "\n",
    "### Train the model\n",
    "# Fit to map (x,k)->(some 2D output)\n",
    "sym_kan.fit(\n",
    "    dataset = dataset,\n",
    "    opt=\"LBFGS\",\n",
    "    steps=1000,\n",
    "    lamb=2,\n",
    "    lamb_l1=10.,\n",
    "    lamb_entropy=10.,\n",
    "    update_grid=True, \n",
    "    grid_update_num=200,\n",
    "    start_grid_update_step=-1, \n",
    "    stop_grid_update_step=1000\n",
    ")\n",
    "\n",
    "sym_kan.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(sym_kan.state_dict(), 'kanosymkan_2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "replacing MLP subnetwork with KAN subnetwork"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    }
   ],
   "source": [
    "from kan import *\n",
    "sym_kan = KAN(width=[[2,0],[1,1]], grid=10, k=3, seed=0, base_fun = 'identity', device=device)\n",
    "sym_kan.load_state_dict(torch.load('kanosymkan_2.pth'))\n",
    "sym_kan.to(device)\n",
    "\n",
    "\n",
    "kano_numeric = Kano(num_layers=1, symbol_net=sym_kan, act_net=nn.Identity())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n",
      "[train_kano] Built pdo cache(s) once using the first sample's domain.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jinlee/kn_mlp/kano/lib/python3.10/site-packages/torch/optim/lr_scheduler.py:62: UserWarning: The verbose parameter is deprecated. Please use get_last_lr() to access the learning rate.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/100] | Train Loss=0.2108487855 | Test Loss=0.0233372529 | Time=25.81s | LR=1.00e-01\n",
      "Epoch [2/100] | Train Loss=0.0196387407 | Test Loss=0.0154118772 | Time=25.80s | LR=1.00e-01\n",
      "Epoch [3/100] | Train Loss=0.0161446939 | Test Loss=0.0185602405 | Time=25.80s | LR=1.00e-01\n",
      "Epoch [4/100] | Train Loss=0.0146266048 | Test Loss=0.0097918968 | Time=25.80s | LR=1.00e-01\n",
      "Epoch [5/100] | Train Loss=0.0135336183 | Test Loss=0.0158314854 | Time=25.81s | LR=1.00e-01\n",
      "Epoch [6/100] | Train Loss=0.0139791012 | Test Loss=0.0153308273 | Time=25.81s | LR=1.00e-01\n",
      "Epoch [7/100] | Train Loss=0.0133020070 | Test Loss=0.0046596205 | Time=25.82s | LR=1.00e-01\n",
      "Epoch [8/100] | Train Loss=0.0124638566 | Test Loss=0.0060086196 | Time=25.82s | LR=1.00e-01\n",
      "Epoch [9/100] | Train Loss=0.0122678905 | Test Loss=0.0159577037 | Time=25.82s | LR=1.00e-01\n",
      "Epoch [10/100] | Train Loss=0.0129144976 | Test Loss=0.0013099735 | Time=25.81s | LR=1.00e-01\n",
      "Epoch [11/100] | Train Loss=0.0121285661 | Test Loss=0.0118127996 | Time=25.81s | LR=1.00e-01\n",
      "Epoch [12/100] | Train Loss=0.0121391729 | Test Loss=0.0039132909 | Time=26.33s | LR=1.00e-01\n",
      "Epoch [13/100] | Train Loss=0.0122589243 | Test Loss=0.0149031024 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [14/100] | Train Loss=0.0111524719 | Test Loss=0.0120894900 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [15/100] | Train Loss=0.0114533953 | Test Loss=0.0041870186 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [16/100] | Train Loss=0.0115082675 | Test Loss=0.0117145801 | Time=26.39s | LR=1.00e-01\n",
      "Epoch [17/100] | Train Loss=0.0117252362 | Test Loss=0.0024430110 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [18/100] | Train Loss=0.0114909585 | Test Loss=0.0028212713 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [19/100] | Train Loss=0.0109301745 | Test Loss=0.0148365038 | Time=25.83s | LR=1.00e-01\n",
      "Epoch [20/100] | Train Loss=0.0110258971 | Test Loss=0.0079399423 | Time=26.04s | LR=1.00e-01\n",
      "Epoch [21/100] | Train Loss=0.0107536409 | Test Loss=0.0060103869 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [22/100] | Train Loss=0.0110297134 | Test Loss=0.0056877116 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [23/100] | Train Loss=0.0109432577 | Test Loss=0.0118772068 | Time=26.34s | LR=1.00e-01\n",
      "Epoch [24/100] | Train Loss=0.0108899154 | Test Loss=0.0148585664 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [25/100] | Train Loss=0.0110673003 | Test Loss=0.0033799186 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [26/100] | Train Loss=0.0100804227 | Test Loss=0.0029000047 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [27/100] | Train Loss=0.0103122779 | Test Loss=0.0052042991 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [28/100] | Train Loss=0.0111836288 | Test Loss=0.0030192313 | Time=26.39s | LR=1.00e-01\n",
      "Epoch [29/100] | Train Loss=0.0105834042 | Test Loss=0.0044652136 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [30/100] | Train Loss=0.0102940069 | Test Loss=0.0101310760 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [31/100] | Train Loss=0.0101326554 | Test Loss=0.0080164897 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [32/100] | Train Loss=0.0097838521 | Test Loss=0.0063561743 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [33/100] | Train Loss=0.0104040862 | Test Loss=0.0051027183 | Time=26.34s | LR=1.00e-01\n",
      "Epoch [34/100] | Train Loss=0.0104771149 | Test Loss=0.0044095046 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [35/100] | Train Loss=0.0095969042 | Test Loss=0.0084318226 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [36/100] | Train Loss=0.0100955688 | Test Loss=0.0049815696 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [37/100] | Train Loss=0.0099171604 | Test Loss=0.0253750389 | Time=26.34s | LR=1.00e-01\n",
      "Epoch [38/100] | Train Loss=0.0099393206 | Test Loss=0.0023787859 | Time=26.39s | LR=1.00e-01\n",
      "Epoch [39/100] | Train Loss=0.0103380209 | Test Loss=0.0017762857 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [40/100] | Train Loss=0.0096180232 | Test Loss=0.0164556041 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [41/100] | Train Loss=0.0094154845 | Test Loss=0.0034925938 | Time=26.37s | LR=1.00e-01\n",
      "Epoch [42/100] | Train Loss=0.0092435618 | Test Loss=0.0018325351 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [43/100] | Train Loss=0.0093380694 | Test Loss=0.0032308280 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [44/100] | Train Loss=0.0099065836 | Test Loss=0.0022386583 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [45/100] | Train Loss=0.0100189723 | Test Loss=0.0097353818 | Time=26.38s | LR=1.00e-01\n",
      "Epoch [46/100] | Train Loss=0.0094363252 | Test Loss=0.0157817296 | Time=26.35s | LR=1.00e-01\n",
      "Epoch [47/100] | Train Loss=0.0094930177 | Test Loss=0.0035061258 | Time=26.36s | LR=1.00e-01\n",
      "Epoch [48/100] | Train Loss=0.0093431229 | Test Loss=0.0043175394 | Time=26.38s | LR=1.00e-02\n",
      "Epoch [49/100] | Train Loss=0.0009560473 | Test Loss=0.0002824479 | Time=26.36s | LR=1.00e-02\n",
      "Epoch [50/100] | Train Loss=0.0009950924 | Test Loss=0.0002573947 | Time=26.38s | LR=1.00e-02\n",
      "Epoch [51/100] | Train Loss=0.0009308110 | Test Loss=0.0005315212 | Time=26.37s | LR=1.00e-02\n",
      "Epoch [52/100] | Train Loss=0.0009031274 | Test Loss=0.0002693491 | Time=26.37s | LR=1.00e-02\n",
      "Epoch [53/100] | Train Loss=0.0009501969 | Test Loss=0.0009835674 | Time=26.38s | LR=1.00e-02\n",
      "Epoch [54/100] | Train Loss=0.0009107096 | Test Loss=0.0003303213 | Time=26.37s | LR=1.00e-02\n",
      "Epoch [55/100] | Train Loss=0.0009543337 | Test Loss=0.0004713729 | Time=26.36s | LR=1.00e-02\n",
      "Epoch [56/100] | Train Loss=0.0009213272 | Test Loss=0.0004917440 | Time=26.37s | LR=1.00e-02\n",
      "Epoch [57/100] | Train Loss=0.0009058133 | Test Loss=0.0002568039 | Time=26.37s | LR=1.00e-02\n",
      "Epoch [58/100] | Train Loss=0.0009636174 | Test Loss=0.0005560575 | Time=26.37s | LR=1.00e-03\n",
      "Epoch [59/100] | Train Loss=0.0001221290 | Test Loss=0.0001362201 | Time=26.37s | LR=1.00e-03\n",
      "Epoch [60/100] | Train Loss=0.0001260887 | Test Loss=0.0001398592 | Time=26.35s | LR=1.00e-03\n",
      "Epoch [61/100] | Train Loss=0.0001294838 | Test Loss=0.0001479139 | Time=26.37s | LR=1.00e-03\n",
      "Epoch [62/100] | Train Loss=0.0001293294 | Test Loss=0.0001351583 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [63/100] | Train Loss=0.0001208271 | Test Loss=0.0001895030 | Time=26.39s | LR=1.00e-03\n",
      "Epoch [64/100] | Train Loss=0.0001248533 | Test Loss=0.0001431739 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [65/100] | Train Loss=0.0001259280 | Test Loss=0.0001941150 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [66/100] | Train Loss=0.0001306057 | Test Loss=0.0001969427 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [67/100] | Train Loss=0.0001187396 | Test Loss=0.0001285239 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [68/100] | Train Loss=0.0001258377 | Test Loss=0.0001715298 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [69/100] | Train Loss=0.0001194568 | Test Loss=0.0001424883 | Time=26.36s | LR=1.00e-03\n",
      "Epoch [70/100] | Train Loss=0.0001216212 | Test Loss=0.0001347535 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [71/100] | Train Loss=0.0001242143 | Test Loss=0.0001747775 | Time=26.38s | LR=1.00e-03\n",
      "Epoch [72/100] | Train Loss=0.0001222841 | Test Loss=0.0001430337 | Time=26.39s | LR=1.00e-03\n",
      "Epoch [73/100] | Train Loss=0.0001194942 | Test Loss=0.0001559957 | Time=26.39s | LR=1.00e-04\n",
      "Epoch [74/100] | Train Loss=0.0000675294 | Test Loss=0.0000863457 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [75/100] | Train Loss=0.0000670785 | Test Loss=0.0000872701 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [76/100] | Train Loss=0.0000671186 | Test Loss=0.0000872320 | Time=26.39s | LR=1.00e-04\n",
      "Epoch [77/100] | Train Loss=0.0000670790 | Test Loss=0.0000869708 | Time=26.37s | LR=1.00e-04\n",
      "Epoch [78/100] | Train Loss=0.0000670362 | Test Loss=0.0000867696 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [79/100] | Train Loss=0.0000669953 | Test Loss=0.0000865117 | Time=26.36s | LR=1.00e-04\n",
      "Epoch [80/100] | Train Loss=0.0000669495 | Test Loss=0.0000862870 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [81/100] | Train Loss=0.0000669071 | Test Loss=0.0000860569 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [82/100] | Train Loss=0.0000668707 | Test Loss=0.0000858545 | Time=26.36s | LR=1.00e-04\n",
      "Epoch [83/100] | Train Loss=0.0000668318 | Test Loss=0.0000856830 | Time=26.36s | LR=1.00e-04\n",
      "Epoch [84/100] | Train Loss=0.0000667898 | Test Loss=0.0000855091 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [85/100] | Train Loss=0.0000667486 | Test Loss=0.0000852979 | Time=26.39s | LR=1.00e-04\n",
      "Epoch [86/100] | Train Loss=0.0000667158 | Test Loss=0.0000852046 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [87/100] | Train Loss=0.0000666788 | Test Loss=0.0000850050 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [88/100] | Train Loss=0.0000666448 | Test Loss=0.0000849175 | Time=26.39s | LR=1.00e-04\n",
      "Epoch [89/100] | Train Loss=0.0000666173 | Test Loss=0.0000847968 | Time=26.37s | LR=1.00e-04\n",
      "Epoch [90/100] | Train Loss=0.0000665783 | Test Loss=0.0000847078 | Time=26.39s | LR=1.00e-04\n",
      "Epoch [91/100] | Train Loss=0.0000665460 | Test Loss=0.0000846439 | Time=26.36s | LR=1.00e-04\n",
      "Epoch [92/100] | Train Loss=0.0000665147 | Test Loss=0.0000844797 | Time=26.35s | LR=1.00e-04\n",
      "Epoch [93/100] | Train Loss=0.0000664838 | Test Loss=0.0000843187 | Time=26.38s | LR=1.00e-04\n",
      "Epoch [94/100] | Train Loss=0.0000664504 | Test Loss=0.0000842259 | Time=26.41s | LR=1.00e-04\n",
      "Epoch [95/100] | Train Loss=0.0000664191 | Test Loss=0.0000841578 | Time=26.55s | LR=1.00e-04\n",
      "Epoch [96/100] | Train Loss=0.0000663892 | Test Loss=0.0000840173 | Time=26.97s | LR=1.00e-04\n",
      "Epoch [97/100] | Train Loss=0.0000663532 | Test Loss=0.0000838564 | Time=26.97s | LR=1.00e-04\n",
      "Epoch [98/100] | Train Loss=0.0000663184 | Test Loss=0.0000839003 | Time=26.91s | LR=1.00e-04\n",
      "Epoch [99/100] | Train Loss=0.0000662909 | Test Loss=0.0000837020 | Time=27.10s | LR=1.00e-04\n",
      "Epoch [100/100] | Train Loss=0.0000662528 | Test Loss=0.0000836140 | Time=27.06s | LR=1.00e-04\n",
      "\n",
      "Total training time: 2633.49s\n"
     ]
    },
    {
     "data": {
      "image/png": "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ijpixAh17dq16urVq9W+ffuqV111VYvbJoFQiLz00ktq9+7d1fDwcHXMmDHqjz/+GOomnfAAj18LFixwHFNVVaXeeuutamJiohoVFaXOmDFDPXz4cOga3U7UD4TkPgfWZ599pg4ePFg1m81q//791X/84x9u+202m/rAAw+oqampqtlsVs855xx1165dIWrtiau0tFS988471e7du6sRERFqr1691D//+c9qTU2N4xi5182zYsUKj3+fZ82apaqqb/f16NGj6lVXXaXGxMSocXFx6uzZs9WysrIWt01RVZcpM4UQQgghOhCpERJCCCFEhyWBkBBCCCE6LAmEhBBCCNFhSSAkhBBCiA5LAiEhhBBCdFgSCAkhhBCiw5JASAghhBAdlgRCQgghhOiwJBASQgg/KYrCxx9/HOpmCCECQAIhIcQJ5brrrkNRlAZfU6ZMCXXThBAnoLBQN0AIIfw1ZcoUFixY4LbNbDaHqDVCiBOZZISEECccs9lMWlqa21diYiKgdVu9+uqrTJ06lcjISHr16sUHH3zg9v5t27Zx9tlnExkZSadOnbjpppsoLy93O+Zf//oXgwYNwmw206VLF2677Ta3/UeOHGHGjBlERUXRt29fPv3009b9poUQrUICISFEu/PAAw9wySWXsGXLFmbOnMmVV17Jjh07AKioqGDy5MkkJiayfv163n//fb755hu3QOfVV18lKyuLm266iW3btvHpp5/Sp08ft2s88sgjXH755WzdupVp06Yxc+ZMiouLg/p9CiECoMXr1wshRBDNmjVLNRqNanR0tNvX448/rqqqqgLqzTff7PaesWPHqrfccouqqqr6j3/8Q01MTFTLy8sd+xcvXqwaDAY1Pz9fVVVVTU9PV//85z97bQOg/uUvf3G8Li8vVwH1yy+/DNj3KYQIDqkREkKccM466yxeffVVt21JSUmO56eeeqrbvlNPPZWcnBwAduzYwbBhw4iOjnbsHz9+PDabjV27dqEoCocOHeKcc85ptA1Dhw51PI+OjiYuLo7CwsLmfktCiBCRQEgIccKJjo5u0FUVKJGRkT4dZzKZ3F4rioLNZmuNJgkhWpHUCAkh2p0ff/yxwesBAwYAMGDAALZs2UJFRYVj//fff4/BYOCkk04iNjaWzMxMli1bFtQ2CyFCQzJCQogTTk1NDfn5+W7bwsLCSE5OBuD9999n1KhRnHbaabz99tusW7eOf/7znwDMnDmThx56iFmzZvHwww9TVFTE7bffzjXXXENqaioADz/8MDfffDMpKSlMnTqVsrIyvv/+e26//fbgfqNCiFYngZAQ4oTz1Vdf0aVLF7dtJ510Ejt37gS0EV0LFy7k1ltvpUuXLvzvf/9j4MCBAERFRfH1119z5513Mnr0aKKiorjkkkt4/vnnHeeaNWsW1dXVvPDCC8ydO5fk5GQuvfTS4H2DQoigUVRVVUPdCCGECBRFUVi0aBHTp08PdVOEECcAqRESQgghRIclgZAQQgghOiypERJCtCvS2y+E8IdkhIQQQgjRYUkgJIQQQogOSwIhIYQQQnRYEggJIYQQosOSQEgIIYQQHZYEQkIIIYTosCQQEkIIIUSHJYGQEEIIITqs/wfye8PKyIFj0wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "\n",
    "loss_history, test_loss_history, early_stop = train_kano(\n",
    "    dataset=train_data,\n",
    "    kano=kano_numeric,\n",
    "    test_dataset=test_data,\n",
    "    num_epochs=100,\n",
    "    lr=1e-1,\n",
    "    device=device,\n",
    "    symbol_is_kan=True,\n",
    "    activation=False,\n",
    "    reduce_on='train',\n",
    "    factor=0.1,\n",
    "    patience=5,\n",
    "    min_lr=1e-10,\n",
    "    cooldown=0,\n",
    "    grid_update_freq=1,\n",
    "    start_grid_update_epoch=0,\n",
    "    stop_grid_update_epoch=9999,\n",
    "    early_stop_threshold=1e-6\n",
    ")\n",
    "\n",
    "torch.save(sym_kan.state_dict(), 'kanosymkan_2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x200 with 11 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sym_kan.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n",
      "[train_kano] Built pdo cache(s) once using the first sample's domain.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10] | Train Loss=0.0000630119 | Test Loss=0.0000743778 | Time=26.86s | LR=1.00e-05\n",
      "Epoch [2/10] | Train Loss=0.0000629659 | Test Loss=0.0000744948 | Time=26.90s | LR=1.00e-05\n",
      "Epoch [3/10] | Train Loss=0.0000629630 | Test Loss=0.0000746006 | Time=26.86s | LR=1.00e-05\n",
      "Epoch [4/10] | Train Loss=0.0000629564 | Test Loss=0.0000746671 | Time=26.93s | LR=1.00e-05\n",
      "Epoch [5/10] | Train Loss=0.0000629493 | Test Loss=0.0000746975 | Time=27.00s | LR=1.00e-05\n",
      "Epoch [6/10] | Train Loss=0.0000629468 | Test Loss=0.0000747225 | Time=26.34s | LR=1.00e-05\n",
      "Epoch [7/10] | Train Loss=0.0000629401 | Test Loss=0.0000747034 | Time=26.33s | LR=1.00e-05\n",
      "Epoch [8/10] | Train Loss=0.0000629387 | Test Loss=0.0000747780 | Time=26.32s | LR=1.00e-05\n",
      "Epoch [9/10] | Train Loss=0.0000629391 | Test Loss=0.0000748572 | Time=26.31s | LR=1.00e-05\n",
      "Epoch [10/10] | Train Loss=0.0000629366 | Test Loss=0.0000748867 | Time=26.34s | LR=1.00e-05\n",
      "\n",
      "Total training time: 266.19s\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmcAAAGwCAYAAADsYcIbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAUDZJREFUeJzt3XtcVHX+P/DXmeEqAoLKVbmplZACCbJKhiJeICnN1BJX1MJvLqQyq661m7pdUNsyvq4spBm6ri1UXtZfXpKLl7y0oohpKKaZWCnKN5Wbcpk5vz+QkXEGmMHBOTqv5+MxDzif8/l8zns4U/PynDNnBFEURRARERGRJMhMXQARERER3cVwRkRERCQhDGdEREREEsJwRkRERCQhDGdEREREEsJwRkRERCQhDGdEREREEmJh6gLIcCqVCr/++ivs7e0hCIKpyyEiIiI9iKKIyspKeHh4QCZr+fgYw9lD6Ndff0XPnj1NXQYRERG1w6VLl9CjR48W1zOcPYTs7e0BNO5cBwcHo81bX1+P3bt3Y+TIkbC0tDTavNQ+3B/Swv0hPdwn0sL90baKigr07NlT/T7eEoazh1DTqUwHBwejh7NOnTrBwcGB/2FJAPeHtHB/SA/3ibRwf+ivrUuS+IEAIiIiIglhOCMiIiKSEIYzIiIiIglhOCMiIiKSEIYzIiIiIglhOCMiIiKSEIYzIiIiIglhOCMiIiKSEIYzIiIiIglhOCMiIiKSEIYzIiIiIglhOCMiIiKSEH7xOREREZkXlQpQNdzzUGouO/uarDyGMyIiImqbsh6orwHqahp/1t+687OxTbhdiZ7/dxRC0XVAEHUHHvHeUKRsJSTd+7OlMUpA1KNP898htv18F98ABKGj/6o6MZwRERE97ETxTli6BdRX3w1OdTWabXXVWqFK/XuLY+6sV9W3WoIFgKcAoPRBPOEOIsgBmQUgkzcGSUFukjIYzoiIiDqSKAINt5uFp1uaYajhdtuhSb1eR2hqejwoggywtAMsbQGrToBl40NlYYNrv1Wgu6sbZBZWjf1kFs0e8haW5W33EfToo888GnPp6GOiI2X3YjgjIiLzpE9oUi/fs66+hXUNuua6Bb1OoxmL3FojNDWGqDthqqnNqtk6rbZ7xzT9vNMmt9IZYpT19fh2xw7ExMRAZmn54J7vI4jhjIjMiyi2ft2Lsl7nNStCfS2cq0ogXHRs/Jy7Snlnnjv9ROWd35XNfm/Wrt5m8+tjVDr6qu6Zr+HudsRm1+BozdfStlX3jLvTJgh3jmzIG38Kd37KZPcsN18v6OjftCzT7t90JELnXPe/LUElwvfaccgOnwdUddIPTQAgs2wWipqCkc39haZ7x8hMcyqOjIfhjIgMo1I1HlFoetTfuvPzduMboPr3ZusaavW8ULdev4t/2/qUVVvL7WABYAgA/GDMPybdDwsA/QHgZyNMJrcCLGzvCU229zw6af60sNFuU4ctXf1tATnfdqltfJUQPcxUqjuBqLZZSLrVLDjdCUzq4GSEfspaUz/rjiOz1H2NitwSoiBH9a1bsLN3hKC+bkXW7BqWpmtjmo7wNLuuRX3tTfN22T3jdMynXt/WfPdsW2MOHdsWZADEu0fgxGZHAUXV3YfO9aKO/k3LqhbmU7ayrv3bUqkacPnadbj39IXM2k77iJTO8KQjbDE0kcTw1Uj0oDTUArVVQG0FUFvZ7FGho60S8ls3MejyRcjXpwHK2/cEpzu/K+tM+5xkFneONtg0vhFa2Nz53fbuTwvrxna5ZesX6epcbt5m2Y4xhmyn9XtyN9TXI+/O9TSWvJ5GEpT19TjKa5zoEcRwRtSapo+nawSpSh3h6t42He0GHnGSAXABgEp9B1jeOQpgrRmYtNruDVO27e/How1EREbH/7PSo0mlAuqq9AhRLQWrZutEpXFrs7QDrO11PBw0lpUWnVB0+hwCQwbBwtpO+4hU8+BkYcOgRET0iOD/zUl6mj7efrsCuH2zMSTdvnHP8s2Wl2/fBOr0PdykL0ErPLUWrFpss+qsd4hS1dfj57Id6P9EDMBTNkREZoPhjIxPpbobmFoMUs0euvoY61oqmUWzkNRSuNIjWFl2avOaJCIiImNgOCNtDbeB279pBymN5VbCV22FkQq5c7TKxhGwufPz3mVdbdZ3frd2aLw2SiJ3fCYiItIHwxk1UtbDIrUvxtRch/x4++4DpUVu3UKwujdItRC+rOx5tIqIiMwOwxk1klsCtysgF5uCWdNRq9aOUOk6YtXsqJWljUmfEhER0cOI4YzUGl7Jw56DRzBs9FhY2jnxqBUREZEJ8N2X7ur+BG5ZdWs88sVgRkREZBJ8ByYiIiKSEIYzIiIiIgnhNWcS4OPjAwcHB8hkMjg5OWHPnj2mLomIiIhMhOFMIg4dOoTOnTubugwiIiIyMZ7WJCIiIpIQk4czHx8fCIKg9UhMTNRr/LJlyyAIAubOnWv02vbv34/Y2Fh4eHhAEARs3bpVq09aWhp8fHxgY2ODsLAwHDlyxODtCIKAiIgIhIaGYuPGjUaonIiIiB5WJj+tWVBQAKVSqV4+deoURowYgQkTJug19uOPP0b//v1b7Xfw4EEMHDgQlvd8eXRxcTG6du0KV1dXneOqq6sRGBiIGTNm4IUXXtBan52dDYVCgYyMDISFhSE1NRWjRo1CSUkJXFxcAABBQUFoaNC+4/7u3bvh4eEBADhw4AA8PT1x+fJlREVFoV+/fm0+JyIiIno0mfzIWffu3eHm5qZ+fPXVV+jVqxciIiJaHVdVVYW4uDisWbMGTk5OLfZTqVRITEzE5MmTNUJgSUkJIiMjsX79+hbHRkdH491338W4ceN0rl+xYgUSEhIwffp0+Pv7IyMjA506dcKnn36q7lNUVIRTp05pPZqCGQB4enoCANzd3RETE4PCwkKd20tLS4O/vz9CQ0NbrJmIiIgebiYPZ83V1dXhX//6F2bMmAGhjS+rTkxMxLPPPouoqKhW+8lkMuzYsQPHjx/H1KlToVKpcP78eURGRmLs2LFYsGBBu2s9duyYxvZlMhmioqJw+PBhveeprq5GZWUlgMbAmZ+fj4CAAJ19ExMTUVxcjIKCgnbVTERERNJn8tOazW3duhU3btzAtGnTWu2XlZWFwsJCvUOKh4cH8vPzMWTIEEyePBmHDx9GVFQU0tPT211reXk5lEql1ilRV1dXnDlzRu95ysrK1EfmlEolEhISeGSMiIjIjEkqnK1duxbR0dEap/zudenSJcyZMwc5OTmwsdH/i7W9vLywYcMGREREwM/PD2vXrm3z6NyD4OfnhxMnTpi6DCIiIpIIyZzWvHjxInJzc/Hqq6+22u/YsWO4evUqnnrqKVhYWMDCwgL79u3DypUrYWFhoXFdWXNlZWWYOXMmYmNjUVNTg+Tk5Puqt1u3bpDL5SgrK9Pajpub233NTUREROZLMuEsMzMTLi4uePbZZ1vtN3z4cJw8eRJFRUXqR0hICOLi4lBUVAS5XK41pry8HMOHD0ffvn2xefNm5OXlITs7G/PmzWt3vVZWVhgwYADy8vLUbSqVCnl5eRg0aFC75yUiIiLzJonTmiqVCpmZmYiPj4eFhWZJq1atwpYtW9QhyN7eHk8++aRGHzs7O3Tt2lWrvWnu6OhoeHt7Izs7GxYWFvD390dOTg4iIyPh6enZ4lG0qqoqnDt3Tr184cIFFBUVwdnZGV5eXlAoFIiPj0dISAgGDhyI1NRUVFdXY/r06ff7JyEiIiIzJYlwlpubi9LSUsyYMUNrXXl5Oc6fP9/uuWUyGVJSUjBkyBBYWVmp2wMDA5Gbm4vu3bu3OPbo0aMYNmyYelmhUAAA4uPjsW7dOkyaNAnXrl3DokWLcOXKFQQFBWHXrl0t3jeNiIiIqC2SCGcjR46EKIo61y1ZsgRLlixpdfzevXtbXT9ixAid7cHBwa2OGzp0aIt1NUlKSkJSUlKrfYiIiIj0JZlrzoiIiIiI4YyIiIhIUhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCSE4YyIiIhIQhjOiIiIiCTEwtQFmDsfHx84ODhAJpPByckJe/bsMXVJREREZEIMZxJw6NAhdO7c2dRlEBERkQTwtCYRERGRhJg8nPn4+EAQBK1HYmKizv5Lly5FaGgo7O3t4eLigrFjx6KkpMTode3fvx+xsbHw8PCAIAjYunWrzn5paWnw8fGBjY0NwsLCcOTIEYO2IwgCIiIiEBoaio0bNxqhciIiInqYmTycFRQU4PLly+pHTk4OAGDChAk6++/btw+JiYn49ttvkZOTg/r6eowcORLV1dUtbuPgwYOor6/Xai8uLkZZWZnOMdXV1QgMDERaWlqL82ZnZ0OhUGDx4sUoLCxEYGAgRo0ahatXr6r7BAUF4cknn9R6/PrrrwCAAwcO4NixY9i2bRtSUlLw3Xfftbg9IiIievSZ/Jqz7t27aywvW7YMvXr1QkREhM7+u3bt0lhet24dXFxccOzYMTzzzDNa/VUqFRITE9GnTx9kZWVBLpcDAEpKShAZGQmFQoEFCxZojYuOjkZ0dHSrta9YsQIJCQmYPn06ACAjIwPbt2/Hp59+ioULFwIAioqKWp3D09MTAODu7o6YmBgUFhaif//+OvumpaUhLS0NSqWy1TmJiIjo4WXyI2fN1dXV4V//+hdmzJgBQRD0GnPz5k0AgLOzs871MpkMO3bswPHjxzF16lSoVCqcP38ekZGRGDt2rM5gpm+tx44dQ1RUlMa2oqKicPjwYb3mqK6uRmVlJQCgqqoK+fn5CAgIaLF/YmIiiouLUVBQ0K6aiYiISPpMfuSsua1bt+LGjRuYNm2aXv1VKhXmzp2L8PBwPPnkky328/DwQH5+PoYMGYLJkyfj8OHDiIqKQnp6ertrLS8vh1KphKurq0a7q6srzpw5o9ccZWVlGDduHABAqVQiISEBoaGh7a6JiIiIHn6SCmdr165FdHQ0PDw89OqfmJiIU6dO4cCBA2329fLywoYNGxAREQE/Pz+sXbtW76NzHcXPzw8nTpwwaQ1EREQkLZI5rXnx4kXk5ubi1Vdf1at/UlISvvrqK+zZswc9evRos39ZWRlmzpyJ2NhY1NTUIDk5+b7q7datG+RyudYHCsrKyuDm5nZfcxMREZH5kkw4y8zMhIuLC5599tlW+4miiKSkJGzZsgX5+fnw9fVtc+7y8nIMHz4cffv2xebNm5GXl4fs7GzMmzev3fVaWVlhwIAByMvLU7epVCrk5eVh0KBB7Z6XiIiIzJskTmuqVCpkZmYiPj4eFhaaJa1atQpbtmxRh6DExER89tln+M9//gN7e3tcuXIFAODo6AhbW1udc0dHR8Pb2xvZ2dmwsLCAv78/cnJyEBkZCU9PT51H0aqqqnDu3Dn18oULF1BUVARnZ2d4eXkBABQKBeLj4xESEoKBAwciNTUV1dXV6k9vEhERERlKEuEsNzcXpaWlmDFjhta68vJynD9/Xr3cdBH/0KFDNfplZmbq/CCBTCZDSkoKhgwZAisrK3V7YGAgcnNztW7l0eTo0aMYNmyYelmhUAAA4uPjsW7dOgDApEmTcO3aNSxatAhXrlxBUFAQdu3apfUhASIiIiJ9SSKcjRw5EqIo6ly3ZMkSLFmyRL3cUr/WjBgxQmd7cHBwi2OGDh2q17aSkpKQlJRkcE1EREREukjmmjMiIiIiYjgjIiIikhSGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCGMyIiIiIJYTgjIiIikhCDw9n69euxfft29fKCBQvQpUsXDB48GBcvXjRqcURERETmxuBwlpKSAltbWwDA4cOHkZaWhvfffx/dunVDcnKy0QskIiIiMicWhg64dOkSevfuDQDYunUrxo8fj5kzZyI8PBxDhw41dn1EREREZsXgI2edO3fG//3f/wEAdu/ejREjRgAAbGxscOvWLeNWR0RERGRmDD5yNmLECLz66qsIDg7G2bNnERMTAwD4/vvv4ePjY+z6iIiIiMyKwUfO0tLSMGjQIFy7dg2bNm1C165dAQDHjh3Dyy+/bPQCiYiIiMyJwUfOunTpglWrVmm1//WvfzVKQURERETmzOAjZ7t27cKBAwfUy2lpaQgKCsLkyZNx/fp1oxZHREREZG4MDmfz589HRUUFAODkyZP44x//iJiYGFy4cAEKhcLoBRIRERGZE4NPa164cAH+/v4AgE2bNmHMmDFISUlBYWGh+sMBRERERNQ+BoczKysr1NTUAAByc3MxdepUAICzs7P6iBrpz8fHBw4ODpDJZHBycsKePXtMXRIRERGZkMHh7Omnn4ZCoUB4eDiOHDmC7OxsAMDZs2fRo0cPoxdoDg4dOoTOnTubugwiIiKSAIOvOVu1ahUsLCzw5ZdfIj09HZ6engCAnTt3YvTo0UYvkIiIiMicGBzOvLy88NVXX+HEiRN45ZVX1O0fffQRVq5cadTiWuLj4wNBELQeiYmJRtvG/v37ERsbCw8PDwiCgK1bt+rsl5aWBh8fH9jY2CAsLAxHjhwxaDuCICAiIgKhoaHYuHGjESonIiKih5nBpzUBQKlUYuvWrTh9+jQAICAgAM899xzkcrlRi2tJQUEBlEqlevnUqVMYMWIEJkyYoLP/wYMHMXDgQFhaWmq0FxcXo2vXrnB1ddUaU11djcDAQMyYMQMvvPCCznmzs7OhUCiQkZGBsLAwpKamYtSoUSgpKYGLiwsAICgoCA0NDVpjd+/eDQ8PDxw4cACenp64fPkyoqKi0K9fP/Tv31/vvwURERE9WgwOZ+fOnUNMTAx++eUXPP744wCApUuXomfPnti+fTt69epl9CLv1b17d43lZcuWoVevXoiIiNDqq1KpkJiYiD59+iArK0sdIEtKShAZGQmFQoEFCxZojYuOjkZ0dHSrdaxYsQIJCQmYPn06ACAjIwPbt2/Hp59+ioULFwIAioqKWp2j6bSwu7s7YmJiUFhY2GI4S0tLQ1pamkYwJSIiokeLwac1Z8+ejV69euHSpUsoLCxEYWEhSktL4evri9mzZ3dEja2qq6vDv/71L8yYMQOCIGitl8lk2LFjB44fP46pU6dCpVLh/PnziIyMxNixY3UGM323e+zYMURFRWlsKyoqCocPH9ZrjurqalRWVgIAqqqqkJ+fj4CAgBb7JyYmori4GAUFBe2qmYiIiKTP4CNn+/btw7fffgtnZ2d1W9euXbFs2TKEh4cbtTh9bN26FTdu3MC0adNa7OPh4YH8/HwMGTIEkydPxuHDhxEVFYX09PR2b7e8vBxKpVLrlKirqyvOnDmj1xxlZWUYN24cgMZTxQkJCQgNDW13TURERPTwMzicWVtbq4/2NFdVVQUrKyujFGWItWvXIjo6Gh4eHq328/LywoYNGxAREQE/Pz+sXbtW55G2B8nPzw8nTpwwaQ1EREQkLQaf1hwzZgxmzpyJ//73vxBFEaIo4ttvv8Vrr72G5557riNqbNHFixeRm5uLV199tc2+ZWVlmDlzJmJjY1FTU4Pk5OT72na3bt0gl8tRVlamtR03N7f7mpuIiIjMl8HhbOXKlejVqxcGDRoEGxsb2NjYIDw8HL1790ZqamoHlNiyzMxMuLi44Nlnn221X3l5OYYPH46+ffti8+bNyMvLQ3Z2NubNm9fubVtZWWHAgAHIy8tTt6lUKuTl5WHQoEHtnpeIiIjMm8GnNbt06YL//Oc/OHfunPpWGn379kXv3r2NXlxrVCoVMjMzER8fDwuLlp+GSqVCdHQ0vL29kZ2dDQsLC/j7+yMnJweRkZHw9PTUeRStqqoK586dUy9fuHABRUVFcHZ2hpeXFwBAoVAgPj4eISEhGDhwIFJTU1FdXa3+9CYRERGRodp1nzMA6N27t0Yg++677xASEoK6ujqjFNaW3NxclJaWYsaMGa32k8lkSElJwZAhQzSuiQsMDERubq7WbTmaHD16FMOGDVMvKxQKAEB8fDzWrVsHAJg0aRKuXbuGRYsW4cqVKwgKCsKuXbt03jeNiIiISB/tDmf3EkXxgd5/a+TIkRBFUa++I0aM0NkeHBzc4pihQ4fqNX9SUhKSkpL0qoOIiIioLQZfc0ZEREREHYfhjIiIiEhC9D6tWVFR0ep6Xfc+IyIiIiLD6B3OunTp0upNW0VRNPlNXYmIiIgednqHsz179nRkHUREREQEA8JZRERER9ZBRER0X5RKJerr601dhtmqr6+HhYUFbt++/UDv3iAllpaWkMvl9z2P0W6lQUREZAqiKOLy5cu4ceOGqUsxa6Iows3NDZcuXTLry5y6dOkCNze3+/obMJwREdFD7erVq6isrISLiws6depk1sHAlFQqFaqqqtC5c2fIZOZ3MwhRFFFTU4OrV68CANzd3ds9F8MZERE9tARBQEVFBVxdXdG1a1dTl2PWVCoV6urqYGNjY5bhDABsbW0BNP6DwcXFpd2nOM3zr0dERI+Epje/Tp06mbgSokZNr8X7uf6R4YyIiB56PJVJUmGM16JB4ezEiRN499138Y9//APl5eUa6yoqKtr8EnIiIiIiap3e4Wz37t0YOHAgsrKysHz5cjzxxBMa9z67desW1q9f3yFFEhERUet8fHyQmppq6jKwbt06dOnSxdRlPNT0DmdLlizBvHnzcOrUKfz0009YsGABnnvuOezatasj6yMiInqkCILQ6mPJkiXtmregoAAzZ868r9qGDh2qrsPGxgaPPfYYli5dClEU72veewmCgK1bt+pct3fvXjz//PNwd3eHnZ0dgoKCsHHjxlbn++mnnyAIAoqKioxap6no/WnN77//Hhs2bADQ+EddsGABevTogRdffBFZWVkIDQ3tsCKJiIgeFZcvX1b/np2djUWLFqGkpETd1rlzZ/XvoihCqVTCwqLtt+vu3bsbpb6EhAS8/fbbqK2tRX5+PmbOnIkuXbpg1qxZRpm/LYcOHUL//v3xpz/9Ca6urvjqq68wdepUODo6YsyYMQ+kBlPT+8iZtbW11g3+Jk+ejE8++QSTJk3Cli1bjF0bERHRI8fNzU39cHR0hCAI6uUzZ87A3t4eO3fuxIABA2BtbY0DBw7g/PnzeP755+Hq6orOnTsjNDQUubm5GvPee1pTEAR88sknGDduHDp16oQ+ffpg27ZtbdbXqVMnuLm5wdvbG9OnT0f//v2Rk5OjXl9bW4t58+bB09MTdnZ2CAsLw969e43158Gbb76Jd955B4MHD0avXr0wZ84cjB49Gps3b273nLW1tZg9ezZcXFxgY2ODp59+GgUFBer1169fR1xcHLp37w5bW1v06dMHmZmZAIC6ujokJSXB3d0dNjY28Pb2xtKlS+/7ebZG7yNnQUFB2LNnDwYMGKDR/tJLL0EURcTHxxu9OCIiIkOIoohb9ab56iBbS7nRPjW6cOFCfPDBB/Dz84OTkxMuXbqEmJgYvPfee7C2tsY///lPxMbGoqSkBF5eXi3O89e//hXvv/8+/va3v+Hvf/874uLicPHiRTg7O7dZgyiKOHDgAM6cOYM+ffqo25OSklBcXIysrCx4eHhgy5YtGD16NE6cOAFXV1ejPP973bx5E3379m33+AULFmDTpk1Yv349vL298f7772PUqFE4d+4cnJ2d8dZbb6G4uBg7d+5Et27dcO7cOdy6dQsAsHLlSmzbtg2ff/45vLy8cOnSJVy6dMlYT00nvcPZrFmzsH//fp3rXn75ZYiiiDVr1hitMCIiIkPdqlfCf9HXJtl28duj0MnKOPd2f/vttzFixAj1srOzMwIDA9XL77zzDrZs2YJt27YhKSmpxXmmTZuGl19+GQCQkpKClStX4siRIxg9enSLY/7xj3/gk08+QV1dHerr62FjY4PZs2cDAEpLS5GZmYnS0lJ4eHgAAObNm4ddu3Zh3bp1+NOf/nRfz1uXzz//HAUFBfj444/bNb66uhrp6elYt24doqOjAQBr1qxBTk4O1q5di/nz56O0tBTBwcEICQkB0HgUsklpaSn69OmDp59+GoIgwNvb+76fU1v0fhWNGzcO48aNa3H9xIkTMXToUGPUREREZNaaQkKTqqoqLFmyBNu3b8fly5fR0NCAW7duobS0tNV5+vfvr/7dzs4ODg4O6q8XaklcXBz+/Oc/4/r161i8eDEGDx6MwYMHAwBOnjwJpVKJxx57TGNMbW2tXkfjDLVnzx5Mnz4da9asQUBAQLvmOH/+POrr6xEeHq5us7S0xMCBA3H69GkAjQegxo8fj8LCQowcORJjx45VP+dp06ZhxIgRePzxxzF69GiMGTMGI0eOvP8n1wqjfX3T999/j6eeespsv4meiIhMz9ZSjuK3R5ls28ZiZ2ensTxv3jzk5OTggw8+QO/evWFra4sXX3wRdXV1rc5jaWmpsSwIAlQqVatjHB0d0bt3bwCNR6169+6N3/3ud4iKikJVVRXkcjmOHTum9dVExv6Whn379iE2NhYfffQRpk6datS57xUdHY2LFy9ix44dyMnJwfDhw5GYmIgPPvgATz31FC5cuICdO3ciNzcXEydORFRUFL788ssOq8eo361p7I/aEhERGUIQBKOdWpSSgwcPYtq0aeozWFVVVfjpp586fLudO3fGnDlzMG/ePBw/fhzBwcFQKpW4evUqhgwZotFXpVKhoqLCKNvdu3cvxowZg+XLl9/37UF69eoFKysrHDx4UH1Ksr6+HgUFBZg7d666X/fu3REfH4/4+HgMGTIE8+fPxwcffAAAcHBwwKRJkzBp0iS8+OKLGD16NH777bcOOVoIGDmc8esziIiIjK9Pnz7YvHkzYmNjIQgC3nrrrTaPgBnL//zP/+Cdd97Bpk2b8OKLLyIuLg5Tp07Fhx9+iODgYFy7dg15eXl48skntQJbay5cuKB1X7I+ffrgyJEjGDNmDObMmYPx48fjypUrAAArK6s2w1DzW5I0CQgIwKxZszB//nw4OzvDy8sL77//PmpqavDKK68AABYtWoQBAwYgICAAtbW1+Oqrr9QfQFixYgXc3d0RHBwMmUyGL774Am5ubh16o91H758XREREj5gVK1ZgxowZGDx4MLp164Y//elPRjtK1RZnZ2dMnToVS5YswQsvvIDMzEy8++67+OMf/4hffvkF3bp1w+9+9zvExMQYNK9CodBq++abb7B+/XrU1NRg6dKlGresiIiIaPOWHS+99JJW26VLl7Bs2TKoVCr8/ve/R2VlJUJCQvD111/DyckJQGPwe+ONN/DTTz/B1tYWQ4YMQVZWFgDA3t4e77//Pn744QfI5XKEhoZix44dkMk67uvJBVHPc5Hfffddq+vPnDmDl19+mdecPQAVFRVwdHTEzZs34eDgYLR56+vrsWPHDsTExGhdp0APHveHtHB/SE99fT12794NX19f+Pn5wcbGxtQlmbWm05oODg4dGlyk7vbt27hw4QJ8fX21XpP6vn8bdJ8zQRB0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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "\n",
    "loss_history, test_loss_history, early_stop = train_kano(\n",
    "    dataset=train_data,\n",
    "    kano=kano_numeric,\n",
    "    test_dataset=test_data,\n",
    "    num_epochs=10,\n",
    "    lr=1e-5,\n",
    "    device=device,\n",
    "    symbol_is_kan=True,\n",
    "    activation=False,\n",
    "    reduce_on='train',\n",
    "    factor=0.1,\n",
    "    patience=5,\n",
    "    min_lr=1e-10,\n",
    "    cooldown=0,\n",
    "    grid_update_freq=1,\n",
    "    start_grid_update_epoch=0,\n",
    "    stop_grid_update_epoch=9999,\n",
    "    early_stop_threshold=1e-6\n",
    ")\n",
    "\n",
    "torch.save(sym_kan.state_dict(), 'kanosymkan_2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x200 with 11 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sym_kan.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Total trainable parameters: 114\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000408293\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000898748\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000572963\n",
      "Overall mean Rel-L2 = 0.0000628766\n",
      "Average inference time / sample = 0.002066 s\n",
      "--------------test----------------\n",
      "Total trainable parameters: 114\n",
      "Function type 'gaussian_hermite': mean Rel-L2 = 0.0000888838\n",
      "Function type 'sinc_pulse': mean Rel-L2 = 0.0000782548\n",
      "Function type 'wave_packet': mean Rel-L2 = 0.0000561808\n",
      "Overall mean Rel-L2 = 0.0000748867\n",
      "Average inference time / sample = 0.002069 s\n",
      "--------------sample----------------\n",
      "Total trainable parameters: 114\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000796526\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000427923\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000586793\n",
      "Overall mean Rel-L2 = 0.0000600670\n",
      "Average inference time / sample = 0.002067 s\n"
     ]
    }
   ],
   "source": [
    "torch.save(sym_kan.state_dict(), 'kanosymkan_2.pth')\n",
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, operator = kano_numeric, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = kano_numeric, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = kano_numeric, device = device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   function  fitting r2    r2 loss  complexity  complexity loss  total loss\n",
      "0      tanh    1.000003 -17.071959           3                3  -17.071959\n",
      "1  gaussian    1.000003 -17.048457           3                3  -17.048457\n",
      "2    arctan    1.000003 -17.025331           4                4  -17.025331\n",
      "3    arccos    1.000003 -17.025331           4                4  -17.025331\n",
      "4       abs    1.000002 -17.002570           3                3  -17.002570\n",
      "   function  fitting r2   r2 loss  complexity  complexity loss  total loss\n",
      "0       cos    0.997690 -8.751414           2                2   -8.751414\n",
      "1       sin    0.997687 -8.749821           2                2   -8.749821\n",
      "2  gaussian    0.997681 -8.745976           3                3   -8.745976\n",
      "3       x^2    0.997674 -8.741442           2                2   -8.741442\n",
      "4       abs    0.935360 -3.951213           3                3   -3.951213\n",
      "  function  fitting r2    r2 loss  complexity  complexity loss  total loss\n",
      "0      cos    1.000001 -16.792769           2                2  -16.792769\n",
      "1     tanh    1.000001 -16.754237           3                3  -16.754237\n",
      "2        x    1.000001 -16.735349           1                1  -16.735349\n",
      "3      1/x    1.000001 -16.716706           2                2  -16.716706\n",
      "4      abs    1.000001 -16.716706           3                3  -16.716706\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('cos',\n",
       " (<function kan.utils.<lambda>(x)>,\n",
       "  <function kan.utils.<lambda>(x)>,\n",
       "  2,\n",
       "  <function kan.utils.<lambda>(x, y_th)>),\n",
       " np.float64(1.0000011920928955),\n",
       " np.int64(2))"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x200 with 11 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sym_kan.plot()\n",
    "sym_kan.suggest_symbolic(0,0,1,weight_simple=0.0)\n",
    "sym_kan.suggest_symbolic(0,1,0,weight_simple=0.0)\n",
    "sym_kan.suggest_symbolic(0,1,2,weight_simple=0.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Fixing symbols for the edges (linear, quadratic, linear)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "class symbol_correct(nn.Module):\n",
    "    \"\"\"\n",
    "    Human‐designed symbol net:\n",
    "    \n",
    "      Input:  x,k\n",
    "      Output: [ Re(a), Im(a) ]\n",
    "      \n",
    "    where\n",
    "      Re(a) = b0 + b1*k + b2*k^2\n",
    "      Im(a) = (a0 + a1*x) * (c0 + c1*k)\n",
    "    \n",
    "    The coefficients {b0,b1,b2}, {a0,a1}, and {c0,c1} are learnable parameters.\n",
    "    \"\"\"\n",
    "    def __init__(self):\n",
    "        super(symbol_correct, self).__init__()\n",
    "        # coefficients for quadratic in k: b0 + b1*k + b2*k^2\n",
    "        self.b = nn.Parameter(torch.randn(3))\n",
    "        # coefficients for linear in x: a0 + a1*x\n",
    "        self.a = nn.Parameter(torch.randn(2))\n",
    "        # coefficients for linear in k: c0 + c1*k\n",
    "        self.c = nn.Parameter(torch.randn(2))\n",
    "\n",
    "    def forward(self, xk: torch.Tensor) -> torch.Tensor:\n",
    "        \"\"\"\n",
    "        xk: Tensor[..., 2] with last‑dim = [x, k]\n",
    "        returns: Tensor[..., 2] = [real_part, imag_part]\n",
    "        \"\"\"\n",
    "        x = xk[..., 0]\n",
    "        k = xk[..., 1]\n",
    "        # real part: quadratic in k\n",
    "        real = (self.b[0]\n",
    "                + self.b[1] * k\n",
    "                + self.b[2] * k.pow(2))\n",
    "        # imag part: (a0 + a1*x) * (c0 + c1*k)\n",
    "        lin_x = self.a[0] + self.a[1] * x\n",
    "        lin_k = self.c[0] + self.c[1] * k\n",
    "        imag = lin_x * lin_k\n",
    "        return torch.stack([real, imag], dim=-1)\n",
    "\n",
    "    def plot(self, x_range=(-5, 5), k_range=(-5, 5), steps=100):\n",
    "        \"\"\"\n",
    "        Plots:\n",
    "          1) Re(a) = quadratic(k)\n",
    "          2) linear(x) factor of Im(a)\n",
    "          3) linear(k) factor of Im(a)\n",
    "        \n",
    "        Args:\n",
    "            x_range (tuple): (min_x, max_x) for linear(x).\n",
    "            k_range (tuple): (min_k, max_k) for quadratic(k) and linear(k).\n",
    "            steps   (int):   # of points per axis.\n",
    "        \"\"\"\n",
    "        b_vals = self.b.detach().cpu().numpy()\n",
    "        a_vals = self.a.detach().cpu().numpy()\n",
    "        c_vals = self.c.detach().cpu().numpy()\n",
    "\n",
    "        k_vals = np.linspace(k_range[0], k_range[1], steps)\n",
    "        x_vals = np.linspace(x_range[0], x_range[1], steps)\n",
    "\n",
    "        real_vals = b_vals[0] + b_vals[1]*k_vals + b_vals[2]*k_vals**2\n",
    "        lin_x_vals = a_vals[0] + a_vals[1]*x_vals\n",
    "        lin_k_vals = c_vals[0] + c_vals[1]*k_vals\n",
    "\n",
    "        fig, axes = plt.subplots(1, 3, figsize=(18, 4))\n",
    "        axes[0].plot(k_vals, real_vals)\n",
    "        axes[0].set_title(\"Re(a) = quadratic(k)\")\n",
    "        axes[0].set_xlabel(\"k\")\n",
    "\n",
    "        axes[1].plot(x_vals, lin_x_vals)\n",
    "        axes[1].set_title(\"lin_x factor of Im(a)\")\n",
    "        axes[1].set_xlabel(\"x\")\n",
    "\n",
    "        axes[2].plot(k_vals, lin_k_vals)\n",
    "        axes[2].set_title(\"lin_k factor of Im(a)\")\n",
    "        axes[2].set_xlabel(\"k\")\n",
    "\n",
    "        plt.tight_layout()\n",
    "        plt.show()\n",
    "\n",
    "    def symbolic_formula(self):\n",
    "        \"\"\"\n",
    "        Prints and returns the symbolic formula:\n",
    "        \n",
    "          Re(a) = b0 + b1*k + b2*k^2\n",
    "          Im(a) = (a0 + a1*x) * (c0 + c1*k)\n",
    "        \"\"\"\n",
    "        b = self.b.detach().cpu().numpy()\n",
    "        a = self.a.detach().cpu().numpy()\n",
    "        c = self.c.detach().cpu().numpy()\n",
    "\n",
    "        real_terms = f\"{b[0]:.4f} + {b[1]:.4f}*k + {b[2]:.4f}*k^2\"\n",
    "        lin_x = f\"{a[0]:.4f} + {a[1]:.4f}*x\"\n",
    "        lin_k = f\"{c[0]:.4f} + {c[1]:.4f}*k\"\n",
    "        \n",
    "        formula = (\n",
    "            \"symbol(x,k) = [ Re(a), Im(a) ]\\n\"\n",
    "            f\"  Re(a) = {real_terms}\\n\"\n",
    "            f\"  Im(a) = ({lin_x}) * ({lin_k})\"\n",
    "        )\n",
    "        print(formula)\n",
    "        return formula"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "sym_ans = symbol_correct()\n",
    "sym_ans.load_state_dict(torch.load('kanosymans_2.pth'))\n",
    "kano_ans = Kano(num_layers=1, symbol_net=sym_ans, act_net=nn.Identity())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n",
      "[train_kano] Built pdo cache(s) once using the first sample's domain.\n",
      "Epoch [1/100] | Train Loss=0.0170182129 | Test Loss=0.0069182402 | Time=6.29s | LR=1.00e-01\n",
      "Epoch [2/100] | Train Loss=0.0121938678 | Test Loss=0.0129256844 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [3/100] | Train Loss=0.0132934761 | Test Loss=0.0064202456 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [4/100] | Train Loss=0.0115601478 | Test Loss=0.0118377431 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [5/100] | Train Loss=0.0112504438 | Test Loss=0.0101219703 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [6/100] | Train Loss=0.0122374873 | Test Loss=0.0123788308 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [7/100] | Train Loss=0.0121525178 | Test Loss=0.0101911621 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [8/100] | Train Loss=0.0119093124 | Test Loss=0.0113815249 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [9/100] | Train Loss=0.0113765266 | Test Loss=0.0122389474 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [10/100] | Train Loss=0.0125539724 | Test Loss=0.0241700073 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [11/100] | Train Loss=0.0109475836 | Test Loss=0.0077833392 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [12/100] | Train Loss=0.0112534708 | Test Loss=0.0149827087 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [13/100] | Train Loss=0.0121698026 | Test Loss=0.0023225426 | Time=6.28s | LR=1.00e-01\n",
      "Epoch [14/100] | Train Loss=0.0125999323 | Test Loss=0.0113538560 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [15/100] | Train Loss=0.0106279444 | Test Loss=0.0101652971 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [16/100] | Train Loss=0.0116670105 | Test Loss=0.0080469710 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [17/100] | Train Loss=0.0113856099 | Test Loss=0.0117775999 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [18/100] | Train Loss=0.0114701644 | Test Loss=0.0162944196 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [19/100] | Train Loss=0.0117986494 | Test Loss=0.0043516520 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [20/100] | Train Loss=0.0124262120 | Test Loss=0.0116583149 | Time=6.27s | LR=1.00e-01\n",
      "Epoch [21/100] | Train Loss=0.0115672407 | Test Loss=0.0157255699 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [22/100] | Train Loss=0.0014449047 | Test Loss=0.0013009094 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [23/100] | Train Loss=0.0011449826 | Test Loss=0.0009228555 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [24/100] | Train Loss=0.0011625896 | Test Loss=0.0007153330 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [25/100] | Train Loss=0.0011164975 | Test Loss=0.0011585242 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [26/100] | Train Loss=0.0011769945 | Test Loss=0.0010837197 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [27/100] | Train Loss=0.0011370484 | Test Loss=0.0016092327 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [28/100] | Train Loss=0.0011845886 | Test Loss=0.0027137136 | Time=6.27s | LR=1.00e-02\n",
      "Epoch [29/100] | Train Loss=0.0011694105 | Test Loss=0.0007776862 | Time=6.20s | LR=1.00e-02\n",
      "Epoch [30/100] | Train Loss=0.0013432488 | Test Loss=0.0009393370 | Time=6.07s | LR=1.00e-02\n",
      "Epoch [31/100] | Train Loss=0.0011792928 | Test Loss=0.0029738879 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [32/100] | Train Loss=0.0001400123 | Test Loss=0.0000734546 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [33/100] | Train Loss=0.0001337069 | Test Loss=0.0000976243 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [34/100] | Train Loss=0.0001315969 | Test Loss=0.0001055379 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [35/100] | Train Loss=0.0001322086 | Test Loss=0.0001514828 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [36/100] | Train Loss=0.0001352188 | Test Loss=0.0001054021 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [37/100] | Train Loss=0.0001332069 | Test Loss=0.0000993184 | Time=6.08s | LR=1.00e-03\n",
      "Epoch [38/100] | Train Loss=0.0001370252 | Test Loss=0.0000656442 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [39/100] | Train Loss=0.0001385727 | Test Loss=0.0003095757 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [40/100] | Train Loss=0.0001225645 | Test Loss=0.0001613616 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [41/100] | Train Loss=0.0001368129 | Test Loss=0.0001041175 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [42/100] | Train Loss=0.0001284138 | Test Loss=0.0000896887 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [43/100] | Train Loss=0.0001351689 | Test Loss=0.0003269111 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [44/100] | Train Loss=0.0001254581 | Test Loss=0.0000948578 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [45/100] | Train Loss=0.0001358099 | Test Loss=0.0001074886 | Time=6.07s | LR=1.00e-03\n",
      "Epoch [46/100] | Train Loss=0.0001401078 | Test Loss=0.0000829039 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [47/100] | Train Loss=0.0000564921 | Test Loss=0.0000601619 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [48/100] | Train Loss=0.0000577652 | Test Loss=0.0000588863 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [49/100] | Train Loss=0.0000577497 | Test Loss=0.0000587963 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [50/100] | Train Loss=0.0000578580 | Test Loss=0.0000589622 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [51/100] | Train Loss=0.0000578860 | Test Loss=0.0000587532 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [52/100] | Train Loss=0.0000578721 | Test Loss=0.0000588283 | Time=6.07s | LR=1.00e-04\n",
      "Epoch [53/100] | Train Loss=0.0000580840 | Test Loss=0.0000588977 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [54/100] | Train Loss=0.0000505653 | Test Loss=0.0000501402 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [55/100] | Train Loss=0.0000506150 | Test Loss=0.0000501767 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [56/100] | Train Loss=0.0000506199 | Test Loss=0.0000501867 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [57/100] | Train Loss=0.0000506203 | Test Loss=0.0000502094 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [58/100] | Train Loss=0.0000506233 | Test Loss=0.0000501980 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [59/100] | Train Loss=0.0000506175 | Test Loss=0.0000502305 | Time=6.07s | LR=1.00e-05\n",
      "Epoch [60/100] | Train Loss=0.0000506218 | Test Loss=0.0000502005 | Time=6.07s | LR=1.00e-06\n",
      "Epoch [61/100] | Train Loss=0.0000499361 | Test Loss=0.0000500876 | Time=6.07s | LR=1.00e-06\n",
      "Epoch [62/100] | Train Loss=0.0000499342 | Test Loss=0.0000500918 | Time=6.07s | LR=1.00e-06\n",
      "Epoch [63/100] | Train Loss=0.0000499354 | Test Loss=0.0000500792 | Time=6.07s | LR=1.00e-06\n",
      "Epoch [64/100] | Train Loss=0.0000499342 | Test Loss=0.0000500734 | Time=6.07s | LR=1.00e-06\n",
      "Epoch [65/100] | Train Loss=0.0000499328 | Test Loss=0.0000500764 | Time=6.06s | LR=1.00e-06\n",
      "Epoch [66/100] | Train Loss=0.0000499358 | Test Loss=0.0000500698 | Time=6.07s | LR=1.00e-06\n",
      "Epoch [67/100] | Train Loss=0.0000499332 | Test Loss=0.0000500697 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [68/100] | Train Loss=0.0000498513 | Test Loss=0.0000499876 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [69/100] | Train Loss=0.0000498446 | Test Loss=0.0000499822 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [70/100] | Train Loss=0.0000498466 | Test Loss=0.0000499852 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [71/100] | Train Loss=0.0000498487 | Test Loss=0.0000499738 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [72/100] | Train Loss=0.0000498471 | Test Loss=0.0000499802 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [73/100] | Train Loss=0.0000498484 | Test Loss=0.0000499817 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [74/100] | Train Loss=0.0000498472 | Test Loss=0.0000499882 | Time=6.07s | LR=1.00e-07\n",
      "Epoch [75/100] | Train Loss=0.0000498491 | Test Loss=0.0000499791 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [76/100] | Train Loss=0.0000498508 | Test Loss=0.0000499809 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [77/100] | Train Loss=0.0000498502 | Test Loss=0.0000499808 | Time=6.06s | LR=1.00e-08\n",
      "Epoch [78/100] | Train Loss=0.0000498497 | Test Loss=0.0000499776 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [79/100] | Train Loss=0.0000498495 | Test Loss=0.0000499761 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [80/100] | Train Loss=0.0000498513 | Test Loss=0.0000499749 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [81/100] | Train Loss=0.0000498516 | Test Loss=0.0000499761 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [82/100] | Train Loss=0.0000498521 | Test Loss=0.0000499733 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [83/100] | Train Loss=0.0000498517 | Test Loss=0.0000499762 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [84/100] | Train Loss=0.0000498507 | Test Loss=0.0000499747 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [85/100] | Train Loss=0.0000498513 | Test Loss=0.0000499748 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [86/100] | Train Loss=0.0000498520 | Test Loss=0.0000499750 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [87/100] | Train Loss=0.0000498498 | Test Loss=0.0000499763 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [88/100] | Train Loss=0.0000498482 | Test Loss=0.0000499737 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [89/100] | Train Loss=0.0000498487 | Test Loss=0.0000499739 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [90/100] | Train Loss=0.0000498493 | Test Loss=0.0000499738 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [91/100] | Train Loss=0.0000498496 | Test Loss=0.0000499729 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [92/100] | Train Loss=0.0000498501 | Test Loss=0.0000499732 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [93/100] | Train Loss=0.0000498498 | Test Loss=0.0000499742 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [94/100] | Train Loss=0.0000498486 | Test Loss=0.0000499776 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [95/100] | Train Loss=0.0000498474 | Test Loss=0.0000499780 | Time=6.07s | LR=1.00e-08\n",
      "Epoch [96/100] | Train Loss=0.0000498470 | Test Loss=0.0000499767 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [97/100] | Train Loss=0.0000498466 | Test Loss=0.0000499807 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [98/100] | Train Loss=0.0000498478 | Test Loss=0.0000499805 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [99/100] | Train Loss=0.0000498482 | Test Loss=0.0000499830 | Time=6.08s | LR=1.00e-08\n",
      "Epoch [100/100] | Train Loss=0.0000498490 | Test Loss=0.0000499809 | Time=6.08s | LR=1.00e-08\n",
      "\n",
      "Total training time: 612.96s\n"
     ]
    },
    {
     "data": {
      "image/png": "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3OB1Bg+uGk+ZkJBAcnJycD+s+kyZMoXf/e537N+/n3vuuYexY8cyduxYAFauXInX66Vfv37V3uN2uyOyzcmnn37K5ZdfzowZMxg4cGCzrvHjjz/i8XgYN25c8JjT6WTUqFGsXr0agGuvvZbzzjuPb7/9llNPPZWzzz47+DNPnTqVU089lQEDBjBx4kROP/10Tj311EP/4eqhICR1KwgJQqoIiUg9DMMIaxdVtCQkJFT7/tZbb2Xu3Lk89thj9OnTh5iYGM477zwqKioavI7T6az2vWEY+Hy+Bt+TkpJCnz59AKsa06dPH4455hjGjx9PcXExdrudpUuX1tpLK3SQdzh8/vnnnHHGGTz55JNceumlYb12TZMmTWLTpk3Mnj2buXPncvLJJ5Obm8tjjz3G0UcfzfLly/nqq6/45JNPuPDCCxk/fjxvvvlmRNqiwdJSt4KQ/+vRGCERaWe++uorLrvsMs455xwGDRpEZmbmQatB4ZCYmMhNN93ErbfeimmaDBs2DK/Xy65du+jTp0+1r8zMzLB97meffcZpp53GI488cshLAvTu3RuXy8VXX30VPObxeFi8eDE5OTnBYx07dmTq1Kn861//4qmnnuKvf/1r8LXk5GQuuugiZsyYwWuvvcZbb73Fvn2R+beo7cd4iYwDqgiJSPvVt29f3n77bc444wwMw+D3v/992Nf2qc///d//8cc//pG33nqL888/nylTpnDppZfy+OOPM2zYMHbv3s28efMYPHgwp512WqOvu2HDhlrr/vTt25dFixZx+umnc9NNN3HeeeeRn58PgMvlOugg79BlCAIGDhzItddey2233UZ6ejpHHHEEjz76KKWlpfzqV78C4O6772b48OEMHDgQt9vN+++/Hxyc/eSTT5KSksLYsWNxOBy88cYbZGZmRmzRSAUhqVvBpqrnqgiJSDvzxBNPcMUVVzB27FgyMjK4/fbb2b+/ZcZLpqenc+mll3Lvvfdy7rnnMnPmTO6//35+/etfs23bNjIyMjjmmGOavMbPtGnTah374osvePnllyktLeWhhx6qNk39hBNOOOg0/Z///Oe1jm3ZsoWHH34Yn8/HJZdcQlFRESNGjOB///sfaWlpgBWy7rzzTjZu3EhcXBzHHXccr776KmBVxZ5++mluvvlm7HY7I0eOZPbs2dhskenEMsyWirhtVGFhISkp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LUf3uuWE4143VAkK0GBpERERabcUhERERKTdUhCKkpiYGO655x5iYmKi3ZTDnu51y9L9bjm61y1H97rltPS91mBpERERabdUERIREZF2S0FIRERE2i0FIREREWm3FIRERESk3VIQipLp06fTs2dPYmNjGT16NIsWLYp2k9q8hx56iJEjR5KUlESnTp04++yzWbt2bbVzysvLyc3NpUOHDiQmJnLeeeexc+fOKLX48PDwww9jGAY333xz8Jjuc3ht27aNX/7yl3To0IG4uDgGDRrEkiVLgq+bpsndd99Nly5diIuLY/z48axbty6KLW6bvF4vd911F9nZ2cTFxdG7d2/++Mc/VturSve6eebPn88ZZ5xB165dMQyDWbNmVXu9Mfd13759TJkyheTkZFJTU/nVr35FcXHxIbdNQSgKXnvtNaZNm8Y999zDt99+y5AhQ5gwYQK7du2KdtPatM8//5zc3Fy++eYb5s6di8fj4dRTT6WkpCR4zi233MJ///tf3njjDT7//HO2b9/OueeeG8VWt22LFy/mhRdeYPDgwdWO6z6Hz/79+xk3bhxOp5MPP/yQvLw8Hn/8cdLS0oLnPProozz99NM8//zzLFy4kISEBCZMmEB5eXkUW972PPLIIzz33HM8++yzrF69mkceeYRHH32UZ555JniO7nXzlJSUMGTIEKZPn17n6425r1OmTOH7779n7ty5vP/++8yfP5+rr7760BtnSosbNWqUmZubG/ze6/WaXbt2NR966KEoturws2vXLhMwP//8c9M0TbOgoMB0Op3mG2+8ETxn9erVJmAuWLAgWs1ss4qKisy+ffuac+fONU844QTzpptuMk1T9zncfvOb35jHHntsva/7fD4zMzPT/NOf/hQ8VlBQYMbExJj/+c9/WqKJh43TTjvNvOKKK6odO/fcc80pU6aYpql7HS6A+c477wS/b8x9zcvLMwFz8eLFwXM+/PBD0zAMc9u2bYfUHlWEWlhFRQVLly5l/PjxwWM2m43x48ezYMGCKLbs8HPgwAEA0tPTAVi6dCkej6fave/fvz9HHHGE7n0z5Obmctppp1W7n6D7HG7vvfceI0aM4IILLqBTp04MGzaMGTNmBF/fsGED+fn51e53SkoKo0eP1v1uorFjxzJv3jx++OEHAFasWMGXX37JpEmTAN3rSGnMfV2wYAGpqamMGDEieM748eOx2WwsXLjwkD5fm662sD179uD1euncuXO14507d2bNmjVRatXhx+fzcfPNNzNu3DiOOuooAPLz83G5XKSmplY7t3PnzuTn50ehlW3Xq6++yrfffsvixYtrvab7HF4//fQTzz33HNOmTeO3v/0tixcv5sYbb8TlcjF16tTgPa3r7xTd76a54447KCwspH///tjtdrxeLw888ABTpkwB0L2OkMbc1/z8fDp16lTtdYfDQXp6+iHfewUhOSzl5uayatUqvvzyy2g35bCzZcsWbrrpJubOnUtsbGy0m3PY8/l8jBgxggcffBCAYcOGsWrVKp5//nmmTp0a5dYdXl5//XVeeeUV/v3vfzNw4ECWL1/OzTffTNeuXXWvD2PqGmthGRkZ2O32WjNodu7cSWZmZpRadXi5/vrref/99/n000/p3r178HhmZiYVFRUUFBRUO1/3vmmWLl3Krl27OProo3E4HDgcDj7//HOefvppHA4HnTt31n0Ooy5dupCTk1Pt2IABA9i8eTNA8J7q75RDd9ttt3HHHXfw85//nEGDBnHJJZdwyy238NBDDwG615HSmPuamZlZa0JRZWUl+/btO+R7ryDUwlwuF8OHD2fevHnBYz6fj3nz5jFmzJgotqztM02T66+/nnfeeYdPPvmE7Ozsaq8PHz4cp9NZ7d6vXbuWzZs36943wcknn8zKlStZvnx58GvEiBFMmTIl+Fz3OXzGjRtXaxmIH374gR49egCQnZ1NZmZmtftdWFjIwoULdb+bqLS0FJut+j+Ldrsdn88H6F5HSmPu65gxYygoKGDp0qXBcz755BN8Ph+jR48+tAYc0lBraZZXX33VjImJMV966SUzLy/PvPrqq83U1FQzPz8/2k1r06699lozJSXF/Oyzz8wdO3YEv0pLS4PnXHPNNeYRRxxhfvLJJ+aSJUvMMWPGmGPGjIliqw8PobPGTFP3OZwWLVpkOhwO84EHHjDXrVtnvvLKK2Z8fLz5r3/9K3jOww8/bKampprvvvuu+d1335lnnXWWmZ2dbZaVlUWx5W3P1KlTzW7dupnvv/++uWHDBvPtt982MzIyzNtvvz14ju518xQVFZnLli0zly1bZgLmE088YS5btszctGmTaZqNu68TJ040hw0bZi5cuND88ssvzb59+5oXX3zxIbdNQShKnnnmGfOII44wXS6XOWrUKPObb76JdpPaPKDOr5kzZwbPKSsrM6+77jozLS3NjI+PN8855xxzx44d0Wv0YaJmENJ9Dq///ve/5lFHHWXGxMSY/fv3N//6179We93n85l33XWX2blzZzMmJsY8+eSTzbVr10aptW1XYWGhedNNN5lHHHGEGRsba/bq1cv83e9+Z7rd7uA5utfN8+mnn9b59/PUqVNN02zcfd27d6958cUXm4mJiWZycrJ5+eWXm0VFRYfcNsM0Q5bMFBEREWlHNEZIRERE2i0FIREREWm3FIRERESk3VIQEhERkXZLQUhERETaLQUhERERabcUhERERKTdUhASERGRdktBSESkiQzDYNasWdFuhoiEgYKQiLQpl112GYZh1PqaOHFitJsmIm2QI9oNEBFpqokTJzJz5sxqx2JiYqLUGhFpy1QREpE2JyYmhszMzGpfaWlpgNVt9dxzzzFp0iTi4uLo1asXb775ZrX3r1y5kp/97GfExcXRoUMHrr76aoqLi6ud8/e//52BAwcSExNDly5duP7666u9vmfPHs455xzi4+Pp27cv7733XmR/aBGJCAUhETns3HXXXZx33nmsWLGCKVOm8POf/5zVq1cDUFJSwoQJE0hLS2Px4sW88cYbfPzxx9WCznPPPUdubi5XX301K1eu5L333qNPnz7VPuO+++7jwgsv5LvvvmPy5MlMmTKFffv2tejPKSJhcMj714uItKCpU6eadrvdTEhIqPb1wAMPmKZpmoB5zTXXVHvP6NGjzWuvvdY0TdP861//aqalpZnFxcXB1z/44APTZrOZ+fn5pmmaZteuXc3f/e539bYBMH//+98Hvy8uLjYB88MPPwzbzykiLUNjhESkzTnppJN47rnnqh1LT08PPh8zZky118aMGcPy5csBWL16NUOGDCEhISH4+rhx4/D5fKxduxbDMNi+fTsnn3xyg20YPHhw8HlCQgLJycns2rWruT+SiESJgpCItDkJCQm1uqrCJS4urlHnOZ3Oat8bhoHP54tEk0QkgjRGSEQOO998802t7wcMGADAgAEDWLFiBSUlJcHXv/rqK2w2G0ceeSRJSUn07NmTefPmtWibRSQ6VBESkTbH7XaTn59f7ZjD4SAjIwOAN954gxEjRnDsscfyyiuvsGjRIv72t78BMGXKFO655x6mTp3Kvffey+7du7nhhhu45JJL6Ny5MwD33nsv11xzDZ06dWLSpEkUFRXx1VdfccMNN7TsDyoiEacgJCJtzkcffUSXLl2qHTvyyCNZs2YNYM3oevXVV7nuuuvo0qUL//nPf8jJyQEgPj6e//3vf9x0002MHDmS+Ph4zjvvPJ544ongtaZOnUp5eTlPPvkkt956KxkZGZx//vkt9wOKSIsxTNM0o90IEZFwMQyDd955h7PPPjvaTRGRNkBjhERERKTdUhASERGRdktjhETksKLefhFpClWEREREpN1SEBIREZF2S0FIRERE2i0FIREREWm3FIRERESk3VIQEhERkXZLQUhERETaLQUhERERabf+H2sXGQcOEIvIAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "\n",
    "loss_history, test_loss_history, early_stop = train_kano(\n",
    "    dataset=train_data,\n",
    "    kano=kano_ans,\n",
    "    test_dataset=test_data,\n",
    "    num_epochs=100,\n",
    "    lr=1e-1,\n",
    "    device=device,\n",
    "    symbol_is_kan=True,\n",
    "    activation=False,\n",
    "    reduce_on='train',\n",
    "    factor=0.1,\n",
    "    patience=5,\n",
    "    min_lr=1e-10,\n",
    "    cooldown=0,\n",
    "    grid_update_freq=1,\n",
    "    start_grid_update_epoch=0,\n",
    "    stop_grid_update_epoch=9999,\n",
    "    early_stop_threshold=1e-6\n",
    ")\n",
    "\n",
    "torch.save(sym_ans.state_dict(), 'kanosymans_2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Checking coefficients"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABv4AAAGGCAYAAACzJfYKAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA3YFJREFUeJzs3Xd0FVXbxuHfSe8JCZBQQgu9915CryoWFESpgiKCNBFUmg0VRAGRYgEsKAI2eg+99xZ6CSUJNSEJqWe+P3jJZ6QlCExycl9rnfWaOTNz7k14yZN5Zva2GIZhICIiIiIiIiIiIiIiIiJZmp3ZAURERERERERERERERETkv1PjT0RERERERERERERERMQGqPEnIiIiIiIiIiIiIiIiYgPU+BMRERERERERERERERGxAWr8iYiIiIiIiIiIiIiIiNgANf5EREREREREREREREREbIAafyIiIiIiIiIiIiIiIiI2QI0/ERERERERERERERERERugxp+IiIiIiIiIiIiIiIiIDVDjT0T+k99++w1fX19iYmIyfGzNmjUZPHjwI0iVNRUqVIguXbo8ts8LDg4mODj4gY4NCwvDxcWFDRs2pDlf2bJl73lcUlISgYGBfP311w/0uSIiIo/TjBkzsFgsnDp1KnXbf/n5+ahFRETw3HPP4efnh8Vi4csvvzQ70mOVGcYfExND7ty5+fnnnzN87JQpUyhQoAAJCQmPIJmIiMij87hrpluft3379gc6/ujRozRr1gxvb28sFgt//vnnww2YyWWG8d/pulJ6DRkyhBo1ajyCVCK2Q40/kWzgVkF06+Xg4EC+fPno0qUL586de+DzpqSkMGLECPr06YOHh0eGj3/77beZNGkS4eHhD5xB7u3gwYOMHDkyTfH9MLz//vvUqFGDOnXqZOg4R0dHBgwYwEcffUR8fPxDzSQiIpLd9e/fn6VLlzJ06FB+/PFHWrRo8VDPHxcXx8iRIwkJCXmo531YMjJ+i8XCG2+88dAzjB8/Hk9PT9q3b5/hY7t06UJiYiJTp0596LlERETk/3Xu3Jl9+/bx0Ucf8eOPP1K1atWHev7z588zcuRIdu/e/VDP+7Ckd/ynTp3CYrEwduzYh57hQa8rAfTr1489e/bw999/P/RcIrbCwewAIvL4vP/++xQuXJj4+Hg2b97MjBkzWL9+Pfv378fFxSXD55s/fz6HDx+mZ8+eD5TnqaeewsvLi6+//pr333//gc4h93bw4EFGjRpFcHAwhQoVSvPesmXLHuicFy9eZObMmcycOfOBju/atStDhgxh1qxZdOvW7YHOISIiYpYH/fn5OKxatYqnnnqKQYMGPZLzx8XFMWrUKIBM+dTjox7//SQlJTF+/Hj69++Pvb19ho93cXGhc+fOjBs3jj59+mCxWB5BShERkccjs9ZMN27cYNOmTbz77ruP5CYguNn4GzVqFIUKFaJixYqP5DMe1OMY//381+tKAQEBPPXUU4wdO5Ynn3zyIacTsQ164k8kG2nZsiUvvfQSr7zyCt9++y2DBg3i+PHjD3yHzPTp06lTpw758uV7oOPt7Ox47rnn+OGHHzAM44HOkd3ExsY+tHM5OTnh5OSU4eN++uknHBwceOKJJx7oc318fGjWrBkzZsx4oONFRETM9KA/Px+HyMhIfHx8zI6RYQ+rvjF7/AsWLODixYs8//zzD3yO559/ntOnT7N69eqHmExEROTxy6w108WLFwGybc2UGcb/X68rwc2aaf369Zw4ceIhJhOxHWr8iWRj9erVA+D48eNptoeGhvLcc8/h6+uLi4sLVatWva05GB8fz5IlS2jSpMlt550+fTqNGjUid+7cODs7U7p0aSZPnnzHDE2bNuX06dOPffqDhIQE+vfvT65cufD09OTJJ5/k7NmzWCwWRo4cmbpfly5dbntSDmDkyJG33YWd3nEbhsGHH35I/vz5cXNzo2HDhhw4cOC2/W5N0bpmzRpef/11cufOTf78+QE4ffo0r7/+OiVKlMDV1RU/Pz/atWuXZkrPGTNm0K5dOwAaNmyYOtXrrem57jTffnx8PCNHjqR48eK4uLiQJ08ennnmmTR/R/78809q1KiRruldly1bhpubGx06dCA5OTl1e9OmTVm/fj1Xrly57zlEREQyk3///AwJCcFisfDbb7/x0UcfkT9/flxcXGjcuDHHjh1L93kNw6Bhw4bkypWLyMjI1O2JiYmUK1eOoKCgu17suVUzGIbBpEmTUn/mA1y5coVBgwZRrlw5PDw88PLyomXLluzZs+e289yrDjh16hS5cuUCYNSoUamf8c+6adWqVdSrVw93d3d8fHx46qmnOHToUJrPuFVDHTx4kBdffJEcOXJQt27de/7ZnDhxgnbt2uHr64ubmxs1a9Zk4cKF6Rp/ev3z+zhq1Cjy5cuHp6cnzz33HFFRUSQkJNCvXz9y586Nh4cHXbt2vW0tvj///JNChQoRFBSUZvvevXvp0qULRYoUwcXFhYCAALp168bly5dvy1GlShV8fX3566+/MpRfREQks3lUNdPdXL16lerVq5M/f34OHz58x31GjhxJwYIFAXjrrbewWCyp13zSc53llmvXrtG/f38KFSqEs7Mz+fPnp1OnTly6dImQkBCqVasG3Jzx6FZd8s+bn+fMmUOVKlVwdXUlZ86cvPTSS7ctxdOlSxc8PDw4fvw4rVq1wtPTk44dO97zz2DXrl20bNkSLy8vPDw8aNy4MZs3b07X+NPrVt21fv16+vbtS65cufDx8eHVV18lMTGRa9eu0alTJ3LkyEGOHDkYPHjwbTf73+260rp162jXrh0FChTA2dmZwMBA+vfvz40bN27Lcet6pGomkTvTVJ8i2dit4iVHjhyp2w4cOJD6FN+QIUNwd3fnt99+o23btsybN4+nn34agB07dpCYmEjlypVvO+/kyZMpU6YMTz75JA4ODsyfP5/XX38dq9VK79690+xbpUoVADZs2EClSpXumffq1aukpKTcd1xubm64ubndc59XXnmFn376iRdffJHatWuzatUqWrdufd9z30t6xz18+HA+/PBDWrVqRatWrdi5cyfNmjUjMTHxjud9/fXXyZUrF8OHD0+94Ldt2zY2btxI+/btyZ8/P6dOnWLy5MkEBwdz8OBB3NzcqF+/Pn379mXChAm88847lCpVCiD1f/8tJSWFNm3asHLlStq3b8+bb77J9evXWb58Ofv37ycoKIikpCS2bdtGr1697vvnsWDBAp577jleeOEFvv/++zRTXlWpUgXDMNi4cSNt2rRJ95+xiIhIZvXJJ59gZ2fHoEGDiIqK4rPPPqNjx45s2bIlXcdbLBa+//57ypcvz2uvvcbvv/8OwIgRIzhw4AAhISG4u7vf8dj69evz448/8vLLL9O0aVM6deqU+t6JEyf4888/adeuHYULFyYiIoKpU6fSoEEDDh48SN68eYH71wFNmjRh8uTJ9OrVi6effppnnnkGgPLlywOwYsUKWrZsSZEiRRg5ciQ3btxg4sSJ1KlTh507d952Ualdu3YUK1aMjz/++J4zP0RERFC7dm3i4uLo27cvfn5+zJw5kyeffJK5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Tbl06RJw866sZcuW0aVLl3SPV0RExNadPXuW/v3788QTT9C5c+fU7R07duTpp59m8ODBd20W3cs777zDwIEDWbp0KW+++SY7d+5k4cKFt033lN464NtvvyVfvnz079+fDh06MHfuXODmrAZLlizBz8+P4cOHM3bsWGrWrMmGDRsoXLjwA/6pgL+/Pxs3bqRp06ZMnDiRoUOH4uTkxPz583n66acf+LyPwhNPPEHOnDn57bff0myfNWsWzZs3Z9KkSQwdOhRHR0cWL158x3PMmTOHAgUK3Db9l4iIiNzblClTaN++PV27duWvv/7K8PHpvc7i4eHBunXr6NWrF4sWLaJv3758/fXXlChRIvXGLUdHR2bOnIm9vT2vvfYaHTp0YM2aNQB06dKF2bNnk5iYyNtvv83UqVN5+umnWb9+PT4+Pg88/jJlyrBu3TrKli3L6NGjGTVqFAULFmT16tXUqFHjgc/7KNzpupKjoyPz58+nYsWKqfmLFSvGDz/8cMdzzJkzh7p16xIUFPS4YotkKRbjQeeMEZFs71aj8Pnnn+eDDz7I8PF//vknL774IsePHydPnjyPIGHGWSyW+64RKNC9e3eOHDnCunXrMnzsl19+yWeffcbx48dxdXV9BOlEREREzPHBBx8wffp0jh49mjplVXolJCRQqFAhhgwZcsebx0RERERsxX+5rhQeHk7hwoX59ddf9cSfyF3oiT8ReWD29va8//77TJo0iZiYmAwf/+mnn/LGG29kmqafpN+IESPYtm0bGzZsyNBxSUlJjBs3jvfee09NPxEREbE5/fv3JyYmhl9//TXDx06fPh1HR0dee+21R5BMREREJPN40OtKcPOG8nLlyqnpJ3IPeuJPROQf9MSfiIiIPGw3btwgKirqnvv4+vri5OT0mBKJiIiIZD6qmUREHg4HswOIiIiIiIjYstmzZ9O1a9d77rN69WqCg4MfTyARERGRTEg1k4jIw6En/kRERERERB6hCxcucODAgXvuU6VKFXLkyPGYEomIiIhkPqqZREQeDjX+RERERERERERERERERGyAndkBREREREREREREREREROS/0xp/gNVq5fz583h6emKxWMyOIyIiIjbAMAyuX79O3rx5sbOznXutVDeJiIjIw6SaSUREROT+MlIzqfEHnD9/nsDAQLNjiIiIiA0KCwsjf/78Zsd4aFQ3iYiIyKOgmklERETk/tJTM6nxB3h6egI3/8C8vLxMTiMiIiK2IDo6msDAwNQ6w1aobhIREZGHSTWTiIiIyP1lpGZS4w9Sp1zw8vJSMSYiIiIPla1N7aS6SURERB4F1UwiIiIi95eemsl2Jk8XERERERERERERERERycbU+BMRERERERERERERERGxAWr8iYiIiGRTn3zyCRaLhX79+pkdRUREREREREREHgI1/kRERESyoW3btjF16lTKly9vdhQREREREREREXlI1PgTERERyWZiYmLo2LEj33zzDTly5DA7joiIiIiIiIiIPCRq/ImIiIhkM71796Z169Y0adLkvvsmJCQQHR2d5iUiIiIiIiIiIpmTg9kBREREROTx+fXXX9m5cyfbtm1L1/6jR49m1KhRjziViIiIiIiIiIg8DDb1xN+kSZMoVKgQLi4u1KhRg61bt5odSURERCTTCAsL48033+Tnn3/GxcUlXccMHTqUqKio1FdYWNgjTikiIiIiIiIiIg/KZhp/s2fPZsCAAYwYMYKdO3dSoUIFmjdvTmRkpNnRRERERDKFHTt2EBkZSeXKlXFwcMDBwYE1a9YwYcIEHBwcSElJue0YZ2dnvLy80rxERERERERERCRzspnG37hx4+jRowddu3aldOnSTJkyBTc3N77//nuzo4mIiIhkCo0bN2bfvn3s3r079VW1alU6duzI7t27sbe3NzsiV2MTzY4gIiIikuldi0vEMAyzY4iIiEgmZBNr/CUmJrJjxw6GDh2aus3Ozo4mTZqwadOm2/ZPSEggISEh9evo6OjHklNEMpf4pBTOXo0jIjqBi9dvvi7FJHAxJoGY+GTiElOITUzmRmIKcYkpWO/wS5Wroz1uzg64Odrj7myPu7MDfu7O5PR0IpeHMzk9ncnt6UygrxteLo4mjFJE5P95enpStmzZNNvc3d3x8/O7bbsZEpJTeHLSeorm8uDd1qUpmtvD7EgiIiIimY5hGLwycztWw2BYm9JUKpDD7EgiIiKSidhE4+/SpUukpKTg7++fZru/vz+hoaG37T969GhGjRr1uOKJiIkMw+Di9QQOXogmNPw6Jy7GcPpyHGeuxHEhKv6xZvF1d6KArxuF/NwolNOdkgGelMrjRWAON+zsLI81i4hIZrTj1FUuXIsn7MoN1h5dy8s1C/Jm42LkcHcyO5qI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",
      "text/plain": [
       "<Figure size 1800x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "symbol(x,k) = [ Re(a), Im(a) ]\n",
      "  Re(a) = -0.0003 + -0.0027*k + -1.0000*k^2\n",
      "  Im(a) = (0.0000 + -1.2283*x) * (31.1017 + -0.8141*k)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "'symbol(x,k) = [ Re(a), Im(a) ]\\n  Re(a) = -0.0003 + -0.0027*k + -1.0000*k^2\\n  Im(a) = (0.0000 + -1.2283*x) * (31.1017 + -0.8141*k)'"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sym_ans.plot(x_range=(-torch.pi, torch.pi), k_range=(-64, 64), steps=100)\n",
    "sym_ans.symbolic_formula()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Total trainable parameters: 1,218\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Function type 'sine_beats': mean Rel-L2 = 0.0006404252\n",
      "Function type 'periodic': mean Rel-L2 = 0.0007647802\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0005859160\n",
      "Overall mean Rel-L2 = 0.0006620571\n",
      "Average inference time / sample = 0.000381 s\n",
      "--------------test----------------\n",
      "Total trainable parameters: 1,218\n",
      "Function type 'gaussian_hermite': mean Rel-L2 = 0.0011822451\n",
      "Function type 'sinc_pulse': mean Rel-L2 = 0.0013611916\n",
      "Function type 'wave_packet': mean Rel-L2 = 0.0005892718\n",
      "Overall mean Rel-L2 = 0.0010548179\n",
      "Average inference time / sample = 0.000381 s\n",
      "--------------sample----------------\n",
      "Total trainable parameters: 1,218\n",
      "Function type 'periodic': mean Rel-L2 = 0.0007223839\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0006614012\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0005832458\n",
      "Overall mean Rel-L2 = 0.0006557772\n",
      "Average inference time / sample = 0.000381 s\n"
     ]
    }
   ],
   "source": [
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, operator = kano_mlp, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = kano_mlp, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = kano_mlp, device = device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Total trainable parameters: 114\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000408293\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000898748\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000572963\n",
      "Overall mean Rel-L2 = 0.0000628766\n",
      "Average inference time / sample = 0.002073 s\n",
      "--------------test----------------\n",
      "Total trainable parameters: 114\n",
      "Function type 'gaussian_hermite': mean Rel-L2 = 0.0000888838\n",
      "Function type 'sinc_pulse': mean Rel-L2 = 0.0000782548\n",
      "Function type 'wave_packet': mean Rel-L2 = 0.0000561808\n",
      "Overall mean Rel-L2 = 0.0000748867\n",
      "Average inference time / sample = 0.002076 s\n",
      "--------------sample----------------\n",
      "Total trainable parameters: 114\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000796526\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000427923\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000586793\n",
      "Overall mean Rel-L2 = 0.0000600670\n",
      "Average inference time / sample = 0.002075 s\n"
     ]
    }
   ],
   "source": [
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, operator = kano_numeric, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = kano_numeric, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = kano_numeric, device = device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Total trainable parameters: 7\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000215150\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000840642\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000431192\n",
      "Overall mean Rel-L2 = 0.0000498473\n",
      "Average inference time / sample = 0.000408 s\n",
      "--------------test----------------\n",
      "Total trainable parameters: 7\n",
      "Function type 'gaussian_hermite': mean Rel-L2 = 0.0000707321\n",
      "Function type 'sinc_pulse': mean Rel-L2 = 0.0000524037\n",
      "Function type 'wave_packet': mean Rel-L2 = 0.0000250013\n",
      "Overall mean Rel-L2 = 0.0000499809\n",
      "Average inference time / sample = 0.000409 s\n",
      "--------------sample----------------\n",
      "Total trainable parameters: 7\n",
      "Function type 'periodic': mean Rel-L2 = 0.0000725297\n",
      "Function type 'sine_beats': mean Rel-L2 = 0.0000244821\n",
      "Function type 'chirped_cosine': mean Rel-L2 = 0.0000446010\n",
      "Overall mean Rel-L2 = 0.0000468066\n",
      "Average inference time / sample = 0.000408 s\n"
     ]
    }
   ],
   "source": [
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, operator = kano_ans, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = kano_ans, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = kano_ans, device = device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Benchmarking with FNO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from neuralop.layers.embeddings import GridEmbeddingND  # adjust the import path as needed\n",
    "\n",
    "#############################################\n",
    "# Data Preprocessing Helpers for FNO\n",
    "#############################################\n",
    "def convert_dataset_for_fno(dataset):\n",
    "    \"\"\"\n",
    "    Convert each sample in the dataset (assumed as tuple: (x, f, Gf, func_type))\n",
    "    to a dictionary format required for FNO evaluation:\n",
    "      - 'x': (n,)\n",
    "      - 'f': (1, n)\n",
    "      - 'Gf': (1, n)\n",
    "      - 'func_type': str\n",
    "    \"\"\"\n",
    "    new_dataset = []\n",
    "    for sample in dataset:\n",
    "        if len(sample) < 4:\n",
    "            raise ValueError(\"Each sample must have at least 4 elements: (x, f, Gf, func_type).\")\n",
    "        x, f, Gf, func_type = sample[:4]\n",
    "        if f.ndim == 1:\n",
    "            f = f.unsqueeze(0)\n",
    "        if Gf.ndim == 1:\n",
    "            Gf = Gf.unsqueeze(0)\n",
    "        new_dataset.append({\n",
    "            'x': x,\n",
    "            'f': f,\n",
    "            'Gf': Gf,\n",
    "            'func_type': func_type\n",
    "        })\n",
    "    return new_dataset\n",
    "\n",
    "def adjust_input_shape(f, Gf):\n",
    "    \"\"\"\n",
    "    Ensure that input tensors f and Gf have shape (batch, channels, spatial_dim).\n",
    "    If they are of shape (channels, n) or (batch, n), add an extra dimension.\n",
    "    \"\"\"\n",
    "    if f.ndim == 2:\n",
    "        f = f.unsqueeze(0)\n",
    "    if Gf.ndim == 2:\n",
    "        Gf = Gf.unsqueeze(0)\n",
    "    return f, Gf\n",
    "\n",
    "def adjust_positional_embedding_to_1d(operator):\n",
    "    \"\"\"\n",
    "    If the operator has a GridEmbeddingND positional embedding that is not 1D,\n",
    "    adjust it so that it expects 1D inputs.\n",
    "    \"\"\"\n",
    "    if hasattr(operator, \"positional_embedding\") and operator.positional_embedding is not None:\n",
    "        emb = operator.positional_embedding\n",
    "        if isinstance(emb, GridEmbeddingND):\n",
    "            if emb.dim != 1:\n",
    "                print(\"Adjusting positional_embedding to 1D.\")\n",
    "                emb.dim = 1\n",
    "                emb.grid_boundaries = [[-15.0, 15.0]]  # one pair for 1D\n",
    "    return operator\n",
    "\n",
    "def relative_l2_error(pred, target):\n",
    "    \"\"\"\n",
    "    Compute relative L2 error: ||pred - target||_2 / (||target||_2 + eps)\n",
    "    \"\"\"\n",
    "    eps = 1e-8\n",
    "    return torch.norm(pred - target) / (torch.norm(target) + eps)\n",
    "\n",
    "#############################################\n",
    "# Loss Computation for Kano and FNO\n",
    "#############################################\n",
    "def compute_average_loss_kano(dataset, operator, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Compute the average relative L2 loss over a dataset for a Kano model that takes (x, f) as input.\n",
    "    \n",
    "    For each sample:\n",
    "       loss = || operator(x, f) - Gf ||_2 / (|| Gf ||_2 + eps)\n",
    "    \"\"\"\n",
    "    operator.to(device)\n",
    "    operator = adjust_positional_embedding_to_1d(operator)\n",
    "    losses = []\n",
    "    with torch.no_grad():\n",
    "        for sample in dataset:\n",
    "            x = sample[\"x\"]\n",
    "            f = sample[\"f\"]\n",
    "            Gf = sample[\"Gf\"]\n",
    "            # Adjust shapes\n",
    "            f, Gf = adjust_input_shape(f, Gf)\n",
    "            # Move to device\n",
    "            x = x.to(device)\n",
    "            f = f.to(device)\n",
    "            Gf = Gf.to(device)\n",
    "            # Kano model takes (x, f)\n",
    "            g_pred = operator(x, f)\n",
    "            loss = relative_l2_error(g_pred, Gf).item()\n",
    "            losses.append(loss)\n",
    "    return np.mean(losses)\n",
    "\n",
    "def compute_average_loss_fno(dataset, operator, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Compute the average relative L2 loss over a dataset for an FNO model that takes only f as input.\n",
    "    \n",
    "    For each sample:\n",
    "       loss = || operator(f) - Gf ||_2 / (|| Gf ||_2 + eps)\n",
    "    \"\"\"\n",
    "    operator.to(device)\n",
    "    operator = adjust_positional_embedding_to_1d(operator)\n",
    "    losses = []\n",
    "    with torch.no_grad():\n",
    "        for sample in dataset:\n",
    "            f = sample[\"f\"]\n",
    "            Gf = sample[\"Gf\"]\n",
    "            f, Gf = adjust_input_shape(f, Gf)\n",
    "            f = f.to(device)\n",
    "            Gf = Gf.to(device)\n",
    "            # FNO model takes just f\n",
    "            g_pred = operator(f)\n",
    "            loss = relative_l2_error(g_pred, Gf).item()\n",
    "            losses.append(loss)\n",
    "    return np.mean(losses)\n",
    "\n",
    "#############################################\n",
    "# Interpolation Helper (for dictionary-formatted data)\n",
    "#############################################\n",
    "def interpolate_dataset_dict(dataset1, dataset2, alpha):\n",
    "    \"\"\"\n",
    "    Given two datasets (lists of dictionaries with keys \"x\", \"f\", \"Gf\", \"func_type\"),\n",
    "    return a new dataset where for each sample the functions are interpolated as:\n",
    "         f_interp = (1 - alpha)*f1 + alpha*f2\n",
    "         Gf_interp = (1 - alpha)*Gf1 + alpha*Gf2\n",
    "    The 'x' and a new 'func_type' are preserved.\n",
    "    \"\"\"\n",
    "    interpolated_dataset = []\n",
    "    for s1, s2 in zip(dataset1, dataset2):\n",
    "        x = s1[\"x\"]\n",
    "        f_interp = (1 - alpha) * s1[\"f\"] + alpha * s2[\"f\"]\n",
    "        Gf_interp = (1 - alpha) * s1[\"Gf\"] + alpha * s2[\"Gf\"]\n",
    "        func_type = f\"interp_{(1-alpha):.2f}:{alpha:.2f}\"\n",
    "        interpolated_dataset.append({\n",
    "            \"x\": x,\n",
    "            \"f\": f_interp,\n",
    "            \"Gf\": Gf_interp,\n",
    "            \"func_type\": func_type\n",
    "        })\n",
    "    return interpolated_dataset\n",
    "\n",
    "#############################################\n",
    "# Main Interpolation Evaluation Module for Four Models\n",
    "#############################################\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "\n",
    "\n",
    "import torch, numpy as np, matplotlib.pyplot as plt\n",
    "\n",
    "def evaluate_and_plot_interpolations(\n",
    "    models: dict[str, torch.nn.Module],\n",
    "    dataset_test_raw, dataset_unseen_raw,\n",
    "    num_steps: int = 100,\n",
    "    device: torch.device = torch.device(\"cpu\")\n",
    "):\n",
    "    # ---------- data ----------\n",
    "    ds_test   = convert_dataset_for_fno(dataset_test_raw)\n",
    "    ds_unseen = convert_dataset_for_fno(dataset_unseen_raw)\n",
    "\n",
    "    alphas  = np.linspace(0.0, 1.0, num_steps + 1)\n",
    "    losses  = {name: [] for name in models}\n",
    "\n",
    "    for α in alphas:\n",
    "        interp = interpolate_dataset_dict(ds_test, ds_unseen, α)\n",
    "        for name, model in models.items():\n",
    "            fn = compute_average_loss_fno if \"fno\" in name.lower() \\\n",
    "                 else compute_average_loss_kano\n",
    "            losses[name].append(fn(interp, model, device))\n",
    "\n",
    "    # ---------- loss → ratio ----------\n",
    "    ratios = {n: [L/(Ls[0] or 1.0) for L in Ls] for n, Ls in losses.items()}\n",
    "\n",
    "    # ---------- plotting ----------\n",
    "    plt.figure(figsize=(8, 6))\n",
    "\n",
    "    color_map = {\"FNO\": \"red\", \"KANO\": \"blue\", \"KANO_symbolic\": \"green\"}\n",
    "    for name, curve in ratios.items():\n",
    "        label = \"KANO\" if name == \"KANO\" else name\n",
    "        plt.plot(alphas, curve, marker='o', linewidth=2.5,\n",
    "                 color=color_map.get(label, \"black\"), label=label)   # no fontweight here\n",
    "\n",
    "    # --- axes & legend in bold ---\n",
    "    label_fs, tick_fs, legend_fs = 22, 18, 20\n",
    "    plt.xlabel(r\"\\textbf{Interpolation Ratio}\", fontsize=label_fs, fontweight='bold')\n",
    "    plt.ylabel(r\"\\textbf{Loss Ratio}\",           fontsize=label_fs, fontweight='bold')\n",
    "\n",
    "    for t in plt.gca().get_xticklabels()+plt.gca().get_yticklabels():\n",
    "        t.set_fontsize(tick_fs);  t.set_fontweight('bold')\n",
    "\n",
    "    lg = plt.legend(fontsize=legend_fs, frameon=False)\n",
    "    for t in lg.get_texts():\n",
    "        t.set_fontweight('bold')\n",
    "\n",
    "    plt.grid(True, linestyle='--', alpha=0.5)\n",
    "    plt.tight_layout();  plt.show()\n",
    "\n",
    "    return ({n: float(np.mean(c)) for n, c in ratios.items()}, ratios)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total parameters: 566401\n"
     ]
    }
   ],
   "source": [
    "# Import your FNO1d and grid embedding classes.\n",
    "from neuralop.models import FNO1d\n",
    "from neuralop.layers.embeddings import GridEmbeddingND\n",
    "    \n",
    "# Create a grid embedding for 1D (with grid boundaries [-5, 5]).\n",
    "pos_emb = GridEmbeddingND(\n",
    "    in_channels=1,\n",
    "    dim=1,\n",
    "    grid_boundaries=[[-torch.pi, torch.pi]]\n",
    ")\n",
    "\n",
    "\n",
    "# Create a 1D FNO model.\n",
    "fno = FNO1d(\n",
    "    n_modes_height=128,\n",
    "    hidden_channels=64,\n",
    "    in_channels=1,\n",
    "    out_channels=1,\n",
    "    positional_embedding=pos_emb,\n",
    "    n_layers=2,\n",
    ").to(device)\n",
    "\n",
    "fno.load_state_dict(torch.load('fno_2.pth', weights_only=False))\n",
    "\n",
    "def count_parameters(model):\n",
    "    return sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "\n",
    "print(\"Total parameters:\", count_parameters(fno))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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S1tMnjzZ5flo+DzIxEJhLS0t0uDBg92CwduXpyDx55iqqiopMzPTr2vExMRIn332mfo3T5IkhScGPH1w9OertLQ0LD8DowvX+4Avnc9/8MEHFbk36lq42r+trU0aOXKk39e55ppr1L95kiQpPDFw9OhRqaCgIKDfAampqVJNTU14fggU8O/osWPH+jxfD58HORRKYXFxcVi7dm2XO1v26NEDL730Eq699tqgrpOVlYWvvvoKhYWFPo9LSkrCsmXLcM455wR1HQpcuGKAtIsxYGzhav9u3bq5rfzjzQ033ID//ve/QV2HAheOGOjRowdWr16NwYMH+3V8Tk4OVq9e7XGzPtIvrX0edN+ej0KWmZmJ7777Du+88w7eeecdbN68GXV1dejZsyf69euH8847D7fccgv69esX0nUKCwuxY8cOvP7661i+fDm2b9+OhoYGJCYmYsCAATj//PNx6623Ii0tTaE7I3+FKwZIuxgDxhau9k9JScG6deuwfPlyLFq0CBs3bkRdXR1iYmKQk5ODM888E3/84x9x2mmnKXRn5K9wxMDAgQOxfft2LFmyBKtWrcK2bdtw4MABHD16FN27d0dGRgZOPvlk/OEPf8BVV12F+Ph4Be+QtEJLnweFX7taiIiIiIiIgsahUEREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkREREREFDImFkTkl7y8PAiC4PI1e/ZsxV6/vr4eDz30EM4880ykp6cjNjbW5VrJycl+v9Ynn3yCadOmYcCAAYiPj3d5nXnz5ilWZ9K/BQsWuMW1IAiRrlaXxo0b51bna6+9NtLVIoXNnj3brZ3z8vLCWgfn9/6YmBikpKRg9OjR+Nvf/oby8vKw1oW0LybSFSBS0wknnIDdu3cDAJ544gncdddd/9/eucfVlPV//HOcU6d7URPd1EFFpkQZBin3y4SKUjOMMkTmwRiPwQySu6d5ZowQj9DMYMxjKAwyjzsTLyKXPMqlYkpqiiai+3r+8Ov8Ou21T/ucThe13q/Xeb3OWfu71v7utdbZe3/3/q7vV1C9DRs2oLCwUKHMy8sLXl5eGtaw8aEZAz4+PnB1dW10Xaq5du0ahg8fjmfPntW7rbCwMGzdulWt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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "models = {\n",
    "    \"KANO\": kano_numeric,\n",
    "    \"FNO\": fno,\n",
    "}\n",
    "\n",
    "avg_fid, fid_by_t = evaluate_and_plot_interpolations(\n",
    "    models,\n",
    "    sample_data,\n",
    "    test_data,\n",
    "    num_steps=100,\n",
    "    device=device\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ----------------------------------------------------------------------\n",
    "#  Re-plot interpolation curves with very large / bold text everywhere\n",
    "# ----------------------------------------------------------------------\n",
    "def plot_interpolation_curves(\n",
    "    fid_by_t: dict[str, list[float]],\n",
    "    *,\n",
    "    label_fs:  int = 34,   # axis-label font size\n",
    "    tick_fs:   int = 28,   # tick-label font size\n",
    "    legend_fs: int = 28    # legend font size\n",
    "):\n",
    "    \"\"\"\n",
    "    fid_by_t : {model_name : [loss_ratio_α0, loss_ratio_α1, …]}\n",
    "    \"\"\"\n",
    "\n",
    "    # ── 1.  Reconstruct α grid ─────────────────────────────────────────\n",
    "    curve_len = len(next(iter(fid_by_t.values())))\n",
    "    alphas    = np.linspace(0.0, 1.0, curve_len)\n",
    "\n",
    "    # ── 2.  Plot settings / colours ───────────────────────────────────\n",
    "    color_map = {\"FNO\": \"red\",\n",
    "                 \"KANO\": \"blue\",\n",
    "                 \"KANO_symbolic\": \"green\"}\n",
    "\n",
    "    plt.figure(figsize=(9, 7))\n",
    "\n",
    "    for name, curve in fid_by_t.items():\n",
    "        lbl = \"KANO\" if name.lower().startswith(\"kano_numeric\") else name\n",
    "        plt.plot(alphas, curve,\n",
    "                 marker='o', linewidth=3.0,\n",
    "                 color=color_map.get(lbl, \"black\"),\n",
    "                 label=lbl)\n",
    "\n",
    "    # ── 3.  Axis labels (large, bold, plain text) ─────────────────────\n",
    "    plt.xlabel(\"Interpolation Ratio\", fontsize=label_fs, fontweight='bold')\n",
    "    plt.ylabel(\"Loss Ratio\",          fontsize=label_fs, fontweight='bold')\n",
    "\n",
    "    # ── 4.  Tick labels enlarged & bold ───────────────────────────────\n",
    "    ax = plt.gca()\n",
    "    for t in ax.get_xticklabels() + ax.get_yticklabels():\n",
    "        t.set_fontsize(tick_fs)\n",
    "        t.set_fontweight('bold')\n",
    "\n",
    "    # ── 5.  Legend (upper-left, big & bold) ───────────────────────────\n",
    "    lg = plt.legend(loc='upper left',\n",
    "                    fontsize=legend_fs,\n",
    "                    frameon=False)\n",
    "    for txt in lg.get_texts():\n",
    "        txt.set_fontweight('bold')\n",
    "\n",
    "    plt.grid(True, linestyle='--', alpha=0.5)\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0tPT4XQ6MXToUIwYMQKynBh1sqqqcLlc6Nu3r9lNIRuxam5aWlqwceNGVFdXo66uDvX19UhLS0NOTg5ycnJw9NFH2/K3conAqpkha2NuSARzk+Ta2oBvvgncFkXPnV1zw+IujO+//x6LFy/Gm2++ifr6+ojHpqenY9y4cTjnnHPwu9/9DqmpqXFqJVGoF154AVdddZVh51uyZAmuvPLKkO0TJ07EJ598EvZ5l112GV588cUOz7927VpMmjRJc98VV1yBF154IdqmAgAOHDiA5557Du+++y7Wr1+PgwcPRjx+1KhROP300/H73/8ew4YN0/VaREREZHE//gi0tARui6K4s6vE6G4y0L59+/C73/0ORx11FJ599tkOCzsAaGpqwqpVqzB79uyojidKBq+88gp++OGHuL2e2+3GokWLMHjwYMyePRsfffRRh4UdAPzwww9YvHgxRo4ciSuuuAI7duyIQ2uJiIgoLoLvtysoALKzTWlKPLC487N9+3aceOKJeOaZZ2y3YKFRJElCTk6O7WYGIutRFAV33XVXXF6roaEBZ599NubNm4eamhqhc7jdbrz44osYM2YMPv30U4NbSMH4WUMimBsSwdwkOYH77QD75obF3SG7du3C5MmT49rTYEWyLCMnJydh7iEkcxUVFeGr4N+YGay6uhonnHACVq1aZcj56urqcNppp+G1114z5HykjZ81JIK5IRHMTZITmCkTsG9ueM/dIb/5zW9QVlYWdn9mZiZOO+00HH300ejVqxeampqwfft2fPHFF/jmm28SpqdPURRUVVVhwIABtgszWdMdd9yBlStXxuTc7e3tuOiii7B169aIxx1//PGYNGkS8vLy4HK58N133+H999/HgQMHNI9va2vDVVddhREjRuCYY46JRdOTHj9rSARzQyKYmyTmdgObNwdui7Lnzq65YXEH4J///CfeffddzX2SJOHWW2/F7bffjp49e2oeU1FRgWXLluGJJ56IZTPjQlVVNDc3J0yxSub74IMPsG7dOowfP97wc99+++1Yt25d2P1Dhw7Fiy++iJNOOilk3969e/H73/8ey5Yt03zugQMHMH36dGzevBnp6emGtZk8+FlDIpgbEsHcJLGffgKCf5EbZc+dXXNjnzI0Rtrb23H33XeH3f/MM8/ggQceCFvYAUB+fj5uueUWlJWVoU+fPrFoJpEhBg0aBFVVdX1pzZSp1+233975xgepqqrC4sWLw+4vKCjA+vXrNQs7AOjVqxeWLl2Ka6+9Nuw5SktL8Y9//KPTbSUiIiITBN9vl58PJPj/1ZO+uHv77bdRVVWlue/CCy+M+B+/YA6HAw6Hw6imESWM9evXY8WKFYae85FHHkFra2vY/a+88gr69evX4XmefPJJDB8+POz+Rx99FC3BUygTERGR9X35ZeDjY481px1xlPTF3XPPPRd2X6QevUQlyzJyc3NtNbaY7OHOO+80bGhDe3s7nn/++bD7/+///g/jxo2L6lxdunTBX/7yl7D7q6ur8c477+huI0XGzxoSwdyQCOYmSRUVAU8/Hbht7VrP9ijYNTf2aq3B3G43/vvf/2ruGzlyJI488sg4t8h8kiQhKyvLdtO+krWMHTs2ZNumTZvw5ptvGnL+r776Co2NjWH3X3bZZbrOd+655yIzMzPs/rVr1+o6H3WMnzUkgrkhEcxNEioqAmbMAIJH+DQ2erZHUeDZNTdJXdxt2bIFTU1Nmvu8kz+sXr0a1157LUaNGoXMzEx07doVeXl5OPHEE3Hrrbdi48aN8WxyzCmKgrKyMiiKYnZTyMbuu+8+zd903X333YZk65NPPgm7T5IknHXWWbrO17VrV0yZMkXo9UgMP2tIBHNDIpibJON2A3PmAJFGC82d6zkuArvmJqmLu0jrb7ndbpx88smYMmUKnn/+efz4449obGxEa2srampq8MUXX+Dhhx/GL3/5S5x99tmoqKiIY8tjR1VVtLa2WmtmILfb042+bJnnewd/GSm87du3Q5KkqL9EJ1MZOXIkLr300pDtP/74I1566aVOXgXw9ddfh91XWFgYcQKkcI4++uiw+3744Qfed2cwS37WkOUxNySCuUky69YBlZXh96sqUFHhOS4Cu+YmqYu7Xbt2hd33/PPPY8OGDVGdZ8WKFRgzZgw+++wzo5pGXkVFQEEBMGkScMklnu8FBVGPlybz3HvvvejSpUvI9vnz56Otra1T566rqwu7b8iQIULnHDp0aMT9e/bsETovERERxVF1tbHH2UxSr3O3d+9ew861e/dunHvuufjiiy8wePBgw84bF4oCeP/j6nbDUV8P7N4NmD3z5/vvA9dcE9qtXlXlGS/9/PPAOeeY07ZwevcGbHbjbawUFhbiN7/5DZ588smA7eXl5Xj22Wdxww03CJ+7vr4+7L6MjAyhc3bU21dfX4/+/fsLnZuIiIjiJC/P2ONsJqmLO5fLFfWxPXr0gMPhwL59+8IeU1dXh+uuuw6rVq0Ke0xLS0vA8C7vpBButxvuQ8MNJUmCLMtQFCWgKzjcdlmWIUlS2O3uoGGM3nuhfGOId++G41DAHQCGRfpBWIH3Gq++2tx2aHBXV0Pq2zc271MH2x0OB1RVNXRsuKqqcLvdmtmLNEzBu++2227DkiVLcCBoAdG//OUvuPzyy9G9e/eQ69Y6l/81SZIUcTKVbt26BZwz2r9P3bp1i9iOhoYGAIjJ++RtS7jt0X4WxOwzIgbXBAD9+/ePmDG7XVMivk9WuyZVVQNykwjXlIjvkxWvyZsbVVUT5pqCt/OaDm0fNw7ygAFAVRW0pkJRJQmS0wn1lFOgRPj/gjc3XmZeU0f/V/KX1MVdNFOb/vKXv8STTz7pm/3v559/xty5c7Fy5UrN4z/88EP897//xcknn6y5/4EHHsD8+fNDtpeWliI9PR0AkJmZiby8PNTW1gYUoDk5OcjJyUFVVRWam5t923Nzc5GVlYVt27YFrPvldDqRnp6O0tLSgMAUFhYiJSUFxcXFAABHfb31CzqbKCsrQ6+UlJi8T17Dhg1De3s7ysvLfdtkWcbw4cPR3NyM2tpaw66nsbERxcXFmtkLLtj87d+/3/d95syZ+Oc//xmwv7q6GvPnz8c111wTdp1Jr+bmZlT6jZ1PTU2N2MvmcrkCfmbR/n0qLS2N2A7vEFOj3qfgaxo8eDBcLhdqamp829PS0pCfn4/6+vqAoajx/oyIxTXt3bs34a4pEd8nXhOvidfEa7LjNWVfcAH6LlqEYKp35stFi+BqarLNNYWbAFKLpNrtLkED3XrrrXj44YfD7u/bty9++ukn9OrVK2B7W1sbRo8ejR9++EHzeTfffDMWLFiguU+r584bJO9wMjN77qhzrNBzt2TJElxzzTWGXM/ll1+Of/7zn5rZmzx5Mj799FPN55WVlaGwsBButxv19fUYOnRoSG9b7969UVxcjE2bNuG0007TPM8VV1yBJUuWhPy28Mwzz8RHH32k+ZzTTjst4Jcv0f59Wrp0KS6//PKwP4vKykoMGDCAvxk16Jra2tpQWlqKwYMHw+FwJMQ1JeL7ZLVramtrQ1lZmS83iXBNifg+We2a2tvbfbnp0qVLQlxTIr5PRl6T9MgjkG+9FcFUpxPqwoWQZ8zo8JrcbjfKysowZMgQdOnSxdRramxsRHZ2NlwuV4e3nyR1z12kda0Az1pZwYUd4PkN/vXXX48bb7xR83nrIsy+07VrV3Tt2jVku/cfKX/hehb1bg8+b8h2s++tSyAOh8N3z53h71MU2/2HvGkZNGgQtm3bFnZ/R/zPLUnh133x7nM4HOjTpw9uvvlm3HPPPQHH7NmzB4sXL8bEiRMjvqYkSSHXmpOTE/b4srIyzZ9NR+9HWVlZxHZ4X9Oo90nPdqM+C2KdPZFrCv7sS4RritV2XtPh7f65SZRr8sdrMvaa/HPj/+9TtG0Pt53vk4Wv6YsvAndMmQLceSek8eMhdfDZEdwW72MzryncPi1JXdwNGDAg4v7jjz8+7L5f/vKXYfdV2232nd69gUMzh3p/S+H9rahp3G5gzBjPTEZancuS5LkR9quvrFWc9u5tdgssad68eXjsscdCZrl89NFHcdRRR+k+3zHHHINXX31Vc593+IJ3mHO0tmzZEnbfiBEjNH8pQ0RERBajqkDwjPeXXQZ08MvkRJHUxd2xxx4bcX/vCP9Rj7TPf9ytLcgy0KeP589uN9wNDZ7HZhdNjz3mmRVTkgILPG+P0WOPAbm55rSNdOnZsyf+9Kc/4Y9//GPA9n379uHBBx/Ufb5IvX2qqmLlypWYMWNG1OdrbW0NO8yzo9cjIiIiC9m+HfC7lw4AcNJJ5rTFBEk9Z/uoUaMizpDnfxNksEgLGkcaMmZ1siyjsLAw4tC+uJk2DVi+HAjuYXU6PdunTTOnXSTk97//vWZv+caNG3Wfa+zYsREnVXn55Zd1ne/dd9+NOHvupEmTdJ2POmapzxqyDeaGRDA3SSZ43enevYFh+qcOtGtu7NVag6WkpGDy5Mlh90e6B8d/hqFgHQ33tLqUFAt16E6bBmzbBqxZAyxd6vleXs7Czoa6deuGu+66y5BzpaSkRJw05p133sHnn38e1bna29sjtisvLw9Tp07V3UbqmKU+a8g2mBsSwdwkkeDi7sQTD4/60smOuUnq4g4ArrzyyrD73nvvPaF9U6ZM6UyTTKUoCoqLi0Nm7DGVw+EZJz1zpue72cNFSdjVV1+NIUOGGHKum2++2bc8gZZLL70Uuw7dSxrJjTfeiJ9++ins/nnz5vF+uxiw5GcNWR5zQyKYmyQTXNwJDsm0a26Svrg799xzkRvmvq0PPvhAc9KGTz/9FEuWLNF8jiRJOO+884xsIlHC6NKlC+69915DzuV0OjFnzpyw+0tLSzF+/Hh8ETxj1iF79+7FZZddhn/84x9hz1FYWIjrrruu020lIiKiODhwANi8OXBbEt1vByT5hCqAZ2mChQsXYubMmZr7L7nkEixduhSnnnoqHA4HvvzyS7zxxhtob2/XPP7CCy/EkUceGcsmE9naJZdcgoceegjfffddp891//33Y8OGDdgQPCvWIVu3bsWJJ56IE088EZMmTUK/fv3Q2NiI7777Du+//75vsXUt3bp1w5tvvhnx3j4iIiKykI0bAf//o8syEGH2+0SU9MUdAFx88cVYtmwZ3n333ZB9qqrivffeizgM0ys3Nxd/+9vfYtFEooQhyzL+/Oc/4/zzz+/0ubp06YI33ngDEyZMQElJSdjjPv/886jvwQM8Y+yff/75DmfUJSIiIgsJHpJ59NGAzqWR7C7ph2V6LVu2LOLkKh3JzMzE+++/j/z8fANbFX+yLGPYsGG2mxmI7OW8886LuFakHv3798cXX3xh2L2uvXv3xqpVq3DJJZcYcj7Sxs8aEsHckAjmJokYdL8dYN/c2Ku1MdSjRw+89957uOaaayDpnFFn7Nix2LRpE8aMGROj1sVXuCGnREb661//ati5srOzsXLlSixYsAB9+/YVOofD4cCsWbOwceNGLn0QJ/ysIRHMDYlgbpKA1uLlnbzfzo65YXHnp0ePHnjuuefw2Wef4fzzz0ePHj3CHutwOHDyySfj9ddfxxdffIHBgwfHsaWxoygKysvLbTczENnP6aefbuji4CkpKbj55ptRXl6OxYsXY/LkyRHXsfQaOXIkZs+eje+//x4vv/wyCgoKDGsThcfPGhLB3JAI5iZJlJcDwbNkd6K4s2tuJFVVVbMbYVUHDhzAZ599hsrKStTW1kJVVWRnZyM/Px8nnXQSMjIyOv0ajY2NyMzMhMvlMuR8neV2u1FcXIxhw4bBwSUHKEpWzc3BgwexceNG7Ny5E3v27MHevXvRo0cP9O7dGzk5OTjmmGPQv39/s5uZlKyaGbI25oZEMDdJ4pVXgEsvPfw4J8dT7AmucWel3OipFzihSgTdu3fv1H14RGSubt264ZRTTjG7GURERBRrWvfbCRZ2dsZhmRTCbjeOkjUwN6QXM0MimBsSwdwkAQMnU/GyY244LNNkVhuWSURERERkK83NQGYm4HYf3rZ2LTBhgmlNMpKeesF+5SjFlKqqaGpqAmt+0oO5Ib2YGRLB3JAI5iYJbNwYWNg5HMDYsZ06pV1zw+KOAiiKgsrKStvNDETmYm5IL2aGRDA3JIK5SQLBQzKPOQZIS+vUKe2aGxZ3RERERERkXwavb2dnLO6IiIiIiMieVDUmk6nYFYs7CiBJElJTUyEl4dSxJI65Ib2YGRLB3JAI5ibBlZYCdXWB2wwo7uyaG86WaTLOlklEREREJOill4DLLz/8uG9foKYmoda442yZJExVVTQ0NNhuZiAyF3NDejEzJIK5IRHMTQJzu4HlywO3GbR4uV1zw+KOAiiKgpqaGtvNDETmYm5IL2aGRDA3JIK5SVBFRUBBAfDuu4HbDRoJZ9fcsLgjIiIiIiL7KCoCZswAKitD9730kmd/kmJxR0RERERE9uB2A3PmeGbJ1CJJwNy5gYuaJxEWdxRAkiSkpaXZbmYgMhdzQ3oxMySCuSERzE2CWbdOu8fOS1WBigrPcZ1g19ykmN0AshZZlpGfn292M8hmmBvSi5khEcwNiWBuEkx1tbHHhWHX3LDnjgIoioK6ujrb3TxK5mJuSC9mhkQwNySCuUkweXnGHheGXXPD4o4CqKqKuro62037SuZibkgvZoZEMDckgrlJMOPHA05n+P2SBOTne47rBLvmhsUdERERERHZg8MBLF6svc97f9yiRZ7jkhCLOyIiIiIiso9p07SHXTqdnkXNp02Lf5ssghOqUABJkpCZmWm7mYHIXMwN6cXMkAjmhkQwNwlo27bQCVP+8Q/g2msN67Gza24k1W4DSRNMY2MjMjMz4XK5kJGRYXZziIiIiIis7emngeuuO/w4JweorQXkxByUqKdeSMyfAAlTFAXV1dW2mxmIzMXckF7MDIlgbkgEc5OAPvgg8PHppxte2Nk1NyzuKICqqnC5XLabGYjMxdyQXswMiWBuSARzk2Da24GPPw7cduaZhr+MXXPD4o6IiIiIiOzhiy+AxsbAbWecYU5bLIjFHRERERER2UPwkMyjj+70guWJhMUdBZAkCTk5ObabGYjMxdyQXswMiWBuSARzk2CCi7sY9drZNTdcCoECyLKMnJwcs5tBNsPckF7MDIlgbkgEc5NA6uuBL78M3BaD++0A++bG1J67gwcPoqamBgcPHjSzGeRHURRUVFTYbmYgMhdzQ3oxMySCuSERzE0C+egjwH+Ck+7dgVNOiclL2TU3ceu5c7vdWLFiBVatWoWPP/4YO3bswP79+337u3fvjoEDB2LKlCk488wz8atf/QoOgxYhpOipqorm5mbbzQxE5mJuSC9mhkQwNySCuUkgwUMyJ04EunWLyUvZNTdxKe6WLVuGu+++G2VlZQCg+UPav38/fvrpJ/z888948sknUVhYiPnz52PWrFnxaCIREREREVmVqoYWdzEakmlnMR2WeeDAAUydOhWXXnopSktLoaqqr7CTJEnzy3tMWVkZLr/8cpxzzjlobm6OZTOJiIiIiMjKfvgBqKoK3MYlEELErLhraGjAqaeeivfffx+qqoYUcQB8hZx/T15wobdixQpMmDABe/fujVVTyY8sy8jNzYUscyJVih5zQ3oxMySCuSERzE2CWLUq8HF+PjBiRMxezq65iVlrr776anz11VcAoFnMBQ/N1NrnLfC+/vprXHXVVbFqKvmRJAlZWVm2m/aVzMXckF7MDIlgbkgEc5MgtIZkxvA9tWtuYlLcPf3003j77bdDijo9vM/xFnjvvfcennrqqVg0l/woioKysjLbzQxE5mJuSC9mhkQwNySCuUkABw4An3wSuC3G99vZNTeGF3dtbW247777Agq7YOHutwtXGXsLvL/85S9ob283usnkR1VVtLa22m5mIDIXc0N6MTMkgrkhEcxNAli3DvBfOk2WgSlTYvqSds2N4cXdq6++iurqagChhV24++20Jlrx8j9HTU0Nli5danSTiYiIiIjIitxu4LnnAredcALQq5c57bE4w5dCePnllzW3e3vfAGDEiBEYM2YM+vfvj7S0NDQ3N2Pnzp3YtGkTfvzxx5Djg89/+eWXG91sIiIiIiKykqIiYM4coLIycHt+vjntsQFJNbCvUVEU9OrVC01NTQAQcM8cAJxzzjm4//778Ytf/CLsOb7//nvcfvvteO+993zP9e/t69mzJxoaGmx3c2M4jY2NyMzMhMvlQkZGhtnN8S3YmJaWljA/Y4o95ob0YmZIBHNDIpgbmyoqAmbM8Kxvp+XNN4Fp02L28lbKjZ56wdBhmVu2bMG+ffsABBZ2kiRh7ty5ePfddyMWdgBw5JFH4p133sG8efNCikMA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ikvyjJA3165dE3feeafD25rWrVuLoqIijT45z6X3nJkxY4am+6hNmzZp+Ol5rnnz5mn6vcyYMcPqehzZf9RWbivhPXc6lpycjO+//172Bl859erVw8qVK5GYmKhxZH/o1asX5s+fDy8vdakUHh6O//73v5JHVsh+Rsgb0h/mDalhhLzx8fHBTz/9hKSkJNV9NGvWDD/88AOCgoI0jMwz6T1npk2bhn79+mnS1+uvv460tDRN+iL900tus7jTue7du2PNmjVo2bKlXcu1atUKa9euRdeuXZ0U2R+GDRuGb7/9Fk2aNLFrubvuuguZmZn8MegERsgb0h/mDalhhLwJDw/H+vXr8dBDD9m9bO/evbF7924O+qMhPeeMn58fli5digkTJth1i8DNGjZsiLlz50peDkzuSxe57dB5P6o1FRUVYtasWSIpKUn2dG6bNm3ErFmzREVFhc19S/Vl72VSxcXF4sUXXxSxsbGSfZpMJnHXXXeJf//738JsNtv5KZC99Jg3cnGomXhZpvb0mDf24GWZrmGUvPnxxx9Fr169hJ+fn2S/fn5+olevXmL16tV290+203vOZGVlifHjx4uIiAib9kcJCQni1VdfFbm5uSo+DZJjhMsyb+bM3FbCAVUM6Pjx49i/fz9yc3NRUFCA4OBgREZGIjk5GbGxsa4ODwBw4MABHD58GLm5uSguLkZoaCgiIyORmprKZwS5iBHyhvSHeUNqGCFviouLsW3bNmRnZ+PChQvw9vZGSEgImjdvjo4dO6q+tIrU0XvOnD59Gvv378f58+dRXFyM8vJyBAQEICgoCLfddhtSUlIQHh7u6jBJh2o7t1ncERERERERuQHec0dEREREROQGWNwRERERERG5ARZ3REREREREboDFHRERERERkRtgcUdEREREROQGWNwRERERERG5ARZ3REREREREboDFHRERERERkRtgcUdEREREROQGWNwRERERERG5ARZ3REREREREboDFHRERERERkRtgcUdERIY2f/58mEwmySkmJsbVIbrMyJEjZT+bkSNHujpEIs1169ZNNu9feeUVV4dI5DQs7ogMSulHm8lkQmZmpqvDJCIiKB+EkJp8fHzQsGFDNG3aFElJSRg4cCCmTZuGFStW4MqVK65+W0SkMz6uDoCICADmzJmDwsJCyfYBAwYgJSWl1uIhqk2ZmZmyB2NiYmJ4ls1Dmc1mFBUVoaioCNnZ2Thw4MCNNn9/f/zpT39Ceno6mjdv7sIo1Vm+fDn27t0r2Z6SkoIBAwbUWjxE7oDFHRHpwpw5c3D69GnJ9piYGBZ35LYyMzORnp4u2d61a1cWd1TD5cuX8eWXX2LRokV466238Mwzz7g6JLssX74c//nPfyTbR4wYweKOyE68LJOIiIjIwK5evYqJEyfijTfecHUoRORiLO6IiIiI3MDLL7+MrKwsV4dBRC7EyzKJiIiIdKBx48Zo0qTJjX9XVlaisLAQZ86cgRBCcfnKykqkp6djyZIlzgyTiHSMxR0REZGbmj9/PubPn+/qMMhGTz75pNVh+ouKipCRkYFp06ahqKhIto+ffvoJFRUVqFOnjpOi1D+OFE2ejJdlEhEREelYgwYNMHbsWHz33XeK85aVlfHSTCIPxjN3RGS3/Px8bN++HdnZ2cjLy0NQUBAiIyPRuXNnREREuDo8u5w+fRpZWVnIz8/HpUuXcPnyZTRs2BChoaGIjo5GamoqfH19azWmiooKbN++HYcOHUJBQQGuXbuG+vXr44knnkBISIhDfQshsG/fPuzbtw+5ubkQQqBx48Zo0aIF7r77bnh7e2v0Lv6Qk5ODPXv2IC8vD5cuXUJJSQmCgoIQEhKCsLAwpKamIiwsTPP1OsJsNuP06dM4e/YssrOzkZ+fjytXrqC8vBx+fn4IDAxEYGAgmjVrhuTkZIe/F6MqLy/H7t27cfbsWRQUFODSpUvw9fVFSEgIQkJC0KpVKyQkJMBkMtVqXGazGdu3b8epU6eQnZ0NLy8vhIeHIzk5GW3btq31eLTStWtXdOzYEdu3b5edLzc3V1X/165dw8mTJ3Hu3DlkZ2fj0qVLN/K+Xr16N/I+JiYGSUlJCAwMVLUeoystLcXOnTuRk5ODgoICFBYWom7dujfyvk2bNmjRooWrwyRPJYjIkEaMGCEAyE4bNmyQ7WPevHmyy0dHR1ebf/ny5aJ3797Cx8fH6vwmk0l07NhRrFmzRjF+pdjtnW6NVU5mZqYYMmSIaNq0qWK//v7+okePHmLhwoWisrLS5nXY+j5v/o4uXLggnn76aREYGGh13j179lTrWykHRowYcWPe0tJSkZ6eLpo0aSI5f1hYmBg3bpy4ePGi3e/zVnv37hWjR48WsbGxNn1/rVq1EuPGjRNHjhyxe1325rE1WVlZ4sMPPxTDhg0TSUlJok6dOnblX7NmzcSYMWPEtm3bbIrZlr9feydrf+/25IitLl26JN566y1x9913Cz8/P8W4QkJCxAMPPCCWLVsmzGaz3euz530fP35cjBkzRoSHh0vO36hRI/HGG2+IsrIyu2NxhFKeAhAzZsxQ7GfcuHGK/WRkZNgU0y+//CLeffddMWjQIJGQkCC5bbc2mUwmERsbKyZPniz2799v0/q6du2qed6fPHnS7vXY8jnfKjs7W0yfPl3ccccdwtvbWzGuxo0bi8GDB4v169fbvS4iR7C4IzKo2izucnJyRJ8+feza4U6cOFFYLBbJdWu9g7flB/yGDRvEnXfeqXodzZs3F8uWLbP9S7LhfVZ9Rxs3bhSNGjWSnVdtcbd161YRFRVl8/sMCQkRixYtsut9Vjlw4IDo3r276s/YZDKJBx98UJw6dcrmdWpR3LVq1UqzXOzevbs4fvy47PqMWNxduXJFTJo0SQQEBKiOMS4uTixevNjmdQph29+QxWIRs2bNsqnYrJoSExPF77//blcsjtCquHvxxRcV+1mxYoVNMdl7EENuevTRR0Vubq7s+oxY3BUUFIg///nPduXWrVNKSori/phIK7znjohkHTp0CHfddRd++uknu5Z777338OKLLzopKvuYzWa89NJLuO+++7B7927V/Zw8eRIPP/wwnnnmGVy7dk2z+DZt2oTevXvjwoULmvVZZdWqVejevTt+//13m5cpKCjA448/jrlz59q1rn//+99o37491q9fb2+YNwghsGLFCqSkpODbb79V3Y8rrV+/HklJSdi6daurQ9HMwYMH0b59e7z99tsoKytT3c+xY8cwaNAg/PWvf8WVK1c0ia2yshJDhw7FlClTcPXqVZuX++2333Dvvfc69H5cobCwUHGeuLg45wdyi2+++QZJSUk4evRora/bWbZs2YKUlBR8/vnnduXWrfbu3Yv77rsPM2bMgNls1jBCoppY3BGRpKKiInTv3h1nzpxRtfxbb72FHTt2aByV/UaOHInXXnsNFotFk/7ef/99jBo1SpO+zp8/j4EDB6K8vFyT/m62f/9+PPLII6r6tlgsePLJJ/HDDz/YNP+sWbM0/cFeWFiIRx55BAsXLtSkv9p2+fJlPPjggzhx4oSrQ3HY4cOH0blzZxw4cECzPv/973/jkUce0eSH7tNPP606T44dO4apU6c6HENtUtqmhoeHIyEhoZaiqe7ChQvo06cPLl265JL1a+nnn3/Gfffdp3r/dyuLxYKZM2fib3/7myb9EUlhcUdEkgoLC5GTk6N6eYvFgtmzZ2sYkf2mT5+OBQsWaN7vl19+aXXIcntNnjwZ+fn5jgdkxZ49exwqtoQQ+Mtf/qIY3+LFi/H888+rXo/c+p944gls3rxZ875rQ35+PqZPn+7qMBxy8eJF3H///U75sb5q1So8/fTTDvdz6NAhh5b/7LPPnPY3qLV169bh119/lZ1n5MiRLh0w5sSJEy7f7jvqf//7HwYMGICKigrN+/7kk08M//mQvnG0TCKyibe3Nx5++GH07NkToaGhOHXqFD7//HMcPHhQdrnly5ejsLAQDRs2rPZ6ampqtX9nZWXJXvYSExOD0NBQyfabH/xbZc+ePXj99ddl4wOAdu3aoX///oiKikJwcDAuXLiAzZs3Y8mSJbJnvf7+979j6NChiI+PV1yHlHPnzqle1h7NmjXDsGHD0KZNG/j6+uLYsWP4+uuvFYdMz8nJwauvvoo5c+ZYbS8uLsaYMWMUH7Bct25dDB48GGlpaQgODkZeXh42bNiAJUuWoLKyUnK5iooKjB49GgcOHHDKSJ7W1K9fHx06dEDLli0RFxeHkJAQBAQEwM/PD+Xl5bh48SKOHDmCtWvX4siRI7J9LVq0CDNnzqxxmVzz5s2r/Q1kZ2fj/PnzsjG1atVKdl3OGLlw2rRpOHnypOJ899xzDwYMGICYmBiUl5cjKysLGRkZivn9r3/9C0OGDME999yjSbzJycl47LHHEBcXh8uXL+OHH37AkiVLZPOzvLwcCxcuxLhx4zSJwRmKioqwYMECTJs2TXa+Ro0aqT7QEhISgrvuugvx8fGIjY1Fw4YNERAQAF9fX1y5cgW5ubn47bff8NNPPyle5v3Pf/4TU6dORYMGDaq93qpVK5SWlt7496lTp2QL69DQUMTExMiuyxnP8/vb3/6GgoICxfn69OmD+++/H02aNEFZWRl+/fVXfPXVV4rLvvjii3jkkUfQvHlzrUIm+oNL7/gjItVqY0CVqik8PFzs2LGjxvIVFRVi4MCBisvbMnpmdHS0bB/z5s2z+zPq2bOnbJ9RUVFi8+bNksufPHlStGnTRraPQYMGycZgy+d78xQXFydGjBghpk6dKsaPHy8efvhhERcXJwD7B1Spmh599FGrIwOazWabBmcIDAwURUVFVt/fSy+9pLh8q1atJAcY2bt3r2jcuLFiH3PnzpX8jLUYUKVz585iwoQJYtu2beLatWuK81f56quvhK+vr+z633//fcV+ZsyYIdtH165dbY7pZo4MqHLkyBHF0RO9vb3F/PnzrS5fWloqBg0apPjdpqWlyb4HW/920tPTrY7G+c033wiTySS77JAhQ+z6XNWwZXvbuHFjkZqaemNKSUkRMTExivED10f23bJli10xxcXFienTp4s9e/bIDoB1M7PZLN555x3FeL777jvFvpwxmqsQjg2osm7dOsX3FhAQIFavXm11+YsXL4ouXboo9jFs2DBV741ICYs7IoOqreLOy8tLbN26VbKPnJwcxWGhZ82apfh+tC7uDh06JNufj4+POHDggGI/R48eFV5eXpL9+Pr6ShY+Qtj+wzQuLk62CD548KDIz8+v9potOZCSkqJYrDzyyCOK/Xz66ac1ljObzSIsLEzxB+eJEydk1//LL7/IfsYAxB133CG5vBbFna0/bK0ZP3687PoHDhyo2Icei7tnn31WMS/eeust2fVfu3ZNpKSkKPazb98+yT5s+ft56qmnZOPo37+/7PKtW7eWXV4Lth5MUzO1bNmyxsEfWziS9w888IBsTM8++6xiH3os7mw5YKk0mnBRUZHsY2eA6wdGCgoKVL0/Ijm8546IZA0ePBh33323ZHtERARatmwp28fFixe1DkvRjz/+KNs+YMAAJCYmKvYTFxeH5ORkyfZr167hv//9r93x3Sw+Ph7btm1Dz549Jee5/fbbVT0oOz09HT4+8lfgv/rqq4r9bNq0qcZru3btQl5enuxyf/3rXxUvPbrrrrswYMAA2Xn27t3r1Dxy5B6ltm3byrY7ek+YqyiNkBsREYGJEyfKzuPj44OZM2cqrmvNmjV2xXYzf39/vPHGG7LzpKWlyba7YhulhcTERHz44Yc4cOAAUlJS7F6eeV9dZWUl1q1bJzvPnXfeiUcffVR2nqCgIMXLY81ms+K6iNRgcUdEsoYPH644T1RUlGy7LUN3a02p4FqyZAlMJpNN0969e2X72rZtm0Oxzp8/H2FhYQ71YU1AQAD69u2rOF9CQoJioWttWH9bHnkwePBgxXkAKP5YEkI49IgFexQUFODrr7/G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",
      "text/plain": [
       "<Figure size 900x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_interpolation_curves(fid_by_t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch, numpy as np, matplotlib.pyplot as plt\n",
    "\n",
    "def plot_avg_l2_loss_by_family(\n",
    "    models: dict[str, torch.nn.Module],\n",
    "    dataset1_raw, dataset2_raw,\n",
    "    train_families: list[str], unseen_families: list[str],\n",
    "    device: torch.device = torch.device(\"cpu\")\n",
    "):\n",
    "    # ── 0. abbreviations for tick labels ───────────────────────────────\n",
    "    abbr = {\n",
    "        \"sine_beats\":       \"s_b\",\n",
    "        \"chirped_cosine\":   \"c_c\",\n",
    "        \"periodic\":         \"p\",\n",
    "        \"wave_packet\":      \"w_p\",\n",
    "        \"sinc_pulse\":       \"s_p\",\n",
    "        \"gaussian_hermite\": \"g_h\",\n",
    "    }\n",
    "\n",
    "    # ── 1. font sizes (MUCH larger & bold) ─────────────────────────────\n",
    "    label_fs, tick_fs, legend_fs = 34, 28, 28      # << bumped up\n",
    "    bold = {\"fontweight\": \"bold\"}\n",
    "\n",
    "    # ── 2. helper conversions -----------------------------------------\n",
    "    def ensure_dict(ds):\n",
    "        return ds if (ds and isinstance(ds[0], dict)) else convert_dataset_for_fno(ds)\n",
    "\n",
    "    def group(ds):\n",
    "        g = {}\n",
    "        for s in ds:\n",
    "            g.setdefault(s[\"func_type\"], []).append(s)\n",
    "        return g\n",
    "\n",
    "    g1, g2 = group(ensure_dict(dataset1_raw)), group(ensure_dict(dataset2_raw))\n",
    "\n",
    "    # ── 3. x-positions -------------------------------------------------\n",
    "    x_train  = np.arange(len(train_families))\n",
    "    x_unseen = len(train_families) + np.arange(len(unseen_families))\n",
    "    xs       = np.concatenate([x_train, x_unseen])\n",
    "\n",
    "    # ── 4. figure & axes ----------------------------------------------\n",
    "    fig, ax = plt.subplots(figsize=(11, 7))\n",
    "    ax.set_ylabel(r\"Re-$\\ell_{2}$ Loss\", fontsize=label_fs, **bold)\n",
    "    ax.grid(True, linestyle=\"--\", alpha=.5)\n",
    "    ax.axvspan(x_unseen[0]-0.5, x_unseen[-1]+0.5,\n",
    "               color=\"lightgrey\", alpha=.3, label=\"Unseen\")\n",
    "\n",
    "    # ── 5. colour map & curves ----------------------------------------\n",
    "    color_map = {\"FNO\": \"red\", \"KANO\": \"blue\", \"KANO_symbolic\": \"green\"}\n",
    "\n",
    "    for name, model in models.items():\n",
    "        is_fno  = \"fno\" in name.lower()\n",
    "        loss_fn = compute_average_loss_fno if is_fno else compute_average_loss_kano\n",
    "\n",
    "        losses_tr = [loss_fn(g1.get(f, []), model, device) for f in train_families]\n",
    "        losses_un = [loss_fn(g2.get(f, []), model, device) for f in unseen_families]\n",
    "\n",
    "        label = \"KANO\" if name.lower().startswith(\"kano_numeric\") else name\n",
    "        ax.plot(xs, np.r_[losses_tr, losses_un],\n",
    "                marker='o', linewidth=3.0,\n",
    "                color=color_map.get(label, \"black\"),\n",
    "                label=label)\n",
    "\n",
    "    # ── 6. x-tick labels (abbr., large & bold) ------------------------\n",
    "    ax.set_xticks(xs)\n",
    "    ax.set_xticklabels(\n",
    "        [abbr.get(f, f) for f in train_families + unseen_families],\n",
    "        rotation=0, ha=\"right\",\n",
    "        fontsize=tick_fs, **bold)\n",
    "\n",
    "    # y-tick labels\n",
    "    for t in ax.get_yticklabels():\n",
    "        t.set_fontsize(tick_fs)\n",
    "        t.set_fontweight(\"bold\")\n",
    "\n",
    "    # ── 7. legend (upper-left, big & bold) ----------------------------\n",
    "    lg = ax.legend(loc=\"upper left\", fontsize=legend_fs, frameon=False,\n",
    "                   prop={\"weight\": \"bold\"})\n",
    "    for txt in lg.get_texts():\n",
    "        if txt.get_text() in {\"KANO\", \"FNO\", \"Unseen\"}:\n",
    "            txt.set_fontsize(legend_fs + 6)\n",
    "            txt.set_fontweight(\"bold\")\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ie6u5OjSpQuSk5OdLq+srMQHH3zgVwzeev3113H48OGAHqOwsNCjW5Huuusul69L9nn0v//9z6Mr1p544gm304VTdFHjNYkikye351FkEY4fh/abb2zG/L0KRK08khs2RNXixZCtvgASZBmGm2+GcPKkKjGRf/iaFB1YBPnbpEmTnF4NkpOTg86dO+Puu+/G/Pnzcffdd6Nz585O75Xv168fbrjhBsVjnD17Nlq1auVw2ebNm3HeeefhgQcewPz58zFjxgz07NnT6aX6EydOxCWXXOLyeM899xzS0tIc/jhz/Phxp9u8//77Dre59dZbUVVV5XSfBw4cQKdOnZzu1/4nEhumiqKI1q1bB61bdXV1NUaNGoXVq1e7Xff222/H66+/7ndsRqMR7733nst1Jk6ciFGjRrlcZ7Hdt0uBZjQaMXfu3IAe44033kBNTY3LddLS0vDvf//b5Tr2eSQIAl588UXExsa63K6wsNCjYhhFj2C/JlFkEkURGRkZzKMoo3/nHduGqA0awOTHeze188jSqxdqHnvMNqaiIhimTWN/kDCjdi5R8Ph+3XqEEQQBCxcuxMUXX+zw9pG//voL8+fPd7ufhIQELFiwICDfjhkMBixcuBDDhg2DxWKpt/zEiRN45pln3O4nLS0Nzz33nNv1ysvLXU6v64gkSU63cVbocNdY78yZM17F4OyWmnAmyzJKS0uRlJQU8G9eKyoqcPXVV3vUZPS+++7Ds88+q8hxV69e7fa5GzduHP7880+XV4z8+OOPOHDgALKzsxWJy5per3d4RcT777+P2bNnu2xg7I+VK1e6XeeOO+5wOZU24DiPWrVqhfHjx+Ptt992ue0HH3yACRMmeB40RbRgviZR5KqdZSghIYF5FC3MZuiWLbMZMl13HRAf7/MuQyGPjLffDs2WLdB99VXdmPbHHxHzn/+g5v/+T5WYyHuhkEsUHCxzWenatavP03oC54oUa9asQadOnRSO7B+XX345lixZ4nOFsnHjxvj222/RtGlThSOjQJIkCQUFBQGfieHs2bMYOnSoRwWQuXPnKlYAAdzfCnPRRRchKysLl112GRo1auTXvnzl7DY3WZZx//33B+SYx48fx++//+52PU+uPnOWR+PHj3e77TfffONRU1aKDsF6TaLIJssyioqKOBNDFNGuXQvR7jYRf2+FCYk8EgRUvfYa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",
      "text/plain": [
       "<Figure size 1100x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "models = {\n",
    "    \"KANO\": kano_numeric,\n",
    "    \"FNO\": fno,\n",
    "}\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "sample_fams  = ['sine_beats','chirped_cosine','periodic']\n",
    "test_fams = ['wave_packet','sinc_pulse','gaussian_hermite']\n",
    "\n",
    "plot_avg_l2_loss_by_family(\n",
    "    models,\n",
    "    sample_data,\n",
    "    test_data,\n",
    "    train_families=sample_fams,\n",
    "    unseen_families=test_fams,\n",
    "    device=device\n",
    ")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "kano",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
