{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "2ee3e4ed-3129-4a89-80ea-2a815b7e2fd4",
   "metadata": {},
   "outputs": [],
   "source": [
    "from kornia.augmentation import RandomJPEG\n",
    "from compressai.zoo import load_state_dict\n",
    "from Network import TestModel\n",
    "from src.helpers.utils import load_model\n",
    "from src.helpers.utils import logger_setup\n",
    "from default_config import ModelModes\n",
    "from torchvision import transforms,datasets\n",
    "from torchvision.models import ResNet50_Weights\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from PIL import Image\n",
    "preproces_t = transforms.Compose([transforms.Resize((256,256)),transforms.CenterCrop((224,224)),transforms.ToTensor()]) \n",
    "testset = datasets.Imagenette(root='./data', split='val', download=False, transform=preproces_t)\n",
    "indices = np.random.choice(len(testset), 100, replace=False)\n",
    "testset = torch.utils.data.Subset(testset, indices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "2b02dbd5-1930-4563-9dd7-15b73f6e9bb8",
   "metadata": {},
   "outputs": [],
   "source": [
    "def rescale(img: np.array) -> np.array:\n",
    "        \"\"\"Function to scale an image from float to uint8\n",
    "\n",
    "        :param:img : np.array -- the image to rescale\n",
    "        :return: rescaled image as numpy array\n",
    "        \"\"\"\n",
    "        return (img * 255.9999).astype(np.uint8)\n",
    "\n",
    "def jpeg_encode(image,path,q):\n",
    "    image = image.squeeze().permute(1, 2, 0)\n",
    "    im = Image.fromarray(rescale(image.numpy()), mode='RGB')\n",
    "    im.save(path, \"JPEG\", quality=q)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "cf3f1ed2-78ba-40cc-9f8f-fb47d7c8cdf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "def bpp(path):\n",
    "    file_size = os.path.getsize(path)\n",
    "    return (file_size*8)/(224*224)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "b9d68532-989f-4563-b402-62bcdec9e261",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_loader = torch.utils.data.DataLoader(testset, batch_size=1,\n",
    "                                                 shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "79ee5540-4ccd-4aa6-a996-d359635da28b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_jpeg(q):\n",
    "    bpps = []\n",
    "    for i,(image,target) in enumerate(data_loader):\n",
    "        jpeg_encode(image,f'images/{i}.jpeg',q)\n",
    "    for f in os.listdir('images/'):\n",
    "        bpps.append(bpp('images/'+f))\n",
    "    return sum(bpps)/len(bpps)\n",
    "    \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "f5085311-795d-4bd2-80b6-b16b48e0062a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BPP for 5:0.3501480728429984\n",
      "BPP for 10:0.4806684431198222\n",
      "BPP for 15:0.5924160815316224\n",
      "BPP for 25:0.7788489467569204\n",
      "BPP for 35:0.9383445519296828\n",
      "BPP for 50:1.138601232572237\n",
      "BPP for 75:1.650194483734088\n",
      "BPP for 95:3.7962877601535645\n"
     ]
    }
   ],
   "source": [
    "for q in [5,10,15,25,35,50,75,95]:\n",
    "    print(f'BPP for {q}:{test_jpeg(q)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "1beb0119-d932-446d-a165-0d4160b61717",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BPP for 1:0.03517223334259446\n"
     ]
    }
   ],
   "source": [
    "print(f'BPP for {1}:{test_jpeg(1)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "c0039e31-ad6c-414f-bdcf-0c07cd8502a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "class ELIC():\n",
    "    def __init__(self,weights = '0016'):\n",
    "        self.state_dict = load_state_dict(torch.load(f'data/ELIC_{weights}_ft_3980_Plateau.pth.tar'))\n",
    "        self.model = TestModel().from_state_dict(self.state_dict)\n",
    "        self.model = self.model.to(torch.device('cuda' if torch.cuda.is_available() else 'cpu'))\n",
    "        self.model.eval()\n",
    "    def compress(self,x):\n",
    "        x = transforms.Resize((256,256))(x)\n",
    "        return self.model.compress(x)['strings']\n",
    "        \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "ed3e8eef-e636-4909-84e7-3acbc37fbd1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_ELIC(weights):\n",
    "    elic_model = ELIC(weights = weights)\n",
    "    bpps = []\n",
    "    for i,(image,target) in enumerate(data_loader):\n",
    "        strings = elic_model.compress(image)\n",
    "        bpp = 0\n",
    "        for s in strings:\n",
    "            for j in s:\n",
    "                if isinstance(j, list):\n",
    "                    for i in j:\n",
    "                        if isinstance(i, list):\n",
    "                            for k in i:\n",
    "                                bpp += len(k)\n",
    "                        else:\n",
    "                            bpp += len(i)\n",
    "                else:\n",
    "                    bpp += len(j)\n",
    "        bpp *= 8.0 / (256*256)\n",
    "        bpps.append(bpp)\n",
    "    return sum(bpps)/100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "c6a7f54c-4a42-4108-81d7-20dfe6b03b28",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1055095/911578149.py:3: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  self.state_dict = load_state_dict(torch.load(f'data/ELIC_{weights}_ft_3980_Plateau.pth.tar'))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BPP for 0004:0.063408203125\n",
      "BPP for 0008:0.093271484375\n",
      "BPP for 0016:0.135673828125\n",
      "BPP for 0032:0.19384765625\n",
      "BPP for 0150:0.41533203125\n",
      "BPP for 0450:0.6925927734375\n"
     ]
    }
   ],
   "source": [
    "for q in ['0004','0008','0016','0032','0150','0450']:\n",
    "    print(f'BPP for {q}:{test_ELIC(q)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cc767e53-7c5d-442a-a596-06023e898317",
   "metadata": {},
   "outputs": [],
   "source": [
    "class HiFiC():\n",
    "\n",
    "    def __init__(self, weights='hific_low.pt',):\n",
    "\n",
    "        self.device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        self.logger = logger_setup(logpath=os.path.join('data/logs/', 'logs'), filepath=os.path.abspath('data/logs'))\n",
    "        self.args,self.transform_model,self.optimizers = load_model('data/'+ weights,self.logger,self.device,model_mode=ModelModes.EVALUATION)\n",
    "\n",
    "    def compress(self, x):\n",
    "        compression_output,attained_bpp = self.transform_model(x)\n",
    "        #attained_bpp = 32 * ((len(compression_output.hyperlatents_encoded) + len(compression_output.latents_encoded)) / np.prod((224,224)))\n",
    "        return attained_bpp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f5e4ce53-6b0a-476a-8a5f-e72510c1aebd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_HiFiC(weights):\n",
    "    hific_model = HiFiC(weights = weights)\n",
    "    bpps = []\n",
    "\n",
    "    for i,(image,target) in enumerate(data_loader):\n",
    "        with torch.no_grad():\n",
    "            bpp = hific_model.compress(image.to('cuda'))\n",
    "            bpps.append(bpp)\n",
    "    return sum(bpps)/100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0937382b-8fe9-451c-8b32-29812a4f02ca",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "14:06:18 INFO - logger_setup: /home/jovyan/data/logs\n",
      "INFO:src.helpers.utils:/home/jovyan/data/logs\n",
      "/home/jovyan/src/helpers/utils.py:175: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  checkpoint = torch.load(save_path)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Building prior probability tables...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 64/64 [00:00<00:00, 1019.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Setting up Perceptual loss...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "/opt/conda/lib/python3.11/site-packages/torchvision/models/_utils.py:208: UserWarning: The parameter 'pretrained' is deprecated since 0.13 and may be removed in the future, please use 'weights' instead.\n",
      "  warnings.warn(\n",
      "/opt/conda/lib/python3.11/site-packages/torchvision/models/_utils.py:223: UserWarning: Arguments other than a weight enum or `None` for 'weights' are deprecated since 0.13 and may be removed in the future. The current behavior is equivalent to passing `weights=AlexNet_Weights.IMAGENET1K_V1`. You can also use `weights=AlexNet_Weights.DEFAULT` to get the most up-to-date weights.\n",
      "  warnings.warn(msg)\n",
      "/home/jovyan/src/loss/perceptual_similarity/dist_model.py:69: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  self.net.load_state_dict(torch.load(model_path, **kw), strict=False)\n",
      "14:06:20 INFO - load_model: Loading model ...\n",
      "INFO:src.helpers.utils:Loading model ...\n",
      "14:06:20 INFO - load_model: MODEL TYPE: compression_gan\n",
      "INFO:src.helpers.utils:MODEL TYPE: compression_gan\n",
      "14:06:20 INFO - load_model: MODEL MODE: evaluation\n",
      "INFO:src.helpers.utils:MODEL MODE: evaluation\n",
      "14:06:20 INFO - load_model: Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "INFO:src.helpers.utils:Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "14:06:20 INFO - load_model: Trainable parameters:\n",
      "INFO:src.helpers.utils:Trainable parameters:\n",
      "14:06:20 INFO - load_model: Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "INFO:src.helpers.utils:Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "14:06:20 INFO - load_model: Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "INFO:src.helpers.utils:Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "14:06:20 INFO - load_model: Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:20 INFO - load_model: Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:20 INFO - load_model: Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:20 INFO - load_model: Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:20 INFO - load_model: Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "14:06:20 INFO - load_model: Hyperprior.prior_entropy_model.CDF - torch.Size([64, 1481])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF - torch.Size([64, 1481])\n",
      "14:06:20 INFO - load_model: Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "14:06:20 INFO - load_model: Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "14:06:20 INFO - load_model: Number of trainable parameters: 148286543\n",
      "INFO:src.helpers.utils:Number of trainable parameters: 148286543\n",
      "14:06:20 INFO - load_model: Estimated model size (under fp32): 593.146 MB\n",
      "INFO:src.helpers.utils:Estimated model size (under fp32): 593.146 MB\n",
      "14:06:20 INFO - load_model: Model init 1.680s\n",
      "INFO:src.helpers.utils:Model init 1.680s\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model from: /home/jovyan/src/loss/perceptual_similarity/weights/v0.1/alex.pth\n",
      "...[net-lin [alex]] initialized\n",
      "...Done\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "14:06:23 INFO - logger_setup: /home/jovyan/data/logs\n",
      "14:06:23 INFO - logger_setup: /home/jovyan/data/logs\n",
      "INFO:src.helpers.utils:/home/jovyan/data/logs\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Building prior probability tables...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 64/64 [00:03<00:00, 17.45it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Setting up Perceptual loss...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "14:06:28 INFO - load_model: Loading model ...\n",
      "14:06:28 INFO - load_model: Loading model ...\n",
      "INFO:src.helpers.utils:Loading model ...\n",
      "14:06:28 INFO - load_model: MODEL TYPE: compression_gan\n",
      "14:06:28 INFO - load_model: MODEL TYPE: compression_gan\n",
      "INFO:src.helpers.utils:MODEL TYPE: compression_gan\n",
      "14:06:28 INFO - load_model: MODEL MODE: evaluation\n",
      "14:06:28 INFO - load_model: MODEL MODE: evaluation\n",
      "INFO:src.helpers.utils:MODEL MODE: evaluation\n",
      "14:06:28 INFO - load_model: Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "14:06:28 INFO - load_model: Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "INFO:src.helpers.utils:Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "14:06:28 INFO - load_model: Trainable parameters:\n",
      "14:06:28 INFO - load_model: Trainable parameters:\n",
      "INFO:src.helpers.utils:Trainable parameters:\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "14:06:28 INFO - load_model: Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "INFO:src.helpers.utils:Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "14:06:28 INFO - load_model: Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "INFO:src.helpers.utils:Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "14:06:28 INFO - load_model: Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "14:06:28 INFO - load_model: Hyperprior.prior_entropy_model.CDF - torch.Size([64, 3197])\n",
      "14:06:28 INFO - load_model: Hyperprior.prior_entropy_model.CDF - torch.Size([64, 3197])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF - torch.Size([64, 3197])\n",
      "14:06:28 INFO - load_model: Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "14:06:28 INFO - load_model: Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "14:06:28 INFO - load_model: Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "14:06:28 INFO - load_model: Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "14:06:28 INFO - load_model: Number of trainable parameters: 148286543\n",
      "14:06:28 INFO - load_model: Number of trainable parameters: 148286543\n",
      "INFO:src.helpers.utils:Number of trainable parameters: 148286543\n",
      "14:06:28 INFO - load_model: Estimated model size (under fp32): 593.146 MB\n",
      "14:06:28 INFO - load_model: Estimated model size (under fp32): 593.146 MB\n",
      "INFO:src.helpers.utils:Estimated model size (under fp32): 593.146 MB\n",
      "14:06:28 INFO - load_model: Model init 5.040s\n",
      "14:06:28 INFO - load_model: Model init 5.040s\n",
      "INFO:src.helpers.utils:Model init 5.040s\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model from: /home/jovyan/src/loss/perceptual_similarity/weights/v0.1/alex.pth\n",
      "...[net-lin [alex]] initialized\n",
      "...Done\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "14:06:31 INFO - logger_setup: /home/jovyan/data/logs\n",
      "14:06:31 INFO - logger_setup: /home/jovyan/data/logs\n",
      "14:06:31 INFO - logger_setup: /home/jovyan/data/logs\n",
      "INFO:src.helpers.utils:/home/jovyan/data/logs\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Building prior probability tables...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 64/64 [00:00<00:00, 1015.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Setting up Perceptual loss...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "14:06:33 INFO - load_model: Loading model ...\n",
      "14:06:33 INFO - load_model: Loading model ...\n",
      "14:06:33 INFO - load_model: Loading model ...\n",
      "INFO:src.helpers.utils:Loading model ...\n",
      "14:06:33 INFO - load_model: MODEL TYPE: compression_gan\n",
      "14:06:33 INFO - load_model: MODEL TYPE: compression_gan\n",
      "14:06:33 INFO - load_model: MODEL TYPE: compression_gan\n",
      "INFO:src.helpers.utils:MODEL TYPE: compression_gan\n",
      "14:06:33 INFO - load_model: MODEL MODE: evaluation\n",
      "14:06:33 INFO - load_model: MODEL MODE: evaluation\n",
      "14:06:33 INFO - load_model: MODEL MODE: evaluation\n",
      "INFO:src.helpers.utils:MODEL MODE: evaluation\n",
      "14:06:33 INFO - load_model: Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_7): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_8): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "14:06:33 INFO - load_model: Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_7): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_8): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "14:06:33 INFO - load_model: Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_7): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_8): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "INFO:src.helpers.utils:Model(\n",
      "  (Encoder): Encoder(\n",
      "    (pre_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (conv_block1): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(3, 60, kernel_size=(7, 7), stride=(1, 1))\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block2): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(60, 120, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block3): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(120, 240, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block4): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(240, 480, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block5): Sequential(\n",
      "      (0): ReflectionPad2d((0, 1, 1, 0))\n",
      "      (1): Conv2d(480, 960, kernel_size=(3, 3), stride=(2, 2), padding_mode=reflect)\n",
      "      (2): ChannelNorm2D()\n",
      "      (3): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (1): Conv2d(960, 220, kernel_size=(3, 3), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Generator): Generator(\n",
      "    (pre_pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "    (asymmetric_pad): ReflectionPad2d((0, 1, 1, 0))\n",
      "    (post_pad): ReflectionPad2d((3, 3, 3, 3))\n",
      "    (conv_block_init): Sequential(\n",
      "      (0): ChannelNorm2D()\n",
      "      (1): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (2): Conv2d(220, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (3): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_0): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_1): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_2): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_3): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_4): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_5): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_6): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_7): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (resblock_8): ResidualBlock(\n",
      "      (pad): ReflectionPad2d((1, 1, 1, 1))\n",
      "      (conv1): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (conv2): Conv2d(960, 960, kernel_size=(3, 3), stride=(1, 1))\n",
      "      (norm1): ChannelNorm2D()\n",
      "      (norm2): ChannelNorm2D()\n",
      "    )\n",
      "    (upconv_block1): Sequential(\n",
      "      (0): ConvTranspose2d(960, 480, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block2): Sequential(\n",
      "      (0): ConvTranspose2d(480, 240, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block3): Sequential(\n",
      "      (0): ConvTranspose2d(240, 120, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (upconv_block4): Sequential(\n",
      "      (0): ConvTranspose2d(120, 60, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
      "      (1): ChannelNorm2D()\n",
      "      (2): ReLU()\n",
      "    )\n",
      "    (conv_block_out): Sequential(\n",
      "      (0): ReflectionPad2d((3, 3, 3, 3))\n",
      "      (1): Conv2d(60, 3, kernel_size=(7, 7), stride=(1, 1))\n",
      "    )\n",
      "  )\n",
      "  (Hyperprior): Hyperprior(\n",
      "    (analysis_net): HyperpriorAnalysis(\n",
      "      (conv1): Conv2d(220, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "      (conv2): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "      (conv3): Conv2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), padding_mode=reflect)\n",
      "    )\n",
      "    (synthesis_mu): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (synthesis_std): HyperpriorSynthesis(\n",
      "      (conv1): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv2): ConvTranspose2d(320, 320, kernel_size=(5, 5), stride=(2, 2), padding=(2, 2), output_padding=(1, 1))\n",
      "      (conv3): ConvTranspose2d(320, 220, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
      "    )\n",
      "    (hyperlatent_likelihood): HyperpriorDensity()\n",
      "    (hyperprior_entropy_model): HyperpriorEntropyModel(\n",
      "      (distribution): HyperpriorDensity()\n",
      "    )\n",
      "    (prior_density): PriorDensity()\n",
      "    (prior_entropy_model): PriorEntropyModel(\n",
      "      (distribution): PriorDensity()\n",
      "    )\n",
      "  )\n",
      "  (squared_difference): MSELoss()\n",
      "  (perceptual_loss): PerceptualLoss()\n",
      ")\n",
      "14:06:33 INFO - load_model: Trainable parameters:\n",
      "14:06:33 INFO - load_model: Trainable parameters:\n",
      "14:06:33 INFO - load_model: Trainable parameters:\n",
      "INFO:src.helpers.utils:Trainable parameters:\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.1.weight - torch.Size([60, 3, 7, 7])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.1.bias - torch.Size([60])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.2.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block1.2.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.1.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.1.bias - torch.Size([120])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.2.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block2.2.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.1.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.1.bias - torch.Size([240])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.2.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block3.2.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.1.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.1.bias - torch.Size([480])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.2.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block4.2.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.1.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Encoder.conv_block5.2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Encoder.conv_block_out.1.weight - torch.Size([220, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Encoder.conv_block_out.1.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.0.gamma - torch.Size([1, 220, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.0.beta - torch.Size([1, 220, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.2.weight - torch.Size([960, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.3.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.conv_block_init.3.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_0.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_1.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_2.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_3.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_4.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_5.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_6.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_7.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_7.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.conv1.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv1.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.conv1.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.conv2.weight - torch.Size([960, 960, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.conv2.bias - torch.Size([960])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.conv2.bias - torch.Size([960])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.norm1.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.norm1.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.norm2.gamma - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.resblock_8.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.resblock_8.norm2.beta - torch.Size([1, 960, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.0.weight - torch.Size([960, 480, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.0.bias - torch.Size([480])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.1.gamma - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block1.1.beta - torch.Size([1, 480, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.0.weight - torch.Size([480, 240, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.0.bias - torch.Size([240])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.1.gamma - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block2.1.beta - torch.Size([1, 240, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.0.weight - torch.Size([240, 120, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.0.bias - torch.Size([120])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.1.gamma - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block3.1.beta - torch.Size([1, 120, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.0.weight - torch.Size([120, 60, 3, 3])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.0.bias - torch.Size([60])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.1.gamma - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "INFO:src.helpers.utils:Generator.upconv_block4.1.beta - torch.Size([1, 60, 1, 1])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "INFO:src.helpers.utils:Generator.conv_block_out.1.weight - torch.Size([3, 60, 7, 7])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "14:06:33 INFO - load_model: Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "INFO:src.helpers.utils:Generator.conv_block_out.1.bias - torch.Size([3])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv1.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv3.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.analysis_net.conv3.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_mu.conv3.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv1.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv1.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv2.weight - torch.Size([320, 320, 5, 5])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv2.bias - torch.Size([320])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv3.weight - torch.Size([320, 220, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "INFO:src.helpers.utils:Hyperprior.synthesis_std.conv3.bias - torch.Size([220])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_0 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_1 - torch.Size([320, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_1 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_1 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_2 - torch.Size([320, 3, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_2 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_2 - torch.Size([320, 3, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.H_3 - torch.Size([320, 1, 3])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.a_3 - torch.Size([320, 1, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "INFO:src.helpers.utils:Hyperprior.hyperlatent_likelihood.b_3 - torch.Size([320, 1, 1])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF - torch.Size([64, 1481])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF - torch.Size([64, 1481])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF - torch.Size([64, 1481])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF - torch.Size([64, 1481])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF_offset - torch.Size([64])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "14:06:33 INFO - load_model: Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "INFO:src.helpers.utils:Hyperprior.prior_entropy_model.CDF_length - torch.Size([64])\n",
      "14:06:33 INFO - load_model: Number of trainable parameters: 181475663\n",
      "14:06:33 INFO - load_model: Number of trainable parameters: 181475663\n",
      "14:06:33 INFO - load_model: Number of trainable parameters: 181475663\n",
      "INFO:src.helpers.utils:Number of trainable parameters: 181475663\n",
      "14:06:33 INFO - load_model: Estimated model size (under fp32): 725.903 MB\n",
      "14:06:33 INFO - load_model: Estimated model size (under fp32): 725.903 MB\n",
      "14:06:33 INFO - load_model: Estimated model size (under fp32): 725.903 MB\n",
      "INFO:src.helpers.utils:Estimated model size (under fp32): 725.903 MB\n",
      "14:06:33 INFO - load_model: Model init 1.398s\n",
      "14:06:33 INFO - load_model: Model init 1.398s\n",
      "14:06:33 INFO - load_model: Model init 1.398s\n",
      "INFO:src.helpers.utils:Model init 1.398s\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model from: /home/jovyan/src/loss/perceptual_similarity/weights/v0.1/alex.pth\n",
      "...[net-lin [alex]] initialized\n",
      "...Done\n"
     ]
    }
   ],
   "source": [
    "output=[]\n",
    "for q in ['hific_low.pt','hific_med.pt','hific_hi.pt']:\n",
    "    output.append(f'BPP for {q}:{test_HiFiC(q)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8eeb43b7-abb6-47a6-a9f5-a91a369ceab7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BPP for hific_low.pt:0.15450650453567505\n",
      "BPP for hific_med.pt:0.42845335602760315\n",
      "BPP for hific_hi.pt:0.46835437417030334\n"
     ]
    }
   ],
   "source": [
    "for o in output:\n",
    "    print(o)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3063cfd-d296-4a59-b420-77058f446dcc",
   "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.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
