{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c848fe94",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cwd: /home/thorben/Documents/generative-diffusion-bridges/code/example-2_mnist-sdf\n",
      "project root added: /home/thorben/Documents/generative-diffusion-bridges/code\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x707ca211c9f0>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dependencies\n",
    "import numpy as np\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import pickle\n",
    "import gc\n",
    "import copy\n",
    "import scipy.ndimage\n",
    "from scipy import linalg\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torchvision\n",
    "from torchvision import transforms\n",
    "from torchvision.transforms.functional import InterpolationMode\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader,Subset\n",
    "from torchmetrics.image.fid import FrechetInceptionDistance\n",
    "from types import SimpleNamespace\n",
    "import dnnlib\n",
    "\n",
    "\n",
    "import sys\n",
    "from pathlib import Path\n",
    "PROJECT_ROOT = Path.cwd().resolve().parent  # root/training -> root\n",
    "DATA_DIR = PROJECT_ROOT / \"data\"\n",
    "sys.path.insert(0, str(PROJECT_ROOT))\n",
    "print(\"cwd:\", Path.cwd().resolve())\n",
    "print(\"project root added:\", PROJECT_ROOT)\n",
    "\n",
    "\n",
    "\n",
    "from models.fourier_unet import FNOUNet2d\n",
    "from utils.aliasfree_dct import Upsample2d\n",
    "import utils.mnist_sdf as mnist_sdf\n",
    "from utils.mnist_sdf import MNISTSDFDataset\n",
    "from utils import torch_dct  \n",
    "from utils.gaussian_noise import matern_eigs_2d\n",
    "from utils.misc import make_v_grid, make_time_grid\n",
    "from utils.vis_funcs import vis_sdf, vis_mask\n",
    "from utils.emp_cov import per_mode_dct_mean_var\n",
    "\n",
    "\n",
    "\n",
    "from utils.forced_diffusions import noising, compute_loss, sample_forced_diffusion, sample_forced_diffusion_strang, sample_forced_diffusion_trotter\n",
    "\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "device = torch.device(\"cuda\")\n",
    "torch.device(device)\n",
    "\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"savefig.format\": \"pdf\",\n",
    "    \"savefig.bbox\": \"tight\",\n",
    "    \"pdf.fonttype\": 42,\n",
    "    \"ps.fonttype\": 42,\n",
    "})\n",
    "\n",
    "torch.manual_seed(67)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "43993d69",
   "metadata": {},
   "source": [
    "# 0. Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f37c8343",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Batch 0\n",
      "  sdf_imgs shape: torch.Size([16, 1, 32, 32])\n",
      "  labels shape:   torch.Size([16])\n",
      "  sdf min/max:    -0.11267347633838654 0.5896238088607788\n",
      "  labels:         [0, 2, 6, 7, 6, 0, 4, 8, 1, 4, 2, 9, 8, 2, 7, 1]\n"
     ]
    }
   ],
   "source": [
    "B = 16\n",
    "size = (32, 32)\n",
    "\n",
    "ds = MNISTSDFDataset(root=\"./data\",train=True,download=True,size=size,return_image=True)\n",
    "loader = DataLoader(ds,batch_size=B,shuffle=True,num_workers=0,drop_last=True)\n",
    "for i, (sdf_imgs, labels) in enumerate(loader):\n",
    "    print(f\"Batch {i}\")\n",
    "    print(\"  sdf_imgs shape:\", sdf_imgs.shape)   # (B, 1, H, W)\n",
    "    print(\"  labels shape:  \", labels.shape)     # (B,)\n",
    "    print(\"  sdf min/max:   \", sdf_imgs.min().item(), sdf_imgs.max().item())\n",
    "    print(\"  labels:        \", labels.tolist())\n",
    "    break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f7466807",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"394.160937pt\" height=\"347.04pt\" viewBox=\"0 0 394.160937 347.04\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2026-01-28T13:20:17.575727</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.10.8, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 347.04 \n",
       "L 394.160937 347.04 \n",
       "L 394.160937 0 \n",
       "L 0 0 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g clip-path=\"url(#p44a25e7ad6)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image80a3548c16\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"7.2\" y=\"-7.528466\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_2\">\n",
       "   <g clip-path=\"url(#p78a6a594fc)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imaged40e47bb56\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"89.321946\" y=\"-7.528466\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_3\">\n",
       "   <g clip-path=\"url(#p3b525f7c81)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image53543c7713\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"171.443891\" y=\"-7.528466\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_4\">\n",
       "   <g clip-path=\"url(#p9594c323c9)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image78d3533bce\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"253.565837\" y=\"-7.528466\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_5\">\n",
       "   <g clip-path=\"url(#p7a946c70a6)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image0cecd235cb\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"7.2\" y=\"-91.690394\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_6\">\n",
       "   <g clip-path=\"url(#p1b40fb1fe0)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image7f72096181\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"89.321946\" y=\"-91.690394\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_7\">\n",
       "   <g clip-path=\"url(#pb7b85f1683)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image86c81ea928\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"171.443891\" y=\"-91.690394\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_8\">\n",
       "   <g clip-path=\"url(#pa2c4719cea)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imageafc47a28ec\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"253.565837\" y=\"-91.690394\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_9\">\n",
       "   <g clip-path=\"url(#pc5910ce939)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagebd2ad9ffb2\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"7.2\" y=\"-175.852321\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_10\">\n",
       "   <g clip-path=\"url(#pe2a7a2bce3)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagedfc70e19c8\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"89.321946\" y=\"-175.852321\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_11\">\n",
       "   <g clip-path=\"url(#p697507394c)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "iVBORw0KGgoAAAANSUhEUgAAAG4AAABuCAYAAADGWyb7AAATwklEQVR4nM2dYXLjOg6EaUXz7n+ZOV1ie3+8hedTuxukHGd2WaWSTUIUiGYDIKU4l9+/f9/v9/sYY4zr9Tput9u4Xq/jfr8/vvOotlnd/X5/1Oln1rHtbH3pXWctVX+5XMb9fj+cV4qTre+Xy+VwbNt2OK+0bdvWyn98fBy+s+yqVB0cdDfQM/IcNA3LdhpY+6M867r+0r1Xirve9eX6pC1Tm7tXkteyV4MbtDOgzjht74xHWZ5p/G3bnsDo5N09f6ro2LWO7KGcsqqTT21adls7xsMl8TvrXbszYCfLeq3r2vR+Ts93lzQp6SFut9vYtu1JPrlslecY6ojAnQGkA9LdtKtfAW2lr6TXO0vH6tSWbLUir6A7+f16vT4ENNnQJMXJdMnJmSRFE5DVpOZvsK2MqZ+dKyxwWF96uSSF8tVWTKw2m5ykmZ+M24GhoP0t4P4G41gISIp7Lm7dbrdW3iUoCnCNby+2jDGeGEamcWmg35WhKqdGdin+bKnQtVX5m4xz6Ts/b9s2rtdrbHN1Y4zHEuF2uz2WA7zvA7gauGOOY4/WJRknvwLIq8z7SfAS4zqWdWycybO9QKTcGIhxY4wImotxbgGeYl5i2aw+Afm/Bk7j0v1+f3KfZXTXxtjl5PUaBfV+vx9jnHN9HdMUZALo3OerbrFmXNf2U+ApaGp4XVsqCCpP2UpCFGSOgcuF6CrPuLsVo88SlVfi2f8DcJ3rKwBYp3KVpLg2vQ/rSTILnNujLGN9fX09sbHb01TGrWSaY2R2Jfka0E+4SmfIy+XPXiKBcC6z2j8+PsYY42k5MMZ49KWukeM5MM65Sp3pKwZcYcY7gXPf/xZw5b4I2IyFlHeMq7oqjHfOm+w1+Or4er2eWnhrjEvMc+x9BezU9pOgVSGDKtvT9F7ruKB28oyDjG+s572jq6RhVhORM4mLi50rcXKF/T8JHNmRskVNWAiIAtPFMGWoJjpPwKlhHYjO+CvAJfkEjlu4z9hZ4/hJ0JI7dOsyB6K2pT5rTGQqPcsBuO8+SF11sauseoWRP1UY31Zcn1u36drPAa0g64R5MI4odoabJSSprevDMeaVpIR1HNw7AXPxTddcpX+KbXSnro3Jy+nkJBnXsSsxrupWGToDWkHlREt9vRs4vk5Q9cUKBSYtFQgcgdF7cBJw0lR/Y4SnAzMAFYiuXutcrHPgzNyhgs0Jwpn5DuBSzOqOknHvlGghiIxnNZY2OanBdgZPh7IqLeC7OKmgJIDTJFOGl5wzFEF17SVDY+/7fjCePrnWnf+SSfFNJxb1YJ8KZum2d8Y6A6K6z+RaU18pZs6YV/1+fX0dAOzA6YzGdro2GpJvZ5UcXZ5LVJR9JAx1YBsZp/o9gOuMl5IBB+6Kq3XuVV2mu7+LYxprCVzHuq5o3FE3RRl1jQRa5VTmdntOQopdvF4n2gO4s67RsUpdYLekOOMy2Ud6WuFkyLoZ4yijTOUeYhn76+vrwKBt28bHx8dh4UzwNGGp++iztjpzXJwwNjl515GYtspgB9wK0G5COIAUvI6NLptjvbpHtrEooM5uHG/6Tt13begAWWHamfjn+jobx8gs7YsAdeB0oCkoTEqY1t9u/75qoK6RLpHLg+qD8Uz3KtUOh6wyIfwK0zrgZm10i4m5nCgu3rn+ZsB1oKnx6x5VX0DxM4HTDJR25pllte1pr/Ks+3MsmQGnG9SuzQGozFNWde75LGg0NllNGb23S/+3bRv7vj+l8zOyOPD4fdebn2UYB5Zc3woLCwznDjtWd25eY6YzgCtpP7JA45lsv1wuh8SFoJVb7NyhjqUDL+5Vrhx6XZeIrDBTU/vUX4qFqo8O2BlGi4tDujjWLLPbGXF6ztxhkmPfS4xLbeoyadj0pIFukDJfX1/jer2Oz8/PB/PUTdE1qovvwGBbF/90F4SguK2rem9SQXVAnGX9rOxnBp0UegVsAswjJS5jHIHjWVNzV9wCWg1Kl0bAeB+Nf3U4VrqD7d8pB8a5suqLKZsSGE1AimVkHJmm/XRFDef0LeCpr9Yp6wqUco2641HX615lybrtsaTzGTAff2aVmKIDXWGWu8aBx4SEmaJjXfWlA3XrLXWLTDDYH+W1bwJWux4EKbGVScnHx8djR0Uf2cxiaJIpnZ5cZQeWKyvgsm8HYOciHeOSW+LAVD9n5ALFZafaL1nmXKRjGQFzjJq59k7GJif6ebWkGKIH3SKZp5ll58p0huvrA5wkVTTFV7ApqwtwnRCU0YnkAPtuTNPytByoz7Myi4up3iUq+tmxNQV7jS0ErkqXsrsssNP57GT+qbK0V+nqq+5sUTa4hboC2bGsYggXunXd5+fn4br6zD1Gp1t9Zpbp5NP4ahyaJL2zLO9VzpQ9o9iZuDjGsOxS8OqRCWMWt6DYj7K4029V1wKq3C2/l3umLq5vp4O7/xjmvcqUUCSjngXMTRJ3/yrqFhNo/E2QYnHnHhNgaXzdpCZItdTRpwhd0uQ8nspUX1V2CrstqaS423aaMc8tQlcyK7dGKhf569evx1kH/86kQMc+xvEtLLUVX3fQPcqu/9VilwMzNqwwpysrBk0Adwyscr1e357FVZmFk+ShOia9UqYxTreoUiKRdku0zJiWFp3q6j4+Psa+72Pf9wcD6bZo6NVS15Gtna5qO64NZ/f9DmhjNMuB1eMds0t9uItHK0fyArPSsZrfKa96ni3f9QhPC/C0n5dA62Kd27JKRuVs7VjnFrYzQ664ZfbDt5V5P/dCLJMQldf+z+rVFft0IBl3FteSO3U7Iu4eutZKhqnEZCXBYVG56q+SCbVFtwTRti72ruh3NpE6ZJXOmDPXN3OvHZidO3MDd4ZaLZwUGsN0x9+5TAUl1SuwZyfYqtypH2HrQJwBx71JfXFVFdc1mgPMGWUlpqmxq3CR7ORLD9XHrSv5dCA9GUjxcyZT44zAKWCz9hXmdaxOynauaXU2u+SHLC4Zt62VEiGdOOnJQKfrDDCVobeYAnemOIATA7vML4HHbS01iA6S92ZRcHRPUcfhgFIm0TNwQ8AxLyVXZ1z/EuO+W1xCsMKQLvvUmTy7H6+rPula67Nbd6rO7F+BI4AKbgKpA9HJVHkLcLOZU0Zz+4eOJWRAyj41djCp0FL3rmurL+4xdtfrfZ17dBsC9BIOxNnSpot/T8B1DEmdO3nu1Y1xXBu5mMZSs5+/M8akwOnr3Nu+7/bxiq4teV+t6+xQ9co43fQmM9XVOhfqAFZsdlVMldQL1GA6GE211UUxCWAfdGEErxihxl/Rh4mHO9IyYKV/fl5JRrolworbtMCRBW6WuU6dkTRDG+P4fn1dw5du3E6NusuqL9ayT8c0/XOm+mtSriHHeH7dj4ZxdRxbAk1jG92lY5qLiTNw7/f72MkSBUPBc6B2TCvF9R0P7UeNxTZdZvBzSvNpMMrq4Km76tPVJZfGsTg7JDamwy0hDssBBc8ZNbm/auP3Lgnp3B2Ly/64HuQrd9SRrCdwxTSyPD3BmOlFZncguIW6Y2lKXFzfNZ6dhlGwHGBpZrEPjRkzQ7gzlaTxL5fLIWkpWSZDyhACR1ftdkpW9K3+V9ZmCRBdm+oaMQH4AE4NUOcVo+u1s+ucu9N2ZyDKV7apxkh6q0sli3UxrhNQx9etKV3GO8Z4AiEx0oGaCPNwlTpINbC2uZIyNx2oTg5naBqKqfvn5+cjQSEDx/jze4/JNZNpBC0lIatF3aYeOtbEuFniQpuMgcc6XXHMcICuxC8HljOaZpZ0c/pWsevf3YPXsO+kw2p5NcWfxTPXV5X4JrN+d+B0T7/18Y0rK661wCKDXLBmf5qwaD8rydFKceA419gtslOi4twm7bL0INUNMsmnN8XSs7jOiGqYLqVO17jM9B2gdTq68yuHc7k1nm/9mZUCNXuxyP2BxyyzcwNxG7jpGmXqTwOXYpkDMIGaruH9lv/MagbgzGXqQ9TZb5FQWQLmduI7l8sBvxs0d4+VtVq3bkvyT65SlegSEVeSfBfzZq8tqFHOMK5LOGYx9dWSgHOsenXdV/0fXOV3SxerOjaeBa9bE/F++m5lkq2+3eczxblL93RgNQnpkpOy119/kJrqVsoMZG1nFsl7a7zQ89kyi3MrTEt9uHbrKl9VPM3oat+242bzLDaxrCRI1EN1GuP511c745wdO88ry4Hk8vXadjmwolg3QDdYglT+mTsAfOLcGYvxcYw//yaN7aVD9UedeT8d08rsXy1pwiTGJbe4wsynGJdmo7bNlHUHQbvf/YNUp0fJF3gFnBpX+9OZO8uEnb5p3Ak4Pc/AcpNn1Z2OMZ4f66iyCRxXVwMucEpOWVKMK6PqnyG5xXLpSLnr9fr4S1TnonhvBUrHR511PK+Altylc5XONfKwe5XJzcxcxwrbKFfuM802dQUOwKpn1lhPCth33ZdP2sc4/lSustBN2BW3OQPOMUyZdSZxqXJgHF1OYhONwNnP2UD3VoC5wdF9siho/Hs31mvfdMt8zaH0JoNUl5Jx7m4FRDdR1YbpBaLSmfpr7GP/9/t/H6Q6BbTOAUmQE+BqnORCnHtUpmmyQiBVpzIezxw4r3cJj457FvdmHijFuI55lKPul8tl7DSaGzDbHHDVEWXJRu5FqhHcyz+6eGad+3Mt1Zu6c5YzTrj7rLjMGYDOba6k+t2R3OXubqTrLQWoBsp2d00Cm/8Fo/pStnCGlcwY4/GLdXpPstL1qe5ZJ4DbyUlZpwNIz85lOsZxYmmdylOvQ3KS6K5gzgDqDjKzPjs/Tr00iUgvI1HPYlWd9eGrxlWW1L4CYOcyO1fZna2rVCMlxlVHGn+YLep1BQ4Zw4FxYe0GzT5dFqgD1GVIvVQ029R2rOMGggNb3Z8DcwYcmTZLXAjcGOOYnMyUSDLK2u7o+nCs4dkZUN/ZXGGUAubAS4BqBt2NZwyfXSp4KQ4m293v93+TkzKAsqR+6k9noWNjDZQDJvM0+dB+HGO4UNdMku5WWe7YwcEreM6Npj8I0VjcGb8DQZMndY0u1lHn3Sm0cszkOSFW+uK+IieLS1p0kig7WBxYKp/cpNvRSW6zY0wCrlsiuLYDcDQMjUWjp+QkuTgHKpMSN2BmnGoo9qN9dMAlhjmQOhDJRoKZxrLKQAXHfXfAjTHmyYkyiDOQn91OCjMi1z8NoLGjyxyVbQ4c9qEv0fJ6dc0Fgk4C/eziIUHsAOgAdq6SS5gDcDpr3DFrdwczyZnLZcrr7l1tPDuwusQivU6YAEnJSndv1bdzmZ2rdNfwXk/JCV0T2VKJiktENA4oQ9WFcpbroFUHGqD0JBAEUg2sf2ugutW1uvmcJsAMYPbpAOr+ht0Bl3614ZCcrLBixrBZP06W16RBEwS6W6eXY0NafM9c7Wr9rOjYOjea4l5dX+N9yio1LtV5Biav63ZZCISLp0nOFbevqTOz+mC8oxunnGPP2eKudy4zZY6OoeohxhjHTeYUZ1xCoa4t7VW6ZMY97tH7pUc+2hdLyuRcZkeAu7bvFHefFMOSGyUhWA6uUgFcWYMl1zrbqNYdj8Q4/bNh5yrV+Gq0mat2Bj9TPytpsiiIncvUcmo5QHD10Y1jV8l36zv2X0WZU/dQ49EtKVu3bXv8dEX9jEX9pEXVqWtyoK4ytJN3ICrrZr/SYIGbKaTgrh5uILP7MRtVxulEUYO4QK//bcPFlZXxs92BoWNblU9eIU2mp+UAY0nV6ZtZNFpiV9WluKfLB96TC+WqI5BjjMObXvraXckXq/75558D48i0WbKgwHYAJ9BX5XUyudcZ1NNMGafxaZVdK+10jxqzCKp7As5BVN/60xPdzzM54FxbBwjt1tnwrHwC9QAc404Xf1La7oCZyXfpvZvl9QtBzkUSuGJU97taK0zrwHP1HLsDaVWe/TuXXhiNEZITl1Wqy1KX54Aq+VJQdxdScWu3y+Uyfv36dfjFBbKwANr3/fDLdQqQA0z/DtsBnQw5Y6gb78xL6X1eepDqFDh7cDYp0DoRlPV0n3z0Q1n2r2B0jFp1kVr/iq3Sdy3p3iof9yrJvMruiLhjmGMjH8ayuASFbq/O3Okg0DUTK5lhBlmMO/MeY7U5Rjr2rfzBhrOPgnCGIFXf7lXOZpWCvPK8TgGq65SJ1bfGNLpfXdt0RnYscy6wkztrnzOArPZfNrpcZK+S7HJPfx1wiaEKEosunMkurtuoLPvh9pBmlbpuK7n0+5ErxwoL0ySYTeYOYAXvwDgyZzWrVLa53ZEV4Nxmsot/+ioDgWNykmLWjGmvgtYB0LWpy+zaKGMZd4bGM4AJLAEgcNxoJkA6GTgRtD8OyLnGBFoybAf0Ckirh7KKZVX+pVcXSl5dozKNs0Rv7pRT+boPWafXuE3m0lHTfFfHo3urmEuLM+62m0yujxkLD8CdYVwHLAEkm7oN6SSv91IW8toEXDKa031m3Nk132XiDIMnxilrilVj/EkCHKsYZ9SAdd627fGuv76tnHZdnAw/1w4Kf4uS15f+afY7tqQfUFMWsg/XNjv0mdsKWx14h+SExu7YpHGnjOpiktarPJMTLQRFs8pSXq+buaPOaBy7q+/i36zuDJNXWPlgHA1JN6aur2azW6xzGVFGdAtvBa7YowDUJFFwCzR9MlAluS+d9cq2BOgsnrnJ0IHdudquP3Wnh3RPUXXFubfUh6O5Y7OTdX10957dJ/XZfXd9OzvNvnfF6bdSHsB1iqYbdnUrg6GhtL6bFMnIZ8BKOswAS/Kpf9fPO8p/AFYPVuKvOlZqAAAAAElFTkSuQmCC\" id=\"image93af2229eb\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"171.443891\" y=\"-175.852321\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_12\">\n",
       "   <g clip-path=\"url(#peba1ad1c67)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imageb18c1c3bf4\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"253.565837\" y=\"-175.852321\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_13\">\n",
       "   <g clip-path=\"url(#p58cbbc8ce3)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagec4faa9d5d5\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"7.2\" y=\"-260.014249\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_14\">\n",
       "   <g clip-path=\"url(#p2b2a7e550f)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image8c1f1b8661\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"89.321946\" y=\"-260.014249\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_15\">\n",
       "   <g clip-path=\"url(#pa8837300ab)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagea23aab2acb\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"171.443891\" y=\"-260.014249\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_16\">\n",
       "   <g clip-path=\"url(#p8416aaa356)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image43eb740b55\" transform=\"scale(1 -1) translate(0 -79.2)\" x=\"253.565837\" y=\"-260.014249\" width=\"79.2\" height=\"79.2\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_17\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 335.687783 339.84 \n",
       "L 342 339.84 \n",
       "L 342 7.2 \n",
       "L 335.687783 7.2 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "   </g>\n",
       "   <image xlink:href=\"data:image/png;base64,\n",
       "iVBORw0KGgoAAAANSUhEUgAAAAkAAAHOCAYAAABKCyOoAAAA2ElEQVR4nN3OsQ0DQQwEMd3D/bfsL+ESwxhK8YKaMzPfudxzG8zMfM4519HvpD+/2y2x4UWJDS9KbPhuiQ0vSmx4UWLDixIbXpTY8KLEhhclNrwoseFFiQ3fLbHhRYkNL0pseFFiw4sSG16U2PCixIYXJTZ8t8SGFyU2vCix4UWJDS9KbHhRYsOLEhtelNjw3RIbXpTY8KLEhhclNrwoseFFiQ0vSmx4UWLDixIbvltiw4sSG16U2PCixIYXJTa8KLHhRYkNL0ps+G6JDS9KbHhRYsOLUjH8BZrXCZbnUAlLAAAAAElFTkSuQmCC\" id=\"image8dab1f423d\" transform=\"scale(1 -1) translate(0 -332.64)\" x=\"335.52\" y=\"-6.48\" width=\"6.48\" height=\"332.64\"/>\n",
       "   <g id=\"matplotlib.axis_1\"/>\n",
       "   <g id=\"matplotlib.axis_2\">\n",
       "    <g id=\"ytick_1\">\n",
       "     <g id=\"line2d_1\">\n",
       "      <defs>\n",
       "       <path id=\"m0377c3062e\" d=\"M 0 0 \n",
       "L 3.5 0 \n",
       "\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </defs>\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"318.662432\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_1\">\n",
       "      <!-- −0.1 -->\n",
       "      <g transform=\"translate(349 322.461651) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-2212\" d=\"M 678 2272 \n",
       "L 4684 2272 \n",
       "L 4684 1741 \n",
       "L 678 1741 \n",
       "L 678 2272 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-2e\" d=\"M 684 794 \n",
       "L 1344 794 \n",
       "L 1344 0 \n",
       "L 684 0 \n",
       "L 684 794 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "        <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-2212\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(83.789062 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(147.412109 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(179.199219 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_2\">\n",
       "     <g id=\"line2d_2\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"276.427872\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_2\">\n",
       "      <!-- 0.0 -->\n",
       "      <g transform=\"translate(349 280.227091) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_3\">\n",
       "     <g id=\"line2d_3\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"234.193312\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_3\">\n",
       "      <!-- 0.1 -->\n",
       "      <g transform=\"translate(349 237.99253) scale(0.1 -0.1)\">\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_4\">\n",
       "     <g id=\"line2d_4\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"191.958751\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_4\">\n",
       "      <!-- 0.2 -->\n",
       "      <g transform=\"translate(349 195.75797) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_5\">\n",
       "     <g id=\"line2d_5\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"149.724191\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_5\">\n",
       "      <!-- 0.3 -->\n",
       "      <g transform=\"translate(349 153.52341) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_6\">\n",
       "     <g id=\"line2d_6\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"107.48963\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_6\">\n",
       "      <!-- 0.4 -->\n",
       "      <g transform=\"translate(349 111.288849) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-34\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_7\">\n",
       "     <g id=\"line2d_7\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"65.25507\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_7\">\n",
       "      <!-- 0.5 -->\n",
       "      <g transform=\"translate(349 69.054289) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"ytick_8\">\n",
       "     <g id=\"line2d_8\">\n",
       "      <g>\n",
       "       <use xlink:href=\"#m0377c3062e\" x=\"342\" y=\"23.02051\" style=\"stroke: #000000; stroke-width: 0.8\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "     <g id=\"text_8\">\n",
       "      <!-- 0.6 -->\n",
       "      <g transform=\"translate(349 26.819728) scale(0.1 -0.1)\">\n",
       "       <defs>\n",
       "        <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       </defs>\n",
       "       <use xlink:href=\"#DejaVuSans-30\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(63.623047 0)\"/>\n",
       "       <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(95.410156 0)\"/>\n",
       "      </g>\n",
       "     </g>\n",
       "    </g>\n",
       "    <g id=\"text_9\">\n",
       "     <!-- Signed distance -->\n",
       "     <g transform=\"translate(384.88125 213.452812) rotate(-90) scale(0.1 -0.1)\">\n",
       "      <defs>\n",
       "       <path id=\"DejaVuSans-53\" d=\"M 3425 4513 \n",
       "L 3425 3897 \n",
       "Q 3066 4069 2747 4153 \n",
       "Q 2428 4238 2131 4238 \n",
       "Q 1616 4238 1336 4038 \n",
       "Q 1056 3838 1056 3469 \n",
       "Q 1056 3159 1242 3001 \n",
       "Q 1428 2844 1947 2747 \n",
       "L 2328 2669 \n",
       "Q 3034 2534 3370 2195 \n",
       "Q 3706 1856 3706 1288 \n",
       "Q 3706 609 3251 259 \n",
       "Q 2797 -91 1919 -91 \n",
       "Q 1588 -91 1214 -16 \n",
       "Q 841 59 441 206 \n",
       "L 441 856 \n",
       "Q 825 641 1194 531 \n",
       "Q 1563 422 1919 422 \n",
       "Q 2459 422 2753 634 \n",
       "Q 3047 847 3047 1241 \n",
       "Q 3047 1584 2836 1778 \n",
       "Q 2625 1972 2144 2069 \n",
       "L 1759 2144 \n",
       "Q 1053 2284 737 2584 \n",
       "Q 422 2884 422 3419 \n",
       "Q 422 4038 858 4394 \n",
       "Q 1294 4750 2059 4750 \n",
       "Q 2388 4750 2728 4690 \n",
       "Q 3069 4631 3425 4513 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-69\" d=\"M 603 3500 \n",
       "L 1178 3500 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 3500 \n",
       "z\n",
       "M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 4134 \n",
       "L 603 4134 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-67\" d=\"M 2906 1791 \n",
       "Q 2906 2416 2648 2759 \n",
       "Q 2391 3103 1925 3103 \n",
       "Q 1463 3103 1205 2759 \n",
       "Q 947 2416 947 1791 \n",
       "Q 947 1169 1205 825 \n",
       "Q 1463 481 1925 481 \n",
       "Q 2391 481 2648 825 \n",
       "Q 2906 1169 2906 1791 \n",
       "z\n",
       "M 3481 434 \n",
       "Q 3481 -459 3084 -895 \n",
       "Q 2688 -1331 1869 -1331 \n",
       "Q 1566 -1331 1297 -1286 \n",
       "Q 1028 -1241 775 -1147 \n",
       "L 775 -588 \n",
       "Q 1028 -725 1275 -790 \n",
       "Q 1522 -856 1778 -856 \n",
       "Q 2344 -856 2625 -561 \n",
       "Q 2906 -266 2906 331 \n",
       "L 2906 616 \n",
       "Q 2728 306 2450 153 \n",
       "Q 2172 0 1784 0 \n",
       "Q 1141 0 747 490 \n",
       "Q 353 981 353 1791 \n",
       "Q 353 2603 747 3093 \n",
       "Q 1141 3584 1784 3584 \n",
       "Q 2172 3584 2450 3431 \n",
       "Q 2728 3278 2906 2969 \n",
       "L 2906 3500 \n",
       "L 3481 3500 \n",
       "L 3481 434 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-6e\" d=\"M 3513 2113 \n",
       "L 3513 0 \n",
       "L 2938 0 \n",
       "L 2938 2094 \n",
       "Q 2938 2591 2744 2837 \n",
       "Q 2550 3084 2163 3084 \n",
       "Q 1697 3084 1428 2787 \n",
       "Q 1159 2491 1159 1978 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1366 3272 1645 3428 \n",
       "Q 1925 3584 2291 3584 \n",
       "Q 2894 3584 3203 3211 \n",
       "Q 3513 2838 3513 2113 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-64\" d=\"M 2906 2969 \n",
       "L 2906 4863 \n",
       "L 3481 4863 \n",
       "L 3481 0 \n",
       "L 2906 0 \n",
       "L 2906 525 \n",
       "Q 2725 213 2448 61 \n",
       "Q 2172 -91 1784 -91 \n",
       "Q 1150 -91 751 415 \n",
       "Q 353 922 353 1747 \n",
       "Q 353 2572 751 3078 \n",
       "Q 1150 3584 1784 3584 \n",
       "Q 2172 3584 2448 3432 \n",
       "Q 2725 3281 2906 2969 \n",
       "z\n",
       "M 947 1747 \n",
       "Q 947 1113 1208 752 \n",
       "Q 1469 391 1925 391 \n",
       "Q 2381 391 2643 752 \n",
       "Q 2906 1113 2906 1747 \n",
       "Q 2906 2381 2643 2742 \n",
       "Q 2381 3103 1925 3103 \n",
       "Q 1469 3103 1208 2742 \n",
       "Q 947 2381 947 1747 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-73\" d=\"M 2834 3397 \n",
       "L 2834 2853 \n",
       "Q 2591 2978 2328 3040 \n",
       "Q 2066 3103 1784 3103 \n",
       "Q 1356 3103 1142 2972 \n",
       "Q 928 2841 928 2578 \n",
       "Q 928 2378 1081 2264 \n",
       "Q 1234 2150 1697 2047 \n",
       "L 1894 2003 \n",
       "Q 2506 1872 2764 1633 \n",
       "Q 3022 1394 3022 966 \n",
       "Q 3022 478 2636 193 \n",
       "Q 2250 -91 1575 -91 \n",
       "Q 1294 -91 989 -36 \n",
       "Q 684 19 347 128 \n",
       "L 347 722 \n",
       "Q 666 556 975 473 \n",
       "Q 1284 391 1588 391 \n",
       "Q 1994 391 2212 530 \n",
       "Q 2431 669 2431 922 \n",
       "Q 2431 1156 2273 1281 \n",
       "Q 2116 1406 1581 1522 \n",
       "L 1381 1569 \n",
       "Q 847 1681 609 1914 \n",
       "Q 372 2147 372 2553 \n",
       "Q 372 3047 722 3315 \n",
       "Q 1072 3584 1716 3584 \n",
       "Q 2034 3584 2315 3537 \n",
       "Q 2597 3491 2834 3397 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-74\" d=\"M 1172 4494 \n",
       "L 1172 3500 \n",
       "L 2356 3500 \n",
       "L 2356 3053 \n",
       "L 1172 3053 \n",
       "L 1172 1153 \n",
       "Q 1172 725 1289 603 \n",
       "Q 1406 481 1766 481 \n",
       "L 2356 481 \n",
       "L 2356 0 \n",
       "L 1766 0 \n",
       "Q 1100 0 847 248 \n",
       "Q 594 497 594 1153 \n",
       "L 594 3053 \n",
       "L 172 3053 \n",
       "L 172 3500 \n",
       "L 594 3500 \n",
       "L 594 4494 \n",
       "L 1172 4494 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "       <path id=\"DejaVuSans-63\" d=\"M 3122 3366 \n",
       "L 3122 2828 \n",
       "Q 2878 2963 2633 3030 \n",
       "Q 2388 3097 2138 3097 \n",
       "Q 1578 3097 1268 2742 \n",
       "Q 959 2388 959 1747 \n",
       "Q 959 1106 1268 751 \n",
       "Q 1578 397 2138 397 \n",
       "Q 2388 397 2633 464 \n",
       "Q 2878 531 3122 666 \n",
       "L 3122 134 \n",
       "Q 2881 22 2623 -34 \n",
       "Q 2366 -91 2075 -91 \n",
       "Q 1284 -91 818 406 \n",
       "Q 353 903 353 1747 \n",
       "Q 353 2603 823 3093 \n",
       "Q 1294 3584 2113 3584 \n",
       "Q 2378 3584 2631 3529 \n",
       "Q 2884 3475 3122 3366 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      </defs>\n",
       "      <use xlink:href=\"#DejaVuSans-53\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-69\" transform=\"translate(63.476562 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-67\" transform=\"translate(91.259766 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6e\" transform=\"translate(154.736328 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(218.115234 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-64\" transform=\"translate(279.638672 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(343.115234 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-64\" transform=\"translate(374.902344 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-69\" transform=\"translate(438.378906 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(466.162109 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-74\" transform=\"translate(518.261719 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(557.470703 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-6e\" transform=\"translate(618.75 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-63\" transform=\"translate(682.128906 0)\"/>\n",
       "      <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(737.109375 0)\"/>\n",
       "     </g>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"LineCollection_1\"/>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 335.687783 339.84 \n",
       "L 338.843891 339.84 \n",
       "L 342 339.84 \n",
       "L 342 7.2 \n",
       "L 338.843891 7.2 \n",
       "L 335.687783 7.2 \n",
       "L 335.687783 339.84 \n",
       "z\n",
       "\" style=\"fill: none; stroke: #000000; stroke-width: 0.8; stroke-linejoin: miter; stroke-linecap: square\"/>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p44a25e7ad6\">\n",
       "   <rect x=\"7.2\" y=\"7.825751\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p78a6a594fc\">\n",
       "   <rect x=\"89.321946\" y=\"7.825751\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p3b525f7c81\">\n",
       "   <rect x=\"171.443891\" y=\"7.825751\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p9594c323c9\">\n",
       "   <rect x=\"253.565837\" y=\"7.825751\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p7a946c70a6\">\n",
       "   <rect x=\"7.2\" y=\"91.987679\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p1b40fb1fe0\">\n",
       "   <rect x=\"89.321946\" y=\"91.987679\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pb7b85f1683\">\n",
       "   <rect x=\"171.443891\" y=\"91.987679\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pa2c4719cea\">\n",
       "   <rect x=\"253.565837\" y=\"91.987679\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pc5910ce939\">\n",
       "   <rect x=\"7.2\" y=\"176.149606\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pe2a7a2bce3\">\n",
       "   <rect x=\"89.321946\" y=\"176.149606\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p697507394c\">\n",
       "   <rect x=\"171.443891\" y=\"176.149606\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"peba1ad1c67\">\n",
       "   <rect x=\"253.565837\" y=\"176.149606\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p58cbbc8ce3\">\n",
       "   <rect x=\"7.2\" y=\"260.311534\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p2b2a7e550f\">\n",
       "   <rect x=\"89.321946\" y=\"260.311534\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pa8837300ab\">\n",
       "   <rect x=\"171.443891\" y=\"260.311534\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p8416aaa356\">\n",
       "   <rect x=\"253.565837\" y=\"260.311534\" width=\"78.902715\" height=\"78.902715\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 600x600 with 17 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"348.730435pt\" height=\"347.04pt\" viewBox=\"0 0 348.730435 347.04\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2026-01-28T13:20:17.671688</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.10.8, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 347.04 \n",
       "L 348.730435 347.04 \n",
       "L 348.730435 -0 \n",
       "L 0 -0 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g clip-path=\"url(#p4e9cc7adb4)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image968e10992a\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_2\">\n",
       "   <g clip-path=\"url(#p9c6c1f2c0a)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image1ab7353dd3\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_3\">\n",
       "   <g clip-path=\"url(#pa3bba05bc9)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagefa31e02632\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_4\">\n",
       "   <g clip-path=\"url(#pfda35c5e5d)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagec6eb8fa271\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_5\">\n",
       "   <g clip-path=\"url(#pa8dc882e7a)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imageea9a74d61e\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_6\">\n",
       "   <g clip-path=\"url(#pdc9fecdfcc)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagef1cfb096de\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_7\">\n",
       "   <g clip-path=\"url(#pff72049f5d)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagebce53e9bac\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_8\">\n",
       "   <g clip-path=\"url(#p3af9297a1f)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagedab1e03342\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_9\">\n",
       "   <g clip-path=\"url(#p07469a23ef)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image0c6aafd9f0\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_10\">\n",
       "   <g clip-path=\"url(#p5fa4994be6)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "iVBORw0KGgoAAAANSUhEUgAAAGUAAABlCAYAAABUfC3PAAAJrElEQVR4nO2cW0hUXRvH/3vPjHNwRGfMVGpozLzwIgkPhZ2zIO1EEpaQFQRRkRFRUlR4Ud0FRVRUFwWVhZRgBFKilB2EDmTmsUxTMNOykXIsx2ZmPd/F9zlfk6Ov6cxe2979gwd0r2E9z17/ddprrb0FAAQFWSHyDkBhKIooMkQRRYYoosgQRRQZoogiQxRRZIgiigxRRJEhiigyRBFFhnARRafTITs7GykpKTzcTwhIaouKiqIvX77QqVOnSBAEj/GIRaYmrcO8vDx6/vw5/fz5kzo6OqiyspIqKyvpxIkTvAtCTiaNo+DgYEpNTaXi4mLyRWVlJaWmppLJZOJdIHIwaRwlJibSz58/iTHmUxTGGLndblq5ciXvAuFukg30bW1t2Lp1KyoqKnymC4IAUVQmg4CEs6+enh4UFBTg2bNn6OjogNvtlsr1hETSpqnT6Sg2NpZsNpvPbkzpviTsvgZxOBzo6+sDEflMX79+PbZt2waVSiVxZPJC8powefJk+vDhAw0MDPhsLfX19RQUFMS9xvIyLiOrzWbDggULcOLECR7uZQ8XUdxuN1pbW9Hd3e0zPSQkBJmZmYiLi5M4MnkgyzmoxWJBYWEh1qxZwzsULshSlEG2b9+O4uJimEwm3qFICldRuru7UV1djf7+fp/pcXFxSEtLQ1JSEiwWi8TR8YXbLEMQBNLr9VRXV+dzFja4/OJ0Oun8+fPcZ0WSlcv//uCGKIrIysqC2WwGAOzcuRMzZ84c8ruGhgbPEk1TUxNOnz4tZZiSw71m/GoFBQVks9mGXbgkIrp//z73OANs3APwspCQEEpNTR32wfLfIIrsZl92ux3v37/H2bNnUVVVxTscLshOFAD49OkT9u3bh/LycjidziHrZIIgQKPRQBAEThEGHu7NdTiLioqiefPmUXd3t1f3Zbfb6fXr17R8+XLuMQbCZNlSBunq6kJ1dTVKS0tRW1vruW40GpGQkICwsDB+wQUQWYsCAN+/f0dOTg7OnDnDOxTJkL0oI7F//35cvHgRWq2Wdyh+ZcKI8vXrV7x588ZrSSY5ORkrVqxAfHw8wsPDOUbnf7gPbKMxURTJYDDQixcvhizD9Pf306FDh7jH6Ld7HaVw3GGMweFw+Jwe63Q6ZGRk4Pjx43/NijL3mjFaE0WRnj9/PuyTfl9fH82cOZNCQ0MpNDSUVCoV95jHdJ9/IJ7s0ev1KCsrQ319Perr65GcnMw7pDGh5h3An0BEuHPnDmpqagAAS5YswfTp0z3poigiMjLS89ugoCC/+o+OjkZ6ejoePHiAtrY2v+b9O9yb61jtxo0b5Ha7fa4oM8Zo0aJFfjvNLwgCLVu2jBhjlJWVFei3BPgX7lgtNjaW1q5dSz9+/PApSkNDA12+fHncBahSqejq1avU2NhIjDFqamqioqIi0mq1iii+LDo6mu7du0dtbW0+B/+nT5+SKIrjFuXly5de+TY1NZFerw/IPU34gb6zsxPp6em4cuUK71D8xoQXZZCioiJs3bp12LNkE4m/RpTa2lrcvHkT379/97qu1WphtVphNBrHlX9nZye6urpARPj8+TM6OjrAGBtXniPBfVzwlwUHB1Nra6tX3+9yuchut9OWLVvGlbder6eVK1cSY4xycnICNp5AyjElKioKR44cQWJiolQuAQAqlQpGoxGZmZnYu3fvmFeU+/v70djYiKNHj6KqqmrYs2r+IuA1WKvV0ty5c8nlclFubi4ZDAYyGAyk0Wj83lLq6+vJ4XD4nIl9/PiRoqOj/e43ABZ4J9euXaP29nZijNHnz5+pubmZmpub6fDhw371IwgCWSwW2rNnj09RnE4ntba20oEDB3gX+ogW0GUWi8WCuXPnYtasWZg6dSoAICIiAhEREQCASZMm+dUfEaG9vR0vXrxAYWEh0tLSMHnyZE+6Wq2G1WrFvHnzsGHDBgBAR0cHnjx54tc4/EHAFM/KyiLG2LAH606dOhXQGvfw4UOffn/l9u3b3FvG7xbQgb6iogJpaWl49eqVz/R169ahtLQUVqs1kGFMOALafXV3d6OiogLPnj2DTqdDfHy811kti8WCqKgopKSkeLZzm5ub8e3bt1HlHxMTg+DgYDQ0NHg9M5hMJsTGxo7q2SQsLAxJSUkA/j/DomHex5SSwDdHUaTk5GRyOp1Dug/GGLlcLo/9ydvB169fp3fv3pHBYPC6np2dTS6Xa8TzyL78V1dXk1qt5t59SbKfwhhDa2srduzYgc2bN2PhwoWeNEEQvN4Ezs3NHfUbXHPmzEFERATOnj0Lp9PpuT5jxoxRv138q39RFGVz6lLSWnDhwoV/rL28aGhooKlTpw5peVLbX7P25Q/i4uJQU1ODnJwcrnFIvh1cXl7uWTRMTEzE4sWLpQ5hWNRqNUwmE3Q6He9Q+DXT3bt3k8PhILfbzbvnIiIit9tNDoeDdu3axXuw5+fcbDZTQkICvXv3jrceRPTf3cSEhAQym81cReF6mqWnpwd2ux0Oh4NnGB40Gg1iYmLQ29uLnp4ebnHIZqAnoiEPbYPXxmLD5TMSVqsVt2/f5v5RBe7nvlwuF3Jzcz1P3/n5+Zg9ezYA4PLlyyguLv7jPBctWoS8vDwAwNu3b5GXlwfGGMLDw3Hu3Llx70IGGu6iEBEePnzo+T8jIwMGgwEA8PjxY5SUlPxxnowxZGRkAADq6upQUlICxhgiIiJQW1uLkJAQiKKI2NhYr00vh8OBlpYW2Gy2cd7V+OE90/Ae5NRq0mg0pNFoxnw0SBRFTx6/L5sMXjcajdTY2Og10NfW1pLBYBj3kSQ/GH8heJhKpaItW7bQpUuXiDFGFy9epE2bNslBkH+vKIOWkZFBNpuNli1b9o+/VavVZDKZpNhO5l8wPE2r1VJkZOSovsS3YMEC6uzspFWrVgU0Ju4DPW8GBgbw6dOnEX8jCAIyMzMxf/58REZGYvXq1TAajbh161bAvhrLvbbK3ZSzxAryeaKfaOj1eixcuBDTpk3ze96KKGNkypQpuHv3LjZu3Oj3vBVRRgFjDAcPHsSxY8c862eCIARs61gRZRQQEcrKyryWgwYxm82wWq1+/+I499nNRLGlS5cOOSEzMDBAXV1dNGXKFGX2xYOWlhbk5+ejrq7Oc+3Ro0c4efIk7Ha7X31xr4ETza5evUq9vb3U29tL+/fv93v+3L+2OhGZNGmSZ3vh69ev6O3t9Wv+iigyRBlTZIgiigxRRJEhiigyRBFFhiiiyBBFFBmiiCJDFFFkiCKKDFFEkSGKKDJEEUWGKKLIEEUUGaKIIkMUUWTIfwDEHJahaWAYqgAAAABJRU5ErkJggg==\" id=\"image1c3238471d\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_11\">\n",
       "   <g clip-path=\"url(#p0fcadf7820)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagec838076e9a\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_12\">\n",
       "   <g clip-path=\"url(#pfb3f10554e)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagec464fd6fb2\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_13\">\n",
       "   <g clip-path=\"url(#ped74fce2e6)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagef5f0a1d215\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_14\">\n",
       "   <g clip-path=\"url(#pbf4a4ec1fb)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image47e5704408\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_15\">\n",
       "   <g clip-path=\"url(#p33052a7593)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image4e35148a85\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_16\">\n",
       "   <g clip-path=\"url(#p56447f2747)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagea86bc7d8f9\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p4e9cc7adb4\">\n",
       "   <rect x=\"7.2\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p9c6c1f2c0a\">\n",
       "   <rect x=\"94.53913\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pa3bba05bc9\">\n",
       "   <rect x=\"181.878261\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pfda35c5e5d\">\n",
       "   <rect x=\"269.217391\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pa8dc882e7a\">\n",
       "   <rect x=\"7.2\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pdc9fecdfcc\">\n",
       "   <rect x=\"94.53913\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pff72049f5d\">\n",
       "   <rect x=\"181.878261\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p3af9297a1f\">\n",
       "   <rect x=\"269.217391\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p07469a23ef\">\n",
       "   <rect x=\"7.2\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p5fa4994be6\">\n",
       "   <rect x=\"94.53913\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p0fcadf7820\">\n",
       "   <rect x=\"181.878261\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pfb3f10554e\">\n",
       "   <rect x=\"269.217391\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"ped74fce2e6\">\n",
       "   <rect x=\"7.2\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pbf4a4ec1fb\">\n",
       "   <rect x=\"94.53913\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p33052a7593\">\n",
       "   <rect x=\"181.878261\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p56447f2747\">\n",
       "   <rect x=\"269.217391\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 600x600 with 16 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "upsample_factor = 2\n",
    "upsample = Upsample2d(scale_factor=upsample_factor, filter_size=9, use_radial=False)\n",
    "\n",
    "sdf_imgs, labels = next(iter(loader))\n",
    "sdf_imgs = upsample(sdf_imgs)\n",
    "sdf_imgs = sdf_imgs.squeeze(1)  # (B, H, W)\n",
    "\n",
    "B_vis = 16\n",
    "vis_sdf(sdf_imgs[:B_vis], title = None, figsize=(6,6))\n",
    "vis_mask(sdf_imgs[:B_vis], title = None, figsize=(6,6))\n",
    "None"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e14fa9c6",
   "metadata": {},
   "source": [
    "# 0.1 Train Func"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1a6444d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(score_nn, args_sde,ckpt_prefix, B = 32, num_steps=2e6, lr=1e-4, device=\"cuda\", ema_decay=0.999, n_report = 500, n_vis = 2500, n_ckpt = 25000):\n",
    "    score_nn.to(device).train()\n",
    "\n",
    "    # Upsample function\n",
    "    upsample = Upsample2d(scale_factor=args_sde.upsample_factor, filter_size=9, use_radial=False)\n",
    "\n",
    "\n",
    "    # Initialize EMA model\n",
    "    ema_score_nn = copy.deepcopy(score_nn).to(device).eval()\n",
    "\n",
    "    opt = torch.optim.Adam(score_nn.parameters(), lr=lr) # Initialise optimiser\n",
    "\n",
    "    # Create data minstsdf data loader\n",
    "    size = (32, 32)\n",
    "    ds = MNISTSDFDataset(root=\"./data\",train=True,download=True,size=size,return_image=True)\n",
    "    loader = DataLoader(ds,batch_size=B,shuffle=True,num_workers=0,drop_last=True)\n",
    "\n",
    "    steps_per_epoch = len(loader)\n",
    "\n",
    "    step = 0\n",
    "    epoch = 0\n",
    "    running_loss = 0.0\n",
    "\n",
    "    while step < num_steps:\n",
    "        epoch += 1\n",
    "\n",
    "        # Each epoch iterates through the (shuffled) loader once\n",
    "        for sdf_imgs, _ in loader:\n",
    "            step += 1\n",
    "            if step > num_steps:\n",
    "                break\n",
    "\n",
    "            sdf_imgs = sdf_imgs.to(device=device, dtype=torch.float32)\n",
    "            sdf_imgs = upsample(sdf_imgs)\n",
    "\n",
    "\n",
    "            # Standard update (online model)\n",
    "            opt.zero_grad(set_to_none=True)\n",
    "            loss = compute_loss(score_nn, sdf_imgs, args_sde)\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "\n",
    "            # EMA update\n",
    "            with torch.no_grad():\n",
    "                for online_param, ema_param in zip(score_nn.parameters(), ema_score_nn.parameters()):\n",
    "                    ema_param.data.mul_(ema_decay).add_(online_param.data, alpha=1 - ema_decay)\n",
    "\n",
    "            running_loss += loss.item()\n",
    "\n",
    "            # Progress\n",
    "            if step % n_report == 0:\n",
    "                avg_loss = running_loss / n_report\n",
    "                running_loss = 0.0\n",
    "                step_in_epoch = (step - 1) % steps_per_epoch + 1\n",
    "                print(f\"[epoch {epoch:4d} | {step_in_epoch:5d}/{steps_per_epoch}] \"\n",
    "                      f\"[step {step:7d}] loss = {avg_loss:.6e}\")\n",
    "\n",
    "            # Periodic checkpointing\n",
    "            if step % n_ckpt == 0:\n",
    "                checkpoint_path = f\"{ckpt_prefix}_ckpt_step_{step}.pth\"\n",
    "                torch.save({\n",
    "                    \"step\": step,\n",
    "                    \"epoch\": epoch,\n",
    "                    \"model_state_dict\": score_nn.state_dict(),\n",
    "                    \"ema_model_state_dict\": ema_score_nn.state_dict(),\n",
    "                    \"optimizer_state_dict\": opt.state_dict(),\n",
    "                    \"args_sde\": args_sde,\n",
    "                }, checkpoint_path)\n",
    "                print(f\"--- Checkpoint saved: {checkpoint_path} ---\")\n",
    "\n",
    "            # Visualise\n",
    "            if step % n_vis == 0:\n",
    "                t_grid = make_time_grid(250, p=2, T=args_sde.T, eps=1e-5, device=device, dtype=torch.float32)\n",
    "                samples = sample_forced_diffusion(ema_score_nn, 16, t_grid, args_sde)\n",
    "                \n",
    "                final_images = torch_dct.idct_2d(samples, norm=\"ortho\")\n",
    "\n",
    "                vis_sdf(final_images, figsize=(6,6))\n",
    "                vis_mask(final_images,figsize=(6,6))\n",
    "\n",
    "\n",
    "    return ema_score_nn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "96da3b51",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_checkpoint_train(\n",
    "    checkpoint_path,\n",
    "    score_nn,\n",
    "    opt=None,\n",
    "    device=\"cuda\",\n",
    "    lr=1e-4,\n",
    "):\n",
    "    ckpt = torch.load(checkpoint_path, map_location=device, weights_only=False)\n",
    "\n",
    "    # Online model\n",
    "    score_nn = score_nn.to(device)\n",
    "    score_nn.load_state_dict(ckpt[\"model_state_dict\"])\n",
    "    score_nn.train()\n",
    "\n",
    "    # Optimizer\n",
    "    if opt is None:\n",
    "        opt = torch.optim.Adam(score_nn.parameters(), lr=lr)\n",
    "    opt.load_state_dict(ckpt[\"optimizer_state_dict\"])\n",
    "\n",
    "    # Move optimizer state tensors to device \n",
    "    for state in opt.state.values():\n",
    "        for k, v in state.items():\n",
    "            if torch.is_tensor(v):\n",
    "                state[k] = v.to(device)\n",
    "\n",
    "    # EMA model\n",
    "    ema_score_nn = copy.deepcopy(score_nn).to(device)\n",
    "    ema_score_nn.load_state_dict(ckpt[\"ema_model_state_dict\"])\n",
    "    ema_score_nn.eval()\n",
    "\n",
    "    start_step = int(ckpt.get(\"step\", 0)) + 1\n",
    "    start_epoch = int(ckpt.get(\"epoch\", 0))\n",
    "    ckpt_args_sde = ckpt.get(\"args_sde\", None)\n",
    "\n",
    "    return start_step, start_epoch, ckpt_args_sde, score_nn, ema_score_nn, opt\n",
    "\n",
    "\n",
    "def train_resumable(\n",
    "    score_nn,\n",
    "    args_sde,\n",
    "    ckpt_prefix,\n",
    "    B=32,\n",
    "    num_steps=2e6,\n",
    "    lr=1e-4,\n",
    "    device=\"cuda\",\n",
    "    ema_decay=0.999,\n",
    "    resume_path=None,\n",
    "    n_report = 500, n_vis = 2500, n_ckpt = 25000):\n",
    "    \n",
    "    # Upsample function (created after args_sde is finalized)\n",
    "    def make_upsample(curr_args_sde):\n",
    "        return Upsample2d(\n",
    "            scale_factor=curr_args_sde.upsample_factor,\n",
    "            filter_size=9,\n",
    "            use_radial=False,\n",
    "        )\n",
    "\n",
    "    # Default init (fresh start)\n",
    "    score_nn = score_nn.to(device).train()\n",
    "    ema_score_nn = copy.deepcopy(score_nn).to(device).eval()\n",
    "    opt = torch.optim.Adam(score_nn.parameters(), lr=lr)\n",
    "\n",
    "    # Data loader\n",
    "    size = (32, 32)\n",
    "    ds = MNISTSDFDataset(root=\"./data\",train=True,download=True,size=size,return_image=True)\n",
    "    loader = DataLoader(ds,batch_size=B,shuffle=True,num_workers=0,drop_last=True)    \n",
    "    steps_per_epoch = len(loader)\n",
    "\n",
    "    step = 0\n",
    "    epoch = 0\n",
    "    running_loss = 0.0\n",
    "\n",
    "    # Resume if requested\n",
    "    if resume_path is not None:\n",
    "        start_step, start_epoch, ckpt_args_sde, score_nn, ema_score_nn, opt = load_checkpoint_train(\n",
    "            resume_path,\n",
    "            score_nn=score_nn,\n",
    "            opt=None,   # create fresh optimizer then load state dict\n",
    "            device=device,\n",
    "            lr=lr,\n",
    "        )\n",
    "\n",
    "        # Optionally override args_sde with the one stored in the checkpoint\n",
    "        if ckpt_args_sde is not None:\n",
    "            args_sde = ckpt_args_sde\n",
    "\n",
    "        # Ensure modes are correct\n",
    "        score_nn.train()\n",
    "        ema_score_nn.eval()\n",
    "\n",
    "        # Continue epoch/step counters coherently\n",
    "        epoch = start_epoch\n",
    "        step = start_step - 1  # so first iteration increments to start_step\n",
    "\n",
    "    # Create upsample AFTER args_sde is finalized (important if resumed args_sde differs)\n",
    "    upsample = make_upsample(args_sde)\n",
    "\n",
    "    num_steps = int(num_steps)\n",
    "\n",
    "    while step < num_steps:\n",
    "        epoch += 1\n",
    "\n",
    "        # Each epoch iterates through the (shuffled) loader once\n",
    "        for sdf_imgs, _ in loader:\n",
    "            step += 1\n",
    "            if step > num_steps:\n",
    "                break\n",
    "\n",
    "            sdf_imgs = sdf_imgs.to(device=device, dtype=torch.float32)\n",
    "            sdf_imgs = upsample(sdf_imgs)\n",
    "\n",
    "            # Standard update (online model)\n",
    "            opt.zero_grad(set_to_none=True)\n",
    "            loss = compute_loss(score_nn, sdf_imgs, args_sde)\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "\n",
    "            # EMA update\n",
    "            with torch.no_grad():\n",
    "                for online_param, ema_param in zip(score_nn.parameters(), ema_score_nn.parameters()):\n",
    "                    ema_param.data.mul_(ema_decay).add_(online_param.data, alpha=1 - ema_decay)\n",
    "\n",
    "            running_loss += float(loss.item())\n",
    "\n",
    "            # Progress\n",
    "            if step % n_report == 0:\n",
    "                avg_loss = running_loss / n_report\n",
    "                running_loss = 0.0\n",
    "                step_in_epoch = (step - 1) % steps_per_epoch + 1\n",
    "                print(\n",
    "                    f\"[epoch {epoch:4d} | {step_in_epoch:5d}/{steps_per_epoch}] \"\n",
    "                    f\"[step {step:7d}] loss = {avg_loss:.6e}\"\n",
    "                )\n",
    "\n",
    "            # Periodic checkpointing (same cadence/filename logic as your train())\n",
    "            if step % n_ckpt == 0:\n",
    "                checkpoint_path = f\"{ckpt_prefix}_ckpt_step_{step}.pth\"\n",
    "                torch.save(\n",
    "                    {\n",
    "                        \"step\": step,\n",
    "                        \"epoch\": epoch,\n",
    "                        \"model_state_dict\": score_nn.state_dict(),\n",
    "                        \"ema_model_state_dict\": ema_score_nn.state_dict(),\n",
    "                        \"optimizer_state_dict\": opt.state_dict(),\n",
    "                        \"args_sde\": args_sde,\n",
    "                    },\n",
    "                    checkpoint_path,\n",
    "                )\n",
    "                print(f\"--- Checkpoint saved: {checkpoint_path} ---\")\n",
    "\n",
    "            if step % n_vis == 0:\n",
    "                t_grid = make_time_grid(\n",
    "                    250, p=2, T=args_sde.T, eps=1e-5, device=device, dtype=torch.float32\n",
    "                )\n",
    "\n",
    "                samples = sample_forced_diffusion(ema_score_nn, 16, t_grid, args_sde)\n",
    "\n",
    "                final_images = torch_dct.idct_2d(samples, norm=\"ortho\")\n",
    "                vis_sdf(final_images, figsize=(6, 6))\n",
    "                vis_mask(final_images, figsize=(6, 6))\n",
    "\n",
    "    return ema_score_nn\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3525ab44",
   "metadata": {},
   "source": [
    "# 1. SDE params\n",
    "## Empirical Covariance and cosine noise schedule"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "382a0e09",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing DCT statistics: 100%|██████████| 3750/3750 [00:09<00:00, 379.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([64, 64])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1.1783e+00, 1.2237e-01, 4.9767e-01, 7.7223e-02, 6.2102e-02, 1.5516e-02,\n",
       "        1.3505e-02, 5.4122e-03, 4.7232e-03, 2.2529e-03, 1.7003e-03, 1.0646e-03,\n",
       "        7.0381e-04, 5.5288e-04, 3.7714e-04, 2.8732e-04, 2.0108e-04, 1.6572e-04,\n",
       "        1.1918e-04, 9.7142e-05, 7.4774e-05, 6.0563e-05, 5.2198e-05, 4.1990e-05,\n",
       "        3.8538e-05, 3.1848e-05, 3.1574e-05, 2.8084e-05, 2.5593e-05, 2.4292e-05,\n",
       "        2.6217e-05, 3.6448e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05,\n",
       "        1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05,\n",
       "        1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05,\n",
       "        1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05,\n",
       "        1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05,\n",
       "        1.1954e-05, 1.1954e-05, 1.1954e-05, 1.1954e-05], device='cuda:0')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Get empirical cov\n",
    "m_dct, C_dct, n = per_mode_dct_mean_var(\n",
    "    loader, upsample = None,\n",
    "    device=\"cuda\",\n",
    "    norm=\"ortho\",\n",
    "    unbiased=False,\n",
    ")\n",
    "C_dct.shape\n",
    "\n",
    "x = C_dct[0]  # (32, 32)\n",
    "min_val = x.min()\n",
    "C = F.pad(\n",
    "    x.unsqueeze(0).unsqueeze(0),  # (1, 1, 32, 32)\n",
    "    (0, 32, 0, 32),\n",
    "    mode=\"constant\",\n",
    "    value=min_val\n",
    ")[0, 0]\n",
    "print(C.shape)  # torch.Size([64, 64])\n",
    "C[0,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "de8f43a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cos_u(t: torch.Tensor,s: float = 0.008,T: float = 1.0,eps_t: float = 1e-5) -> torch.Tensor:\n",
    "    if not torch.is_tensor(t):\n",
    "        raise TypeError(\"t must be a torch.Tensor\")\n",
    "    t = t.clamp(min=0.0, max=T - eps_t)\n",
    "    return ((t / T) + s) / (1.0 + s) * (math.pi / 2.0)\n",
    "\n",
    "\n",
    "def log_alpha_square(\n",
    "    t: torch.Tensor,s: float = 0.008,T: float = 1.0,eps_t: float = 1e-5,clamp_cos: float = 1e-12) -> torch.Tensor:\n",
    "    u = cos_u(t, s=s, T=T, eps_t=eps_t)\n",
    "    c = torch.cos(u).clamp_min(clamp_cos)\n",
    "    return 2.0 * torch.log(c)\n",
    "\n",
    "\n",
    "def cos_B(t: torch.Tensor,s: float = 0.008,T: float = 1.0,eps_t: float = 1e-5,clamp_cos: float = 1e-12) -> torch.Tensor:\n",
    "    # B(t) = -log(alpha^2(t)) = -2 log cos(u(t))\n",
    "    # B(t) = int_0^t cos_beta(s) ds\n",
    "    return (-log_alpha_square(t, s=s, T=T, eps_t=eps_t, clamp_cos=clamp_cos)).clamp_min(0.0)\n",
    "\n",
    "\n",
    "def cos_beta(t: torch.Tensor,s: float = 0.008,T: float = 1.0,eps_t: float = 1e-5,clamp_cos: float = 1e-12,max_beta: float = 1e6) -> torch.Tensor:\n",
    "    u = cos_u(t, s=s, T=T, eps_t=eps_t)\n",
    "\n",
    "    # tan(u) = sin(u)/cos(u) with safe denominator\n",
    "    sin_u = torch.sin(u)\n",
    "    cos_u_ = torch.cos(u).clamp_min(clamp_cos)\n",
    "    tan_u = sin_u / cos_u_\n",
    "\n",
    "    b = (math.pi / (T * (1.0 + s))) * tan_u\n",
    "    return b.clamp_max(max_beta)\n",
    "\n",
    "\n",
    "def beta(t: torch.Tensor, *, s: float = 0.008, T: float = 1.0, max_beta: float = 1e6) -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    time reversal cosine beta noise schedule. tilde{beta} in notation above\n",
    "    \"\"\"\n",
    "    return cos_beta(T-t, s=s, T=T,max_beta=max_beta)\n",
    "\n",
    "def beta_int(t: torch.Tensor, *, s: float = 0.008, T: float = 1.0, clamp: float = 1e-12) -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    int_t^T beta(s) ds with beta the time reversed noise schedule\n",
    "    \"\"\"\n",
    "    return cos_B(T-t, s=s, T=T, clamp_cos=clamp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "949647df",
   "metadata": {},
   "outputs": [],
   "source": [
    "args_sde = SimpleNamespace(upsample_factor =2, T = 1.0, beta_min = 0.1, beta_max = 20, gamma = 0.05)\n",
    "H = args_sde.upsample_factor * 32\n",
    "W = H\n",
    "\n",
    "# Get A, Q  \n",
    "A = 0.5 * C.pow(-args_sde.gamma)\n",
    "Q = C.pow(1-args_sde.gamma)\n",
    "\n",
    "\n",
    "args_sde.H = H \n",
    "args_sde.W = W\n",
    "args_sde.A = A\n",
    "args_sde.Q = Q\n",
    "args_sde.beta = beta\n",
    "args_sde.beta_int = beta_int"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5838756",
   "metadata": {},
   "source": [
    "## 2. NN Setup and train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e1c123f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "modes = 32                  \n",
    "in_channels = 1             \n",
    "ch = 64                     \n",
    "ch_mult = (1, 2, 2)         \n",
    "num_res_blocks = 4          \n",
    "dropout = 0.0               \n",
    "norm = \"group_norm\"         \n",
    "use_pointwise_op = True     \n",
    "use_pos = True              \n",
    "base_resolution = int(upsample_factor*32)# None #64        # adjust from None if upsample\n",
    "\n",
    "score_nn = FNOUNet2d(\n",
    "    modes_height=modes,\n",
    "    modes_width=modes,\n",
    "    in_channels=in_channels,\n",
    "    out_channels=1,              \n",
    "    ch=ch,\n",
    "    ch_mult=ch_mult,\n",
    "    num_res_blocks=num_res_blocks,\n",
    "    dropout=dropout,\n",
    "    norm=norm,\n",
    "    use_pointwise_op=use_pointwise_op,\n",
    "    use_pos=use_pos,\n",
    "    base_resolution=base_resolution,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08d30e89",
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mKeyboardInterrupt\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[10]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m score_nn = \u001b[43mtrain\u001b[49m\u001b[43m(\u001b[49m\u001b[43mscore_nn\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43margs_sde\u001b[49m\u001b[43m,\u001b[49m\u001b[43mckpt_prefix\u001b[49m\u001b[43m \u001b[49m\u001b[43m=\u001b[49m\u001b[43m \u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mrc\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[4]\u001b[39m\u001b[32m, line 40\u001b[39m, in \u001b[36mtrain\u001b[39m\u001b[34m(score_nn, args_sde, ckpt_prefix, B, num_steps, lr, device, ema_decay, n_report, n_vis, n_ckpt)\u001b[39m\n\u001b[32m     38\u001b[39m opt.zero_grad(set_to_none=\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[32m     39\u001b[39m loss = compute_loss(score_nn, sdf_imgs, args_sde)\n\u001b[32m---> \u001b[39m\u001b[32m40\u001b[39m \u001b[43mloss\u001b[49m\u001b[43m.\u001b[49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m     41\u001b[39m opt.step()\n\u001b[32m     43\u001b[39m \u001b[38;5;66;03m# EMA update\u001b[39;00m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/generative-diffusion-bridges/code/.venv/lib/python3.12/site-packages/torch/_tensor.py:625\u001b[39m, in \u001b[36mTensor.backward\u001b[39m\u001b[34m(self, gradient, retain_graph, create_graph, inputs)\u001b[39m\n\u001b[32m    615\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m has_torch_function_unary(\u001b[38;5;28mself\u001b[39m):\n\u001b[32m    616\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m handle_torch_function(\n\u001b[32m    617\u001b[39m         Tensor.backward,\n\u001b[32m    618\u001b[39m         (\u001b[38;5;28mself\u001b[39m,),\n\u001b[32m   (...)\u001b[39m\u001b[32m    623\u001b[39m         inputs=inputs,\n\u001b[32m    624\u001b[39m     )\n\u001b[32m--> \u001b[39m\u001b[32m625\u001b[39m \u001b[43mtorch\u001b[49m\u001b[43m.\u001b[49m\u001b[43mautograd\u001b[49m\u001b[43m.\u001b[49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m    626\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgradient\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minputs\u001b[49m\u001b[43m=\u001b[49m\u001b[43minputs\u001b[49m\n\u001b[32m    627\u001b[39m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/generative-diffusion-bridges/code/.venv/lib/python3.12/site-packages/torch/autograd/__init__.py:354\u001b[39m, in \u001b[36mbackward\u001b[39m\u001b[34m(tensors, grad_tensors, retain_graph, create_graph, grad_variables, inputs)\u001b[39m\n\u001b[32m    349\u001b[39m     retain_graph = create_graph\n\u001b[32m    351\u001b[39m \u001b[38;5;66;03m# The reason we repeat the same comment below is that\u001b[39;00m\n\u001b[32m    352\u001b[39m \u001b[38;5;66;03m# some Python versions print out the first line of a multi-line function\u001b[39;00m\n\u001b[32m    353\u001b[39m \u001b[38;5;66;03m# calls in the traceback and some print out the last line\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m354\u001b[39m \u001b[43m_engine_run_backward\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m    355\u001b[39m \u001b[43m    \u001b[49m\u001b[43mtensors\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    356\u001b[39m \u001b[43m    \u001b[49m\u001b[43mgrad_tensors_\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    357\u001b[39m \u001b[43m    \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    358\u001b[39m \u001b[43m    \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    359\u001b[39m \u001b[43m    \u001b[49m\u001b[43minputs_tuple\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    360\u001b[39m \u001b[43m    \u001b[49m\u001b[43mallow_unreachable\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m    361\u001b[39m \u001b[43m    \u001b[49m\u001b[43maccumulate_grad\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m    362\u001b[39m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/Documents/generative-diffusion-bridges/code/.venv/lib/python3.12/site-packages/torch/autograd/graph.py:841\u001b[39m, in \u001b[36m_engine_run_backward\u001b[39m\u001b[34m(t_outputs, *args, **kwargs)\u001b[39m\n\u001b[32m    839\u001b[39m     unregister_hooks = _register_logging_hooks_on_whole_graph(t_outputs)\n\u001b[32m    840\u001b[39m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m841\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mVariable\u001b[49m\u001b[43m.\u001b[49m\u001b[43m_execution_engine\u001b[49m\u001b[43m.\u001b[49m\u001b[43mrun_backward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m  \u001b[49m\u001b[38;5;66;43;03m# Calls into the C++ engine to run the backward pass\u001b[39;49;00m\n\u001b[32m    842\u001b[39m \u001b[43m        \u001b[49m\u001b[43mt_outputs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\n\u001b[32m    843\u001b[39m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# Calls into the C++ engine to run the backward pass\u001b[39;00m\n\u001b[32m    844\u001b[39m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[32m    845\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m attach_logging_hooks:\n",
      "\u001b[31mKeyboardInterrupt\u001b[39m: "
     ]
    }
   ],
   "source": [
    "score_nn = train(score_nn, args_sde,ckpt_prefix = \"rc\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "147c76b1",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'train_resumable' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mNameError\u001b[39m                                 Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[1]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m score_nn = train_resumable(score_nn, args_sde,ckpt_prefix = \u001b[33m\"\u001b[39m\u001b[33mpc\u001b[39m\u001b[33m\"\u001b[39m, resume_path=\u001b[33m\"\u001b[39m\u001b[33mrc_ckpt_step_475000.pth\u001b[39m\u001b[33m\"\u001b[39m)\n",
      "\u001b[31mNameError\u001b[39m: name 'train_resumable' is not defined"
     ]
    }
   ],
   "source": [
    "score_nn = train_resumable(score_nn, args_sde,ckpt_prefix = \"pc\", resume_path=\"rc_ckpt_step_475000.pth\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "39058924",
   "metadata": {},
   "source": [
    "# Vis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "10b550e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "score_nn = load_checkpoint_train(\n",
    "    \"pc_ckpt_step_700000.pth\",\n",
    "    score_nn,\n",
    "    opt=None,\n",
    "    device=\"cuda\",\n",
    "    lr=1e-4,\n",
    ")[-2]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38b8dae1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "@torch.no_grad()\n",
    "def make_logsnr_grid_from_B(\n",
    "    N: int,\n",
    "    B,                      # callable: B(t)\n",
    "    T: float = 1.0,\n",
    "    eps_t: float = 1e-5,\n",
    "    device=\"cpu\",\n",
    "    M: int = 20000,\n",
    "    eps_stability: float = 1e-12,\n",
    "):\n",
    "    \"\"\"\n",
    "    Reverse-time grid t_0 > ... > t_N with uniform spacing in log-SNR,\n",
    "    using ONLY B(t) (cumulative beta).\n",
    "\n",
    "    Assumes VP form: alpha^2 = exp(-B), sigma^2 = 1 - exp(-B).\n",
    "    \"\"\"\n",
    "\n",
    "    # 1) Fine grid in t\n",
    "    t_fine = torch.linspace(0.0, T - eps_t, M, device=device)\n",
    "    B_fine = B(t_fine).clamp_min(0.0)\n",
    "\n",
    "    # Enforce nondecreasing B (guards tiny numerical nonmonotonicity)\n",
    "    B_fine = torch.maximum(B_fine, torch.cat([B_fine[:1], B_fine[:-1]]))\n",
    "\n",
    "    # 2) Compute log-SNR lambda(t) from B(t)\n",
    "    # lambda = -B - log(1 - exp(-B))\n",
    "    exp_negB = torch.exp(-B_fine).clamp(min=0.0, max=1.0 - eps_stability)\n",
    "    one_minus = (1.0 - exp_negB).clamp_min(eps_stability)\n",
    "    lam_fine = -B_fine - torch.log(one_minus)\n",
    "\n",
    "    # Enforce monotonicity: lam should be nonincreasing in t (since SNR decreases with t)\n",
    "    # We'll invert using an ascending x-axis, so work with -lam which is nondecreasing.\n",
    "    x = (-lam_fine).contiguous()\n",
    "\n",
    "    # Defensive: enforce nondecreasing x\n",
    "    x = torch.maximum(x, torch.cat([x[:1], x[:-1]]))\n",
    "\n",
    "    # 3) Uniform grid in lambda between endpoints\n",
    "    lam_start = lam_fine[0]          # at t=0 (largest)\n",
    "    lam_end   = lam_fine[-1]         # at t=T-eps (smallest)\n",
    "\n",
    "    lam_grid = torch.linspace(lam_end.item(), lam_start.item(), N + 1, device=device)\n",
    "    x_grid = (-lam_grid).contiguous()  # ascending\n",
    "\n",
    "    # 4) Invert x(t) -> t(x) by searchsorted + linear interpolation\n",
    "    idx = torch.searchsorted(x, x_grid, right=True).clamp(1, M - 1)\n",
    "\n",
    "    x0 = x[idx - 1]\n",
    "    x1 = x[idx]\n",
    "    t0 = t_fine[idx - 1]\n",
    "    t1 = t_fine[idx]\n",
    "\n",
    "    w = (x_grid - x0) / (x1 - x0 + eps_stability)\n",
    "    t_grid_asc = t0 + w * (t1 - t0)\n",
    "\n",
    "    # We built from lam_end -> lam_start, which corresponds roughly to large t -> small t,\n",
    "    # so return in reverse-time order: start near T, go to 0\n",
    "    return t_grid_asc.flip(0)\n",
    "\n",
    "t_grid = 1- make_logsnr_grid_from_B(250, cos_B).flip(0).to(device)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbf0f9a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "t_grid = 1- make_logsnr_grid_from_B(500, cos_B).flip(0).to(device)\n",
    "#t_grid = make_time_grid(250, p =1.5, T = args_sde.T)\n",
    "samples = sample_forced_diffusion_trotter(score_nn, 16,t_grid,args_sde)\n",
    "gen_imgs = torch_dct.idct_2d(samples, norm=\"ortho\")                    # (B,64,64)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "a6e4c594",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"348.730435pt\" height=\"347.04pt\" viewBox=\"0 0 348.730435 347.04\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2026-01-28T10:51:44.722945</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.10.8, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 347.04 \n",
       "L 348.730435 347.04 \n",
       "L 348.730435 -0 \n",
       "L 0 -0 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g clip-path=\"url(#p59690784b5)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image4168965a6a\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_2\">\n",
       "   <g clip-path=\"url(#p8b69e7f536)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image45087e9c71\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_3\">\n",
       "   <g clip-path=\"url(#pf18ba273d9)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image0e22dec9f1\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_4\">\n",
       "   <g clip-path=\"url(#p91e0a67db5)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image0f52388582\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-6.793043\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_5\">\n",
       "   <g clip-path=\"url(#p61fa6e3249)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "iVBORw0KGgoAAAANSUhEUgAAAGUAAABlCAYAAABUfC3PAAAObElEQVR4nO2de0wU1xfHv7OwDxZcQJCXLNRu0aDS8LC0FItQrDUErdHUmmpsmramTVtDS2LTFv9obf/owxpJg21slCZ9pJo2BE1pUSyKKSoPtVgg5SEPYZc3LAv7nvP7g7IRBXbZnd0Z+ttPcv7Znbnn3D33nJl77p1ZBgDBi6AQ8W2Al/vxOkWAeJ0iQLxOESBepwgQr1MEiNcpAsTrFAHidYoA8TpFgHidIkC8ThEgXqcIEK9TBIjXKQLE6xQB4nWKAPHl2wBH8ff3R3BwMADAaDRiYGDAofMkEgnCwsIAAFarFRqNBkTCX2ylxSAvvPACjY2N0djYGJ09e9bh81JSUmhkZITGxsaoubmZFAoF732xJ4KPFKlUin379iErKwsKhQIAEB8fj3fffdeh86Ojo6FQKCASTWXq/Px8GAwGWCwWnDhxAkNDQ26z3RV4Hxn3CsMwJJPJyM/PjyIjI0mtVhPXGAwGSkxMJIlEcp9eHx8fvn8D/p1wr6hUKvr777/pn3/+oba2NjKbzZw7hWVZ6ujooGPHjtn0xsXFUWNjI+3du5fX/gsmfUVERCA9PR3AVMqJi4uDWCx2mz6GYRAbG4vk5GTs2LEDAKBUKhEXF4cNGzZgYmICANDe3o7r16+7zY654D0yAFBOTg6xLMt5RLhKUVHR/1ekbN++Ha+99hoAIDQ0FAzD8GnOrGzZsgVxcXEAgOvXr+PAgQNu1+lxpyiVSoSGhgIA0tLSsHHjRk+bsCCio6MRHR0NAFiyZAmSkpIATM2Vmpqa3Dbn8WhoFhUVkdlsJrPZTBaLhe/stCCsVqvN9qamJpLJZIs7fSmVShw4cAAZGRnw9eVO7eDgID7++GMYjUZIpVIUFBQgJCTE9n1HRwc+//xzsCyLwMBAHDx4EHK53CldIpHINt+JiIjA0aNH8csvv+D333/npC934/boCAwMpOzsbM4iw2g0Ul9fH/X19VFNTQ3J5XICQHK5nGpra23f9fX1UVlZGYlEIgJA4eHh1NLSQn19fdTf38/JrfZ77723OCPl5MmTyMrKso0yV7l27Rq2bdsGIgLLspicnAQATE5OYuPGjTP0WCwWsCwLAOjv70dqaioYhoFUKkVlZSVWrlzJiU1c4han+Pr6Yvfu3QgMDAQArFmzBkFBQQtup6qqCvX19QCAtWvXIisrC6dOncLly5fnLI+Mjo7O2R4RYWRkBADg4+OD4uJipKWlITc3F6Wlpejo6AAAbNiwAYmJiQ7Z+Pjjj+PVV1/Fd999B51O53Df7MF5+Pn5+VFra6tT6cBsNpPRaCSj0Uh5eXm2Nl966SXS6/WUkpLCqa1btmwho9FITz/9tO2zw4cPk8lkcnjepNVqacWKFVyWZ4TllNdff50SEhIoISGBQkNDbW0uXbqU1q5dS35+fpzaqlAoKCEhgQICAmyfRUZG0vr162lwcNAhmy0WCzU2NtJHH320eK4pjtDf34+6ujrU1NSgoaHhvu+Hh4cxPDzMuV6tVnufPrVaDZ1Oh/LycgQFBYFhGKSlpdnS8b34+PggPj4ejz32GDZv3gxgKo1euXLFabsEESkLWSPxtPj4+FBdXZ3dPrAsa5M///yTGIZxSh/ny8HPPvssTp06hYiICK6bFjwMw9jEFThPX6tWrUJubu68x1gsFty+fRtWq9X22Z07d7g2hVM6OjoQGhoKpVLp0I/u5+eHVatWobe3F1qtdsH6OA31goICu2Gu0WgoMjKSpFKpTcRiMe9paj6RSCS0efNmh+/IrFYr6fV62rNnz4J1cRYpQUFByM/PR2Zm5rzH/fzzz6ioqMDIyAiMRiNX6t2OyWSC2Wx2+HiRSASZTAYfH58F6+LEKXK5HNHR0cjLy0NAQMCsx1gsFuh0Opw9exbFxcVcqPU4FosFo6Oj8Pf3h0QisXusTqeDyWRySpfLoV1YWEgajYasVuuc4Xzz5k2Kjo621akWo0gkEoqKiqIzZ87YTV+1tbW0fPlyp+ZVnERKcHAwwsPD5z3GbDZDrVbPuLgvNkwmE3p7e6HX6x0+lpxYb+HklphlWbAsuyg2uXEB/VsIdWd/XQ7rBx98kLZu3UoTExPzhrMAtu5wIg899BBt376d9Hr9nP3lffLY3t6OGzduzJuaAgIC8MQTT/wnJpVisRhSqXTe+YpCoUBGRobdtD4XnIyemJgY0mq1c46c6fLDvn37eB/prspPP/1k64+9/jqzh8xjBUkh7lRxFkdKKdPfO9NvTpwyXX5wZGUxJCQESqUSPT09thVBV/D19UVUVNSMzk9MTGBwcNDltu9FJpMhPDwc/v7+Dp8TGhqK6Oho9PT0LOjGwOVwPn78OOl0OodKEAaDgdra2ig4OJiTVBIbG0sajYbGx8dtcuLECbekrczMTBofH1/Q2r5er6fm5mZasmSJZ9OXTCZzePRIpVLI5XLO0plIJEJAQMAM/SkpKTh48CC+/fZbdHV1AQByc3MRFxeHoqKiBZV3UlJSkJOTAwBQqVTw9/dfkO2//fYbqqqqFjyzd3kEffPNNzQxMeFwsU6j0dDy5ctdLkJKJBJavXo16XS6WS+0Tz31FMnlcpLL5XTy5Enq7e2lyMhI22f33rIyDGP7blr279/vcFTcjcViIZ1OR7t373amb647ZdmyZbR+/fpZf5zZMJvNdPv2bXr//fdd0nv06FHq7OyctbzDsiz19PRQa2srtba20tjYmE1va2srNTY2kkqlmtHeypUrqbm52XZOa2sr9ff3O+WUuro6UqlUM5aZHRVO0tfAwACICKdPn0ZKSgoSEhLmPd5isaC+vh7d3d1O6QsLC0NWVhbWrVuHmJiYWY9hGAZRUVH3ff7AAw8AmCr7PPPMM7h27RouX76MjIwMpKamQqVSubRZkIhQUVGB6upqtLe3Oz3r5/Ri6Mh6ilqtpqVLlzqtIzMzk6xWKye79EtKSggA/frrry63xbIsWa1WSk9Pd+k3XJRPB9+4cQPZ2dn4448/XG4rPT0dFy5cQGpqqsttnTt3DtnZ2bh165ZL7XDuFLVajfr6ercuYI2OjqKyshJXrlxBQ0ODS5Xn0NBQZGVlzdh/vFCsViv++usvVFdXo7KyEmNjY063NQ2n6YthGAoICKC2trY5w9zV9HW3LpVK5fANhrvQarUUGxvrdAHyXuE8UogIVqt13gucQqHAkSNHsHPnTpd19ff344033sCZM2dcastV7PV5IbjlmkJEGBgYsO3bvRe5XI69e/ciLS3NZV3j4+MoLi7GpUuXoFaroVar591PzDXj4+Po6+vjpGR0N5ymr2kJDAykF198cd6wP3LkCGf6ZDIZBQcHU3BwML388svuz1n/cujQIQoKCuIsdQFurBKPjY3ZnrCdi6SkJOzfvx/ff/+9yy8ZMBgMMBgMAIC6ujp88cUXAKYe7tm1axdnj2Hci16vd0tkuiVSANCOHTvIYDDMu6HCaDRSYmIi+fr6usWGdevW0eTkJKeP8plMJjIYDGQwGOidd95xh93uc4pCoaDVq1dTdXX1nB1kWZZaW1vd9mi0TCaj+Ph4On36NGdOycvLo/j4eIqPj5/xZABX4tZFLq1Wi8bGxnnTGMMwUKlUc5ZLXMVgMKCpqQmXLl1CYGAgMjMznX5pwsDAAK5evYqamho0NTVxbOlM3BYp03L+/Hm7JRFP7LqPioqikZERu0u5s8GyLJ07d87tNsLdkTJNQUEBHn30URw+fNipbZxcMTQ0hF27dsHX1xdisRiFhYVQKpV2z7NarXj77bdx9epVD1g5hUe8n5ycPO+K3cWLF2nNmjVOlbqdEbFYTKWlpdTQ0EANDQ3zbvowm82UlJTkEbv+FWE4xWq1ktFopJycHI91XiwW26SsrEwwTmGmPeNuwsLC8Pzzz2Pnzp3zzuRLSkrQ3t4OACgtLcXFixc9YR62bduGtLQ05Ofnw8fHBxMTE/jkk0+g0+nAsix++OEHh1+RyAWeDEv66quvHLuyElF+fr5HbYuPjyeNRkNDQ0PU0tLilttdR0QwD6IKgZaWFjz88MNgGAYsy7rlwVdH8DrlLiwWC/r7+/k2w/PvJWZZ1uEyN8MwbqtZCR2P5suYmBjatGkTjY6O2r2mdHV10YULFygkJISX3M6XeDx9dXV1YXx8HJWVlVAoFGAYBo888sism/mUSiUCAgLc+i5JocLrqJBIJHTr1q05o2V4eJgiIiJ4H72eFN4TNhHNe33x9/fH119/jVdeecWDVvEL706xh0QiwdatW/Hkk09ixYoVkEqlfJvkEXgNVbFYTA0NDXYv+iaTibRaLSUnJ/OeXtwtvM9TrFYrvvzyS6Snp2PPnj1z7mi/efMmSkpKoFar52xLLBbjzTffnPHCtzt37uD48eOL7iFZ3kcGANq0aRNptdoZRUuDwUBarZa0Wi0VFhbOe75EIqHw8HDq6OiYEWE1NTWkUCjcttzsJuHdAAKmXkcVExND58+ft/2ghw4dopiYGIqJibG7ee+tt96izs7O+yrRBoOBOjo66LnnnuO9j44K7+lrGr1ej66uLpSVlUGj0QAAqqurbQ/92CMoKGjWJWWpVIrY2FhkZ2fbFtiampp4eX/9QuB9ZHAhH3zwgd2bhWk+/fRT3u21I7wb4JJERkZSeXk5dXZ2OuyU7u5uqqiooNjYWN7tn00EP09xBLFYvKDCpUgkEnzphveR4aqIRCL68MMPHY6Uzz77zPZWbyGKYC70ruDIy2uKi4tRVVUFAGhoaOB8QzaX/CecAkxt/FOr1Vi2bNmMZxZNJhMGBwdRXl6OH3/8kUcLFwbv4cqFSKVSioyMvG/yWFtbS8HBwYJ/R+Xd8p+JFKPRiKGhIRw7dsz2J50A0N3djdHR0UVVZvHYFiMvjvOfuCX+r+F1igDxOkWAeJ0iQLxOESBepwgQr1MEiNcpAuR/JQ/0frqbj28AAAAASUVORK5CYII=\" id=\"image86afe44b91\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_6\">\n",
       "   <g clip-path=\"url(#p5c2aaed8a9)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image6c423aa819\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_7\">\n",
       "   <g clip-path=\"url(#pd53bd6f6fe)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "iVBORw0KGgoAAAANSUhEUgAAAGUAAABlCAYAAABUfC3PAAAFaElEQVR4nO2dPUgbbxzHv3cxjcfZBDGxaCk4RBA6KIIUChZBpODg4i5CUSjoKl06dKirk3RRcfFlKNJFwaEOxpdApQ6+tKlIimgUr6XQqq0c5vef/CNVc7kk9Xme8/eB75QTvuGT53kuuedODQCBkQpddAHmMixFQliKhLAUCWEpEsJSJISlSAhLkRCWIiEsRUJYioSwFAlhKRLCUiTEU1J0XUd9fT2qq6tFV8kb8kpM06Tt7W0aGxsT3iWfaFD8Ilc4HEZ/fz8CgQCKiorQ1tYGy7IQi8XQ39+PRCIhumJOCP9k5JqysjJ6/PgxHR8f09+k02lqb2+n8vJy4T1ziPACOWdkZIR+/fpF6XT6SilHR0c0NzdHuq4L7+omSi/0hmGgpKQEmqZdek3TNJimiWg0ihcvXqC2tlZAw9woEl0gF3RdRyAQgM/nczz2wYMHeP36NX78+IFEIoE/f/7cQMP8ET5c3ebRo0f05csX+vnz56Vp6zoODg5oYWGB7t69K7y/U5QcKYZhIBqNXjltXcfu7i42Nzdxdnb2D5sVBiWlnENEjmKICADw5s0bDA8P30StgiB8uLpNaWkpNTc309zcnOO09enTJ2ppaaHKykrhvV1EeIGcMzEx4SglHo/zKTGTP0qvKZkgIgwMDGBpaen/dUUVPCsFAN69e4dYLCa6hmt4+pIQliIhLEVCWIqEsBQJYSkSwlIkhKVICEuREJYiISxFQliKhLAUCWEpEsJSJISlSAhLkRCWIiGellJRUYGKigrRNVzjaSmjo6MYHx+Hrqv1NtVq6wJN02AYBgzDEF3FNZ7dzUJEOD09VWaX/UU8KwUAOjs7EYvFkE6nRVdxhWenLwBIpVJIpVKia7jG01Lc3CohG8I3NLtNXV0dvX//ng4ODq7d2J1Op+njx480ODhImqYJ7+wywgu4TlNT05U3n17F2toaNTQ0UDgcFt4723h6+gKAhw8fYnl5GW1tbaKrZI2SUhKJBLq7u/HhwwfHYzVNg8/nU2p9UVLK/v4+hoaGsL29nfXfhEIhRCIRZeQIn0NzTTZ3cp1zdHREGxsbFAwGhfd2ipIj5Zzp6WkMDw/Dtm3HY03TRCgU4pFyE6mqqqLv37+TbdsZR4pt25RMJikUCgnvnEWEF8grfr+fampqaHBwMKOUly9fUnV1tRI3pSr/25dt2/j8+TO+ffuW8bhUKoWtra0bapUfSq8pXuXWSOnt7cXo6ChM0xRdxRHlpy+/349oNIpIJJLxuNraWoTDYRQVyf+W5W/owP3797G4uIhgMCi6SkERfraRT4LBIPX09NDs7GzGs6/JyUnq6uqiQCAgvHMWEV6gIHn16lVGKc+ePRPeMdvcmoVeJViKhHhCiq7rjr9p6bqu1P4v4XNoPqmsrKT5+Xna29vLuKYkk0mamZmhkpIS4Z2dovwpcSAQQH19veOXwqqqKvj9/qye0CoadcbzLUJ5KYeHh+jo6MDbt29FVykYyks5Pj7G1NQUFhYWkEwmr73gZVkWdnZ2lNktKXxhK0T8fj9FIhH6+vXrlQv98+fPyTAM4T2zifIj5RzbtnFycnLt8yJbW1vR09OD4uLiG26WG8I/GYWKaZq0vr5Ov3//vnK07O7uKnE52DMjBQBOTk7w9OlT9PX1ia6SF8p/T7kIEWFvbw+WZV16LR6PY2VlJaudL6LxlJSL/L22DA0N8bPuRSYSiVBjYyOtrq7SxsYGPXnyhO7duye8V7bx5EixLAuWZSEej+POnTuIxWJKPcVb+f9el4nzX45VEgJ4XIqqeOqU2CuwFAlhKRLCUiSEpUgIS5EQliIhLEVCWIqEsBQJYSkSwlIk5D+sjUSwNbAbeAAAAABJRU5ErkJggg==\" id=\"imagec8a53ae00d\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_8\">\n",
       "   <g clip-path=\"url(#p1806d92163)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image7169eeda0a\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-93.568696\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_9\">\n",
       "   <g clip-path=\"url(#pa0794597db)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image87e170dcd7\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_10\">\n",
       "   <g clip-path=\"url(#p13b11a420e)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image2bb986aad4\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_11\">\n",
       "   <g clip-path=\"url(#pa4e13905d7)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "iVBORw0KGgoAAAANSUhEUgAAAGUAAABlCAYAAABUfC3PAAAKwElEQVR4nO2dbWxT1R/Hv/e2XR/ZlnVbAVeQsRkJwbHiiDE8DHwIsqgJPtS5SAhzIeMFqMTFSEIiGBMxISHESAJoomygmGyRqjF9wQtgGQbEZ3wosE1ncOwB15W1vbf354v91z8dD1vbe+85m/eT/BK46z3ne+6353fuPee0FQAQDLhCZC3A4GYMUzjEMIVDDFM4xDCFQwxTOMQwhUMMUzjEMIVDDFM4xDCFQwxTOMQwhUMMUzjEMIVDDFM4xDCFQ7g2JS8vD3fddRdEMVWm1WpFSUkJ7HY7I2XawrUpr776Ktrb21FYWJhyfOnSpfjxxx/x2GOPMVKmLWbWAm6F2+1GfX09VqxYgaKiImzduhXDw8PJv5eWliI3NxfPPPMMPB4PDh48CEmSGCpWH+IhRFEku91OdrudKisrKRqN0mS4fPkyud1ustvtZLPZSBCEZJk5OTlktVqZty3dEMDJbpaVK1fiwIEDAICcnBzMmTMHgiBMeJ4kSeju7oaiKLh+/TpqamrQ09MDAGhubobVasWzzz4LRVE01a8mTNKX1WrFo48+ipycnOQxn8+HsrKySRlxIxaLBfPnzwcARKNRPP7447h69SoAYPHixbBYLFi3bh2ICCMjIwgGg1Mi1enePT0eD/X19U0qPanJn3/+Sfn5+czT00Sh+93XSy+9hE8++QS5ubl6V43CwkK0traioaEBFosFhw4dQjAYRDAYRFVVle56bofu6evee+/FihUr9K4WwGjarK6uRldXF7777jusWrUK8+bNAxFh6dKlCIfD+OWXX5hoG4+uXXP//v26p63xJBIJkiSJFEVJHpNlmc6fP09ms5l5+tKtp3i9XjQ1NWHZsmV6VXlbRFG8aZbAZDLB6/Vi3759UBQFkUgEu3btQjgc1l2fbrfEPp8PZ86cgdk88ftAlmUMDg7C6XTC4XDooO5mBgYGsGzZMvT19QEABgcHIcuyLnVzOc1y8eJF3Hffffjggw+YacjPz8epU6dw4cIF/PDDD1iwYIFudeuWvnp7e7Fv3z48/PDDWLRo0R1fm5eXh9raWvT392Pv3r3J44IgwO/3w+PxaC0XoiiioKAAwGjPnUwPVxNuB/pt27al3r+LIrW3t980SGuNJElUVVVFJpNpej6nZIOiKFi/fj02bdqka70mkwnNzc147733dKmPy1niOxEKheBwOPDll1+mTMmUlZWhvLxckzoFQUB5eTm6uro0KX88U84UAPj+++9RU1OTcuyNN97Ajh07GClSF67T14YNG3D48GHk5+dP+NqWlhb4/X78/fffmumpqKhAW1sbHnzwQc3qADg3pbi4GOXl5ZO68/n111/x+eefY2RkRDM9RUVFePLJJzF79mzN6gA4N2XPnj1Yvnx58gHuvwLXpsiyjHg8PunXx+NxvPXWW2hubtZQFfDCCy+gqalJs2cXrk1JF0mScODAAQQCAU3reeKJJ/Diiy/CYrFoUv60MmW6wLUpVVVVqKurS3t/16VLl/D+++/jypUrGikDcnNzsX79elRUVGhSPrfTLEREAwMDNHPmzIzqOnHiBMmynIxEIqH69Mz27dtJFMWpuZ7CgsbGxpRl58LCQhw9ehQzZsxQrY5NmzbhoYcewnPPPYfe3l5VytTNFJfLhcrKSsyaNSut88xmMx544AH09/cDAM6fP5+yMe9OjF/adbvdOHnyJFwuFwRBwJIlS7Jer5FlGbFYDETqLkvpkrZ8Ph/F4/G004eiKMmQJInuv/9+VfRYrVb6+eefVUlfal8rXQd6QRDS3tc1do4gCDCZTNi1axdef/31rLVIkoSmpibU1dWhrq4O3377bUblqN1DAB3TVywWQ1dXF4qLizPO6YIgYM2aNcjLy0NLSwt6e3tx/fr1jMpSFCXleeaRRx5JzrEVFBRMuAVKkiT89ddf+OeffzKqfyJ0SV+iKJLT6aRDhw5lnTJkWaZwOExPPfWUavpsNhs5nU5yOp307rvvTqghFApRYWEhWSwW1a+Vbj1lbIdIW1sbBgcHsXnz5ow/X2IymeByueD3+zF79mzs378/662o0Wg0+e9AIIBIJILGxka4XK7k8UuXLuHw4cMAgP7+fly7dk2zzRS69JQbQ81tqxcvXiSHw6G6xoKCArp8+TINDw8nIxAI6HJ9pvVzSjZcu3YN1dXVMJlMyWNaLgvcCBNTotEoWltb4fP54PP5Mi6nvb0dZ8+eRSKRUFHdKIqi6Lb8eyt0T19jsXXr1qxSl9/vZ6Zdy+B6QvK/CpP0ZTabsXDhQni93ozOHxoawm+//YaBgQGVlfGD7t3T4/FQb28vJRKJjNLWiRMndNsYxyKYpK+hoSFs27YNx44dy+h8ItJkcOcFJulrZGQEH330EWw2G1auXAm3263Z0upUhOlA/+GHH6KiogKhUIilDO5gakosFsPg4GDaqcjr9eLll1/GPffco5Ey9jAd1CwWC33zzTcUj8eN5xSWA/2NSJKEp59+Glu2bNFkbWIqwtwUYHT2tbu7O+3zfD4fVq9enTI/NV1g3l0B0Nq1azPaaaLVLDHjYC6AAFBxcTHV1NTQmTNn0jIlEonQF198QcePH6djx45RcXEx87ZMG1PG4vjx42n3ljHC4TDNnTuXeRuyDS7GFINUuDPl4MGDePvtt3X7zDqvMO+u42PBggWT/hK2GxkeHqaKigpyOp3M25BNcNdTssFutyMYDOKdd95hLSUrppUpoiiiqKhoUp+R5BluTUkkEpBlGYlEIu0n/bHdlFMZ5jl0fNhsNvL5fLRkyRKqrq6mq1evpjW29Pf309dff02VlZXM25JhMBdwx3C5XPTpp5/ShQsX0jJGURTasmUL+Xw+5m2YdqaMRUNDQ1qmjBnT0dGh+od6DFP+F6WlpeT3+ykUCqVlTF9fH3388ce0atUq5m2YdqYAo5vEW1tbqaenJ+3Jy9dee41KS0uptLSUCgoKmLdl2pgCjN4ErFmzJm1TotFock/wm2++ybwdd4opt5c4Go2m7JCfLFarFVarFQCwevVq7Ny5E8DoR/BaWlpU1agGzN8Z6cby5ctpaGgooyXk8QQCAXK5XORyuXhal2EuIO2wWq00Z84c+uyzz7I2JRKJUGdnJ3V2dtJXX3313/oKXDWJxWLo7u5GJBLJuiyHw4G5c+cCGJ2mqa2tRSKRQCwWQyAQQCwWy7qOTGD+zsg0jhw5knVPuR19fX3k8XiYtIvbuS/W5Obmoq2tDa+88orudU/J9DVGKBRCR0cHAKCkpAQlJSWqlm+xWHT/6tsxmKehTEMQBBJFkURRpJ07d6qevmbOnJnyy0U6BvuLq0ZUVlZSY2Nj2jPKt6K5uZmef/55stlsrNrD/oKqFQ6Hgzo6OmhgYCAjM+LxOPX09FB9fT3rtrC/mGrGjBkzaOPGjRmZ8tNPP5Hb7aacnBymbZjSA/2tCIfDOHfuHHbv3o3a2trkt28rigKXy4X6+nrYbLZbnptIJDA0NMTFb3Yxf3drFcFgkE6ePJlcT5k1axZduXLlltMzsViMzp49y8UT/bQ2xev1puyYNJvNVF5eTrt3704xRFEUamhooLvvvpu5ZmAapq8b+eOPP1L+L8syfv/9d5w+fRplZWUpfzt37hw6Ozt1VHd7uPnxTYP/Y0yzcIhhCocYpnCIYQqHGKZwyL88h9ah5rCo1wAAAABJRU5ErkJggg==\" id=\"imageec3ca73f24\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_12\">\n",
       "   <g clip-path=\"url(#p02a0b6c401)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagee78154f6bf\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-180.344348\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_13\">\n",
       "   <g clip-path=\"url(#p34c7d39dea)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagee2c96f11a6\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"7.2\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_14\">\n",
       "   <g clip-path=\"url(#pe9aefdc1cd)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagee25ca528c2\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"94.53913\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_15\">\n",
       "   <g clip-path=\"url(#pf44162a9ef)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"imagec5f353fca0\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"181.878261\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       "  <g id=\"axes_16\">\n",
       "   <g clip-path=\"url(#p48532dccd5)\">\n",
       "    <image xlink:href=\"data:image/png;base64,\n",
       "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\" id=\"image86d297788f\" transform=\"scale(1 -1) translate(0 -72.72)\" x=\"269.217391\" y=\"-267.12\" width=\"72.72\" height=\"72.72\"/>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p59690784b5\">\n",
       "   <rect x=\"7.2\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p8b69e7f536\">\n",
       "   <rect x=\"94.53913\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pf18ba273d9\">\n",
       "   <rect x=\"181.878261\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p91e0a67db5\">\n",
       "   <rect x=\"269.217391\" y=\"7.2\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p61fa6e3249\">\n",
       "   <rect x=\"7.2\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p5c2aaed8a9\">\n",
       "   <rect x=\"94.53913\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pd53bd6f6fe\">\n",
       "   <rect x=\"181.878261\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p1806d92163\">\n",
       "   <rect x=\"269.217391\" y=\"93.975652\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pa0794597db\">\n",
       "   <rect x=\"7.2\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p13b11a420e\">\n",
       "   <rect x=\"94.53913\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pa4e13905d7\">\n",
       "   <rect x=\"181.878261\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p02a0b6c401\">\n",
       "   <rect x=\"269.217391\" y=\"180.751304\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p34c7d39dea\">\n",
       "   <rect x=\"7.2\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pe9aefdc1cd\">\n",
       "   <rect x=\"94.53913\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"pf44162a9ef\">\n",
       "   <rect x=\"181.878261\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       "  <clipPath id=\"p48532dccd5\">\n",
       "   <rect x=\"269.217391\" y=\"267.526957\" width=\"72.313043\" height=\"72.313043\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<Figure size 600x600 with 16 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "vis_mask(gen_imgs, title = None, figsize=(6,6))\n",
    "None"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "80d5c4e9",
   "metadata": {},
   "source": [
    "# Eval"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "96c8a7f3",
   "metadata": {},
   "source": [
    "### Preprocesing Funcs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc20b744",
   "metadata": {},
   "outputs": [],
   "source": [
    "def from_sdf_to_mask(x: torch.Tensor) -> torch.Tensor:\n",
    "    return (x < 0.).float()\n",
    "\n",
    "def ensure_nchw_1ch(x: torch.Tensor) -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    Accept:\n",
    "      - (B,H,W)  -> (B,1,H,W)\n",
    "      - (B,1,H,W)-> (B,1,H,W)\n",
    "    \"\"\"\n",
    "    if x.ndim == 3:\n",
    "        return x.unsqueeze(1)\n",
    "    if x.ndim == 4 and x.shape[1] == 1:\n",
    "        return x\n",
    "    raise ValueError(f\"Expected (B,H,W) or (B,1,H,W), got {tuple(x.shape)}\")\n",
    "\n",
    "def upsample_to_64(x_1ch: torch.Tensor, upsample_module=None) -> torch.Tensor:\n",
    "    if upsample_module is None:\n",
    "        return x_1ch\n",
    "    return upsample_module(x_1ch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "cc27fcf7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def preprocess_to_inception_uint8(\n",
    "    x_1ch_float_01: torch.Tensor,\n",
    "    interpolation: str = \"bilinear\",\n",
    "    antialias: bool = False,\n",
    ") -> torch.Tensor:\n",
    "    \"\"\"\n",
    "      - resize to 299x299 with F.interpolate(mode=..., align_corners=False, antialias=...)\n",
    "      - if 1ch: repeat to 3ch\n",
    "      - (x*255).clamp(0,255).uint8\n",
    "    Input MUST be float in [0,1] with shape (B,1,H,W) or (B,3,H,W).\n",
    "    Output: uint8 (B,3,299,299)\n",
    "    \"\"\"\n",
    "    if x_1ch_float_01.dtype not in (torch.float16, torch.float32, torch.float64):\n",
    "        raise ValueError(f\"Expected float tensor, got {x_1ch_float_01.dtype}\")\n",
    "\n",
    "    # optional sanity: repo assumes [0,1] before scaling to 255\n",
    "    # (do not clamp here unless you want to deviate; I keep it strict)\n",
    "    if torch.isfinite(x_1ch_float_01).all():\n",
    "        mn = float(x_1ch_float_01.min().item())\n",
    "        mx = float(x_1ch_float_01.max().item())\n",
    "        if mn < -1e-6 or mx > 1.0 + 1e-6:\n",
    "            raise ValueError(f\"Expected x in [0,1], got min={mn}, max={mx}\")\n",
    "\n",
    "    # resize to 299x299 (repo tensor-mode path)\n",
    "    x = F.interpolate(\n",
    "        x_1ch_float_01,\n",
    "        size=(299, 299),\n",
    "        mode=interpolation,\n",
    "        align_corners=False,\n",
    "        antialias=antialias,\n",
    "    )\n",
    "\n",
    "    # gray -> rgb\n",
    "    if x.shape[1] == 1:\n",
    "        x = x.repeat(1, 3, 1, 1)\n",
    "\n",
    "    # float [0,1] -> uint8 [0,255]\n",
    "    x = (x * 255.0).clamp(0, 255).to(torch.uint8)\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09637fe7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Preprocessing pipeline..\n",
    "#  starting point: images in SDF space B,H,W, generated by \n",
    "# samples = sample_forced_diffusion_trotter(score_nn, 16,t_grid,args_sde)\n",
    "# gen_imgs = torch_dct.idct_2d(samples, norm=\"ortho\")                    # (B,64,64)\n",
    "\n",
    "gen_imgs.shape\n",
    "# binary masked images with valeus in {0,1}\n",
    "masked_imgs = from_sdf_to_mask(gen_imgs)\n",
    "\n",
    "# \n",
    "masked_imgs = ensure_nchw_1ch(masked_imgs) # (B,1, H,W), H = W = 64\n",
    "\n",
    "# Preprocess: \n",
    "gen_imgs_preprocessed = preprocess_to_inception_uint8(masked_imgs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "684a44ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([16, 3, 299, 299])"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gen_imgs_preprocessed.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb0ea36",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "5805772a",
   "metadata": {},
   "source": [
    "## Other Funcs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "35365ce2",
   "metadata": {},
   "outputs": [],
   "source": [
    "_feature_detector_cache = dict()\n",
    "\n",
    "def get_feature_detector(url, cache_dir=None, device=torch.device('cpu'), num_gpus=1, rank=0, verbose=False):\n",
    "    assert 0 <= rank < num_gpus\n",
    "    key = (url, device)\n",
    "    if key not in _feature_detector_cache:\n",
    "        is_leader = (rank == 0)\n",
    "        if not is_leader and num_gpus > 1:\n",
    "            torch.distributed.barrier() # leader goes first\n",
    "        with dnnlib.util.open_url(url, cache_dir=cache_dir, verbose=(verbose and is_leader)) as f:\n",
    "            _feature_detector_cache[key] = pickle.load(f).to(device)\n",
    "        if is_leader and num_gpus > 1:\n",
    "            torch.distributed.barrier() # others follow\n",
    "    return _feature_detector_cache[key]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "0f263c63",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading https://api.ngc.nvidia.com/v2/models/nvidia/research/stylegan3/versions/1/files/metrics/inception-2015-12-05.pkl ... done\n",
      "torch.Size([16, 2048])\n"
     ]
    }
   ],
   "source": [
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "detector = get_feature_detector(\n",
    "    url=\"https://api.ngc.nvidia.com/v2/models/nvidia/research/stylegan3/versions/1/files/metrics/inception-2015-12-05.pkl\",\n",
    "    cache_dir=\"./fid_cache\",\n",
    "    device=device,\n",
    "    num_gpus=1,\n",
    "    rank=0,\n",
    "    verbose=True,\n",
    ")\n",
    "detector.eval()\n",
    "\n",
    "with torch.no_grad():\n",
    "    feats = detector(gen_imgs_preprocessed.to(device), return_features=True)\n",
    "\n",
    "print(feats.shape)   # expected: (B, 2048)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43503e90",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "@torch.no_grad()\n",
    "def collect_real_features(\n",
    "    detector,\n",
    "    real_loader,\n",
    "    device,\n",
    "    num_real: int,\n",
    "    upsample_module=None,\n",
    "    interpolation=\"bilinear\",\n",
    "    antialias=False,\n",
    "    print_every=1000,          # print every this many real samples\n",
    "):\n",
    "    feats = []\n",
    "    seen = 0\n",
    "    last_print = 0\n",
    "\n",
    "    for sdf_imgs, _labels in real_loader:\n",
    "        if seen >= num_real:\n",
    "            break\n",
    "\n",
    "        sdf_imgs = sdf_imgs.to(device)  # (B,1,32,32)\n",
    "\n",
    "        if upsample_module is not None:\n",
    "            sdf_imgs = upsample_module(sdf_imgs)  # (B,1,64,64)\n",
    "\n",
    "        mask = (sdf_imgs < 0.).float()  # (B,1,H,W)\n",
    "\n",
    "        x_uint8 = preprocess_to_inception_uint8(\n",
    "            mask,\n",
    "            interpolation=interpolation,\n",
    "            antialias=antialias,\n",
    "        )  # (B,3,299,299) uint8\n",
    "\n",
    "        f = detector(x_uint8, return_features=True)  # (B,2048)\n",
    "        feats.append(f.cpu())\n",
    "        seen += f.shape[0]\n",
    "\n",
    "        if seen - last_print >= print_every or seen >= num_real:\n",
    "            print(f\"[real FID] processed {min(seen, num_real)}/{num_real}\")\n",
    "            last_print = seen\n",
    "\n",
    "    feats = torch.cat(feats, dim=0)[:num_real]\n",
    "    return feats\n",
    "\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def collect_gen_features(\n",
    "    detector,\n",
    "    gen_sampler_fn,               # returns (B,64,64)\n",
    "    device,\n",
    "    num_gen: int,\n",
    "    interpolation=\"bilinear\",\n",
    "    antialias=False,\n",
    "    print_every=1000,             # print every this many samples\n",
    "):\n",
    "    feats = []\n",
    "    seen = 0\n",
    "    last_print = 0\n",
    "\n",
    "    while seen < num_gen:\n",
    "        gen_imgs = gen_sampler_fn().to(device)       # (B,64,64)\n",
    "\n",
    "        mask = (gen_imgs.unsqueeze(1) < 0.).float()  # (B,1,64,64)\n",
    "\n",
    "        x_uint8 = preprocess_to_inception_uint8(\n",
    "            mask,\n",
    "            interpolation=interpolation,\n",
    "            antialias=antialias,\n",
    "        )                                            # (B,3,299,299) uint8\n",
    "\n",
    "        f = detector(x_uint8, return_features=True)  # (B,2048)\n",
    "        feats.append(f.cpu())\n",
    "        seen += f.shape[0]\n",
    "\n",
    "        if seen - last_print >= print_every or seen >= num_gen:\n",
    "            print(f\"[gen FID] processed {min(seen, num_gen)}/{num_gen}\")\n",
    "            last_print = seen\n",
    "\n",
    "    feats = torch.cat(feats, dim=0)[:num_gen]\n",
    "    return feats\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "ff347c15",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_frechet_distance(mu1, sigma1, mu2, sigma2, eps=1e-6):\n",
    "    \"\"\"Numpy implementation of the Frechet Distance.\n",
    "    The Frechet distance between two multivariate Gaussians X_1 ~ N(mu_1, C_1)\n",
    "    and X_2 ~ N(mu_2, C_2) is\n",
    "            d^2 = ||mu_1 - mu_2||^2 + Tr(C_1 + C_2 - 2*sqrt(C_1*C_2)).\n",
    "    Stable version by Dougal J. Sutherland.\n",
    "    Params:\n",
    "    -- mu1   : Numpy array containing the activations of a layer of the\n",
    "               inception net (like returned by the function 'get_predictions')\n",
    "               for generated samples.\n",
    "    -- mu2   : The sample mean over activations, precalculated on an\n",
    "               representative data set.\n",
    "    -- sigma1: The covariance matrix over activations for generated samples.\n",
    "    -- sigma2: The covariance matrix over activations, precalculated on an\n",
    "               representative data set.\n",
    "    Returns:\n",
    "    --   : The Frechet Distance.\n",
    "    \"\"\"\n",
    "\n",
    "    mu1 = np.atleast_1d(mu1)\n",
    "    mu2 = np.atleast_1d(mu2)\n",
    "\n",
    "    sigma1 = np.atleast_2d(sigma1)\n",
    "    sigma2 = np.atleast_2d(sigma2)\n",
    "\n",
    "    assert mu1.shape == mu2.shape, \\\n",
    "        'Training and test mean vectors have different lengths'\n",
    "    assert sigma1.shape == sigma2.shape, \\\n",
    "        'Training and test covariances have different dimensions'\n",
    "\n",
    "    diff = mu1 - mu2\n",
    "\n",
    "    # Product might be almost singular\n",
    "    covmean, _ = linalg.sqrtm(sigma1.dot(sigma2), disp=False)\n",
    "    if not np.isfinite(covmean).all():\n",
    "        msg = ('fid calculation produces singular product; '\n",
    "               'adding %s to diagonal of cov estimates') % eps\n",
    "        print(msg)\n",
    "        offset = np.eye(sigma1.shape[0]) * eps\n",
    "        covmean = linalg.sqrtm((sigma1 + offset).dot(sigma2 + offset))\n",
    "\n",
    "    # Numerical error might give slight imaginary component\n",
    "    if np.iscomplexobj(covmean):\n",
    "        if not np.allclose(np.diagonal(covmean).imag, 0, atol=1e-3):\n",
    "            m = np.max(np.abs(covmean.imag))\n",
    "            raise ValueError('Imaginary component {}'.format(m))\n",
    "        covmean = covmean.real\n",
    "\n",
    "    tr_covmean = np.trace(covmean)\n",
    "\n",
    "    return (diff.dot(diff) + np.trace(sigma1) +\n",
    "            np.trace(sigma2) - 2 * tr_covmean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "31df1ddd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def fid_from_features(real_features: torch.Tensor, gen_features: torch.Tensor) -> float:\n",
    "    real_np = real_features.numpy()\n",
    "    gen_np  = gen_features.numpy()\n",
    "\n",
    "    m0 = np.mean(real_np, axis=0)\n",
    "    s0 = np.cov(real_np, rowvar=False)\n",
    "\n",
    "    m  = np.mean(gen_np, axis=0)\n",
    "    s  = np.cov(gen_np, rowvar=False)\n",
    "\n",
    "    return float(calculate_frechet_distance(m0, s0, m, s))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "a31cef67",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_fid_repo_style_end_to_end(\n",
    "    real_loader,\n",
    "    gen_sampler_fn,\n",
    "    device,\n",
    "    num_real=10000,\n",
    "    num_gen=5000,\n",
    "    upsample_module=None,\n",
    "    detector_cache_dir=\"./fid_cache\",\n",
    "    interpolation=\"bilinear\",\n",
    "    antialias=False,\n",
    "):\n",
    "    detector_url = \"https://api.ngc.nvidia.com/v2/models/nvidia/research/stylegan3/versions/1/files/metrics/inception-2015-12-05.pkl\"\n",
    "\n",
    "    detector = get_feature_detector(\n",
    "        url=detector_url,\n",
    "        cache_dir=detector_cache_dir,\n",
    "        device=device,\n",
    "        num_gpus=1,\n",
    "        rank=0,\n",
    "        verbose=True,\n",
    "    )\n",
    "    detector.eval()\n",
    "\n",
    "    real_features = collect_real_features(\n",
    "        detector,\n",
    "        real_loader,\n",
    "        device=device,\n",
    "        num_real=num_real,\n",
    "        upsample_module=upsample_module,\n",
    "        interpolation=interpolation,\n",
    "        antialias=antialias,\n",
    "    )\n",
    "\n",
    "    gen_features = collect_gen_features(\n",
    "        detector,\n",
    "        gen_sampler_fn,\n",
    "        device=device,\n",
    "        num_gen=num_gen,\n",
    "        interpolation=interpolation,\n",
    "        antialias=antialias,\n",
    "    )\n",
    "\n",
    "    # sanity\n",
    "    assert torch.isfinite(real_features).all(), \"real features contain NaN/Inf\"\n",
    "    assert torch.isfinite(gen_features).all(),  \"gen features contain NaN/Inf\"\n",
    "\n",
    "    fid = fid_from_features(real_features, gen_features)\n",
    "    return fid, real_features, gen_features\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "b400c0d0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[gen FID] processed 1024/5000\n",
      "[gen FID] processed 2048/5000\n",
      "[gen FID] processed 3072/5000\n",
      "[gen FID] processed 4096/5000\n",
      "[gen FID] processed 5000/5000\n",
      "FID: 4.833100609685346\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_966419/2099528689.py:34: DeprecationWarning: The `disp` argument is deprecated and will be removed in SciPy 1.18.0.\n",
      "  covmean, _ = linalg.sqrtm(sigma1.dot(sigma2), disp=False)\n"
     ]
    }
   ],
   "source": [
    "# Your generator sampler wrapper must return (B,64,64)\n",
    "B = 32\n",
    "def gen_sampler_fn():\n",
    "    samples = sample_forced_diffusion_trotter(score_nn, B, t_grid, args_sde)  # (B,64,64) in SDF space\n",
    "    gen_imgs = torch_dct.idct_2d(samples, norm=\"ortho\")                       # (B,64,64)\n",
    "    return gen_imgs\n",
    "\n",
    "fid, real_feats, gen_feats = compute_fid_repo_style_end_to_end(\n",
    "    real_loader=loader,\n",
    "    gen_sampler_fn=gen_sampler_fn,\n",
    "    device=device,\n",
    "    num_real=10000,\n",
    "    num_gen=5000,\n",
    "    upsample_module=upsample,           # 32->64 for real\n",
    "    detector_cache_dir=\"./fid_cache\",\n",
    "    interpolation=\"bilinear\",\n",
    "    antialias=False,\n",
    ")\n",
    "\n",
    "print(\"FID:\", fid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e139cf8f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bea1dd8a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "2ea9270f",
   "metadata": {},
   "source": [
    "## Estimate h(0,x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9dca3589",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6 (700001, 374, namespace(upsample_factor=2, T=1.0, beta_min=0.1, beta_max=20, gamma=0.05, H=64, W=64, A=tensor([[0.4959, 0.5554, 0.5178,  ..., 0.8812, 0.8812, 0.8812],\n",
      "        [0.5630, 0.4957, 0.5402,  ..., 0.8812, 0.8812, 0.8812],\n",
      "        [0.5318, 0.5430, 0.5628,  ..., 0.8812, 0.8812, 0.8812],\n",
      "        ...,\n",
      "        [0.8812, 0.8812, 0.8812,  ..., 0.8812, 0.8812, 0.8812],\n",
      "        [0.8812, 0.8812, 0.8812,  ..., 0.8812, 0.8812, 0.8812],\n",
      "        [0.8812, 0.8812, 0.8812,  ..., 0.8812, 0.8812, 0.8812]],\n",
      "       device='cuda:0'), Q=tensor([[1.1687e+00, 1.3592e-01, 5.1534e-01,  ..., 2.1068e-05, 2.1068e-05,\n",
      "         2.1068e-05],\n",
      "        [1.0477e-01, 1.1791e+00, 2.2969e-01,  ..., 2.1068e-05, 2.1068e-05,\n",
      "         2.1068e-05],\n",
      "        [3.1000e-01, 2.0863e-01, 1.0545e-01,  ..., 2.1068e-05, 2.1068e-05,\n",
      "         2.1068e-05],\n",
      "        ...,\n",
      "        [2.1068e-05, 2.1068e-05, 2.1068e-05,  ..., 2.1068e-05, 2.1068e-05,\n",
      "         2.1068e-05],\n",
      "        [2.1068e-05, 2.1068e-05, 2.1068e-05,  ..., 2.1068e-05, 2.1068e-05,\n",
      "         2.1068e-05],\n",
      "        [2.1068e-05, 2.1068e-05, 2.1068e-05,  ..., 2.1068e-05, 2.1068e-05,\n",
      "         2.1068e-05]], device='cuda:0'), beta=<function beta at 0x707b340df740>, beta_int=<function beta_int at 0x707b340df7e0>), FNOUNet2d(\n",
      "  (act): SiLU()\n",
      "  (temb_net): TimestepEmbedding(\n",
      "    (main): Sequential(\n",
      "      (0): Linear(in_features=64, out_features=256, bias=True)\n",
      "      (1): SiLU()\n",
      "      (2): Linear(in_features=256, out_features=256, bias=True)\n",
      "    )\n",
      "  )\n",
      "  (lifting): Conv2d(3, 64, kernel_size=(1, 1), stride=(1, 1))\n",
      "  (down_modules): ModuleList(\n",
      "    (0): ModuleDict(\n",
      "      (0a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0b_downsample): SpectralDownsample2d(\n",
      "        (down): Downsample2d(\n",
      "          scale_factor=0.5,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (down): ModuleList(\n",
      "            (0): _Downsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (1): ModuleDict(\n",
      "      (1a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(64, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (1a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (1a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (1b_downsample): SpectralDownsample2d(\n",
      "        (down): Downsample2d(\n",
      "          scale_factor=0.5,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (down): ModuleList(\n",
      "            (0): _Downsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (2): ModuleDict(\n",
      "      (2a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (2a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (2a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (2a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "    )\n",
      "  )\n",
      "  (mid_modules): ModuleList(\n",
      "    (0-1): 2 x SpectralResidualBlock2d(\n",
      "      (cond_type): improved\n",
      "      (act): SiLU()\n",
      "      (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "      (norm1): SpectralGroupNorm(\n",
      "        (num_groups): 32\n",
      "        (num_channels): 128\n",
      "        (modes_height): 16\n",
      "        (affine): True\n",
      "        (cutoff): True\n",
      "      )\n",
      "      (conv1): SpectralConv2d(\n",
      "        128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "        (skip): PointwiseOp(\n",
      "          (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "        )\n",
      "      )\n",
      "      (norm2): SpectralGroupNorm(\n",
      "        (num_groups): 32\n",
      "        (num_channels): 128\n",
      "        (modes_height): 16\n",
      "        (affine): True\n",
      "        (cutoff): True\n",
      "      )\n",
      "      (conv2): SpectralConv2d(\n",
      "        128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "        (skip): PointwiseOp(\n",
      "          (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "        )\n",
      "      )\n",
      "      (shortcut): Identity()\n",
      "    )\n",
      "  )\n",
      "  (up_modules): ModuleList(\n",
      "    (0): ModuleDict(\n",
      "      (2a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_4a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2b_upsample): SpectralUpsample2d(\n",
      "        (up): Upsample2d(\n",
      "          scale_factor=2,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (up): ModuleList(\n",
      "            (0): _Upsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (1): ModuleDict(\n",
      "      (1a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_4a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 192\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          192, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(192, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(192, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1b_upsample): SpectralUpsample2d(\n",
      "        (up): Upsample2d(\n",
      "          scale_factor=2,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (up): ModuleList(\n",
      "            (0): _Upsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (2): ModuleDict(\n",
      "      (0a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 192\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          192, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(192, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(192, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_4a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "    )\n",
      "  )\n",
      "  (projection): Sequential(\n",
      "    (0): SiLU()\n",
      "    (1): Conv2d(64, 1, kernel_size=(1, 1), stride=(1, 1))\n",
      "  )\n",
      "), FNOUNet2d(\n",
      "  (act): SiLU()\n",
      "  (temb_net): TimestepEmbedding(\n",
      "    (main): Sequential(\n",
      "      (0): Linear(in_features=64, out_features=256, bias=True)\n",
      "      (1): SiLU()\n",
      "      (2): Linear(in_features=256, out_features=256, bias=True)\n",
      "    )\n",
      "  )\n",
      "  (lifting): Conv2d(3, 64, kernel_size=(1, 1), stride=(1, 1))\n",
      "  (down_modules): ModuleList(\n",
      "    (0): ModuleDict(\n",
      "      (0a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (0b_downsample): SpectralDownsample2d(\n",
      "        (down): Downsample2d(\n",
      "          scale_factor=0.5,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (down): ModuleList(\n",
      "            (0): _Downsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (1): ModuleDict(\n",
      "      (1a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          64, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(64, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (1a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (1a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (1b_downsample): SpectralDownsample2d(\n",
      "        (down): Downsample2d(\n",
      "          scale_factor=0.5,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (down): ModuleList(\n",
      "            (0): _Downsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (2): ModuleDict(\n",
      "      (2a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (2a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (2a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "      (2a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Identity()\n",
      "      )\n",
      "    )\n",
      "  )\n",
      "  (mid_modules): ModuleList(\n",
      "    (0-1): 2 x SpectralResidualBlock2d(\n",
      "      (cond_type): improved\n",
      "      (act): SiLU()\n",
      "      (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "      (norm1): SpectralGroupNorm(\n",
      "        (num_groups): 32\n",
      "        (num_channels): 128\n",
      "        (modes_height): 16\n",
      "        (affine): True\n",
      "        (cutoff): True\n",
      "      )\n",
      "      (conv1): SpectralConv2d(\n",
      "        128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "        (skip): PointwiseOp(\n",
      "          (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "        )\n",
      "      )\n",
      "      (norm2): SpectralGroupNorm(\n",
      "        (num_groups): 32\n",
      "        (num_channels): 128\n",
      "        (modes_height): 16\n",
      "        (affine): True\n",
      "        (cutoff): True\n",
      "      )\n",
      "      (conv2): SpectralConv2d(\n",
      "        128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "        (skip): PointwiseOp(\n",
      "          (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "        )\n",
      "      )\n",
      "      (shortcut): Identity()\n",
      "    )\n",
      "  )\n",
      "  (up_modules): ModuleList(\n",
      "    (0): ModuleDict(\n",
      "      (2a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2a_4a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 16\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (2b_upsample): SpectralUpsample2d(\n",
      "        (up): Upsample2d(\n",
      "          scale_factor=2,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (up): ModuleList(\n",
      "            (0): _Upsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          128, 128, modes_height=16, modes_width=16, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (1): ModuleDict(\n",
      "      (1a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 256\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          256, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(256, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1a_4a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=256, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 192\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          192, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(192, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(192, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (1b_upsample): SpectralUpsample2d(\n",
      "        (up): Upsample2d(\n",
      "          scale_factor=2,\n",
      "          stopband_rel=1.23114,\n",
      "          filter_size=9,\n",
      "          use_radial=False,\n",
      "          (up): ModuleList(\n",
      "            (0): _Upsample2d(\n",
      "              (dct): LinearDCT(\n",
      "                (dct_type): dct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "              (idct): LinearDCT(\n",
      "                (dct_type): idct\n",
      "                (dim): 2\n",
      "                (norm): None\n",
      "              )\n",
      "            )\n",
      "          )\n",
      "        )\n",
      "        (conv): SpectralConv2d(\n",
      "          128, 128, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 128, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "      )\n",
      "    )\n",
      "    (2): ModuleDict(\n",
      "      (0a_0a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 192\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          192, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(192, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(192, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_1a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_2a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_3a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "      (0a_4a_block): SpectralResidualBlock2d(\n",
      "        (cond_type): improved\n",
      "        (act): SiLU()\n",
      "        (temb_proj): Linear(in_features=256, out_features=128, bias=True)\n",
      "        (norm1): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 128\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv1): SpectralConv2d(\n",
      "          128, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (norm2): SpectralGroupNorm(\n",
      "          (num_groups): 32\n",
      "          (num_channels): 64\n",
      "          (modes_height): 32\n",
      "          (affine): True\n",
      "          (cutoff): True\n",
      "        )\n",
      "        (conv2): SpectralConv2d(\n",
      "          64, 64, modes_height=32, modes_width=32, fft_norm=forward, separable=False\n",
      "          (skip): PointwiseOp(\n",
      "            (conv): Conv2d(64, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "          )\n",
      "        )\n",
      "        (shortcut): Conv2d(128, 64, kernel_size=(1, 1), stride=(1, 1), bias=False)\n",
      "      )\n",
      "    )\n",
      "  )\n",
      "  (projection): Sequential(\n",
      "    (0): SiLU()\n",
      "    (1): Conv2d(64, 1, kernel_size=(1, 1), stride=(1, 1))\n",
      "  )\n",
      "), Adam (\n",
      "Parameter Group 0\n",
      "    amsgrad: False\n",
      "    betas: (0.9, 0.999)\n",
      "    capturable: False\n",
      "    decoupled_weight_decay: False\n",
      "    differentiable: False\n",
      "    eps: 1e-08\n",
      "    foreach: None\n",
      "    fused: None\n",
      "    lr: 0.0001\n",
      "    maximize: False\n",
      "    weight_decay: 0\n",
      "))\n"
     ]
    }
   ],
   "source": [
    "ckpt = load_checkpoint_train(\n",
    "    \"pc_ckpt_step_700000.pth\",\n",
    "    score_nn,\n",
    "    opt=None,\n",
    "    device=\"cuda\",\n",
    "    lr=1e-4,\n",
    ")\n",
    "\n",
    "# Inspect what you got\n",
    "print(len(ckpt), ckpt)\n",
    "\n",
    "# Example: suppose it returns (step, opt, model, ema_model)\n",
    "start_step, start_epoch, ckpt_args_sde, score_nn, ema_score_nn, opt = ckpt\n",
    "\n",
    "# Keep what you want\n",
    "\n",
    "# Kill everything else\n",
    "del ckpt, ckpt_args_sde, opt, score_nn\n",
    "import gc, torch\n",
    "gc.collect()\n",
    "torch.cuda.empty_cache()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "007a5efb",
   "metadata": {},
   "source": [
    "## Test h(0,X_0), X_0 \\sim N(0,C)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6aa5381f",
   "metadata": {},
   "outputs": [],
   "source": [
    "@torch.no_grad()\n",
    "def mc_mean_score(\n",
    "    score_nn,\n",
    "    Q, A,\n",
    "    H, W,\n",
    "    device,\n",
    "    num_samples=1000,\n",
    "    batch_size=1,\n",
    "    t_value=1e-2,\n",
    "):\n",
    "    score_nn.eval().to(device)\n",
    "\n",
    "    C = Q / (2.0 * A)  # (H,W)\n",
    "\n",
    "    mean = torch.zeros(1, H, W, device=\"cpu\", dtype=torch.float32)\n",
    "    n_batches = 0\n",
    "\n",
    "    for k in range(0, num_samples, batch_size):\n",
    "        bs = min(batch_size, num_samples - k)\n",
    "\n",
    "        # Sample Y in DCT space\n",
    "        Y = torch.sqrt(C)[None, :, :] * torch.randn(\n",
    "            bs, H, W, device=device, dtype=Q.dtype\n",
    "        )\n",
    "\n",
    "        v = make_v_grid(bs, H, W, device=device, dtype=Y.dtype)\n",
    "        x_img = torch_dct.idct_2d(Y, norm=\"ortho\").unsqueeze(1)\n",
    "        t = torch.full((bs,), t_value, device=device, dtype=torch.float32)\n",
    "\n",
    "        score_img = score_nn(x=x_img, temp=t, v=v)   # (bs,1,H,W)\n",
    "\n",
    "        # accumulate on CPU\n",
    "        mean += score_img.mean(dim=0).float().cpu()\n",
    "        n_batches += 1\n",
    "\n",
    "        # free memory aggressively\n",
    "        del Y, v, x_img, t, score_img\n",
    "        torch.cuda.empty_cache()\n",
    "\n",
    "    return mean / n_batches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "1e62d277",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_score = mc_mean_score(\n",
    "    score_nn=ema_score_nn,\n",
    "    Q=Q, A=A,\n",
    "    H=H, W=W,\n",
    "    device=device,\n",
    "    num_samples=1000,\n",
    "    batch_size=200,\n",
    "    t_value=1e-5,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "9bc09531",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0334)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(mean_score)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eec54ceb",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.13.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
