{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "59cd92c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "import numpy as np\n",
    "import torch\n",
    "from model.network_swinir_mask import SwinIR\n",
    "from data.dataset_multi_noise import *\n",
    "from test import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7c00af94",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed=0\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)\n",
    "torch.cuda.seed_all()\n",
    "device=\"cuda:0\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bb164b77",
   "metadata": {},
   "source": [
    "# Load the pretrained model: masked SwinIR in MT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a32c3550",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\User\\anaconda3\\lib\\site-packages\\torch\\functional.py:504: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at ..\\aten\\src\\ATen\\native\\TensorShape.cpp:3484.)\n",
      "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "SwinIR(\n",
       "  (conv_first): Conv2d(3, 60, kernel_size=(1, 1), stride=(1, 1))\n",
       "  (patch_embed): PatchEmbed(\n",
       "    (norm): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "  )\n",
       "  (patch_unembed): PatchUnEmbed()\n",
       "  (pos_drop): Dropout(p=0.0, inplace=False)\n",
       "  (layers): ModuleList(\n",
       "    (0): RSTB(\n",
       "      (residual_group): BasicLayer(\n",
       "        dim=60, input_resolution=(64, 64), depth=6\n",
       "        (blocks): ModuleList(\n",
       "          (0): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): Identity()\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (1): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.004)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (2): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.009)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (3): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.013)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (4): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.017)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (5): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.022)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "      (conv): Sequential(\n",
       "        (0): Conv2d(60, 15, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "        (1): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (2): Conv2d(15, 15, kernel_size=(1, 1), stride=(1, 1))\n",
       "        (3): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (4): Conv2d(15, 60, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "      )\n",
       "      (patch_embed): PatchEmbed()\n",
       "      (patch_unembed): PatchUnEmbed()\n",
       "    )\n",
       "    (1): RSTB(\n",
       "      (residual_group): BasicLayer(\n",
       "        dim=60, input_resolution=(64, 64), depth=6\n",
       "        (blocks): ModuleList(\n",
       "          (0): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.026)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (1): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.030)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (2): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.035)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (3): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.039)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (4): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.043)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (5): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.048)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "      (conv): Sequential(\n",
       "        (0): Conv2d(60, 15, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "        (1): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (2): Conv2d(15, 15, kernel_size=(1, 1), stride=(1, 1))\n",
       "        (3): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (4): Conv2d(15, 60, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "      )\n",
       "      (patch_embed): PatchEmbed()\n",
       "      (patch_unembed): PatchUnEmbed()\n",
       "    )\n",
       "    (2): RSTB(\n",
       "      (residual_group): BasicLayer(\n",
       "        dim=60, input_resolution=(64, 64), depth=6\n",
       "        (blocks): ModuleList(\n",
       "          (0): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.052)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (1): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.057)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (2): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.061)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (3): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.065)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (4): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.070)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (5): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.074)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "      (conv): Sequential(\n",
       "        (0): Conv2d(60, 15, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "        (1): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (2): Conv2d(15, 15, kernel_size=(1, 1), stride=(1, 1))\n",
       "        (3): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (4): Conv2d(15, 60, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "      )\n",
       "      (patch_embed): PatchEmbed()\n",
       "      (patch_unembed): PatchUnEmbed()\n",
       "    )\n",
       "    (3): RSTB(\n",
       "      (residual_group): BasicLayer(\n",
       "        dim=60, input_resolution=(64, 64), depth=6\n",
       "        (blocks): ModuleList(\n",
       "          (0): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.078)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (1): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.083)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (2): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.087)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (3): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.091)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (4): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=0, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.096)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (5): SwinTransformerBlock(\n",
       "            dim=60, input_resolution=(64, 64), num_heads=6, window_size=8, shift_size=4, mlp_ratio=2\n",
       "            (norm1): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (attn): WindowAttention(\n",
       "              dim=60, window_size=(8, 8), num_heads=6\n",
       "              (qkv): Linear(in_features=60, out_features=180, bias=True)\n",
       "              (attn_drop): Dropout(p=0.0, inplace=False)\n",
       "              (proj): Linear(in_features=60, out_features=60, bias=True)\n",
       "              (proj_drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "            (drop_path): DropPath(drop_prob=0.100)\n",
       "            (norm2): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "            (mlp): Mlp(\n",
       "              (fc1): Linear(in_features=60, out_features=120, bias=True)\n",
       "              (act): GELU(approximate='none')\n",
       "              (fc2): Linear(in_features=120, out_features=60, bias=True)\n",
       "              (drop): Dropout(p=0.0, inplace=False)\n",
       "            )\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "      (conv): Sequential(\n",
       "        (0): Conv2d(60, 15, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "        (1): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (2): Conv2d(15, 15, kernel_size=(1, 1), stride=(1, 1))\n",
       "        (3): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "        (4): Conv2d(15, 60, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "      )\n",
       "      (patch_embed): PatchEmbed()\n",
       "      (patch_unembed): PatchUnEmbed()\n",
       "    )\n",
       "  )\n",
       "  (norm): LayerNorm((60,), eps=1e-05, elementwise_affine=True)\n",
       "  (conv_after_body): Sequential(\n",
       "    (0): Conv2d(60, 15, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "    (1): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "    (2): Conv2d(15, 15, kernel_size=(1, 1), stride=(1, 1))\n",
       "    (3): LeakyReLU(negative_slope=0.2, inplace=True)\n",
       "    (4): Conv2d(15, 60, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "  )\n",
       "  (conv_last): Conv2d(60, 3, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       ")"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "opt_net= {\n",
    "      \"net_type\": \"swinir\"\n",
    "      , \"upscale\": 1\n",
    "      , \"in_chans\": 3\n",
    "      , \"img_size\": 64\n",
    "      , \"window_size\": 8\n",
    "      , \"img_range\": 1.0\n",
    "      , \"depths\": [6, 6, 6, 6]\n",
    "      , \"embed_dim\": 60\n",
    "      , \"num_heads\": [6, 6, 6, 6]\n",
    "      , \"mlp_ratio\": 2\n",
    "      , \"upsampler\": None        \n",
    "      , \"resi_connection\": \"3conv\"        \n",
    "\n",
    "      , \"init_type\": \"default\"\n",
    "\n",
    "      , \"talking_heads\": False\n",
    "      , \"attn_fn\": \"softmax\"\n",
    "      , \"head_scale\": False\n",
    "      , \"on_attn\": False\n",
    "\n",
    "      , \"use_mask\": True         \n",
    "      , \"mask_ratio1\": 75        \n",
    "      , \"mask_ratio2\": 75        \n",
    "      , \"mask_is_diff\": False\n",
    "\n",
    "      , \"type\": \"stand\"\n",
    "\n",
    "    }\n",
    "net = SwinIR(upscale=opt_net['upscale'],\n",
    "                   in_chans=opt_net['in_chans'],\n",
    "                   img_size=opt_net['img_size'],\n",
    "                   window_size=opt_net['window_size'],\n",
    "                   img_range=opt_net['img_range'],\n",
    "                   depths=opt_net['depths'],\n",
    "                   embed_dim=opt_net['embed_dim'],\n",
    "                   num_heads=opt_net['num_heads'],\n",
    "                   mlp_ratio=opt_net['mlp_ratio'],\n",
    "                   upsampler=opt_net['upsampler'],\n",
    "                   resi_connection=opt_net['resi_connection'],\n",
    "                   talking_heads=opt_net['talking_heads'], \n",
    "                   use_attn_fn=opt_net['attn_fn'],                   \n",
    "                   head_scale=opt_net['head_scale'],                   \n",
    "                   on_attn=opt_net['on_attn'],     \n",
    "                   use_mask=opt_net['use_mask'],     \n",
    "                   mask_ratio1=opt_net['mask_ratio1'],     \n",
    "                   mask_ratio2=opt_net['mask_ratio2'],     \n",
    "                   mask_is_diff=opt_net['mask_is_diff'],     \n",
    "                   type=opt_net['type'],     \n",
    "                   opt=opt_net,     \n",
    "                   )\n",
    "pretrained_model = torch.load(\"model_zoo/input_mask_80_90.pth\")\n",
    "net.load_state_dict(pretrained_model, strict=True)\n",
    "net.eval()\n",
    "net.to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "05594d77",
   "metadata": {},
   "source": [
    "## Test speckle noise σ^2 = 0.024"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e9330342",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: MultiNoise. Only dataroot_H is needed.\n",
      "img name testsets/McMaster/1.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 25.818816262771065/0.7970442145697686/0\n",
      "img name testsets/McMaster/10.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.317400553319917/0.7901563761825492/0\n",
      "img name testsets/McMaster/11.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.79355780749626/0.7507917276032151/0\n",
      "img name testsets/McMaster/12.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.15167716585269/0.8755140353456609/0\n",
      "img name testsets/McMaster/13.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 34.26499668845429/0.8904084153892956/0\n",
      "img name testsets/McMaster/14.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.079572464212085/0.8039206917524163/0\n",
      "img name testsets/McMaster/15.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.655715027263792/0.6989053740420023/0\n",
      "img name testsets/McMaster/16.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.510305725553554/0.7796066175766173/0\n",
      "img name testsets/McMaster/17.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.568434863638338/0.795909109017589/0\n",
      "img name testsets/McMaster/18.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.57337241136924/0.8096817092094085/0\n",
      "img name testsets/McMaster/2.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.485632835810172/0.7727225058773478/0\n",
      "img name testsets/McMaster/3.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.087954583085484/0.8611879026850984/0\n",
      "img name testsets/McMaster/4.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 26.933743806850806/0.8181214994804599/0\n",
      "img name testsets/McMaster/5.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.103772491865794/0.8045124236505474/0\n",
      "img name testsets/McMaster/6.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.132628158598376/0.8455323081984263/0\n",
      "img name testsets/McMaster/7.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.075474426748002/0.786750645228035/0\n",
      "img name testsets/McMaster/8.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.920668973115376/0.6721032121152003/0\n",
      "img name testsets/McMaster/9.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.25206906852897/0.8228991824279136/0\n",
      "testset McMaster, iter_time iter_time, avg psnr/ssim/psnrb is 30.21/0.7987/0.0\n"
     ]
    }
   ],
   "source": [
    "# replace the H_path and L_path with yours\n",
    "H_path=\"testsets/McMaster/\"\n",
    "L_path=\"testsets/McMaster_speckle_0.024/\"\n",
    "test_loader=create_dataset_simple(H_path,L_path)\n",
    "# format: model,device_name, testset,iter_time,test_loader\n",
    "test_backbone(net,device, \"McMaster\",\"iter_time\",test_loader)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9fb085f7",
   "metadata": {},
   "source": [
    "## Test salt & pepper noise d=0.004"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f511c1c3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: MultiNoise. Only dataroot_H is needed.\n",
      "img name testsets/McMaster/1.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 26.84383413804147/0.8008132487055443/0\n",
      "img name testsets/McMaster/10.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.508231500335015/0.7984066115457281/0\n",
      "img name testsets/McMaster/11.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.821869114278517/0.7532239039919597/0\n",
      "img name testsets/McMaster/12.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.23794818330185/0.889043529873109/0\n",
      "img name testsets/McMaster/13.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 33.88971650347518/0.9162999913609736/0\n",
      "img name testsets/McMaster/14.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.19610215639015/0.8113953145797862/0\n",
      "img name testsets/McMaster/15.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.67393717450796/0.7045706099715273/0\n",
      "img name testsets/McMaster/16.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.940180010507962/0.7880893022089022/0\n",
      "img name testsets/McMaster/17.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.522280158262628/0.7903710843376816/0\n",
      "img name testsets/McMaster/18.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.519497508120203/0.8193500542124782/0\n",
      "img name testsets/McMaster/2.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.974697915688928/0.776909043689714/0\n",
      "img name testsets/McMaster/3.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.925382397868574/0.894178913140289/0\n",
      "img name testsets/McMaster/4.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.079969612780832/0.9351053881120253/0\n",
      "img name testsets/McMaster/5.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.893536100656874/0.8507036320259721/0\n",
      "img name testsets/McMaster/6.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.056713521164156/0.8372584211821478/0\n",
      "img name testsets/McMaster/7.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.66412509303383/0.7995393441219033/0\n",
      "img name testsets/McMaster/8.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.16078991531235/0.6771867353806033/0\n",
      "img name testsets/McMaster/9.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.736539332338705/0.8523789086963057/0\n",
      "testset McMaster, iter_time iter_time, avg psnr/ssim/psnrb is 30.76/0.8164/0.0\n"
     ]
    }
   ],
   "source": [
    "# replace the H_path and L_path with yours\n",
    "H_path=\"testsets/McMaster/\"\n",
    "L_path=\"testsets/McMaster_sp_0.004/\"\n",
    "test_loader=create_dataset_simple(H_path,L_path)\n",
    "# format: model,device_name, testset,iter_time,test_loader\n",
    "test_backbone(net,device, \"McMaster\",\"iter_time\",test_loader)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5687d2c5",
   "metadata": {},
   "source": [
    "## Test poisson noise alpha=1.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "83fe8b55",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: MultiNoise. Only dataroot_H is needed.\n",
      "img name testsets/McMaster/1.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 26.52723486095496/0.8034270920762782/0\n",
      "img name testsets/McMaster/10.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.661720482964082/0.800886500520674/0\n",
      "img name testsets/McMaster/11.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.92745069104528/0.7529902273410736/0\n",
      "img name testsets/McMaster/12.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.394541911658045/0.887125190186803/0\n",
      "img name testsets/McMaster/13.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 34.40121397745357/0.9113459365578981/0\n",
      "img name testsets/McMaster/14.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.44174258389364/0.8159685511693807/0\n",
      "img name testsets/McMaster/15.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.85605370771399/0.7035860888481067/0\n",
      "img name testsets/McMaster/16.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.938604360767396/0.7895619662463417/0\n",
      "img name testsets/McMaster/17.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.641233029285075/0.7969490966805751/0\n",
      "img name testsets/McMaster/18.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.938762730563337/0.8232472296899943/0\n",
      "img name testsets/McMaster/2.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.97009355377604/0.7841555838366979/0\n",
      "img name testsets/McMaster/3.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.721898979209413/0.8920738573125995/0\n",
      "img name testsets/McMaster/4.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.28553991726552/0.927098957607615/0\n",
      "img name testsets/McMaster/5.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.03707430776518/0.8536271347517469/0\n",
      "img name testsets/McMaster/6.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.236159177883707/0.848192855826165/0\n",
      "img name testsets/McMaster/7.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.874857377159607/0.8197705643169239/0\n",
      "img name testsets/McMaster/8.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.27577474879707/0.6762253309116248/0\n",
      "img name testsets/McMaster/9.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.72627016470489/0.8493786377557013/0\n",
      "testset McMaster, iter_time iter_time, avg psnr/ssim/psnrb is 30.77/0.8186/0.0\n"
     ]
    }
   ],
   "source": [
    "# replace the H_path with yours, poisson noise will be automatically generated and controlled by scale alpha\n",
    "H_path=\"testsets/McMaster/\"\n",
    "noise_opt={\"noise_type\":\"Poisson Noise\",\"alpha\":1.5}\n",
    "test_loader=create_dataset(H_path,noise_opt)\n",
    "# format: model,device_name, testset,iter_time,test_loader\n",
    "test_backbone(net,device, \"McMaster\",\"iter_time\",test_loader)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "984c3a82",
   "metadata": {},
   "source": [
    "## Test mixture noise Level 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "26b45ab2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: MultiNoise. Only dataroot_H is needed.\n",
      "img name testsets/McMaster/1.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 26.384918948549757/0.7994766732116476/0\n",
      "img name testsets/McMaster/10.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.569763683005903/0.7982201627269127/0\n",
      "img name testsets/McMaster/11.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.85197905614411/0.7519731462925213/0\n",
      "img name testsets/McMaster/12.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.35873864411427/0.8862962329668194/0\n",
      "img name testsets/McMaster/13.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 34.35972429450664/0.9130847234999558/0\n",
      "img name testsets/McMaster/14.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.307300945790956/0.8131048206334061/0\n",
      "img name testsets/McMaster/15.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.78794518036986/0.7039500950484664/0\n",
      "img name testsets/McMaster/16.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.860678135620024/0.7861976616666267/0\n",
      "img name testsets/McMaster/17.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.553686067085344/0.792690820817016/0\n",
      "img name testsets/McMaster/18.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.545740261707962/0.8204072092167678/0\n",
      "img name testsets/McMaster/2.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.872138620413452/0.7793488534535666/0\n",
      "img name testsets/McMaster/3.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.78817328978664/0.8922785627468692/0\n",
      "img name testsets/McMaster/4.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.233351610772726/0.9283306861621775/0\n",
      "img name testsets/McMaster/5.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.03137298655083/0.8520572213033043/0\n",
      "img name testsets/McMaster/6.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.2045738267448/0.8434511555321992/0\n",
      "img name testsets/McMaster/7.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.89414176819796/0.8155766508035632/0\n",
      "img name testsets/McMaster/8.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.25727842289421/0.6781329609736265/0\n",
      "img name testsets/McMaster/9.tif,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.740049990279164/0.8501206724562581/0\n",
      "testset McMaster, iter_time iter_time, avg psnr/ssim/psnrb is 30.7/0.8169/0.0\n"
     ]
    }
   ],
   "source": [
    "# replace the H_path and L_path with yours\n",
    "H_path=\"testsets/McMaster/\"\n",
    "L_path=\"testsets/McMaster_speckle_0.004_sp_0.002/\"\n",
    "# follow the mixture order in our paper, poisson noise with scale 1 will be added subsequently\n",
    "noise_opt={\"noise_type\":\"Poisson Noise\",\"alpha\":1}\n",
    "test_loader=create_dataset_mix(H_path,L_path,noise_opt)\n",
    "# format: model,device_name, testset,iter_time,test_loader\n",
    "test_backbone(net,device, \"McMaster\",\"iter_time\",test_loader)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67ec460f",
   "metadata": {},
   "source": [
    "## Test ISP noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "de334f72",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: MultiNoise. Only dataroot_H is needed.\n",
      "img name testsets/McMaster_ISP_gt/0.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 27.69894118638237/0.7788774459855127/0\n",
      "img name testsets/McMaster_ISP_gt/1.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.50732089432662/0.8770239539886372/0\n",
      "img name testsets/McMaster_ISP_gt/10.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.92661154033354/0.8213655887636415/0\n",
      "img name testsets/McMaster_ISP_gt/11.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.987173772038698/0.8146021650870868/0\n",
      "img name testsets/McMaster_ISP_gt/12.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 29.00354786119435/0.8992340675050268/0\n",
      "img name testsets/McMaster_ISP_gt/13.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 26.613876628524736/0.7438619454714067/0\n",
      "img name testsets/McMaster_ISP_gt/14.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.961118829061043/0.8655392284236537/0\n",
      "img name testsets/McMaster_ISP_gt/15.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.50085776978444/0.8106841520216802/0\n",
      "img name testsets/McMaster_ISP_gt/16.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.60657843174691/0.8737939431289923/0\n",
      "img name testsets/McMaster_ISP_gt/17.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 27.279516331599595/0.7507133860887735/0\n",
      "img name testsets/McMaster_ISP_gt/2.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 32.235606616902295/0.8484329639221432/0\n",
      "img name testsets/McMaster_ISP_gt/3.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 31.971576874763826/0.9010018113358016/0\n",
      "img name testsets/McMaster_ISP_gt/4.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 33.779045801168806/0.9227543586633348/0\n",
      "img name testsets/McMaster_ISP_gt/5.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 33.3405110431297/0.892980014176524/0\n",
      "img name testsets/McMaster_ISP_gt/6.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 25.667117772477074/0.6331395949706575/0\n",
      "img name testsets/McMaster_ISP_gt/7.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.9390756451074/0.7368667993190933/0\n",
      "img name testsets/McMaster_ISP_gt/8.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 30.31846675374328/0.8261061574328082/0\n",
      "img name testsets/McMaster_ISP_gt/9.png,testset McMaster, iter_time iter_time, psnr/ssim/psnrb is 28.297940092295114/0.8198075672117376/0\n",
      "testset McMaster, iter_time iter_time, avg psnr/ssim/psnrb is 30.15/0.8232/0.0\n"
     ]
    }
   ],
   "source": [
    "# replace the H_path and L_path with yours\n",
    "H_path=\"testsets/McMaster_ISP_gt/\"\n",
    "L_path=\"testsets/McMaster_ISP_noise/\"\n",
    "test_loader=create_dataset_simple(H_path,L_path)\n",
    "# format: model,device_name, testset,iter_time,test_loader\n",
    "test_backbone(net,device, \"McMaster\",\"iter_time\",test_loader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "41554ad4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'2.0.1+cu118'"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.__version__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09e31840",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
