{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "596d192c-de00-40b4-a8b3-25e6b01e1e4b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/dcpc-experiments-utah/dcpc_experiments\n"
     ]
    }
   ],
   "source": [
    "%cd .."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "43ef1c2d-5a3a-42dc-b547-312e997c87ff",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/lib/python3/dist-packages/pkg_resources/__init__.py:116: PkgResourcesDeprecationWarning: 1.12.1-git20200711.33e2d80-dfsg1-0.6 is an invalid version and will not be supported in a future release\n",
      "  warnings.warn(\n",
      "Seed set to 123\n"
     ]
    }
   ],
   "source": [
    "import argparse\n",
    "import collections\n",
    "import lightning\n",
    "import numpy as np\n",
    "import pyro\n",
    "import torch\n",
    "import logger, train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "32ff760e-320f-4a87-ac44-f44ca3338e2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pyro.enable_validation(True)\n",
    "# torch.autograd.set_detect_anomaly(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "496e2ad7-e3e4-4f32-9cf6-54e7ed5caf11",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/lib/python3/dist-packages/pkg_resources/__init__.py:116: PkgResourcesDeprecationWarning: 1.12.1-git20200711.33e2d80-dfsg1-0.6 is an invalid version and will not be supported in a future release\n",
      "  warnings.warn(\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n"
     ]
    }
   ],
   "source": [
    "config, (data, model, trainer) = train.from_file(\"experiments/dcpc_flowers_config.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "81cd8e00-c403-48a3-9d16-ba1ba1bd605c",
   "metadata": {},
   "outputs": [],
   "source": [
    "logger = config.get_logger('valid')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "579c162c-3fd4-4478-ba5b-dd0e51341090",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "[rank: 0] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 0, MEMBER: 1/8\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "You are using a CUDA device ('NVIDIA H100 80GB HBM3') that has Tensor Cores. To properly utilize them, you should set `torch.set_float32_matmul_precision('medium' | 'high')` which will trade-off precision for performance. For more details, read https://pytorch.org/docs/stable/generated/torch.set_float32_matmul_precision.html#torch.set_float32_matmul_precision\n",
      "[rank: 3] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 3, MEMBER: 4/8\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "[rank: 5] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 5, MEMBER: 6/8\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "[rank: 1] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 1, MEMBER: 2/8\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "[rank: 2] Seed set to 123\n",
      "[rank: 6] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 2, MEMBER: 3/8\n",
      "Initializing distributed: GLOBAL_RANK: 6, MEMBER: 7/8\n",
      "[rank: 7] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 7, MEMBER: 8/8\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "[rank: 4] Seed set to 123\n",
      "Initializing distributed: GLOBAL_RANK: 4, MEMBER: 5/8\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "----------------------------------------------------------------------------------------------------\n",
      "distributed_backend=nccl\n",
      "All distributed processes registered. Starting with 8 processes\n",
      "----------------------------------------------------------------------------------------------------\n",
      "\n",
      "Missing logger folder: saved/log/FlowersDiffusion_Dcpc/0519_024841/lightning_logs\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:653: Checkpoint directory /home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841 exists and is not empty.\n",
      "Restoring states from the checkpoint path at saved/models/FlowersDiffusion_Dcpc/0518_064135/checkpoint_979.ckpt\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 6 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 4 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 2 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 5 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 3 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 1 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/lightning/pytorch/callbacks/model_checkpoint.py:361: The dirpath has changed from '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0518_064135' to '/home/ubuntu/dcpc-experiments-utah/dcpc_experiments/saved/models/FlowersDiffusion_Dcpc/0519_024841', therefore `best_model_score`, `kth_best_model_path`, `kth_value`, `last_model_path` and `best_k_models` won't be reloaded. Only `best_model_path` will be reloaded.\n",
      "LOCAL_RANK: 7 - CUDA_VISIBLE_DEVICES: [0,1,2,3,4,5,6,7]\n",
      "\n",
      "  | Name       | Type         | Params\n",
      "--------------------------------------------\n",
      "0 | graph      | DiffusionDcpc | 137 M \n",
      "1 | predictive | Predictive   | 0     \n",
      "--------------------------------------------\n",
      "137 M     Trainable params\n",
      "0         Non-trainable params\n",
      "137 M     Total params\n",
      "551.106   Total estimated model params size (MB)\n",
      "Restored all states from the checkpoint at saved/models/FlowersDiffusion_Dcpc/0518_064135/checkpoint_979.ckpt\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Sanity Checking: |                                                                                            …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "35fe15b2c52a4250a63a7f698cb6ce4b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Training: |                                                                                                   …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Validation: |                                                                                                 …"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=1000` reached.\n"
     ]
    }
   ],
   "source": [
    "trainer.fit(model, data, ckpt_path=\"saved/models/FlowersDiffusion_Dcpc/0518_064135/checkpoint_979.ckpt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "faa5b900-0121-4cf6-91b6-2c9b0b12716f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "LightningDcpc(\n",
       "  (graph): DiffusionDcpc(\n",
       "    (diffusion): DiffusionStep(\n",
       "      (unet): ScoreNetwork0(\n",
       "        (_convs): ModuleList(\n",
       "          (0): Sequential(\n",
       "            (0): Conv2d(4, 32, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "            (1): LogSigmoid()\n",
       "          )\n",
       "          (1): Sequential(\n",
       "            (0): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)\n",
       "            (1): Conv2d(32, 64, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "            (2): LogSigmoid()\n",
       "          )\n",
       "          (2): Sequential(\n",
       "            (0): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)\n",
       "            (1): Conv2d(64, 128, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "            (2): LogSigmoid()\n",
       "          )\n",
       "          (3): Sequential(\n",
       "            (0): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)\n",
       "            (1): Conv2d(128, 256, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "            (2): LogSigmoid()\n",
       "          )\n",
       "          (4): Sequential(\n",
       "            (0): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)\n",
       "            (1): Conv2d(256, 512, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "            (2): LogSigmoid()\n",
       "          )\n",
       "        )\n",
       "        (mlp): Sequential(\n",
       "          (0): Linear(in_features=8192, out_features=8192, bias=True)\n",
       "          (1): SiLU()\n",
       "          (2): Linear(in_features=8192, out_features=8192, bias=True)\n",
       "        )\n",
       "        (_tconvs): ModuleList(\n",
       "          (0): Sequential(\n",
       "            (0): ConvTranspose2d(512, 256, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
       "            (1): LogSigmoid()\n",
       "          )\n",
       "          (1): Sequential(\n",
       "            (0): ConvTranspose2d(512, 128, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
       "            (1): LogSigmoid()\n",
       "          )\n",
       "          (2): Sequential(\n",
       "            (0): ConvTranspose2d(256, 64, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
       "            (1): LogSigmoid()\n",
       "          )\n",
       "          (3): Sequential(\n",
       "            (0): ConvTranspose2d(128, 32, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1), output_padding=(1, 1))\n",
       "            (1): LogSigmoid()\n",
       "          )\n",
       "          (4): Sequential(\n",
       "            (0): Conv2d(64, 32, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "            (1): LogSigmoid()\n",
       "            (2): Conv2d(32, 3, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (prior): DiffusionPrior()\n",
       "  )\n",
       "  (predictive): Predictive()\n",
       ")"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.graph.clear()\n",
    "model.eval()\n",
    "model.cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b90c473f-d1de-410d-9f9c-df268bd62a79",
   "metadata": {},
   "outputs": [],
   "source": [
    "xs, _, _ = list(data.val_dataloader())[0]\n",
    "xs = xs.to(model.device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "f57f66da-aef7-406c-b7b1-02918be5a6c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "B = len(xs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "4bcc32fe-6a50-4302-8253-d79bc5ace14e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/.local/lib/python3.10/site-packages/torch/autograd/graph.py:744: UserWarning: Plan failed with a cudnnException: CUDNN_BACKEND_EXECUTION_PLAN_DESCRIPTOR: cudnnFinalize Descriptor Failed cudnn_status: CUDNN_STATUS_NOT_SUPPORTED (Triggered internally at ../aten/src/ATen/native/cudnn/Conv_v8.cpp:919.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Free energy of reconstruction: 1.65E+15\n"
     ]
    }
   ],
   "source": [
    "with model.graph.condition(X__0=xs) as predictive:\n",
    "    predictive(B=len(xs), lr=1e-8, mode=\"prior\", P=model.num_particles)\n",
    "    trace, log_weight = predictive(B=len(xs), lr=1e-8, P=model.num_particles)\n",
    "logger.info(\"Free energy of reconstruction: %.2E\" % -log_weight.mean())\n",
    "x_hats = trace.nodes['X__0']['fn'].base_dist.loc.mean(dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "53c76257-aef8-40e3-934a-a1e534924256",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f750bfb2-80aa-4fad-885e-752772706a9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 16 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(nrows=2, ncols=8, sharex=\"all\", sharey=\"all\", layout=\"tight\")\n",
    "\n",
    "for i in range(8):\n",
    "    orgs = data.reverse_transform(xs[i].squeeze().detach().cpu())\n",
    "    estimates = data.reverse_transform(x_hats[i].squeeze().detach().cpu())\n",
    "    axes[0, i].imshow(orgs)\n",
    "    axes[1, i].imshow(estimates)\n",
    "\n",
    "fig.savefig(\"dcpc_flowers_recons.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "34f8050d-f8c0-440a-9bbd-d7fb8a904249",
   "metadata": {},
   "outputs": [],
   "source": [
    "del log_weight\n",
    "del trace\n",
    "del xs\n",
    "del x_hats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e5c1cbe3-b37e-40d8-879b-0072a6b68b80",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.graph.clear()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "3c48c964-fc69-4cad-bfe5-e456ac545d73",
   "metadata": {},
   "outputs": [],
   "source": [
    "x_hats = model.graph(B=B, lr=1e-8, mode=\"prior\", P=model.num_particles).mean(dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "e8d52c91-326b-469a-954d-ca5b4e4c67c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(nrows=1, ncols=8, sharex=\"all\", sharey=\"all\", layout=\"tight\")\n",
    "\n",
    "for i in range(8):\n",
    "    estimates = data.reverse_transform(x_hats[i].squeeze().detach().cpu())\n",
    "    axes[i].imshow(estimates)\n",
    "\n",
    "fig.savefig(\"dcpc_flowers_samples.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4a8e8aef-77f3-483a-a4b8-b36b01fdffaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "del estimates\n",
    "del x_hats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "7657733f-5780-47fc-a10e-a01fbac6b4a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "SEEDS = [123, 456, 789, 101112, 131415]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "94d66fc2-7539-4ef9-ad74-1cc77a0e8306",
   "metadata": {},
   "outputs": [],
   "source": [
    "LOG_LIKELIHOODS = torch.zeros(len(SEEDS), requires_grad=False)\n",
    "MEAN_SQUARED_ERROR = torch.zeros(len(SEEDS), requires_grad=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "089f3a60-5009-4238-9c1b-f1a2e7797546",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Evaluated likelihood for valid batch 0 under seed 0\n",
      "Evaluated likelihood for valid batch 1 under seed 0\n",
      "Evaluated likelihood for valid batch 2 under seed 0\n",
      "Evaluated likelihood for valid batch 3 under seed 0\n",
      "Evaluated likelihood for valid batch 4 under seed 0\n",
      "Evaluated likelihood for valid batch 5 under seed 0\n",
      "Evaluated likelihood for valid batch 6 under seed 0\n",
      "Evaluated likelihood for valid batch 7 under seed 0\n",
      "Evaluated likelihood for valid batch 8 under seed 0\n",
      "Evaluated likelihood for valid batch 9 under seed 0\n",
      "Evaluated likelihood for valid batch 10 under seed 0\n",
      "Evaluated likelihood for valid batch 11 under seed 0\n",
      "Evaluated likelihood for valid batch 12 under seed 0\n",
      "Evaluated likelihood for valid batch 13 under seed 0\n"
     ]
    },
    {
     "ename": "OutOfMemoryError",
     "evalue": "CUDA out of memory. Tried to allocate 20.00 MiB. GPU ",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mOutOfMemoryError\u001b[0m                          Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_1130366/3546870013.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      6\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgraph\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcondition\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX__0\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mxs\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mpredictive\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      7\u001b[0m             \u001b[0mpredictive\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mB\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mxs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlr\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1e-8\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"prior\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mP\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_particles\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 8\u001b[0;31m             \u001b[0mtrace\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog_weight\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpredictive\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mB\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mxs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlr\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1e-8\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mP\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_particles\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      9\u001b[0m         \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgraph\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclear\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     10\u001b[0m         \u001b[0mx_hats\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtrace\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnodes\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'X__0'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'value'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.10/site-packages/pyro/nn/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    448\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    449\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pyro_context\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 450\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    451\u001b[0m         if (\n\u001b[1;32m    452\u001b[0m             \u001b[0mpyro\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msettings\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"validate_poutine\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.10/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1530\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_compiled_call_impl\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[misc]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1531\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1532\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_call_impl\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1533\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1534\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_call_impl\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.10/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1539\u001b[0m                 \u001b[0;32mor\u001b[0m \u001b[0m_global_backward_pre_hooks\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0m_global_backward_hooks\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1540\u001b[0m                 or _global_forward_hooks or _global_forward_pre_hooks):\n\u001b[0;32m-> 1541\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mforward_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1542\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1543\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/dcpc-experiments-utah/dcpc_experiments/base/base_model.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, B, mode, P, *args, **kwargs)\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     47\u001b[0m                 \u001b[0mkwargs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"mode\"\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmode\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 48\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mutils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mimportance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     49\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     50\u001b[0m     \u001b[0;34m@\u001b[0m\u001b[0mabstractmethod\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/dcpc-experiments-utah/dcpc_experiments/utils/util.py\u001b[0m in \u001b[0;36mimportance\u001b[0;34m(model, guide, *args, **kwargs)\u001b[0m\n\u001b[1;32m    117\u001b[0m         \u001b[0mtp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpyro\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpoutine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    118\u001b[0m     \u001b[0mtq\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute_log_prob\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 119\u001b[0;31m     \u001b[0mtp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute_log_prob\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    120\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mtp\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog_joint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtp\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mlog_joint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtq\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    121\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.10/site-packages/pyro/poutine/trace_struct.py\u001b[0m in \u001b[0;36mcompute_log_prob\u001b[0;34m(self, site_filter)\u001b[0m\n\u001b[1;32m    262\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0;34m\"log_prob\"\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0msite\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    263\u001b[0m                     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 264\u001b[0;31m                         log_p = site[\"fn\"].log_prob(\n\u001b[0m\u001b[1;32m    265\u001b[0m                             \u001b[0msite\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"value\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0msite\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"args\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0msite\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"kwargs\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    266\u001b[0m                         )\n",
      "\u001b[0;32m~/.local/lib/python3.10/site-packages/torch/distributions/independent.py\u001b[0m in \u001b[0;36mlog_prob\u001b[0;34m(self, value)\u001b[0m\n\u001b[1;32m    105\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    106\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mlog_prob\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvalue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 107\u001b[0;31m         \u001b[0mlog_prob\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbase_dist\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog_prob\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mvalue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    108\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0m_sum_rightmost\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlog_prob\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreinterpreted_batch_ndims\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    109\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.10/site-packages/torch/distributions/normal.py\u001b[0m in \u001b[0;36mlog_prob\u001b[0;34m(self, value)\u001b[0m\n\u001b[1;32m     84\u001b[0m         )\n\u001b[1;32m     85\u001b[0m         return (\n\u001b[0;32m---> 86\u001b[0;31m             \u001b[0;34m-\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mvalue\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloc\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m**\u001b[0m \u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m/\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mvar\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     87\u001b[0m             \u001b[0;34m-\u001b[0m \u001b[0mlog_scale\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     88\u001b[0m             \u001b[0;34m-\u001b[0m \u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqrt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpi\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mOutOfMemoryError\u001b[0m: CUDA out of memory. Tried to allocate 20.00 MiB. GPU "
     ]
    }
   ],
   "source": [
    "for (s, SEED) in enumerate(SEEDS):\n",
    "    torch.manual_seed(SEED)\n",
    "    np.random.seed(SEED)\n",
    "    for b, (xs, target, indices) in enumerate(data.val_dataloader()):\n",
    "        xs = xs.to(model.device)\n",
    "        with model.graph.condition(X__0=xs) as predictive:\n",
    "            predictive(B=len(xs), lr=1e-8, mode=\"prior\", P=model.num_particles)\n",
    "            trace, log_weight = predictive(B=len(xs), lr=1e-8, P=model.num_particles)\n",
    "        model.graph.clear()\n",
    "        x_hats = trace.nodes['X__0']['value'].mean(dim=0)\n",
    "\n",
    "        LOG_LIKELIHOODS[s] += trace.nodes['X__0']['fn'].log_prob(xs).sum().cpu()\n",
    "        MEAN_SQUARED_ERROR[s] += ((xs - x_hats) ** 2).sum(dim=0).mean().cpu()\n",
    "\n",
    "        del xs\n",
    "        del x_hats\n",
    "        del target\n",
    "        del indices\n",
    "        del log_weight\n",
    "        del trace\n",
    "        torch.cuda.empty_cache()\n",
    "\n",
    "        logger.info(\"Evaluated likelihood for valid batch %d under seed %s\" % (b, s))\n",
    "\n",
    "    LOG_LIKELIHOODS[s] /= len(trainer.valid_data_loader.sampler)\n",
    "    MEAN_SQUARED_ERROR[s] /= len(trainer.valid_data_loader.sampler)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23203c5d-e7f0-4f5d-868b-a0ba77d1b9e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "LOG_LIKELIHOODS.mean(), LOG_LIKELIHOODS.std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ce608df3-f41d-4637-862c-7a825403f72f",
   "metadata": {},
   "outputs": [],
   "source": [
    "MEAN_SQUARED_ERROR.mean(), MEAN_SQUARED_ERROR.std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d787fd1-48f0-4ae8-82ae-fae7bffbc98a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
